## Spartan-3E FPGA Family: Complete Data Sheet

## Module 1:

Introduction and Ordering Information
DS312-1 (v1.1) March 21, 2005
6 pages

- Introduction
- Features
- Architectural Overview
- Package Marking
- Ordering Information


## Module 2:

## Functional Description

DS312-2 (v1.1) March 21, 2005
96 pages

- Input/Output Blocks (IOBs)
- Overview
- SelectIO ${ }^{\text {TM }}$ Signal Standards
- Configurable Logic Block (CLB)
- Block RAM
- Dedicated Multipliers
- Digital Clock Manager (DCM)
- Clock Network
- Configuration
- Powering Spartan-3E FPGAs


## Module 3:

## DC and Switching Characteristics

DS312-3 (v1.0) March 1, 2005
18 pages

- DC Electrical Characteristics
- Absolute Maximum Ratings
- Supply Voltage Specifications
- Recommended Operating Conditions
- DC Characteristics
- Switching Characteristics
- DCM Timing
- Configuration and JTAG Timing


## Module 4:

Pinout Descriptions
DS312-4 (v1.1) March 21, 2005
72 pages

- Pin Descriptions
- Package Overview
- Pinout Tables
- Footprint Diagrams

[^0]

# Spartan-3E FPGA Family: Introduction and Ordering Information 

Advance Product Specification

## Introduction

The Spartan ${ }^{\text {TM }}$-3E family of Field-Programmable Gate Arrays (FPGAs) is specifically designed to meet the needs of high volume, cost-sensitive consumer electronic applications. The five-member family offers densities ranging from 100,000 to 1.6 million system gates, as shown in Table 1.
The Spartan-3E family builds on the success of the earlier Spartan-3 family by increasing the amount of logic per I/O, significantly reducing the cost per logic cell. New features improve system performance and reduce the cost of configuration. These Spartan-3E enhancements, combined with advanced 90 nm process technology, deliver more functionality and bandwidth per dollar than was previously possible, setting new standards in the programmable logic industry.
Because of their exceptionally low cost, Spartan-3E FPGAs are ideally suited to a wide range of consumer electronics applications, including broadband access, home networking, display/projection, and digital television equipment.
The Spartan-3E family is a superior alternative to mask programmed ASICs. FPGAs avoid the high initial cost, the lengthy development cycles, and the inherent inflexibility of conventional ASICs. Also, FPGA programmability permits design upgrades in the field with no hardware replacement necessary, an impossibility with ASICs.

## Features

- Very low cost, high-performance logic solution for high-volume, consumer-oriented applications
- Proven advanced 90 -nanometer process technology
- Multi-voltage, multi-standard SelectIO ${ }^{\text {TM }}$ interface pins
- Up to 376 I/O pins or 156 differential signal pairs
- LVCMOS, LVTTL, HSTL, and SSTL single-ended signal standards
- True LVDS, RSDS, mini-LVDS differential I/O
- $3.3 \mathrm{~V}, 2.5 \mathrm{~V}, 1.8 \mathrm{~V}, 1.5 \mathrm{~V}$, and 1.2 V signaling
- Enhanced Double Data Rate (DDR) support
- Abundant, flexible logic resources
- Densities up to 33,192 logic cells, including optional shift register or distributed RAM support
- Efficient wide multiplexers, wide logic
- Fast look-ahead carry logic
- Enhanced $18 \times 18$ multipliers with optional pipeline
- IEEE 1149.1/1532 JTAG programming/debug port
- Hierarchical SelectRAM ${ }^{\text {TM }}$ memory architecture
- Up to 648 Kbits of fast block RAM
- Up to 231 Kbits of efficient distributed RAM
- Up to eight Digital Clock Managers (DCMs)
- Clock skew elimination (delay locked loop)
- Frequency synthesis, multiplication, division
- High-resolution phase shifting
- Wide frequency range ( 5 MHz to over 300 MHz )
- Eight global clocks and eight clocks for each half of device, plus abundant low-skew routing
- Configuration interface to industry-standard PROMs
- Low-cost, space-saving SPI serial Flash PROM
- $\quad x 8$ or x8/x16 parallel NOR Flash PROM
- Low-cost Xilinx Platform Flash with JTAG
- Complete Xilinx ISE ${ }^{\text {TM }}$, WebPACK ${ }^{\text {TM }}$ development system support
- MicroBlaze ${ }^{\text {TM }}$, PicoBlaze ${ }^{\text {TM }}$ embedded processor cores
- Fully compliant $32-/ 64-$ bit $33 / 66 \mathrm{MHz} \mathrm{PCI}$ support
- Low-cost QFP and BGA packaging options
- Common footprints support easy density migration
- Pb-free packaging options


## Table 1: Summary of Spartan-3E FPGA Attributes

| Device | System Gates | Equivalent Logic Cells | CLB Array (One CLB = Four Slices) |  |  |  | Distributed RAM bits ${ }^{(1)}$ | Block RAM bits ${ }^{(1)}$ | Dedicated Multipliers | DCMs | Maximum User I/O | Maximum Differential I/O Pairs |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Rows | Columns | Total CLBs | Total Slices |  |  |  |  |  |  |
| XC3S100E | 100K | 2,160 | 22 | 16 | 240 | 960 | 15K | 72K | 4 | 2 | 108 | 40 |
| XC3S250E | 250K | 5,508 | 34 | 26 | 612 | 2,448 | 38K | 216K | 12 | 4 | 172 | 68 |
| XC3S500E | 500K | 10,476 | 46 | 34 | 1,164 | 4,656 | 73K | 360K | 20 | 4 | 232 | 92 |
| XC3S1200E | 1200K | 19,512 | 60 | 46 | 2,168 | 8,672 | 136K | 504K | 28 | 8 | 304 | 124 |
| XC3S1600E | 1600K | 33,192 | 76 | 58 | 3,688 | 14,752 | 231K | 648K | 36 | 8 | 376 | 156 |

## Notes:

1. By convention, one Kb is equivalent to 1,024 bits.

## Architectural Overview

The Spartan-3E family architecture consists of five fundamental programmable functional elements:

- Configurable Logic Blocks (CLBs) contain flexible Look-Up Tables (LUTs) that implement logic plus storage elements used as flip-flops or latches. CLBs perform a wide variety of logical functions as well as store data.
- Input/Output Blocks (IOBs) control the flow of data between the I/O pins and the internal logic of the device. Each IOB supports bidirectional data flow plus 3 -state operation. Supports a variety of signal standards, including four high-performance differential standards. Double Data-Rate (DDR) registers are included.
- Block RAM provides data storage in the form of 18-Kbit dual-port blocks.
- Multiplier Blocks accept two 18-bit binary numbers as inputs and calculate the product.
- Digital Clock Manager (DCM) Blocks provide self-calibrating, fully digital solutions for distributing, delaying, multiplying, dividing, and phase-shifting clock signals.
These elements are organized as shown in Figure 1. A ring of IOBs surrounds a regular array of CLBs. Each device has two columns of block RAM except for the XC3S100E, which has one column. Each RAM column consists of several 18-Kbit RAM blocks. Each block RAM is associated with a dedicated multiplier. The DCMs are positioned in the center with two at the top and two at the bottom of the device. The XC3S100E has only one DCM at the top and bottom, while the XC3S1200E and XC3S1600E add two DCMs in the middle of the left and right sides.
The Spartan-3E family features a rich network of traces that interconnect all five functional elements, transmitting signals among them. Each functional element has an associated switch matrix that permits multiple connections to the routing.


DS312_01_111904

## Notes:

1. The XC3S1200E and XC3S1600E have two additional DCMs on both the left and right sides as indicated by the dashed lines. The XC3S100E has only one DCM at the top and one at the bottom.

Figure 1: Spartan-3E Family Architecture

## 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 x 8 or $\mathrm{x} 8 / \mathrm{x} 16$ 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.


## 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.3 \mathrm{~V}, 2.5 \mathrm{~V}, 1.8 \mathrm{~V}$, 1.5 V , or 1.2 V
- 3.3 V PCI at 33 MHz and 66 MHz
- HSTL I and III at 1.8 V , typically for memory applications
- SSTL I at 1.8 V and 2.5 V , typically for memory applications
Spartan-3E FPGAs support the following differential standards:
- LVDS
- Bus LVDS
- mini-LVDS
- RSDS

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

|  | $\begin{aligned} & \text { VQ100 } \\ & \text { VQG100 } \end{aligned}$ |  | $\begin{aligned} & \text { CP132 } \\ & \text { CPG132 } \end{aligned}$ |  | $\begin{gathered} \text { TQ144 } \\ \text { TQG144 } \end{gathered}$ |  | $\begin{aligned} & \text { PQ208 } \\ & \text { PQG208 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { FT256 } \\ & \text { FTG256 } \end{aligned}$ |  | $\begin{aligned} & \text { FG320 } \\ & \text { FGG320 } \end{aligned}$ |  | $\begin{aligned} & \text { FG400 } \\ & \text { FGG400 } \end{aligned}$ |  | $\begin{aligned} & \text { FG484 } \\ & \text { FGG484 } \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Device | User | Diff | User | Diff | User | Diff | User | Diff | User | Diff | User | Diff | User | Diff | User | Diff |
| XC3S100E | 66 | 30 | - | - | 108 | 40 | - | - | - | - | - | - | - | - | - | - |
| XC3S250E | 66 | 30 | 92 | 41 | 108 | 40 | 158 | 65 | 172 | 68 | - | - | - | - | - | - |
| XC3S500E | - | - | 92 | 41 | - | - | 158 | 65 | 190 | 77 | 232 | 92 | - | - | - | - |
| XC3S1200E | - | - | - | - | - | - | - | - | 190 | 77 | 250 | 99 | 304 | 124 | - | - |
| XC3S1600E | - | - | - | - | - | - | - | - | - | - | 250 | 99 | 304 | 124 | 376 | 156 |

## Notes:

1. All Spartan-3E devices in the same package are pin-compatible.

## Package Marking

Figure 2 provides a top marking example for Spartan-3E FPGAs in the quad-flat packages. Figure 3 shows the top marking for Spartan-3E FPGAs in BGA packages except the 132 -ball chip-scale package (CP132 and CPG132). The markings for the BGA packages are nearly identical to those for the quad-flat packages, except that the marking is rotated with respect to the ball A1 indicator. Figure 4 shows
the top marking for Spartan-3E FPGAs in the CP132 and CPG132 packages.
Use the seven digits of the Lot Code to access additional information for a specific device using the Xilinx web-based Genealogy Viewer.


Figure 2: Spartan-3E QFP Example Package Marking


Figure 3: Spartan-3E BGA Example Package Marking


Figure 4: Spartan-3E CP132 and CPG132 Example Package Marking

## Ordering Information

Spartan-3E FPGAs are available in both standard and Pb-free packaging options for all device/package combinations. The $P b$-free packages include a ' $G$ ' character in the ordering code.

## Standard Packaging



## Pb-Free Packaging



| Device |  | Speed Grade | Package Type / Number of Pins |  | Temperature Range ( $\mathrm{T}_{\mathrm{J}}$ ) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| XC3S100E | -4 | Standard Performance | VQ(G)100 | 100-pin Very Thin Quad Flat Pack (VQFP) | C | Commercial ( $0^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ ) |
| XC3S250E | -5 | High Performance | $\mathrm{CP}(\mathrm{G}) 132$ | 132-ball Chip-Scale Package (CSP) | 1 | Industrial ( $-40^{\circ} \mathrm{C}$ to $100^{\circ} \mathrm{C}$ ) |
| XC3S500E |  |  | TQ(G)144 | 144-pin Thin Quad Flat Pack (TQFP) |  |  |
| XC3S1200E |  |  | PQ(G)208 | 208-pin Plastic Quad Flat Pack (PQFP) |  |  |
| XC3S1600E |  |  | FT(G)256 | 256-ball Fine-Pitch Thin Ball Grid Array (FTBGA) |  |  |
|  |  |  | FG(G)320 | 320-ball Fine-Pitch Ball Grid Array (FBGA) |  |  |
|  |  |  | FG(G)400 | 400-ball Fine-Pitch Ball Grid Array (FBGA) |  |  |
|  |  |  | FG(G)484 | 484-ball Fine-Pitch Ball Grid Array (FBGA) |  |  |

## Notes:

1. The -5 speed grade is exclusively available in the Commercial temperature range.

## 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 CP132 package to Table 2. Corrected number of differential I/O pairs <br> for CP132 package. Added package markings for QFP packages (Figure 2) and <br> CP132/CPG132 packages (Figure 4). |

## The Spartan-3E Family Data Sheet

DS312-1, Spartan-3E FPGA Family: Introduction and Ordering Information (Module 1)
DS312-2, Spartan-3E FPGA Family: Functional Description (Module 2)
DS312-3, Spartan-3E FPGA Family: DC and Switching Characteristics (Module 3)
DS312-4, Spartan-3E FPGA Family: Pinout Descriptions (Module 4)

## Spartan-3E FPGA Family: Functional Description

Advance Product Specification

## Introduction

As described in Architectural Overview, the Spartan ${ }^{\text {TM }}$-3E FPGA architecture consists of five fundamental functional elements:

- Input/Output Blocks (IOBs)
- Configurable Logic Block (CLB) and Slice Resources
- Block RAM
- Dedicated Multipliers
- Digital Clock Managers (DCMs)

The following sections provide detailed information on each of these functions. In addition, this section also describes the following functions:

- Clocking Infrastructure
- Interconnect
- Configuration
- Powering Spartan-3E FPGAs


## Input/Output Blocks (IOBs)

## IOB Overview

The Input/Output Block (IOB) provides a programmable, unidirectional or bidirectional interface between a package pin and the FPGA's internal logic. The IOB is similar to that of the Spartan-3 family with the following differences:

- Input-only blocks are added
- Programmable input delays are added to all blocks
- DDR flip-flops can be shared between adjacent IOBs

The unidirectional input-only block has a subset of the full IOB capabilities. Thus there are no connections or logic for an output path. The following paragraphs assume that any reference to output functionality does not apply to the input-only blocks. The number of input-only blocks varies with device size, but is never more than $25 \%$ of the total IOB count.
Figure 1, page 2 is a simplified diagram of the IOB's internal structure. There are three main signal paths within the IOB: the output path, input path, and 3-state path. Each path has its own pair of storage elements that can act as either registers or latches. For more information, see Storage Element Functions. The three main signal paths are as follows:

- The input path carries data from the pad, which is bonded to a package pin, through an optional programmable delay element directly to the I line. After
the delay element, there are alternate routes through a pair of storage elements to the IQ1 and IQ2 lines. The IOB outputs I, IQ1, and IQ2 lead to the FPGA's internal logic. The delay element can be set to ensure a hold time of zero (see Input Delay Functions).
- The output path, starting with the O1 and O2 lines, carries data from the FPGA's internal logic through a multiplexer and then a three-state driver to the IOB pad. In addition to this direct path, the multiplexer provides the option to insert a pair of storage elements.
- The 3-state path determines when the output driver is high impedance. The T1 and T2 lines carry data from the FPGA's internal logic through a multiplexer to the output driver. In addition to this direct path, the multiplexer provides the option to insert a pair of storage elements.
- All signal paths entering the IOB, including those associated with the storage elements, have an inverter option. Any inverter placed on these paths is automatically absorbed into the IOB.



## Notes:

1. All IOB signals communicating with the FPGA's internal logic have the option of inverting polarity inside the IOB.
2. Signals shown with dashed lines connect to the adjacent IOB in a differential pair only, not to the FPGA fabric.

Figure 1: Simplified IOB Diagram

## Input Delay Functions

Each IOB has a programmable delay block that can delay the input signal from 0 to nominally 4000 ps. In Figure 2, the signal is first delayed by either 0 or 2000 ps (nominal) and is then applied to an 8 tap delay line. This delay line has a nominal value of 250 ps per tap. All 8 taps are available via a multiplexer for use as an asynchronous input directly into the FPGA fabric. In this way, the delay is programmable from 0 to 4000 ps in 250 ps steps. Four of the 8 taps are also available via a multiplexer to the D inputs of the synchronous storage elements. The delay inserted in the path to the storage element can be varied from 0 to 4000 ps in 500 ps steps. The first, coarse delay element is common to both asynchronous and synchronous paths, and must be either used or not used for both paths.

The delay values are set up in the silicon once at configuration time-they are non-modifiable in device operation.
The primary use for the input delay element is as an adequate delay to ensure that there is no hold time requirement when using the input flip-flop(s) with a global clock. The necessary value for this function is chosen by the Xilinx software tools and depends on device size. If the design is using a DCM in the clock path, then the delay element can be safely set to zero in the user's design, and there is still no hold time requirement.
Both asynchronous and synchronous values can be modified by the user, which is useful where extra delay is required on clock or data inputs, for example, in interfaces to various types of RAM.
See Module 3 of the Spartan-3E data sheet for exact values for the delay elements.


Figure 2: Input Delay Elements

## Storage Element Functions

There are three pairs of storage elements in each IOB, one pair for each of the three paths. It is possible to configure each of these storage elements as an edge-triggered D-type flip-flop (FD) or a level-sensitive latch (LD).

The storage-element pair on either the Output path or the Three-State path can be used together with a special multiplexer to produce Double-Data-Rate (DDR) transmission.

This is accomplished by taking data synchronized to the clock signal's rising edge and converting it to bits synchronized on both the rising and the falling edge. The combination of two registers and a multiplexer is referred to as a Double-Data-Rate D-type flip-flop (ODDR2).

Table 1 describes the signal paths associated with the storage element.

## Table 1: Storage Element Signal Description

| Storage <br> Element <br> Signal | Description |  |
| :--- | :--- | :--- |
| D | Data input | Data at this input is stored on the active edge of CK and enabled by CE. For latch <br> operation when the input is enabled, data passes directly to the output Q. |
| Q | Data output | The data on this output reflects the state of the storage element. For operation as a latch <br> in transparent mode, Q mirrors the data at D. |
| CK | Clock input | Data is loaded into the storage element on this input's active edge with CE asserted. |
| CE | Clock Enable input | When asserted, this input enables CK. If not connected, CE defaults to the asserted <br> state. |
| SR | Set/Reset input | This input forces the storage element into the state specified by the SRHIGH/SRLOW <br> attributes. The SYNC/ASYNC attribute setting determines if the SR input is <br> synchronized to the clock or not. If both SR and REV are active at the same time, the <br> storage element gets a value of 0. |
| REV | Reverse input | This input is used together with SR. It forces the storage element into the state opposite <br> from what SR does. The SYNC/ASYNC attribute setting determines whether the REV <br> input is synchronized to the clock or not. If both SR and REV are active at the same time, <br> the storage element gets a value of 0. |

As shown in Figure 1, the upper registers in both the output and three-state paths share a common clock. The OTCLK1 clock signal drives the CK clock inputs of the upper registers on the output and three-state paths. Similarly, OTCLK2 drives the CK inputs for the lower registers on the output and three-state paths. The upper and lower registers on the input path have independent clock lines: ICLK1 and ICLK2.
The OCE enable line controls the CE inputs of the upper and lower registers on the output path. Similarly, TCE con-
trols the CE inputs for the register pair on the three-state path and ICE does the same for the register pair on the input path.
The Set/Reset (SR) line entering the IOB controls all six registers, as is the Reverse (REV) line.
In addition to the signal polarity controls described in IOB Overview, each storage element additionally supports the controls described in Table 2.

## Table 2: Storage Element Options

| Option Switch | Function | Specificity |
| :--- | :--- | :--- |
| FF/Latch | Chooses between an edge-triggered flip-flop <br> or a level-sensitive latch | Independent for each storage element |
| SYNC/ASYNC | Determines whether the SR set/reset control is <br> synchronous or asynchronous | Independent for each storage element |

Table 2: Storage Element Options

| Option Switch | Function | Specificity |
| :--- | :--- | :--- |
| SRHIGH/SRLOW | Determines whether SR acts as a Set, which <br> forces the storage element to a logic "1" <br> (SRHIGH) or a Reset, which forces a logic "0" <br> (SRLOW) | Independent for each storage element, except <br> when using ODDR2. In the latter case, the selection <br> for the upper element will apply to both elements. |
| INIT1/INIT0 | When Global Set/Reset (GSR) is asserted or <br> after configuration this option specifies the <br> initial state of the storage element, either set <br> (INIT1) or reset (INIT0). By default, choosing <br> SRLLOW also selects INITO; choosing SRHIGH <br> also selects INIT1. | Independent for each storage element, except <br> when using ODDR2, which uses two IOBs. In the <br> ODDR2 case, selecting INITO for one IOBs applies <br> to both elements within the IOB, although INIT1 <br> could be selected for the elements in the other IOB. |

## Double-Data-Rate Transmission

Double-Data-Rate (DDR) transmission describes the technique of synchronizing signals to both the rising and falling edges of the clock signal. Spartan-3E devices use register pairs in all three IOB paths to perform DDR operations.
The pair of storage elements on the IOB's Output path (OFF1 and OFF2), used as registers, combine with a special multiplexer to form a DDR D-type flip-flop (ODDR2). This primitive permits DDR transmission where output data bits are synchronized to both the rising and falling edges of a clock. DDR operation requires two clock signals (usually $50 \%$ duty cycle), one the inverted form of the other. These signals trigger the two registers in alternating fashion, as shown in Figure 3. The Digital Clock Manager (DCM) generates the two clock signals by mirroring an incoming signal, and then shifting it 180 degrees. This approach ensures minimal skew between the two signals. Alternatively, the inverter inside the IOB can be used to invert the clock signal, thus only using one clock line and both rising and falling edges of that clock line as the two clocks for the DDR flip-flops.

The storage-element pair on the Three-State path (TFF1 and TFF2) also can be combined with a local multiplexer to form a DDR primitive. This permits synchronizing the output enable to both the rising and falling edges of a clock. This DDR operation is realized in the same way as for the output path.
The storage-element pair on the input path (IFF1 and IFF2) allows an I/O to receive a DDR signal. An incoming DDR clock signal triggers one register, and the inverted clock signal triggers the other register. The registers take turns capturing bits of the incoming DDR data signal. The primitive to allow this functionality is called IDDR2.
Aside from high bandwidth data transfers, DDR outputs also can be used to reproduce, or mirror, a clock signal on the output. This approach is used to transmit clock and data signals together (source synchronously). A similar approach is used to reproduce a clock signal at multiple outputs. The advantage for both approaches is that skew across the outputs is minimal.


Figure 3: Two Methods for Clocking the DDR Register

## Register Cascade Feature

In the Spartan-3E family, one of the IOBs in a differential pair can cascade either its input or output storage elements with those in the other IOB of the differential pair. This is intended to make DDR operation at high speed much simpler to implement. The new DDR connections that are available are shown in Figure 1 (dashed lines), and are only available for routing between IOBs and are not accessible to the FPGA fabric. Note that this feature is only available when using differential I/O.

## IDDR2

As a DDR input pair, the master IOB registers incoming data on the rising edge of ICLK1 (= D1) and the rising edge of ICLK2 (= D2), which is typically the same as the falling edge of ICLK1. This data is then transferred into the FPGA fabric. At some point, both signals must be brought into the same clock domain, typically ICLK1. This can be difficult at high frequencies because the available time is only one half of a clock cycle assuming a $50 \%$ duty cycle. See Figure 4 for a graphical illustration of this function.
In the Spartan-3E device, the signal D2 can be cascaded into the storage element of the adjacent slave IOB. There it is re-registered to ICLK1, and only then fed to the FPGA fabric where it is now already in the same time domain as D1. Here, the FPGA fabric uses only the clock ICLK1 to process the received data. See Figure 5 for a graphical illustration of this function.


Figure 4: Input DDR (without Cascade Feature)


Figure 5: Input DDR Using Spartan-3E Cascade Feature

## ODDR2

As a DDR output pair, the master IOB registers data coming from the FPGA fabric on the rising edge of OCLK1 (= D1) and the rising edge of OCLK2 (= D2), which is typically the same as the falling edge of OCLK1. These two bits of data are multiplexed by the DDR mux and forwarded to the output pin. At some point in the FPGA fabric, the signal D2 must be brought into the clock domain OCLK2 from the domain OCLK1. This can be difficult at high frequencies, because the time available is only one half a clock cycle. See Figure 6 for a graphical illustration of this function.
In the Spartan-3E device, the signal D2 can be cascaded via the storage element of the adjacent slave IOB. Here, it is registered by OCLK1 and then forwarded to the master IOB where it is re-registered to OCLK2, selected as usual by the DDR multiplexer, and then forwarded to the output pin. This way the data for transmission can be processed using just the clock OCLK1 in the FPGA fabric. See Figure 7 for a graphical illustration of this function.


Figure 6: Output DDR (without Cascade Feature)


Figure 7: Output DDR Using Spartan-3E Cascade Feature

## SelectIO Signal Standards

The Spartan-3E I/Os feature inputs and outputs that support a wide range of I/O signaling standards (Table 3 and Table 4). The majority of the I/Os also can be used to form differential pairs to support any of the differential signaling standards (Table 4).
To define the I/O signaling standard in a design, set the IOSTANDARD attribute to the appropriate setting. Xilinx provides a variety of different methods for applying the IOSTANDARD for maximum flexibility. For a full description of different methods of applying attributes to control IOSTANDARD, refer to "Entry Strategies for Xilinx Constraints" in the Xilinx Software Manuals and Help.
Spartan-3E FPGAs provide additional input flexibility by allowing I/O standards to be mixed in different banks. Special care must be taken to ensure the input voltages do not exceed $\mathrm{V}_{\mathrm{CCO}}$ (see Module 3 for the specifications). For a particular $\mathrm{V}_{\mathrm{CCO}}$ voltage, Table 3 and Table 4 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 3: Single-Ended IOSTANDARD Bank Compatibility

| Single-Ended IOSTANDARD | $\mathrm{V}_{\text {cco }}$ Supply/Compatibility |  |  |  |  |  | Input Requirements |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1.2 V | 1.5 V | 1.8 V | 2.5 V | 3.0 V | 3.3 V | $V_{\text {REF }}$ for Inputs | Board Termination Voltage ( $\mathrm{V}_{\mathrm{TT}}$ ) |
| LVTTL | - | - | - | - | - | Input/ Output | N/R | N/R |
| LVCMOS33 | - | - | - | - | - | Input/ Output | N/R | N/R |
| LVCMOS25 | - | - | - | Input/ Output | Input | Input | N/R | N/R |
| LVCMOS18 | - | - | Input/ Output | Input | Input | Input | N/R | N/R |
| LVCMOS15 | - | Input/ Output | Input | Input | Input | Input | N/R | N/R |
| LVCMOS12 | Input/ Output | Input | Input | Input | Input | Input | $\mathrm{N} / \mathrm{R}^{(1)}$ | N/R |
| PCI33_3 | - | - | - | - | Input/ Output | Input | $N / R$ | N/R |
| PCI66_3 | - | - | - | - | Input/ Output | Input | N/R | N/R |
| PCIX |  |  |  |  | Input/ Output | Input | N/R | N/R |
| HSTL_I_18 | - | - | Input/ Output | Input | Input | Input | 0.9 | 0.9 |
| HSTL_III_18 | - | - | Input/ Output | Input | Input | Input | 1.1 | 1.8 |
| SSTL18_I | - | - | Input/ Output | Input | Input | Input | 0.9 | 0.9 |
| SSTL2_I | - | - | - | Input/ Output | Input | Input | 1.25 | 1.25 |

## Notes:

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

Table 4: Differential IOSTANDARD Bank Compatibility

| Differential IOSTANDARD | $\mathrm{V}_{\text {cco }}$ Supply |  | Input Requirements: $\mathbf{V}_{\text {REF }}$ |
| :---: | :---: | :---: | :---: |
|  | 2.5V | 3.3V |  |
| LVDS_25 | Input, <br> On-chip Differential Termination, Output ${ }^{(1)}$ | Input |  |
| RSDS_25 | Input, <br> On-chip Differential Termination, Output(1) | Input |  |
| MINI_LVDS_25 | Input, <br> On-chip Differential Termination, Output ${ }^{(1)}$ | Input | N/R <br> (Not Required) |
| LVPECL_25 | Input, <br> On-chip Differential Termination | Input |  |
| BLVDS_25 | Input, <br> On-chip Differential Termination, Output | Input |  |

## Notes:

1. Each bank can support any two of the following: LVDS_25 outputs, MINI_LVDS_25 outputs, RSDS_25 outputs.

HSTL and SSTL inputs use the Reference Voltage ( $\mathrm{V}_{\text {REF }}$ ) to bias the input-switching threshold. Once a configuration data file is loaded into the FPGA that calls for the I/Os of a given bank to use HSTL/SSTL, a few specifically reserved I/O pins on the same bank automatically convert to $\mathrm{V}_{\text {REF }}$ inputs. For banks that do not contain HSTL or SSTL, V VEF pins remain available for user I/Os or input pins.
Differential standards employ a pair of signals, one the opposite polarity of the other. The noise canceling properties (for example, Common-Mode Rejection) of these standards permit exceptionally high data transfer rates. This subsection introduces the differential signaling capabilities of Spartan-3E devices.
Each device-package combination designates specific I/O pairs specially optimized to support differential standards. Differential pairs can be shown in the Pin and Area Constraints Editor (PACE) with the "Show Differential Pairs" option. A unique $L$-number, part of the pin name, identifies the line-pairs associated with each bank (see Module 4). For each pair, the letters $P$ and $N$ designate the true and inverted lines, respectively. For example, the pin names IO_L43P_3 and IO_L43N_3 indicate the true and inverted lines comprising the line pair L 43 on Bank 3.
$\mathrm{V}_{\mathrm{CCO}}$ provides current to the outputs and additionally powers the On-Chip Differential Termination. $\mathrm{V}_{\text {Cco }}$ must be 2.5 V when using the On-Chip Differential Termination. The $\mathrm{V}_{\mathrm{REF}}$ lines are not required for differential operation.
To further understand how to combine multiple IOSTANDARDs within a bank, refer to IOBs Organized into Banks, page 10.

## On-Chip Differential Termination

Spartan-3E devices provide an on-chip $100 \Omega$ differential termination across the input differential receiver terminals
(See Module 3 for the specific range). The on-chip input differential termination in Spartan-3E devices eliminates the external $100 \Omega$ termination resistor commonly found in differential receiver circuits. Use differential termination for LVDS, mini-LVDS, and BLVDS as applications permit.
On-chip Differential Termination is available in banks with $\mathrm{V}_{\mathrm{CCO}}=2.5 \mathrm{~V}$ and is not supported on dedicated input pins. Set the DIFF_TERM attribute to TRUE to enable Differential Termination on a differential I/O pin pair.
The DIFF_TERM attribute uses the following syntax in the UCF file:

INST <I/O_BUFFER_INSTANTIATION_NAME>
DIFF_TERM = "<TRUE/FALSE>";


Figure 8: Differential Inputs and Outputs

## Pull-Up and Pull-Down Resistors

Pull-up and pull-down resistors inside each IOB optionally force a floating I/O pin to a determined state. Pull-up and
pull-down resistors are commonly applied to unused I/Os, inputs, and three-state outputs, but can be used on any I/O. The pull-up resistor connects an I/O to $\mathrm{V}_{\mathrm{CcO}}$ through a resistor. The resistance value depends on the $\mathrm{V}_{\mathrm{CCO}}$ voltage (see Module 3 for the specifications). The pull-down resistor similarly connects an I/O to ground with a resistor. The PULLUP and PULLDOWN attributes and library primitives turn on these optional resistors.
By default, PULLDOWN resistors terminate all unused I/Os. Unused I/Os can alternatively be set to PULLUP or FLOAT. To change the unused I/O Pad setting, set the Bitstream Generator (BitGen) option UnusedPin to PULLUP, PULLDOWN, or FLOAT. The UnusedPin option is accessed through the Properties for Generate Programming File in ISE.
During configuration a Low logic level on HSWAP activates the pull-up resistors for all I/Os not used directly in the selected configuration mode.

## Keeper Circuit

Each I/O has an optional keeper circuit (see Figure 9) that keeps bus lines from floating when not being actively driven. The KEEPER circuit retains the last logic level on a line after all drivers have been turned off. Apply the KEEPER attribute or use the KEEPER library primitive to use the KEEPER circuitry. Pull-up and pull-down resistors override the KEEPER settings.


Figure 9: Keeper Circuit

## Slew Rate Control and Drive Strength

Each IOB has a slew-rate control that sets the output switching edge-rate for LVCMOS and LVTTL outputs. The SLEW attribute controls the slew rate and can either be set to SLOW (default) or FAST.
Each LVCMOS and LVTTL output additionally supports up to six different drive current strengths as shown in Table 5.

To adjust the drive strength for each output set the DRIVE attribute to the desired drive strength: $2,4,6,8,12$, and 16 .

Table 5: Programmable Output Drive Current

| Signal <br> Standard | Output Drive Current (mA) |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{2}$ | $\mathbf{4}$ | $\mathbf{6}$ | $\mathbf{8}$ | $\mathbf{1 2}$ | $\mathbf{1 6}$ |
| LVTTL | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| LVCMOS33 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| LVCMOS25 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | - |
| LVCMOS18 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | - | - |
| LVCMOS15 | $\checkmark$ | $\checkmark$ | $\checkmark$ | - | - | - |
| LVCMOS12 | $\checkmark$ | - | - | - | - | - |

High output current drive strength and FAST output slew rates generally result in fastest I/O performance. However, these same settings generally also result in transmission line effects on the printed circuit board (PCB) for all but the shortest board traces. Each IOB has independent slew rate and drive strength controls. Use the slowest slew rate and lowest output drive current that meets the performance requirements for the end application.
Likewise, due to lead inductance, a given package supports a limited number of simultaneous switching outputs (SSOs) when using fast, high-drive outputs. Only use fast, high-drive outputs when required by the application.

## IOBs Organized into Banks

The Spartan-3E architecture organizes IOBs into four I/O banks as shown in Figure 10. Each bank maintains separate $\mathrm{V}_{\mathrm{CCO}}$ and $\mathrm{V}_{\text {REF }}$ supplies. The separate supplies allow each bank to independently set $\mathrm{V}_{\mathrm{CCO}}$. Similarly, the $\mathrm{V}_{\text {REF }}$ supplies may be set for each bank. Refer to Table 3 and Table 4 for $\mathrm{V}_{\mathrm{CCO}}$ and $\mathrm{V}_{\text {REF }}$ requirements.
When working with Spartan-3E devices, most of the differential I/O standards are compatible and can be combined within any given bank. Each bank can support any two of the following differential standards: LVDS_25 outputs, MINI_LVDS_25 outputs, and RSDS_25 outputs. As an example, LVDS_25 outputs, RSDS_25 outputs, and any other differential inputs while using on-chip differential termination are a valid combination. A combination not allowed is a single bank with LVDS_25 outputs, RSDS_25 outputs, and MINI_LVDS_25 outputs.


DS312-2_26_021205
Figure 10: Spartan-3E I/O Banks (top view)

## I/O Banking Rules

When assigning I/Os to banks, these $\mathrm{V}_{\mathrm{CCO}}$ rules must be followed:

1. All $\mathrm{V}_{\mathrm{CCO}}$ pins on the FPGA must be connected even if a bank is unused.
2. All $\mathrm{V}_{\mathrm{CCO}}$ lines associated within a bank must be set to the same voltage level.
3. The $\mathrm{V}_{\mathrm{CcO}}$ levels used by all standards assigned to the I/Os of any given bank must agree. The Xilinx development software checks for this. Table 3 and Table 4 describe how different standards use the $\mathrm{V}_{\mathrm{CCO}}$ supply.
4. If a bank does not have any $\mathrm{V}_{\mathrm{CCO}}$ requirements, connect $\mathrm{V}_{\mathrm{CCO}}$ to an available voltage, such as 2.5 V or 3.3 V . Some configuration modes might place additional $\mathrm{V}_{\mathrm{CCO}}$ requirements. Refer to Configuration, page 56 for more information.
If any of the standards assigned to the Inputs of the bank use $\mathrm{V}_{\text {REF }}$, then the following additional rules must be observed:
5. All $\mathrm{V}_{\mathrm{REF}}$ pins must be connected within a bank.
6. All $\mathrm{V}_{\text {REF }}$ lines associated with the bank must be set to the same voltage level.
7. The $\mathrm{V}_{\text {REF }}$ levels used by all standards assigned to the Inputs of the bank must agree. The Xilinx development software checks for this. Table 3 describes how different standards use the $\mathrm{V}_{\text {REF }}$ supply.
If $\mathrm{V}_{\text {REF }}$ is not required to bias the input switching thresholds, all associated $V_{\text {REF }}$ pins within the bank can be used as user I/Os or input pins.

## Package Footprint Compatibility

Sometimes, applications outgrow the logic capacity of a specific Spartan-3E FPGA. Fortunately, the Spartan-3E family is designed so that multiple part types are available in pin-compatible package footprints, as described in Module 4. In some cases, there are subtle differences between $\bar{d}$ devices available in the same footprint. These differences
are outlined for each package, such as pins that are unconnected on one device but connected on another in the same package or pins that are dedicated inputs on one package but full I/O on another. When designing the printed circuit board (PCB), plan for potential future upgrades and package migration.
The Spartan-3E family is not pin-compatible with any previous Xilinx FPGA family.

## Dedicated Inputs

Dedicated Inputs are IOBs used only as inputs. Pin names designate a Dedicated Input if the name starts with IP, for example, IP or IP_Lxxx_x. Dedicated inputs retain the full functionality of the IOB for input functions with a single exception for differential inputs (IP_Lxxx_x). For the differential Dedicated Inputs, the on-chip differential termination is not available. To replace the on-chip differential termination, choose a differential pair that supports outputs (IO_Lxxx_x) or use an external $100 \Omega$ termination resistor on the board.

## ESD Protection

Clamp diodes protect all device pads against damage from Electro-Static Discharge (ESD) as well as excessive voltage transients. Each I/O has two clamp diodes: one diode extends P-to-N from the pad to $\mathrm{V}_{\mathrm{CCO}}$ and a second diode extends N -to-P from the pad to GND. During operation, these diodes are normally biased in the off state. These clamp diodes are always connected to the pad, regardless of the signal standard selected. The presence of diodes limits the ability of Spartan-3E I/Os to tolerate high signal voltages. The $\mathrm{V}_{\mathrm{IN}}$ absolute maximum rating in Table 1 of Module 3 specifies the voltage range that I/Os can tolerate.

## Supply Voltages for the IOBs

The IOBs are powered by three supplies:

1. The $\mathrm{V}_{\mathrm{CCO}}$ supplies, one for each of the FPGA's I/O banks, power the output drivers. The voltage on the $\mathrm{V}_{\mathrm{CCO}}$ pins determines the voltage swing of the output signal.
2. $\mathrm{V}_{\mathrm{CCINT}}$ is the main power supply for the FPGA's internal logic.
3. $\mathrm{V}_{\text {CCAUX }}$ is an auxiliary source of power, primarily to optimize the performance of various FPGA functions such as I/O switching.

## The I/Os During Power-On, Configuration, and User Mode

All I/Os have ESD clamp diodes to their respective $\mathrm{V}_{\mathrm{CCO}}$ supply and from GND, as shown in Figure 1. The $\mathrm{V}_{\text {CCINT }}$ $(1.2 \mathrm{~V}), \mathrm{V}_{\text {CCAUX }}(2.5 \mathrm{~V})$, and $\mathrm{V}_{\mathrm{CCO}}$ supplies can be applied in any order. Before the FPGA can start its configuration process, $\mathrm{V}_{\mathrm{CCINT}}, \mathrm{V}_{\mathrm{CCO}}$ Bank 2, and $\mathrm{V}_{\text {CCAUX }}$ must have reached their respective minimum recommended operating
levels (see Table 2 of Module 3). At this time, all I/O drivers are in a high-impedance state. $\mathrm{V}_{\mathrm{CCO}}$ Bank 2, $\mathrm{V}_{\mathrm{CCINT}}$, and $\mathrm{V}_{\text {CCAUX }}$ serve as inputs to the internal Power-On Reset circuit (POR).
A Low level applied to the HSWAP input enables pull-up resistors on User I/Os from power-on throughout configuration. A High level on HSWAP disables the pull-up resistors, allowing the I/Os to float. HSWAP contains a weak pull-up and defaults to High if left floating. As soon as power is applied, the FPGA begins initializing its configuration memory. At the same time, the FPGA internally asserts the Global Set-Reset (GSR), which asynchronously resets all IOB storage elements to a default Low state.
Upon the completion of initialization and the beginning of configuration, INIT_B goes High, sampling the M0, M1, and M 2 inputs to determine the configuration mode. At this point in time, the configuration data is loaded into the FPGA. The I/O drivers remain in a high-impedance state (with or without pull-up resistors, as determined by the HSWAP input) throughout configuration.
At the end of configuration, the GSR net is released, placing the IOB registers in a Low state by default, unless the
loaded design reverses the polarity of their respective $S R$ inputs.
The Global Three State (GTS) net is released during Start-Up, marking the end of configuration and the beginning of design operation in the User mode. After the GTS net is released, all user I/Os go active while all unused I/Os are weakly pulled down (PULLDOWN). The designer can control how the unused I/Os are terminated after GTS is released by setting the Bitstream Generator (BitGen) option UnusedPin to PULLUP, PULLDOWN, or FLOAT.
One clock cycle later (default), the Global Write Enable (GWE) net is released allowing the RAM and registers to change states. Once in User mode, any pull-up resistors enabled by HSWAP revert to the user settings and HSWAP is available as a general-purpose I/O. For more information on PULLUP and PULLDOWN, see Pull-Up and Pull-Down Resistors.

## JTAG Boundary-Scan Capability

All Spartan-3E IOBs support boundary-scan testing compatible with IEEE 1149.1/1532 standards. See JTAG Mode, page 86 for more information on programming via JTAG.

## Configurable Logic Block (CLB) and Slice Resources

## 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 $16 \times 1$ 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 11.
Each density varies by the number of rows and columns of CLBs (see Table 6).


Figure 11: CLB Locations

Table 6: Spartan-3E CLB Resources

| Device | CLB <br> Rows | CLB <br> Columns | CLB <br> Total(1) | Slices | LUTs / <br> Flip-Flops | Equivalent <br> Logic Cells | RAM16/ <br> SRL16 | Distributed <br> RAM Bits |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| XC3S100E | 22 | 16 | 240 | 960 | 1920 | 2160 | 960 | 15360 |
| XC3S250E | 34 | 26 | 612 | 2448 | 4896 | 5508 | 2448 | 39168 |
| XC3S500E | 46 | 34 | 1164 | 4656 | 9312 | 10476 | 4656 | 74496 |
| XC3S1200E | 60 | 46 | 2168 | 8672 | 17344 | 19512 | 8672 | 138752 |
| XC3S1600E | 76 | 58 | 3688 | 14752 | 29504 | 33192 | 14752 | 236032 |

## 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 Module 1, Figure 1).

## Slices

Each CLB comprises four interconnected slices, as shown in Figure 13. 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 12: Simplified Diagram of the Left-Hand SLICEM


Figure 13: Arrangement of Slices within the CLB

## Slice Location Designations

The Xilinx development software designates the location of a slice according to its $X$ and $Y$ coordinates, starting in the bottom left corner, as shown in Figure 11. The letter ' $X$ ' followed by a number identifies columns of slices, incrementing from the left side of the die to the right. The letter ' $Y$ ' followed by a number identifies the position of each slice in a pair as well as indicating the CLB row, incrementing from the bottom of the die. Figure 13 shows the CLB located in the lower left-hand corner of the die. The SLICEM always has an even ' $X$ ' number, and the SLICEL always has an odd ' X ' number.

## Slice Overview

A slice includes two LUT function generators and two storage elements, along with additional logic, as shown in Figure 14.
Both SLICEM and SLICEL have the following elements in common to provide logic, arithmetic, and ROM functions:

- Two 4-input LUT function generators, $F$ and $G$
- Two storage elements
- Two wide-function multiplexers, F5MUX and FiMUX
- Carry and arithmetic logic


SLICEM


SLICEL DS312:-213_02095

Figure 14: Resources in a Slice

The SLICEM pair supports two additional functions:

- Two $16 \times 1$ distributed RAM blocks, RAM16
- Two 16-bit shift registers, SRL16

Each of these elements is described in more detail in the following sections.

## Logic Cells

The combination of a LUT and a storage element is known as a "Logic Cell". The additional features in a slice, such as the wide multiplexers, carry logic, and arithmetic gates, add to the capacity of a slice, implementing logic that would otherwise require additional LUTs. Benchmarks have shown that the overall slice is equivalent to 2.25 simple logic cells. This calculation provides the equivalent logic cell count shown in Table 6.

## Slice Details

Figure 16 is a detailed diagram of the SLICEM. It represents a superset of the elements and connections to be found in all slices. The dashed and gray lines (blue when viewed in color) indicate the resources found only in the SLICEM and not in the SLICEL.
Each slice has two halves, which are differentiated as top and bottom to keep them distinct from the upper and lower slices in a CLB. The control inputs for the clock (CLK), Clock

Enable (CE), Slice Write Enable (SLICEWE1), and Reset/Set (RS) are shared in common between the two halves.
The LUTs located in the top and bottom portions of the slice are referred to as "G" and "F", respectively, or the "G-LUT" and the "F-LUT". The storage elements in the top and bottom portions of the slice are called FFY and FFX, respectively.
Each slice has two multiplexers with F5MUX in the bottom portion of the slice and FiMUX in the top portion. Depending on the slice, the FiMUX takes on the name F6MUX, F7MUX, or F8MUX, according to its position in the multiplexer chain. The lower SLICEL and SLICEM both have an F6MUX. The upper SLICEM has an F7MUX, and the upper SLICEL has an F8MUX.
The carry chain enters the bottom of the slice as CIN and exits at the top as COUT. Five multiplexers control the chain: CYINIT, CYOF, and CYMUXF in the bottom portion and CYOG and CYMUXG in the top portion. The dedicated arithmetic logic includes the exclusive-OR gates XORF and XORG (bottom and top portions of the slice, respectively) as well as the AND gates FAND and GAND (bottom and top portions, respectively).
See Table 7 for a description of all the slice input and output signals.

## Table 7: Slice Inputs and Outputs

| Name | Location | Direction | Description |
| :--- | :--- | :---: | :--- |
| F[4:1] | SLICEL/M Bottom | Input | F-LUT and FAND inputs |
| G[4:1] | SLICEL/M Top | Input | G-LUT and GAND inputs or Write Address (SLICEM) |
| BX | SLICEL/M Bottom | Input | Bypass to or output (SLICEM) or storage element, or control input to <br> F5MUX, input to carry logic, or data input to RAM (SLICEM) |
| BY | SLICEL/M Top | Input | Bypass to or output (SLICEM) or storage element, or control input to <br> FiMUX, input to carry logic, or data input to RAM (SLICEM) |
| BXOUT | SLICEM Bottom | Output | BX bypass output |
| BYOUT | SLICEM Top | Output | BY bypass output |
| ALTDIG | SLICEM Top | Input | Alternate data input to RAM |
| DIG | SLICEM Top | Output | ALTDIG or SHIFTIN bypass output |
| SLICEWE1 | SLICEM Common | Input | RAM Write Enable |
| F5 | SLICEL/M Bottom | Output | Output from F5MUX; direct feedback to FiMUX |
| FXINA | SLICEL/M Top | Input | Input to FiMUX; direct feedback from F5MUX or another FiMUX |
| FXINB | SLICEL/M Top | Input | Input to FiMUX; direct feedback from F5MUX or another FiMUX |
| Fi | SLICEL/M Top | Output | Output from FiMUX; direct feedback to another FiMUX |
| CE | SLICEL/M Common | Input | FFX/Y Clock Enable |
| SR | SLICEL/M Common | Input | FFX/Y Set or Reset or RAM Write Enable (SLICEM) |

Table 7: Slice Inputs and Outputs (Continued)

| Name | Location | Direction | Description |
| :--- | :--- | :---: | :--- |
| CLK | SLICEL/M Common | Input | FFX/Y Clock or RAM Clock (SLICEM) |
| SHIFTIN | SLICEM Top | Input | Data input to G-LUT RAM |
| SHIFTOUT | SLICEM Bottom | Output | Shift data output from F-LUT RAM |
| CIN | SLICEL/M Bottom | Input | Carry chain input |
| COUT | SLICEL/M Top | Output | Carry chain output |
| X | SLICEL/M Bottom | Output | Combinatorial output |
| Y | SLICEL/M Top | Output | Combinatorial output |
| XB | SLICEL/M Bottom | Output | Combinatorial output from carry or F-LUT SRL16 (SLICEM) |
| YB | SLICEL/M Top | Output | Combinatorial output from carry or G-LUT SRL16 (SLICEM) |
| XQ | SLICEL/M Bottom | Output | FFX output |
| YQ | SLICEL/M Top | Output | FFY output |

## Main Logic Paths

Central to the operation of each slice are two nearly identical data paths at the top and bottom of the slice. The description that follows uses names associated with the bottom path. (The top path names appear in parentheses.) The basic path originates at an interconnect switch matrix outside the CLB. See Interconnect for more information on the switch matrix and the routing connections.
Four lines, F1 through F4 (or G1 through G4 on the upper path), enter the slice and connect directly to the LUT. Once inside the slice, the lower 4-bit path passes through a LUT "F" (or "G") that performs logic operations. The LUT Data output, "D", offers five possible paths:

1. Exit the slice via line " X " (or " Y ") and return to interconnect.
2. Inside the slice, "X" (or "Y") serves as an input to the DXMUX (or DYMUX) which feeds the data input, "D", of the FFY (or FFX) storage element. The "Q" output of the storage element drives the line $X Q$ (or YQ ) which exits the slice.
3. Control the CYMUXF (or CYMUXG) multiplexer on the carry chain.
4. With the carry chain, serve as an input to the XORF (or XORG) exclusive-OR gate that performs arithmetic operations, producing a result on "X" (or "Y").
5. Drive the multiplexer F5MUX to implement logic functions wider than four bits. The "D" outputs of both the F-LUT and G-LUT serve as data inputs to this multiplexer.
In addition to the main logic paths described above, there are two bypass paths that enter the slice as $B X$ and $B Y$. Once inside the FPGA, BX in the bottom half of the slice (or

BY in the top half) can take any of several possible branches:

1. Bypass both the LUT and the storage element, and then exit the slice as BXOUT (or BYOUT) and return to interconnect.
2. Bypass the LUT, and then pass through a storage element via the D input before exiting as XQ (or YQ ).
3. Control the wide function multiplexer F5MUX (or FiMUX).
4. Via multiplexers, serve as an input to the carry chain.
5. Drive the DI input of the LUT.
6. BY can control the REV inputs of both the FFY and FFX storage elements. See Storage Element Functions.
7. Finally, the DIG_MUX multiplexer can switch BY onto the DIG line, which exits the slice.
The control inputs CLK, CE, SR, BX and BY have programmable polarity. The LUT inputs do not need programmable polarity because their function can be inverted inside the LUT.
The sections that follow provide more detail on individual functions of the slice.

## Look-Up Tables

The Look-Up Table or LUT is a RAM-based function generator and is the main resource for implementing logic functions. Furthermore, the LUTs in each SLICEM pair can be configured as Distributed RAM or a 16 -bit shift register, as described later.
Each of the two LUTs ( F and G ) in a slice have four logic inputs (A1-A4) and a single output (D). Any four-variable Boolean logic operation can be implemented in one LUT. Functions with more inputs can be implemented by cascad-
ing LUTs or by using the wide function multiplexers that are described later.
The output of the LUT can connect to the wide multiplexer logic, the carry and arithmetic logic, or directly to a CLB output or to the CLB storage element. See Figure 15.


## Wide Multiplexers

Wide-function multiplexers effectively combine LUTs in order to permit more complex logic operations. Each slice has two of these multiplexers with F5MUX in the bottom portion of the slice and FiMUX in the top portion. The F5MUX multiplexes the two LUTs in a slice. The FiMUX multiplexes two CLB inputs which connect directly to the F5MUX and FiMUX results from the same slice or from other slices. See Figure 16.

Figure 15: LUT Resources in a Slice


Figure 16: Dedicated Multiplexers in Spartan-3E CLB

Depending on the slice, FiMUX takes on the name F6MUX, F7MUX, or F8MUX. The designation indicates the number of inputs possible without restriction on the function. For example, an F7MUX can generate any function of seven inputs. Figure 17 shows the names of the multiplexers in each position in the Spartan-3E CLB. The figure also includes the direct connections within the CLB, along with the F7MUX connection to the CLB below.
Each mux can create logic functions of more inputs than indicated by its name. The F5MUX, for example, can gener-
ate any function of five inputs, with four inputs duplicated to two LUTs and the fifth input controlling the mux. Because each LUT can implement independent 2:1 muxes, the F5MUX can combine them to create a $4: 1$ mux, which is a six-input function. If the two LUTs have completely independent sets of inputs, some functions of all nine inputs can be implemented. Table 8 shows the connections for each multiplexer and the number of inputs possible for different types of functions.


DS312-2_38_021305
Figure 17: Muxes and Dedicated Feedback in Spartan-3E CLB

Table 8: Mux Capabilities

| Mux |  | Total Number of Inputs per Function |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Usage | Input Source | For Any <br> Function | For Mux | For Limited <br> Functions |
|  | F5MUX | LUTs | 5 | $6(4: 1 \mathrm{mux})$ | 9 |
| FiMUX | F6MUX | F5MUX | 6 | $11(8: 1 \mathrm{mux})$ | 19 |
|  | F7MUX | F6MUX | 7 | $20(16: 1 \mathrm{mux})$ | 39 |
|  | F8MUX | F7MUX | 8 | $37(32: 1 \mathrm{mux})$ | 79 |

The wide multiplexers can be used by the automatic tools or instantiated in a design using a component such as the F5MUX. The symbol, signals, and function are described below. The description is similar for the F6MUX, F7MUX, and F8MUX. Each has versions with a general output, local output, or both.


DS312-2_35_021205
Figure 18: F5MUX with Local and General Outputs

Table 9: F5MUX Inputs and Outputs

| Signal | Function |
| :--- | :--- |
| IO | Input selected when S is Low |
| I1 | Input selected when S is High |
| S | Select input |
| LO | Local Output that connects to the F5 or FX CLB <br> pins, which use local feedback to the FXIN <br> inputs to the FiMUX for cascading |
| O | General Output that connects to the <br> general-purpose combinatorial or registered <br> outputs of the CLB |

Table 10: F5MUX Function

| Inputs |  |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathbf{S}$ | $\mathbf{1 0}$ | $\mathbf{I 1}$ | $\mathbf{O}$ | LO |
| 0 | 1 | $X$ | 1 | 1 |
| 0 | 0 | $X$ | 0 | 0 |
| 1 | $X$ | 1 | 1 | 1 |
| 1 | $X$ | 0 | 0 | 0 |

For more details on using the multiplexers, see XAPP466: "Using Dedicated Multiplexers in Spartan-3 FPGAs".

## Carry and Arithmetic Logic

The carry chain, together with various dedicated arithmetic logic gates, support fast and efficient implementations of math operations. The carry logic is automatically used for most arithmetic functions in a design. The gates and multiplexers of the carry and arithmetic logic can also be used for general-purpose logic, including simple wide Boolean functions.
The carry chain enters the slice as CIN and exits as COUT, controlled by several multiplexers. The carry chain connects directly from one CLB to the CLB above. The carry chain can be initialized at any point from the BX (or BY) inputs.
The dedicated arithmetic logic includes the exclusive-OR gates XORF and XORG (upper and lower portions of the slice, respectively) as well as the AND gates GAND and FAND (upper and lower portions, respectively). These gates work in conjunction with the LUTs to implement efficient arithmetic functions, including counters and multipliers, typically at two bits per slice. See Figure 19 and Table 11.


Figure 19: Carry Logic

## Table 11: Carry Logic Functions

| Function | Description |
| :--- | :--- |
| CYINIT | Initializes carry chain for a slice. Fixed selection of: <br> - CIN carry input from the slice below <br> - BX input |
| CYOF | Carry generation for bottom half of slice. Fixed selection of: <br> - F1 or F2 inputs to the LUT (both equal 1 when a carry is to be generated) <br> - FAND gate for multiplication <br> - BX input for carry initialization <br> - Fixed "1" or "0" input for use as a simple Boolean function |
| CY0G | Carry generation for top half of slice. Fixed selection of: <br> - G1 or G2 inputs to the LUT (both equal 1 when a carry is to be generated) <br> - GAND gate for multiplication <br> - BY input for carry initialization <br> - Fixed "1" or "0" input for use as a simple Boolean function |
| CYMUXF | Carry generation or propagation mux for bottom half of slice. Dynamic selection via CYSELF of: <br> - CYINIT carry propagation (CYSELF $=1$ ) <br> - CYOF carry generation (CYSELF $=0$ ) |

Table 11: Carry Logic Functions (Continued)

| Function | Description |
| :--- | :--- |
| CYMUXG | Carry generation or propagation mux for top half of slice. Dynamic selection via CYSELF of: <br> - CYMUXF carry propagation (CYSELG $=1)$ <br> - CYOG carry generation (CYSELG = 0) |
| CYSELF | Carry generation or propagation select for bottom half of slice. Fixed selection of: <br> - F-LUT output typically XOR result) <br> - Fixed "1" to always propagate |
| CYSELG | Carry generation or propagation select for top half of slice. Fixed selection of: <br> - G-LUT output (typically XOR result) <br> - Fixed "1" to always propagate |
| XORF | Sum generation for bottom half of slice. Inputs from: <br> - F-LUT <br> - CYINIT carry signal from previous stage <br> Result is sent to either the combinatorial or registered output for the top of the slice. |
| XORG | Sum generation for top half of slice. Inputs from: <br> - G-LUT <br> - CYMUXF carry signal from previous stage <br> Result is sent to either the combinatorial or registered output for the top of the slice. |
| FAND | Multiplier partial product for bottom half of slice. Inputs: <br> - F-LUT F1 input <br> - F-LUT F2 input <br> Result is sent through CY0F to become the carry generate signal into CYMUXF |
| GAND | Multiplier partial product for top half of slice. Inputs: <br> - G-LUT G1 input <br> - G-LUT G2 input <br> Result is sent through CY0G to become the carry generate signal into CYMUXG |

The basic usage of the carry logic is to generate a half-sum in the LUT via an XOR function, which generates or propagates a carry out COUT via the carry mux CYMUXF (or CYMUXG), and then complete the sum with the dedicated XORF (or XORG) gate and the carry input CIN. This structure allows two bits of an arithmetic function in each slice. The CYMUXF (or CYMUXG) can be instantiated using the MUXCY element, and the XORF (or XORG) can be instantiated using the XORCY element.


Figure 20: Using the MUXCY and XORCY in the Carry Logic

The FAND (or GAND) gate is used for partial product multiplication and can be instantiated using the MULT_AND component. Partial products are generated by two-input AND gates and then added. The carry logic is efficient for the adder, but one of the inputs must be outside the LUT as shown in Figure 20. The FAND (or GAND) gate is used to duplicate one of the partial products, while the LUT generates both partial products and the XOR function, as shown in Figure 21.


Figure 21: Using the MULT_AND for Multiplication in Carry Logic

The MULT_AND is useful for small multipliers. Larger multipliers can be built using the dedicated $18 \times 18$ multiplier blocks (see Dedicated Multipliers).

## Storage Elements

The storage element, which is programmable as either a D-type flip-flop or a level-sensitive transparent latch, provides a means for synchronizing data to a clock signal, among other uses. The storage elements in the top and bot-
tom portions of the slice are called FFY and FFX, respectively. FFY has a fixed multiplexer on the $D$ input selecting either the combinatorial output Y or the bypass signal BY. FFX selects between the combinatorial output $X$ or the bypass signal BX.
The functionality of a slice storage element is identical to that described earlier for the I/O storage elements. All signals have programmable polarity; the default active-High function is described.

## Table 12: Storage Element Signals

| Signal | Description |
| :--- | :--- |
| D | Input. For a flip-flop data on the D input is loaded when R and S (or CLR and PRE) are Low and CE is High <br> during the Low-to-High clock transition. For a latch, Q reflects the D input while the gate (G) input and gate <br> enable (GE) are High and R and S (or CLR and PRE) are Low. The data on the D input during the High-to-Low <br> gate transition is stored in the latch. The data on the Q output of the latch remains unchanged as long as G or <br> GE remains Low. |
| Q | Output. Toggles after the Low-to-High clock transition for a flip-flop and immediately for a latch. |
| C | Clock for edge-triggered flip-flops. |
| G | Gate for level-sensitive latches. |
| CE | Clock Enable for flip-flops. |
| GE | Gate Enable for latches. |
| S | Synchronous Set (Q = High). When the S input is High and R is Low, the flip-flop is set, output High, during the <br> Low-to-High clock (C) transition. A latch output is immediately set, output High. |
| R | Synchronous Reset (Q = Low); has precedence over Set. |
| PRE | Asynchronous Preset (Q = High). When the PRE input is High and CLR is Low, the flip-flop is set, output High, <br> during the Low-to-High clock (C) transition. A latch output is immediately set, output High. |
| CLR | Asynchronous Clear (Q = Low); has precedence over Preset to reset Q output Low |
| SR | CLB input for R, S, CLR, or PRE |
| REV | CLB input for opposite of SR. Must be asynchronous or synchronous to match SR. |

The control inputs $R, S, C E$, and $C$ are all shared between the two flip-flops in a slice.


Figure 22: FD Flip-Flop Component with Synchronous Reset, Set, and Clock Enable

Table 13: FD Flip-Flop Functionality with Synchronous Reset, Set, and Clock Enable

| Inputs |  |  |  |  | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{R}$ | $\mathbf{S}$ | CE | $\mathbf{D}$ | $\mathbf{C}$ | $\mathbf{Q}$ |
| 1 | X | X | X | $\uparrow$ | 0 |
| 0 | 1 | X | X | $\uparrow$ | 1 |
| 0 | 0 | 0 | X | X | No Change |
| 0 | 0 | 1 | 1 | $\uparrow$ | 1 |
| 0 | 0 | 1 | 0 | $\uparrow$ | 0 |

## Initialization

The CLB storage elements are initialized at power-up, during configuration, by the global GSR signal, and by the individual SR or REV inputs to the CLB.

## Table 14: Slice Storage Element Initialization

| Signal | Description |
| :--- | :--- |
| SR | Set/Reset input. Forces the storage element <br> into the state specified by the attribute SRHIGH <br> or SRLOW. SRHIGH forces a logic "1" when SR <br> is asserted. SRLOW forces a logic "0". For each <br> slice, set and reset can be set to be <br> synchronous or asynchronous. |
| REV | Reverse of Set/Reset input. A second input <br> (BY) forces the storage element into the <br> opposite state. The reset condition is <br> predominant over the set condition if both are <br> active. Same synchronous/asynchronous <br> setting as for SR. |
| GSR | Global Set/Reset. GSR defaults to active High <br> but can be inverted by adding an inverter in <br> front of the GSR input of the <br> STARTUP_SPARTAN3E element. The initial <br> state after configuration or GSR is defined by a <br> separate INIT0 and INIT1 attribute. By default, <br> setting the SRLOW attribute sets INIT0, and <br> setting the SRHIGH attribute sets INIT1. |

## Distributed RAM

The LUTs in the SLICEM can be programmed as distributed RAM. This type of memory affords moderate amounts of data buffering anywhere along a data path. One SLICEM LUT stores 16 bits (RAM16). The four LUT inputs $\mathrm{F}[4: 1]$ or $\mathrm{G}[4: 1]$ become the address lines labeled $\mathrm{A}[4: 1]$ in the device model and $\mathrm{A}[3: 0]$ in the design components, provid-
ing a $16 \times 1$ configuration in one LUT. Multiple SLICEM LUTs can be combined in various ways to store larger amounts of data, including $16 \times 4,32 \times 2$, or $64 \times 1$ configurations in one CLB. The fifth and sixth address lines required for the 32-deep and 64-deep configurations, respectively, are implemented using the $B X$ and $B Y$ inputs, which connect to the write enable logic for writing and the F5MUX and F6MUX for reading.
Writing to distributed RAM is always synchronous to the SLICEM clock (WCLK for distributed RAM) and enabled by the SLICEM SR input which functions as the active-High Write Enable (WE). The read operation is asynchronous, and, therefore, during a write, the output initially reflects the old data at the address being written.
The distributed RAM outputs can be captured using the flip-flops within the SLICEM element. The WE write-enable control for the RAM and the CE clock-enable control for the flip-flop are independent, but the WCLK and CLK clock inputs are shared. Because the RAM read operation is asynchronous, the output data always reflects the currently addressed RAM location.
A dual-port option combines two LUTs so that memory access is possible from two independent data lines. The same data is written to both $16 \times 1$ memories but they have independent read address lines and outputs. The dual-port function is implemented by cascading the G-LUT address lines, which are used for both read and write, to the F-LUT write address lines (WF[4:1] in Figure 12), and by cascading the G-LUT data input D1 through the DIF_MUX in Figure 12 and to the D1 input on the F-LUT. One CLB provides a $16 \times 1$ dual-port memory as shown in Figure 23.
Any write operation on the D input and any read operation on the SPO output can occur simultaneously with and independently from a read operation on the second read-only port, DPO.


Figure 23: RAM16X1D Dual-Port Usage


Figure 24: Dual-Port RAM Component

Table 15: Dual-Port RAM Function

| Inputs |  |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: |
| WE (mode) | WCLK | D | SPO | DPO |
| 0 (read) | X | X | data_a | data_d |
| 1 (read) | 0 | X | data_a | data_d |
| 1 (read) | 1 | X | data_a | data_d |
| 1 (write) | $\uparrow$ | D | D | data_d |
| 1 (read) | $\downarrow$ | X | data_a | data_d |

## Notes:

1. data $\_$a $=$word addressed by bits A3-AO.
2. data_d = word addressed by bits DPRA3-DPRAO.

## Table 16: Distributed RAM Signals

| Signal | Description |
| :--- | :--- |
| WCLK | The clock is used for synchronous <br> writes. The data and the address input <br> pins have setup times referenced to the <br> WCLK pin. Active on the positive edge <br> by default with built-in programmable <br> polarity. |
| WE | The enable pin affects the write <br> functionality of the port. An inactive <br> Write Enable prevents any writing to <br> memory cells. An active Write Enable <br> causes the clock edge to write the data <br> input signal to the memory location <br> pointed to by the address inputs. Active <br> High by default with built-in <br> programmable polarity. |

Table 16: Distributed RAM Signals (Continued)

| Signal | Description |
| :--- | :--- |
| A0, A1, A2, A3 <br> (A4, A5) | The address inputs select the memory <br> cells for read or write. The width of the <br> port determines the required address <br> inputs. |
| D | The data input provides the new data <br> value to be written into the RAM. |
| O, SPO, and <br> DPO | The data output O on single-port RAM <br> or the SPO and DPO outputs on <br> dual-port RAM reflects the contents of <br> the memory cells referenced by the <br> address inputs. Following an active <br> write clock edge, the data out (O or <br> SPO) reflects the newly written data. |

The INIT attribute can be used to preload the memory with data during FPGA configuration. The default initial contents for RAM is all zeros. If the WE is held Low, the element can be considered a ROM. The ROM function is possible even in the SLICEL.
The global write enable signal, GWE, is asserted automatically at the end of device configuration to enable all writable elements. The GWE signal guarantees that the 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).
For more information on distributed RAM, see XAPP464: "Using Look-Up Tables as Distributed RAM in Spartan-3 FPGAs".

## Shift Registers

It is possible to program each SLICEM LUT as a 16 -bit shift register (see Figure 25). 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 12). 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 25: 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 $\mathrm{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 26 for an example of the SRLC16E component.


Figure 26: SRL16 Shift Register Component with Cascade and Clock Enable

The functionality of the shift register is shown in Table 17. 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.
Table 17: SRL16 Shift Register Function

| Inputs |  |  |  | Outputs |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Am | CLK | CE | $\mathbf{D}$ | Q | Q15 |
| $A m$ | X | 0 | X | $\mathrm{Q}[\mathrm{Am}]$ | $\mathrm{Q}[15]$ |
| Am | $\uparrow$ | 1 | D | $\mathrm{Q}[A m-1]$ | $\mathrm{Q}[15]$ |

## Notes:

1. $\mathrm{m}=0,1,2,3$.

For more information on the SRL16, refer to XAPP465: "Using Look-Up Tables as Shift Registers (SRL16) in Spartan-3 FPGAs".

## Block RAM

Spartan-3E devices incorporate 4 to 36 dedicated block RAMs, which are organized as dual-port configurable 18 Kbit blocks. Functionally, the block RAM is identical to the Spartan-3 architecture block RAM. Block RAM synchronously stores large amounts of data while distributed RAM, previously described, is better suited for buffering small amounts of data anywhere along signal paths. This section describes basic block RAM functions. For detailed implementation information, refer to XAPP463: "Using Block RAM in Spartan-3 Series FPGAs".
Each block RAM is configurable by setting the content's initial values, default signal value of the output registers, port aspect ratios, and write modes. Block RAM can be used in single-port or dual-port modes.

## Arrangement of RAM Blocks on Die

The block RAMs are located together with the multipliers on the die in one or two columns depending on the size of the device. The XC3S100E has one column of block RAM. The Spartan-3E devices ranging from the XC3S250E to XC3S1600E have two columns of block RAM. Table 18 shows the number of RAM blocks, the data storage capacity, and the number of columns for each device. Row(s) of CLBs are located above and below each block RAM column.

## Table 18: Number of RAM Blocks by Device

| Device | Total <br> Number of <br> RAM <br> Blocks | Total <br> Addressable <br> Locations <br> (bits) | Number <br> of <br> Columns |
| :--- | :---: | :---: | :---: |
| XC3S100E | 4 | 73,728 | 1 |
| XC3S250E | 12 | 221,184 | 2 |
| XC3S500E | 20 | 368,640 | 2 |
| XC3S1200E | 28 | 516,096 | 2 |
| XC3S1600E | 36 | 663,552 | 2 |

Immediately adjacent to each block RAM is an embedded $18 \times 18$ hardware multiplier. The upper 16 bits of the block RAM's Port A Data input bus are shared with the upper 16 bits of the A multiplicand input bus of the multiplier. Similarly, the upper 16 bits of Port B's data input bus are shared with the $B$ multiplicand input bus of the multiplier. Details on the
block RAM's shared connectivity with the multipliers are located in XAPP463.

## The Internal Structure of the Block RAM

The block RAM has a dual port structure. The two identical data ports called $A$ and $B$ permit independent access to the common block RAM, which has a maximum capacity of 18,432 bits, or 16,384 bits with no parity bits (see parity bits description in Table 19). Each port has its own dedicated set of data, control, and clock lines for synchronous read and write operations. There are four basic data paths, as shown in Figure 27:

1. Write to and read from Port A
2. Write to and read from Port B
3. Data transfer from Port A to Port B
4. Data transfer from Port B to Port A


Figure 27: Block RAM Data Paths

## Number of Ports

A choice among primitives determines whether the block RAM functions as dual- or single-port memory. A name of the form RAMB16_S[ $\left.w_{A}\right] \_S\left[w_{B}\right]$ calls out the dual-port primitive, where the integers $w_{A}$ and $w_{B}$ specify the total data path width at ports $A$ and $B$, respectively. Thus, a RAMB16_S9_S18 is a dual-port RAM with a 9-bit Port A and an 18-bit Port B. A name of the form RAMB16_S[w] identifies the single-port primitive, where the integer w specifies the total data path width of the lone port A. A RAMB16_S18 is a single-port RAM with an 18-bit port.

## Port Aspect Ratios

Each port of the block RAM can be configured independently to select a number of different possible widths for the data input (DI) and data output (DO) signals as shown in Table 19.

## Table 19: Port Aspect Ratios

| Total Data Path Width (w bits) | DI/DO Data Bus Width (w-p bits) ${ }^{1}$ | DIP/DOP <br> Parity Bus Width (p bits) | ADDR Bus Width (r bits) ${ }^{2}$ | $\begin{gathered} \text { DI/DO } \\ {[w-p-1: 0]} \end{gathered}$ | DIP/DOP [p-1:0] | $\begin{aligned} & \text { ADDR } \\ & {[r-1: 0]} \end{aligned}$ | No. of Addressable Locations ( $n$ ) ${ }^{3}$ | Block RAM Capacity $\left(w^{*} n\right.$ bits) ${ }^{4}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 14 | [0:0] | - | [13:0] | 16,384 | 16,384 |
| 2 | 2 | 0 | 13 | [1:0] | - | [12:0] | 8,192 | 16,384 |
| 4 | 4 | 0 | 12 | [3:0] | - | [11:0] | 4,096 | 16,384 |
| 9 | 8 | 1 | 11 | [7:0] | [0:0] | [10:0] | 2,048 | 18,432 |
| 18 | 16 | 2 | 10 | [15:0] | [1:0] | [9:0] | 1,024 | 18,432 |
| 36 | 32 | 4 | 9 | [31:0] | [3:0] | [8:0] | 512 | 18,432 |

## Notes:

1. The width of the total data path (w) is the sum of the DI/DO bus width (w-p) and any parity bits (p).
2. The width selection made for the $\mathrm{DI} / \mathrm{DO}$ bus determines the number of address lines $(\mathrm{r})$ according to the relationship expressed as: $r=14-[\log (w-p) / \log (2)]$.
3. The number of address lines delimits the total number ( n ) of addressable locations or depth according to the following equation: $\mathrm{n}=2^{\mathrm{r}}$.
4. The product of $w$ and $n$ yields the total block RAM capacity.

If the data bus width of Port A differs from that of Port B, the block RAM automatically performs a bus-matching function as described in Figure 28. When data is written to a port with a narrow bus and then read from a port with a wide bus, the latter port effectively combines "narrow" words to form "wide" words. Similarly, when data is written into a port with a wide bus and then read from a port with a narrow bus, the latter port divides "wide" words to form "narrow" words. Par-
ity bits are not available if the data port width is configured as $\times 4, \times 2$, or $\times 1$. For example, if a $\times 36$ data word ( 32 data, 4 parity) is addressed as two x18 halfwords (16 data, 2 parity), the parity bits associated with each data byte are mapped within the block RAM to the appropriate parity bits. The same effect happens when the x 36 data word is mapped as four x 9 words.


Figure 28: Data Organization and Bus-matching Operation with Different Port Widths on Port A and Port B

## Block RAM Port Signal Definitions

Representations of the dual-port primitive RAMB16_S $\left[w_{A}\right]$ S $\left[w_{B}\right]$ and the single-port primitive RAMB16_S[w] with their associated signals are shown in Figure 29a and Figure 29b, respectively. These signals are
defined in Table 20. The control signals (WE, EN, CLK, and SSR) on the block RAM are active High. However, optional inverters on the control signals change the polarity of the active edge to active Low.

(a) Dual-Port

(b) Single-Port

## Notes:

1. $\mathrm{w}_{\mathrm{A}}$ and $\mathrm{w}_{\mathrm{B}}$ are integers representing the total data path width (i.e., data bits plus parity bits) at Ports A and B , respectively.
2. $\quad p_{A}$ and $p_{B}$ are integers that indicate the number of data path lines serving as parity bits.
3. $r_{A}$ and $r_{B}$ are integers representing the address bus width at ports $A$ and $B$, respectively.
4. The control signals CLK, WE, EN, and SSR on both ports have the option of inverted polarity.

Figure 29: Block RAM Primitives

Table 20: Block RAM Port Signals

| Signal <br> Description | Port A <br> Signal <br> Name | Port B <br> Signal <br> Name | Direction |  |
| :--- | :---: | :---: | :---: | :--- |
| Address Bus | ADDRA | ADDRB | Input | The Address Bus selects a memory location for read or write <br> operations. The width (w) of the port's associated data path <br> determines the number of available address lines (r), as per <br> Table 18. |
| Data Input Bus | DIA | DIB | Input | Data at the DI input bus is written to the RAM location specified <br> by the address input bus (ADDR) during the active edge of the <br> CLK input, when the clock enable (EN) and write enable (WE) <br> inputs are active. |
| It is possible to configure a port's DI input bus width (w-p) based |  |  |  |  |
| on Table 18. This selection applies to both the DI and DO paths |  |  |  |  |
| of a given port. |  |  |  |  |

Table 20: Block RAM Port Signals (Continued)

| Signal <br> Description | Port A <br> Signal <br> Name | Port B <br> Signal <br> Name | Direction |  |
| :--- | :---: | :---: | :---: | :--- |
| Data Output Bus | DOA | DOB | Output | Data is written to the DO output bus from the RAM location <br> specified by the address input bus, ADDR. See the DI signal <br> description for DO port width configurations. <br> Basic data access occurs on the active edge of the CLK when <br> WE is inactive and EN is active. The DO outputs mirror the data <br> stored in the address ADDR memory location. Data access with <br> WE active if the WRITE_MODE attribute is set to the value: <br> WRITE_FIRST, which accesses data after the write takes place. <br> READ_FIRST accesses data before the write occurs. A third <br> attribute, NO_CHANGE, latches the DO outputs upon the <br> assertion of WE. See Block RAM Data Operations for details on <br> the WRITE_MODE attribute. |
| Parity Data <br> Output(s) | DOPA | DOPB | Output | Parity outputs represent additional bits included in the data input <br> path. The number of parity bits 'p' included in the DI bus (same <br> as for the DO bus) depends on a port's total data path width (w). <br> See the DIP signal description for configuration details. |
| Write Enable | WEA | WEB | Input | When asserted together with EN, this input enables the writing of <br> data to the RAM. When WE is inactive with EN asserted, read <br> operations are still possible. In this case, a latch passes data <br> from the addressed memory location to the DO outputs. |
| Clock Enable | ENA | ENB | Input | When asserted, this input enables the CLK signal to perform <br> read and write operations to the block RAM. When inactive, the <br> block RAM does not perform any read or write operations. |
| Set/Reset | SSRA | SSRB | Input | When asserted, this pin forces the DO output latch to the value <br> of the SRVAL attribute. It is synchronized to the CLK signal. |
| Clock | CLKA | CLKB | Input | This input accepts the clock signal to which read and write <br> operations are synchronized. All associated port inputs are <br> required to meet setup times with respect to the clock signal's <br> active edge. The data output bus responds after a clock-to-out <br> delay referenced to the clock signal's active edge. |

## Block RAM Attribute Definitions

A block RAM has a number of attributes that control its behavior as shown in Table 21.

Table 21: Block RAM Attributes

| Function | Attribute | Possible Values |
| :--- | :---: | :--- |
| Initial Content for Data Memory, Loaded <br> during Configuration | INITxx (INIT_00 through <br> INIT3F) | Each initialization string defines 32 hex values <br> of the 16384-bit data memory of the block RAM. |
| Initial Content for Parity Memory, Loaded <br> during Configuration | INITPxx (INITP_00 <br> through INITPOF) | Each initialization string defines 32 hex values <br> of the 2048-bit parity data memory of the block <br> RAM. |
| Data Output Latch Initialization | INIT (single-port) <br> INITA, INITB (dual-port) | Hex value the width of the chosen port. |

Table 21: Block RAM Attributes (Continued)

| Function | Attribute | Possible Values |
| :--- | :---: | :---: |
| Data Output Latch Synchronous <br> Set/Reset Value | SRVAL (single-port) <br> SRVAL_A, SRVAL_B <br> (dual-port) | Hex value the width of the chosen port. |
| Data Output Latch Behavior during Write <br> (see Block RAM Data Operations) | WRITE_MODE | WRITE_FIRST, READ_FIRST, NO_CHANGE |

## Block RAM Data Operations

Writing data to and accessing data from the block RAM are synchronous operations that take place independently on each of the two ports. Table 22 describes the data operations of each port as a result of the block RAM control signals in their default active-High edges.

The waveforms for the write operation are shown in the top half of Figure 30, Figure 31, and Figure 32. When the WE and EN signals enable the active edge of CLK, data at the DI input bus is written to the block RAM location addressed by the ADDR lines.

## Table 22: Block RAM Function Table

| Input Signals |  |  |  |  |  |  |  | Output Signals |  | RAM Data |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| GSR | EN | SSR | WE | CLK | ADDR | DIP | DI | DOP | DO | Parity | Data |
| Immediately After Configuration |  |  |  |  |  |  |  |  |  |  |  |
| Loaded During Configuration |  |  |  |  |  |  |  | X | X | INITP_xx | INIT_xx |
| Global Set/Reset Immediately After Configuration |  |  |  |  |  |  |  |  |  |  |  |
| 1 | X | X | X | X | X | X | X | INIT | INIT | No Chg | No Chg |
| RAM Disabled |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | X | X | X | X | X | X | No Chg | No Chg | No Chg | No Chg |
| Synchronous Set/Reset |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 0 | $\uparrow$ | X | X | X | SRVAL | SRVAL | No Chg | No Chg |
| Synchronous Set/Reset During Write RAM |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | $\uparrow$ | addr | pdata | Data | SRVAL | SRVAL | RAM(addr) $\leftarrow$ pdata | RAM(addr) $\leftarrow$ data |
| Read RAM, no Write Operation |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 0 | 0 | $\uparrow$ | addr | X | X | RAM(pdata) | RAM(data) | No Chg | No Chg |
| Write RAM, Simultaneous Read Operation |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 0 | 1 | $\uparrow$ | addr | pdata | Data | WRITE_MODE = WRITE_FIRST |  |  |  |
|  |  |  |  |  |  |  |  | pdata | data | RAM(addr) $\leftarrow$ pdata | RAM(addr) $\leftarrow$ data |
|  |  |  |  |  |  |  |  | WRITE_MODE = READ_FIRST |  |  |  |
|  |  |  |  |  |  |  |  | RAM(data) | RAM(data) | RAM(addr) $\leftarrow$ pdata | RAM(addr) $\leftarrow$ pdata |
|  |  |  |  |  |  |  |  | WRITE_MODE = NO_CHANGE |  |  |  |
|  |  |  |  |  |  |  |  | No Chg | No Chg | RAM(addr) $\leftarrow$ pdata | RAM(addr) $\leftarrow$ pdata |

There are a number of different conditions under which data can be accessed at the DO outputs. Basic data access always occurs when the WE input is inactive. Under this condition, data stored in the memory location addressed by the ADDR lines passes through a output latch to the DO outputs. The timing for basic data access is shown in the
portions of Figure 30, Figure 31, and Figure 32 during which WE is Low.

Data also can be accessed on the DO outputs when asserting the WE input based on the value of the WRITE_MODE attribute as described in Table 23.

## Table 23: WRITE_MODE Effect on Data Output Latches During Write Operations

| Write Mode | Effect on Same Port | Effect on Opposite Port <br> (dual-port only with same address) |
| :--- | :--- | :--- |
| WRITE_FIRST <br> Read After Write | Data on DI and DIP inputs is written into <br> specified RAM location and simultaneously <br> appears on DO and DOP outputs. | Invalidates data on DO and DOP outputs. |
| READ_FIRST <br> Read Before Write | Data from specified RAM location appears on <br> DO and DOP outputs. <br> Data on DI and DIP inputs is written into <br> specified location. | Data from specified RAM location appears on <br> DO and DOP outputs. |
| NO_CHANGE <br> No Read on Write | Data on DO and DOP outputs remains <br> unchanged. <br> Data on DI and DIP inputs is written into <br> specified location. | Invalidates data on DO and DOP outputs. |



Figure 30: Waveforms of Block RAM Data Operations with WRITE_FIRST Selected

Setting the WRITE_MODE attribute to a value of WRITE_FIRST, data is written to the addressed memory location on an enabled active CLK edge and is also passed to the DO outputs. WRITE_FIRST timing is shown in the portion of Figure 30 during which WE is High.

Setting the WRITE_MODE attribute to a value of READ_FIRST, data already stored in the addressed location passes to the DO outputs before that location is overwritten with new data from the DI inputs on an enabled active CLK edge. READ_FIRST timing is shown in the portion of Figure 31 during which WE is High.


DS312-2_06_020905
Figure 31: Waveforms of Block RAM Data Operations with READ_FIRST Selected


Figure 32: Waveforms of Block RAM Data Operations with NO_CHANGE Selected

Setting the WRITE_MODE attribute to a value of NO_CHANGE, puts the DO outputs in a latched state when asserting WE. Under this condition, the DO outputs retain
the data driven just before WE is asserted. NO_CHANGE timing is shown in the portion of Figure 32 during which WE is High.

## Dedicated Multipliers

The Spartan-3E devices provide 4 to 36 dedicated multiplier blocks per device. The multipliers are located together with the block RAM in one or two columns depending on device density. See Arrangement of RAM Blocks on Die for details on the location of these blocks and their connectivity.
The multiplier blocks primarily perform two's complement numerical multiplication but can also perform some less obvious applications such as simple data storage and barrel shifting. Logic slices also implement efficient small multipliers and thereby supplement the dedicated multipliers. The Spartan-3E dedicated multiplier blocks have additional features beyond those provided in Spartan-3 FPGAs.
Each multiplier performs the principle operation $\mathrm{P}=\mathrm{A} \times \mathrm{B}$, where ' $A$ ' and ' $B$ ' are 18 -bit words in two's complement form, and ' P ' is the full-precision 36 -bit product, also in two's complement form. The 18 -bit inputs represent values ranging from $-131,072_{10}$ to $+131,071_{10}$ with a resulting product ranging from $-17,179,738,112_{10}$ to $+17,179,869,184_{10}$.

Implement multipliers with inputs less than 18 bits by sign-extending the inputs (i.e., replicating the most-significant bit). Wider multiplication operations are performed by combining the dedicated multipliers and slice-based logic in any viable combination or by time-sharing a single multiplier. Perform unsigned multiplication by restricting the inputs to the positive range. Tie the most-significant bit Low and represent the unsigned value in the remaining 17 lesser-significant bits.
As shown in Figure 33, each multiplier block has optional registers on each of the multiplier inputs and the output. The registers are named AREG, BREG, and PREG and can be used in any combination. The clock input is common to all the registers within a block, but each register has an independent clock enable and synchronous reset controls making them ideal for storing data samples and coefficients. When used for pipelining, the registers boost the multiplier clock rate, beneficial for higher performance applications.
Figure 33 illustrates the principle features of the multiplier block.


Figure 33: Principle Ports and Functions of Dedicated Multiplier Blocks

Use the MULT18X18SIO primitive shown in Figure 34 to instantiate a multiplier within a design. Although high-level logic synthesis software usually automatically infers a multiplier, adding the pipeline registers usually requires the MULT18X18SIO primitive. Connect the appropriate signals
to the MULT18X18SIO multiplier ports and set the individual AREG, BREG, and PREG attributes to ' 1 ' to insert the associated register, or to 0 to remove it and make the signal path combinatorial.


Figure 34: MULT18X18SIO Primitive

The MULT18X18SIO primitive has two additional ports called BCIN and BCOUT to cascade or share the multiplier's 'B' input among several multiplier bocks. The 18-bit BCIN "cascade" input port offers an alternate input source from the more typical ' $B$ ' input. The B_INPUT attribute specifies whether the specific implementation uses the BCIN or 'B' input path. Setting B_INPUT to DIRECT chooses the 'B' input. Setting B_INPUT to CASCADE selects the alternate BCIN input. The BREG register then optionally holds the selected input value, if required.
BCOUT is an 18-bit output port that always reflects the value that is applied to the multiplier's second input, which is either the ' $B$ ' input, the cascaded value from the BCIN input, or the output of the BREG if it is inserted.

Figure 35 illustrates the four possible configurations using different settings for the B_INPUT attribute and the BREG attribute.


Figure 35: Four Configurations of the B Input

The BCIN and BCOUT ports have associated dedicated routing that connects adjacent multipliers within the same column. Via the cascade connection, the BCOUT port of one multiplier block drives the BCIN port of the multiplier block directly above it. There is no connection to the BCIN port of the bottom-most multiplier block in a column or a connection from the BCOUT port of the top-most block in a column. As an example, Figure 36 shows the multiplier cascade capability within the XC3S100E FPGA, which has a single column of multiplier, four blocks tall. For clarity, the figure omits the register control inputs.


Figure 36: Multiplier Cascade Connection
When using the BREG register, the cascade connection forms a shift register structure typically used in DSP algorithms such as direct-form FIR filters. When the BREG register is omitted, the cascade structure essentially feeds the same input value to more than one multiplier. This parallel connection serves to create wide-input multipliers, implement transpose FIR filters, and is used in any application that requires that several multipliers have the same input value.

Table 24 defines each port of the MULT18X18SIO primitive.

## Table 24: MULT18X18SIO Embedded Multiplier Primitives Description

| Signal Name | Direction | Function |
| :---: | :---: | :---: |
| A[17:0] | Input | The primary 18 -bit two's complement value for multiplication. The block multiplies by this value asynchronously if the optional AREG and PREG registers are omitted. When AREG and/or PREG are used, the value provided on this port is qualified by the rising edge of CLK, subject to the appropriate register controls. |
| $\mathrm{B}[17: 0]$ | Input | The second 18-bit two's complement value for multiplication if the B_INPUT attribute is set to DIRECT. The block multiplies by this value asynchronously if the optional BREG and PREG registers are omitted. When BREG and/or PREG are used, the value provided on this port is qualified by the rising edge of CLK, subject to the appropriate register controls. |
| BCIN[17:0] | Input | The second 18-bit two's complement value for multiplication if the B_INPUT attribute is set to CASCADE. The block multiplies by this value asynchronously if the optional BREG and PREG registers are omitted. When BREG and/or PREG are used, the value provided on this port is qualified by the rising edge of CLK, subject to the appropriate register controls. |
| P [35:0] | Output | The 36-bit two's complement product resulting from the multiplication of the two input values applied to the multiplier. If the optional AREG, BREG and PREG registers are omitted, the output operates asynchronously. Use of PREG causes this output to respond to the rising edge of CLK with the value qualified by CEP and RSTP. If PREG is omitted, but AREG and BREG are used, this output responds to the rising edge of CLK with the value qualified by CEA, RSTA, CEB, and RSTB. If PREG is omitted and only one of AREG or BREG is used, this output responds to both asynchronous and synchronous events. |
| BCOUT[17:0] | Output | The value being applied to the second input of the multiplier. When the optional BREG register is omitted, this output responds asynchronously in response to changes at the $\mathrm{B}[17: 0]$ or $\mathrm{BCIN}[17: 0]$ ports according to the setting of the B_INPUT attribute. If BREG is used, this output responds to the rising edge of CLK with the value qualified by CEB and RSTB. |
| CEA | Input | Clock enable qualifier for the optional AREG register. The value provided on the A[17:0] port is captured by AREG in response to a rising edge of CLK when this signal is High, provided that RSTA is Low. |
| RSTA | Input | Synchronous reset for the optional AREG register. AREG content is forced to the value zero in response to a rising edge of CLK when this signal is High. |
| CEB | Input | Clock enable qualifier for the optional BREG register. The value provided on the $\mathrm{B}[17: 0]$ or $\mathrm{BCIN}[17: 0]$ port is captured by BREG in response to a rising edge of CLK when this signal is High, provided that RSTB is Low. |
| RSTB | Input | Synchronous reset for the optional BREG register. BREG content is forced to the value zero in response to a rising edge of CLK when this signal is High. |
| CEP | Input | Clock enable qualifier for the optional PREG register. The value provided on the output of the multiplier port is captured by PREG in response to a rising edge of CLK when this signal is High, provided that RSTP is Low. |
| RSTP | Input | Synchronous reset for the optional PREG register. PREG content is forced to the value zero in response to a rising edge of CLK when this signal is High. |

## Notes:

1. The control signals CLK, CEA, RSTA, CEB, RSTB, CEP, and RSTP have the option of inverted polarity.

## Digital Clock Managers (DCMs)

## Differences from the Spartan-3 Architecture

- Spartan-3E FPGAs have two, four, or eight DCMs, depending on device size.
- The Spartan-3E DCM has a maximum phase shift range of $\pm 180^{\circ}$. The Spartan-3 DCM range is $\pm 360^{\circ}$.
- The Spartan-3E DLL supports lower input frequencies, down to 5 MHz . Spartan-3 DLLs supports down to 24 MHz.


## Overview

Spartan-3E Digital Clock Managers (DCMs) provide flexible, complete control over clock frequency, phase shift and skew. To accomplish this, the DCM employs a Delay-Locked Loop (DLL), a fully digital control system that uses feedback to maintain clock signal characteristics with a high degree of precision despite normal variations in operating temperature and voltage. This section provides a fundamental description of the DCM. See XAPP462: "Using Digital Clock Managers (DCMs) in Spartan-3 Series FPGAs" for further information.
The XC3S100E FPGA has two DCMs, one at the top and one at the bottom of the device. The XC3S250E and XC3S500E FPGAs each include four DCMs, two at the top and two at the bottom. The XC3S1200E and XC3S1600E FPGAs contain eight DCMs with two on each edge (see also Figure 42). The DCM in Spartan-3E FPGAs is surrounded by CLBs within the logic array and is no longer located at the top and bottom of a column of block RAM as in the Spartan-3 architecture,. The Digital Clock Manager is instantiated into a design as the "DCM" primitive.

The DCM supports three major functions:

- Clock-skew Elimination: Clock skew describes the extent to which clock signals may, under normal circumstances, deviate from zero-phase alignment. It occurs when slight differences in path delays cause the clock signal to arrive at different points on the die at different times. This clock skew can increase set-up and hold time requirements as well as clock-to-out time, which may be undesirable in applications operating at a high frequency, when timing is critical. The DCM eliminates clock skew by aligning the output clock signal it generates with another version of the clock signal that is fed back. As a result, the two clock signals establish a zero-phase relationship. This effectively cancels out clock distribution delays that might lie in the signal path leading from the clock output of the DCM to its feedback input.
- Frequency Synthesis: Provided with an input signal, the DCM can generate a wide range of different output clock frequencies. This is accomplished by either multiplying and/or dividing the frequency of the input clock signal by any of several different factors.
- Phase Shifting: The DCM provides the ability to shift the phase of all its output clock signals with respect to its input clock signal.
The DCM has four functional components: the Delay-Locked Loop (DLL), the Digital Frequency Synthesizer (DFS), the Phase Shifter (PS), and the Status Logic. Each component has its associated signals, as shown in Figure 37.


DS099-2_07_040103
Figure 37: DCM Functional Blocks and Associated Signals


Figure 38: Simplified Functional Diagram of DLL

Table 25: DLL Signals

| Signal | Direction | Description |
| :--- | :---: | :--- |
| CLKIN | Input | Accepts original clock signal. |
| CLKFB | Input | Accepts either CLKO or CLK2X as the feedback signal. (Set CLK_FEEDBACK attribute <br> accordingly). |
| CLK0 | Output | Generates a clock signal with same frequency and phase as CLKIN. |
| CLK90 | Output | Generates a clock signal with same frequency as CLKIN, only phase-shifted $90^{\circ}$. |
| CLK180 | Output | Generates a clock signal with same frequency as CLKIN, only phase-shifted $180^{\circ}$. |
| CLK270 | Output | Generates a clock signal with same frequency as CLKIN, only phase-shifted $270^{\circ}$. |
| CLK2X | Output | Generates a clock signal with same phase as CLKIN, only twice the frequency. |
| CLK2X180 | Output | Generates a clock signal with twice the frequency of CLKIN, phase-shifted $180^{\circ}$ with <br> respect to CLKIN. |
| CLKDV | Output | Divides the CLKIN frequency by CLKDV_DIVIDE value to generate lower frequency <br> clock signal that is phase-aligned to CLKIN. |

## Delay-Locked Loop (DLL)

The most basic function of the DLL component is to eliminate clock skew. The main signal path of the DLL consists of an input stage, followed by a series of discrete delay elements or taps, which in turn leads to an output stage. This path together with logic for phase detection and control forms a system complete with feedback as shown in Figure 38. In Spartan-3E FPGAs, the DLL is implemented using a counter-based delay line.
The DLL component has two clock inputs, CLKIN and CLKFB, as well as seven clock outputs, CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, and CLKDV as described in Table 25. The clock outputs drive simulta-
neously. Signals that initialize and report the state of the DLL are discussed in the Status Logic Component section.
The clock signal supplied to the CLKIN input serves as a reference waveform. The DLL seeks to align the rising-edge of feedback signal at the CLKFB input with the rising-edge of CLKIN input. When eliminating clock skew, the common approach to using the DLL is as follows: The CLK0 signal is passed through the clock distribution network to all the registers it synchronizes. These registers are either internal or external to the FPGA. After passing through the clock distribution network, the clock signal returns to the DLL via a feedback line called CLKFB. The control block inside the DLL measures the phase error between CLKFB and CLKIN.

This phase error is a measure of the clock skew that the clock distribution network introduces. The control block activates the appropriate number of delay elements to cancel out the clock skew. Once the DLL has brought the CLK0 signal in phase with the CLKIN signal, it asserts the LOCKED output, indicating a lock on to the CLKIN signal.

## DLL Attributes and Related Functions

A number of different functional options can be set for the DLL component through the use of the attributes described in Table 26. Each attribute is described in detail in the sections that follow:

## Table 26: DLL Attributes

| Attribute | Description | Values |
| :--- | :--- | :--- |
| CLK_FEEDBACK | Chooses either the CLK0 or CLK2X output to <br> drive the CLKFB input | NONE, 1X, 2X |
| CLKIN_DIVIDE_BY_2 | Halves the frequency of the CLKIN signal just <br> as it enters the DCM | TRUE, FALSE |
| CLKDV_DIVIDE | Selects the constant used to divide the CLKIN <br> input frequency to generate the CLKDV <br> output frequency | $1.5,2,2.5,3,3.5,4,4.5,5,5.5,6.0$, <br> $6.5,7.5,8,9,10,11,12,13,14$, <br> $15, ~ a n d ~ 16 ~$ |
| DUTY_CYCLE_CORRECTION | Enables 50\% duty cycle correction for the <br> CLK0, CLK90, CLK180, and CLK270 outputs | TRUE, FALSE |

## DLL Clock Input Connections

An external clock source enters the FPGA using a Global Clock Input Buffer (IBUFG), which directly accesses the global clock network or via an Input Buffer (IBUF). Clock signals within the FPGA drive a global clock net using a Global Clock Multiplexer Buffer (BUFGMUX). The global clock net connects directly to the CLKIN input. The internal and external connections are shown in Figure 39a and Figure 39c, respectively. A differential clock (e.g., LVDS) can serve as an input to CLKIN.

## DLL Clock Output and Feedback Connections

As many as four of the nine DCM clock outputs can simultaneously drive four of the BUFGMUX buffers on the same die edge. All DCM clock outputs can simultaneously drive general routing resources, including interconnect leading to OBUF buffers.

The feedback loop is essential for DLL operation and is established by driving the CLKFB input with either the CLK0 or the CLK2X signal so that any undesirable clock distribution delay is included in the loop. It is possible to use either of these two signals for synchronizing any of the seven DLL outputs: CLK0, CLK90, CLK180, CLK270, CLKDV, CLK2X, or CLK2X180. The value assigned to the CLK_FEEDBACK attribute must agree with the physical feedback connection: a value of 1 X for the CLK0 case, 2 X for the CLK2X case. If the DCM is used in an application that does not require the DLL - that is, only the DFS is used - then there is no required feedback loop so CLK_FEEDBACK is set to NONE.
There are two basic cases that determine how to connect the DLL clock outputs and feedback connections: on-chip synchronization and off-chip synchronization, which are illustrated in Figure 39a through Figure 39d.


Figure 39: Input Clock, Output Clock, and Feedback Connections for the DLL

In the on-chip synchronization case in Figure 39a and Figure 39b, it is possible to connect any of the DLL's seven output clock signals through general routing resources to the FPGA's internal registers. Either a Global Clock Buffer (BUFG) or a BUFGMUX affords access to the global clock network. As shown in Figure 39a, the feedback loop is created by routing CLK0 (or CLK2X, in Figure 39b to a global clock net, which in turn drives the CLKFB input.
In the off-chip synchronization case in Figure 39c and Figure 39d, CLK0 (or CLK2X) plus any of the DLL's other output clock signals exit the FPGA using output buffers (OBUF) to drive an external clock network plus registers on the board. As shown in Figure 39c, the feedback loop is formed by feeding CLK0 (or CLK2X, in Figure 39d) back into the FPGA using an IBUFG, which directly accesses the global clock network, or an IBUF. Then, the global clock net is connected directly to the CLKFB input.

## Accommodating High Input Frequencies

If the frequency of the CLKIN signal is high such that it exceeds the maximum permitted, divide it down to an acceptable value using the CLKIN_DIVIDE_BY_2 attribute. When this attribute is set to TRUE, the CLKIN frequency is divided by a factor of two just as it enters the DCM.

## Coarse Phase Shift Outputs of the DLL Component

In addition to CLK0 for zero-phase alignment to the CLKIN signal, the DLL also provides the CLK90, CLK180, and CLK270 outputs for $90^{\circ}, 180^{\circ}$, and $270^{\circ}$ phase-shifted signals, respectively. These signals are described in Table 25. Their relative timing is shown in Figure 40. For control in finer increments than $90^{\circ}$, see Phase Shifter (PS).

## Basic Frequency Synthesis Outputs of the DLL Component

The DLL component provides basic options for frequency multiplication and division in addition to the more flexible synthesis capability of the DFS component, described in a later section. These operations result in output clock signals with frequencies that are either a fraction (for division) or a multiple (for multiplication) of the incoming clock frequency. The CLK2X output produces an in-phase signal that is twice the frequency of CLKIN. The CLK2X180 output also doubles the frequency, but is $180^{\circ}$ out-of-phase with respect to CLKIN. The CLKDIV output generates a clock frequency that is a predetermined fraction of the CLKIN frequency. The CLKDV_DIVIDE attribute determines the factor used to divide the CLKIN frequency. The attribute can be set to var-
ious values as described in Table 26. The basic frequency synthesis outputs are described in Table 25.

## Duty Cycle Correction of DLL Clock Outputs

The CLK2X ${ }^{(1)}$, CLK2X180, and CLKDV ${ }^{(2)}$ output signals ordinarily exhibit a $50 \%$ duty cycle - even if the incoming CLKIN signal has a different duty cycle. Fifty-percent duty cycle means that the High and Low times of each clock cycle are equal. The DUTY_CYCLE_CORRECTION attribute determines whether or not duty cycle correction is applied to the CLK0, CLK90, CLK180, and CLK270 outputs. If DUTY_CYCLE_CORRECTION is set to TRUE, then the duty cycle of these four outputs is corrected to $50 \%$. If DUTY_CYCLE_CORRECTION is set to FALSE, then these outputs exhibit the same duty cycle as the CLKIN signal. Figure 40 compares the characteristics of the DLL's output signals to those of the CLKIN signal.
The CLK2X output generates a $25 \%$ duty cycle clock at the same frequency as the CLKIN signal until the DLL has achieved lock.
The duty cycle of the CLKDV outputs may differ somewhat from $50 \%$ (i.e., the signal is High for less than $50 \%$ of the period) when the CLKDV_DIVIDE attribute is set to a non-integer value and the DLL is operating in the High Frequency mode.

## Digital Frequency Synthesizer (DFS)

The DFS component generates clock signals the frequency of which is a product of the clock frequency at the CLKIN input and a ratio of two user-determined integers. Because of the wide range of possible output frequencies such a ratio permits, the DFS feature provides still further flexibility than the DLL's basic synthesis options as described in the preceding section. The DFS component's two dedicated outputs, CLKFX and CLKFX180, are defined in Table 28.
The signal at the CLKFX180 output is essentially an inversion of the CLKFX signal. These two outputs always exhibit a $50 \%$ duty cycle. This is true even when the CLKIN signal does not. These DFS clock outputs are driven at the same time as the DLL's seven clock outputs.
The numerator of the ratio is the integer value assigned to the attribute CLKFX_MULTIPLY and the denominator is the integer value assigned to the attribute CLKFX_DIVIDE. These attributes are described in Table 27.
The output frequency (fcLKFX) can be expressed as a function of the incoming clock frequency ( $f$ cLKin) as follows:
$\mathrm{f}_{\text {CLKFX }}=\mathrm{f}_{\text {CLKIN }}{ }^{*}$ (CLKFX_MULTIPLY/CLKFX_DIVIDE) (3)
Regarding the two attributes, it is possible to assign any combination of integer values, provided that two conditions are met:

1. The two values fall within their corresponding ranges, as specified in Table 27.
2. The $\mathrm{f}_{\mathrm{CLKFX}}$ frequency calculated from the above expression accords with the DCM's operating frequency specifications.
For example, if CLKFX_MULTIPLY = 5 and CLKFX_DIVIDE $=3$, then the frequency of the output clock signal is $5 / 3$ that of the input clock signal.

Phase: $\quad 0^{\circ} \quad 90^{\circ} 180^{\circ} 270^{\circ} 0^{\circ} \quad 90^{\circ} 180^{\circ} 270^{\circ} \quad 0^{\circ}$

## Input Signal (30\% Duty Cycle)



## Output Signal - Duty Cycle is Always Corrected



Output Signal - Attribute Corrects Duty Cycle


DUTY_CYCLE_CORRECTION = TRUE


Figure 40: Characteristics of the DLL Clock Outputs

## DFS With or Without the DLL

The DFS component can be used with or without the DLL component: Without the DLL, the DFS component multiplies or divides the CLKIN signal frequency according to the respective CLKFX_MULTIPLY and CLKFX_DIVIDE values,
generating a clock with the new target frequency on the CLKFX and CLKFX180 outputs. Though classified as belonging to the DLL component, the CLKIN input is shared with the DFS component. This case does not employ feedback loop. Therefore, it cannot correct for clock distribution delay.
With the DLL, the DFS operates as described in the preceding case, only with the additional benefit of eliminating the clock distribution delay. In this case, a feedback loop from the CLK0 output to the CLKFB input must be present.
The DLL and DFS components work together to achieve this phase correction as follows: Given values for the CLKFX_MULTIPLY and CLKFX_DIVIDE attributes, the DLL selects the delay element for which the output clock edge coincides with the input clock edge whenever mathematically possible. For example, when CLKFX_MULTIPLY = 5 and CLKFX_DIVIDE $=3$, the input and output clock edges coincide every three input periods, which is equivalent in time to five output periods.
Smaller CLKFX_MULTIPLY and CLKFX_DIVIDE values achieve faster lock times. With no factors common to the two attributes, alignment occurs once with every number of cycles equal to the CLKFX_DIVIDE value. Therefore, it is recommended that the user reduce these values by factoring wherever possible. For example, given CLKFX_MULTIPLY = 9 and CLKFX_DIVIDE = 6, removing a factor of three yields CLKFX_MULTIPLY = 3 and CLKFX_DIVIDE $=2$. While both value-pairs result in the multiplication of clock frequency by $3 / 2$, the latter value-pair enables the DLL to lock more quickly.

## Table 27: DFS Attributes

| Attribute | Description | Values |
| :--- | :--- | :--- |
| CLKFX_MULTIPLY | Frequency <br> multiplier <br> constant | Integer from <br> 2 to 32, <br> inclusive |
| CLKFX_DIVIDE | Frequency divisor <br> constant | Integer from <br> 1 to 32, <br> inclusive |

## Table 28: DFS Signals

| Signal | Direction | Description |
| :--- | :--- | :--- |
| CLKFX | Output | Multiplies the CLKIN frequency <br> by the attribute-value ratio <br> (CLKFX_MULTIPLY/ |
| CLKFX_DIVIDE) to generate a |  |  |
| clock signal with a new target |  |  |
| frequency. |  |  |$|$

## DFS Clock Output Connections

There are two basic cases that determine how to connect the DFS clock outputs: on-chip and off-chip, which are illustrated in Figure 39a and Figure 39c, respectively. This is similar to what has already been described for the DLL component. See DLL Clock Output and Feedback Connections.
In the on-chip case, it is possible to connect either of the DFS's two output clock signals through general routing resources to the FPGA's internal registers. Either a Global Clock Buffer (BUFG) or a BUFGMUX affords access to the global clock network. The optional feedback loop is formed in this way, routing CLKO to a global clock net, which in turn drives the CLKFB input.
In the off-chip case, the DFS's two output clock signals, plus CLKO for an optional feedback loop, can exit the FPGA using output buffers (OBUF) to drive a clock network plus registers on the board. The feedback loop is formed by feeding the CLKO signal back into the FPGA using an IBUFG, which directly accesses the global clock network, or an IBUF. Then the global clock net is connected directly to the CLKFB input.

## Phase Shifter (PS)

The DCM provides two approaches to controlling the phase of a DCM clock output signal relative to the CLKIN signal: First, there are nine clock outputs that employ the DLL to achieve a desired phase relationship: CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, CLKDV CLKFX, and CLKFX180. These outputs afford "coarse" phase control.
The second approach uses the PS component described in this section to provide a still finer degree of control. The PS component accomplishes this by introducing a "fine phase shift" ( $\mathrm{T}_{\mathrm{PS}}$ ) between the CLKFB and CLKIN signals inside the DLL component. The user can control this fine phase shift down to a resolution of $1 / 512$ of a CLKIN cycle or one tap delay (DCM_TAP), whichever is greater. When in use, the PS component shifts the phase of all nine DCM clock output signals together. If the PS component is used together with a DCM clock output such as the CLK90, CLK180, CLK270, CLK2X180, and CLKFX180, then the fine phase shift of the former gets added to the coarse phase shift of the latter.

## PS Component Enabling and Mode Selection

The CLKOUT_PHASE_SHIFT attribute enables the PS component for use in addition to selecting between two operating modes. As described in Table 29, this attribute has three possible values: NONE, FIXED, and VARIABLE. When CLKOUT_PHASE_SHIFT is set to NONE, the PS component is disabled and its inputs, PSEN, PSCLK, and PSINCDEC, must be tied to GND. The set of waveforms in Figure 41a shows the disabled case, where the DLL maintains a zero-phase alignment of signals CLKFB and CLKIN upon which the PS component has no effect. The PS com-
ponent is enabled by setting the attribute to either the FIXED or VARIABLE values, which select the Fixed Phase
mode and the Variable Phase mode, respectively. These two modes are described in the sections that follow.

Table 29: PS Attributes

| Attribute | Description | Values |
| :--- | :--- | :--- |
| CLKOUT_PHASE_SHIFT | Disables the PS component or chooses between <br> Fixed Phase and Variable Phase modes. | NONE, FIXED, VARIABLE |
| PHASE_SHIFT | Determines size and direction of initial fine phase <br> shift. | Integers from -255 to +255 |

## Determining the Fine Phase Shift

The user controls the phase shift of CLKFB relative to CLKIN by setting and/or adjusting the value of the PHASE_SHIFT attribute. This value must be an integer ranging from -255 to +255 . This corresponds to a phase shift range of -180 to +180 degrees, which is different from the original Spartan-3 DCM. The PS component uses this value to calculate the desired fine phase shift ( $\mathrm{T}_{\mathrm{PS}}$ ) as a fraction of the CLKIN period ( $T_{\text {CLKIN }}$ ). Given values for PHASE_SHIFT and $T_{\text {CLKIN }}$, it is possible to calculate $T_{\text {PS }}$ as follows:

$$
\mathrm{T}_{\mathrm{PS}}=\left(\text { PHASE_SHIFT/512) }{ }^{*} \mathrm{~T}_{\text {CLKIN }}\right. \text { (4) }
$$

Both the Fixed Phase and Variable Phase operating modes employ this calculation. If the PHASE_SHIFT value is zero, then CLKFB and CLKIN are in phase, the same as when the PS component is disabled. When the PHASE_SHIFT value is positive, the CLKFB signal is shifted later in time with respect to CLKIN. If the attribute value is negative, the CLKFB signal is shifted earlier in time with respect to CLKIN.

## The Fixed Phase Mode

This mode fixes the desired fine phase shift to a fraction of the $\mathrm{T}_{\text {CLKIN }}$, as determined by Equation (4) and its user-selected PHASE_SHIFT value P. The set of waveforms in Figure 41b illustrates the relationship between CLKFB and CLKIN in the Fixed Phase mode. In the Fixed Phase mode, the PSEN, PSCLK, and PSINCDEC inputs are not used and must be tied to GND.
In Figure 41:

- $\quad$ represents the integer value ranging from -255 to +255 to which the PHASE_SHIFT attribute is assigned. ( $\mathrm{P}=$ approximately -90 as shown)
- $\quad \mathrm{N}$ is an integer value ranging from ( $\mathrm{P}-255$ ) to ( +255 - P) that represents the net phase shift effect from a series of increment and/or decrement operations.
- $\mathrm{N}=$ \{Total number of increments $\}$ - $\{$ Total number of decrements\} provided the user does not try to increment past + 255 or decrement past -255. A positive value for N indicates a net increment; a negative value indicates a net decrement.
a. CLKOUT_PHASE_SHIFT = NONE

b. CLKOUT_PHASE_SHIFT = FIXED

c. CLKOUT_PHASE_SHIFT = VARIABLE


Figure 41: Phase Shifter Waveforms

## The Variable Phase Mode

The Variable Phase mode dynamically adjusts the fine phase shift over time using three inputs to the PS compo-
nent (PSEN, PSCLK, and PSINCDEC), as defined in Table 30.

## Table 30: Signals for Variable Phase Mode

| Signal | Direction | Description |
| :--- | :--- | :--- |
| PSEN $^{(1)}$ | Input | Enables PSCLK for variable phase adjustment. |
| PSCLK ${ }^{(1)}$ | Input | Clock to synchronize phase shift adjustment. |
| PSINCDEC ${ }^{(1)}$ | Input | Chooses between increment and decrement for phase adjustment. It is <br> synchronized to the PSCLK signal. |
| PSDONE | Output | Goes High to indicate that present phase adjustment is complete and PS component <br> is ready for next phase adjustment request. It is synchronized to the PSCLK signal. |

## Notes:

1. It is possible to program this input for either a true or inverted polarity.

Just following device configuration, the PS component initially determines $T_{\text {PS }}$ by evaluating Equation (4) for the value assigned to the PHASE_SHIFT attribute. Then to dynamically adjust that phase shift, use the three PS inputs to increase or decrease the fine phase shift.
PSINCDEC is synchronized to the PSCLK clock signal, which is enabled by asserting PSEN. It is possible to drive the PSCLK input with the CLKIN signal or any other clock signal. A request for phase adjustment is entered as follows: For each PSCLK cycle that PSINCDEC is High, the PS component adds $1 / 512$ of a CLKIN cycle to $\mathrm{T}_{\text {PS }}$. Similarly, for each enabled PSCLK cycle that PSINCDEC is Low, the PS component subtracts $1 / 512$ of a CLKIN cycle from $T_{\text {PS }}$. The phase adjustment may require as many as 100 CLKIN cycles plus three PSCLK cycles to take effect, at which point the output PSDONE goes High for one PSCLK cycle. This pulse indicates that the PS component has finished the present adjustment and is now ready for the next request.

Asserting the Reset (RST) input, returns $T_{P S}$ to its original shift time, as determined by the PHASE_SHIFT attribute value. The set of waveforms in Figure 41c illustrates the relationship between CLKFB and CLKIN in the Variable Phase mode.

## The Status Logic Component

The Status Logic component not only reports on the state of the DCM but also provides a means of resetting the DCM to an initial known state. The signals associated with the Status Logic component are described in Table 31.
As a rule, the Reset (RST) input is asserted only upon configuring the device or changing the CLKIN frequency. A DCM reset does not affect attribute values (e.g., CLKFX_MULTIPLY and CLKFX_DIVIDE). If not used, tie RST to GND.
The eight bits of the STATUS bus are defined in Table 32.

Table 31: Status Logic Signals

| Signal | Direction | Description |
| :--- | :--- | :--- |
| RST | Input | A High resets the entire DCM to its initial power-on state. Initializes the DLL taps for <br> a delay of zero. Sets the LOCKED output Low. This input is asynchronous. |
| STATUS[7:0] | Output | The bit values on the STATUS bus provide information regarding the state of DLL and <br> PS operation |
| LOCKED | Output | Indicates that the CLKIN and CLKFB signals are in phase by going High. The two <br> signals are out-of-phase when Low. |

## Table 32: DCM Status Bus

| Bit | Name | Description |
| :---: | :--- | :--- |
| 0 | Reserved | - |
| 1 | CLKIN Stopped | A value of 1 indicates that the CLKIN input signal is not toggling. A value of 0 indicates toggling. <br> This bit functions only when the CLKFB input is connected.(1) |
| 2 | CLKFX Stopped | A value of 1 indicates that the CLKFX output is not toggling. A value of 0 indicates toggling. <br> This bit functions only when the CLKFX or CLKFX180 output are connected. |
| $3-6$ | Reserved | - |

## Notes:

1. If only the DFS clock outputs are used, but none of the DLL clock outputs, this bit does not go High when the CLKIN signal stops.

## Stabilizing DCM Clocks Before User Mode

The STARTUP_WAIT attribute shown in Table 33 optionally delays the end of the FPGA's configuration process until after the DCM locks to the incoming clock frequency. This option ensures that the FPGA remains in the Startup phase of configuration until all clock outputs generated by the DCM are stable. When all the DCMs with their STARTUP_WAIT attribute set to TRUE assert the LOCKED signal, then the FPGA completes its configuration process and proceeds to user mode. The associated bitstream generator (BitGen) option LCK_cycle specifies one of the six cycles in the Startup phase. The selected cycle defines the point at which configuration halts until the all the LOCKED outputs go High. Also see Start-Up, page 91.

## Table 33: STARTUP WAIT Attribute

| Attribute | Description | Values |
| :---: | :--- | :---: |
| STARTUP_WAIT | Delays transition <br> from configuration <br> to user mode until <br> DCM locks to <br> input clock. |  |

## Clocking Infrastructure

The Spartan-3E clocking infrastructure, shown in Figure 42, provides a series of low-capacitance, low-skew interconnect lines well-suited to carrying high-frequency signals throughout the FPGA. The infrastructure also includes the clock inputs and BUFGMUX clock buffers/multiplexers. The Xilinx Place-and-Route (PAR) software automatically routes high-fanout clock signals using these resources.

## Clock Inputs

Clock pins accept external clock signals and connect directly to DCMs and BUFGMUX elements. Each Spartan-3E FPGA has:

- 16 Global Clock inputs (GCLK0 through GCLK15) located along the top and bottom edges of the FPGA
- 8 Right-Half Clock inputs (RHCLKO through RHCLK7) located along the right edge
- 8 Left-Half Clock inputs (LHCLKO through LHCLK7) located along the left edge
Clock inputs optionally connect directly to DCMs using dedicated connections. Table 35 shows the clock inputs that feed a specific DCM within a given Spartan-3E part number. Different Spartan-3E FPGA densities have different numbers of DCMs.
Each clock input is also optionally a user-l/O pin and connects to internal interconnect. Some clock pad pins are input-only pins as indicated in Module 4 of the Spartan-3E Data Sheet.


## Clock Buffers/Multiplexers

Clock Buffers/Multiplexers either drive clock input signals directly onto a clock line (BUFG) or optionally provide a multiplexer to switch between two unrelated, possibly asynchronous clock signals (BUFGMUX).
Each BUFGMUX element, shown in Figure 43, is a 2-to-1 multiplexer. The select line, S, chooses which of the two inputs, IO or I1, drives the BUFGMUX's output signal, O, as described in Table 34. The switching from one clock to the other is glitch-less, and done in such a way that the output High and Low times are never shorter than the shortest High or Low time of either input clock.

Table 34: BUFGMUX Select Mechanism

| S Input | O Output |
| :---: | :---: |
| 0 | 10 Input |
| 1 | 11 Input |

The BUFG clock buffer primitive drives a single clock signal onto the clock network and is essentially the same element as a BUFGMUX, just without the clock select mechanism. Similarly, the BUFGCE primitive creates an enabled clock buffer using the BUFGMUX select mechanism.
The 10 and 11 inputs to an BUFGMUX element originate from clock input pins, DCMs, or Double-Line interconnect, as shown in Figure 43. As shown in Figure 42, there are 24 BUFGMUX elements distributed around the four edges of the device. Clock signals from the four BUFGMUX elements at the top edge and the four at the bottom edge are truly global and connect to all clocking quadrants. The eight left-edge BUFGMUX elements only connect to the two clock quadrants in the left half of the device. Similarly, the eight right-edge BUFGMUX elements only connect to the right half of the device.
BUFGMUX elements are organized in pairs and share 10 and I1 connections with adjacent BUFGMUX elements from a common clock switch matrix as shown in Figure 43. For example, the input on 10 of one BUFGMUX also a shared input to I1 of the adjacent BUFGMUX.
The clock switch matrix for the left- and right-edge BUFGMUX elements receive signals from any of the three following sources: an LHCLK or RHCLK pin as appropriate, a Double-Line interconnect, or a DCM in the XC3S1200E and XC3S1600E devices.
By contrast, the clock switch matrixes on the top and bottom edges receive signals from any of the five following sources: two GCLK pins, two DCM outputs, or one Double-Line interconnect.
Table 36 indicates permissible connections between clock inputs and BUFGMUX elements. The four BUFGMUX elements on the top edge are paired together and share inputs from the eight global clock inputs along the top edge. Each

BUFGMUX pair connects to four of the eight global clock inputs, as shown in Figure 42. This optionally allows differential inputs to the global clock inputs without wasting a BUFGMUX element.

The connections for the bottom-edge BUFGMUX elements is similar to the top-edge connections.
On the left and right edges, only two clock inputs feed each pair of BUFGMUX elements.


## Notes:

1. Number of DCMs and locations of these DCM varies for different device densities.
2. The left and right DCMs are only in the XC3S1200E and XC3S1600E. The XC3S100E has only two DCMs, one on the top right and one on the bottom right of the die.

Figure 42: Spartan-3E Internal Quadrant-Based Clock Network (Top View)

Table 35: Direct Connections from Clock Inputs to DCMs and Associated DCM Location String

| Clock Input | XC3S100E | XC3S250E/XC3S500E | XC3S1200E/XC3S1600E |
| :---: | :---: | :---: | :---: |
| GCLK[3:0] | DCM_X0Y0 | DCM_X1Y0 | DCM_X2Y0 |
| RHCLK[3:0] | N/A | N/A | DCM_X3Y1 |
| RHCLK[7:4] | N/A | N/A | DCM_X3Y2 |
| GCLK[7:4] | DCM_X0Y1 | DCM_X1Y1 | DCM_X2Y2 |
| GCLK[11:8] | $\mathrm{N} / A$ | DCM_X0Y1 | DCM_X1Y3 |
| LHCLK[3:0] | $\mathrm{N} / \mathrm{A}$ | $\mathrm{N} / A$ | DCM_X0Y2 |
| LHCLK[7:4] | $\mathrm{N} / \mathrm{A}$ | $\mathrm{N} / \mathrm{A}$ | DCM_X0Y1 |
| GCLK[15:12] | $\mathrm{N} / A$ | DCM_X0Y0 | DCM_X1Y0 |

Table 36: Connections from Clock Inputs to BUFGMUX Elements and Associated Quadrant Clock

| Quadrant | Left-Half BUFGMUX |  |  | Top or Bottom BUFGMUX |  |  | Right-Half BUFGMUX |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Location ${ }^{(2)}$ | 10 Input | 11 Input | Location ${ }^{(2)}$ | 10 Input | 11 Input | Location ${ }^{(2)}$ | 10 Input | 11 Input |
| A | XOY2 | LHCLK7 | LHCLK6 | X2Y1 | GCLK0 or GCLK12 | GCLK1 or GCLK13 | X3Y2 | RHCLK0 | RHCLK1 |
| B | X0Y3 | LHCLK6 | LHCLK7 | X2Y0 | GCLK1 or GCLK13 | GCLK0 or GCLK12 | Х3Y3 | RHCLK1 | RHCLKO |
| C | X0Y4 | LHCLK5 | LHCLK4 | X1Y1 | $\begin{gathered} \text { GCLK2 or } \\ \text { GCLK14 } \end{gathered}$ | $\begin{gathered} \text { GCLK3 or } \\ \text { GCLK15 } \end{gathered}$ | X3Y4 | RHCLK2 | RHCLK3 |
| D | X0Y5 | LHCLK4 | LHCLK5 | X1Y0 | $\begin{gathered} \text { GCLK3 or } \\ \text { GCLK15 } \end{gathered}$ | $\begin{gathered} \text { GCLK2 or } \\ \text { GCLK14 } \end{gathered}$ | X3Y5 | RHCLK3 | RHCLK2 |
| E | X0Y6 | LHCLK3 | LHCLK2 | X2Y11 | $\begin{gathered} \text { GCLK4 or } \\ \text { GCLK8 } \end{gathered}$ | $\begin{gathered} \text { GCLK5 or } \\ \text { GCLK9 } \end{gathered}$ | X3Y6 | RHCLK4 | RHCLK5 |
| F | X0Y7 | LHCLK2 | LHCLK3 | X2Y10 | GCLK5 or GCLK9 | $\begin{gathered} \text { GCLK4 or } \\ \text { GCLK8 } \end{gathered}$ | X3Y7 | RHCLK5 | RHCLK4 |
| G | X0Y8 | LHCLK1 | LHCLKO | X1Y11 | $\begin{gathered} \text { GCLK6 or } \\ \text { GCLK10 } \end{gathered}$ | $\begin{gathered} \text { GCLK7 or } \\ \text { GCLK11 } \end{gathered}$ | X3Y8 | RHCLK6 | RHCLK7 |
| H | X0Y9 | LHCLKO | LHCLK1 | X1Y10 | GCLK7 or GCLK11 | $\begin{gathered} \text { GCLK6 or } \\ \text { GCLK10 } \end{gathered}$ | X3Y9 | RHCLK7 | RHCLK6 |

## Notes:

1. See Quadrant Clock Routing for connectivity details for the eight quadrant clocks.
2. See Figure 42 for specific BUFGMUX locations and Figure 44 for information on how BUFGMUX elements drive onto a specific clock line within a quadrant.


Figure 43: Clock Switch Matrix to BUFGMUX Pair Connectivity

## Quadrant Clock Routing

The clock routing within the FPGA is quadrant-based, as shown in Figure 42. Each clock quadrant supports eight total clock signals, labeled 'A' through 'H' in Table 36 and Figure 44. The clock source for an individual clock line originates either from a global BUFGMUX element along the top and bottom edges or from a BUFGMUX element along the associated edge, as shown in Figure 44. The clock lines feed the synchronous resource elements (CLBs, IOBs, block RAM, multipliers, and DCMs) within the quadrant.

The four quadrants of the device are:

- Top Right (TR)
- Bottom Right (BR)
- Bottom Left (BL)
- Top Left (TL)

Note that the quadrant clock notation (TR, BR, BL, TL) is separate from that used for similar IOB placement constraints.

a. Left (TL and BL Quadrants) Half of Die



Figure 44: Clock Sources for the Eight Clock Lines within a Clock Quadrant

The outputs of the top or bottom BUFGMUX elements connect to two vertical spines, each comprising four vertical clock lines as shown in Figure 42. At the center of the die, these clock signals connect to the eight-line horizontal clock spine.
Outputs of the left and right BUFGMUX elements are routed onto the left or right horizontal spines, each comprising eight horizontal clock lines.
Each of the eight clock signals in a clock quadrant derives either from a global clock signal or a half clock signal. In other words, there are up to 24 total potential clock inputs to the FPGA, eight of which can connect to clocked elements
in a single clock quadrant. Figure 44 shows how the clock lines in each quadrant are selected from associated BUFGMUX sources. For example, if quadrant clock ' $A$ ' in the bottom left (BL) quadrant originates from BUFGMUX_X2Y1, then the clock signal from BUFGMUX_X0Y2 is unavailable in the bottom left quadrant. However, the top left (TL) quadrant clock ' A ' can still solely use the output from either BUFGMUX_X2Y1 or BUFGMUX_X0Y2 as the source.
To minimize the dynamic power dissipation of the clock network, the Xilinx development software automatically disables all clock segments not in use.

## Interconnect

Interconnect is the programmable network of signal pathways between the inputs and outputs of functional elements within the FPGA, such as IOBs, CLBs, DCMs, block RAM, etc.

Interconnect, also called routing, is segmented for optimal connectivity. Functionally, interconnect resources are identical to that of the Spartan-3 architecture. There are four kinds of interconnects: long lines, hex lines, double lines, and direct lines. The Xilinx Place and Route (PAR) software exploits the rich interconnect array to deliver optimal system performance and the fastest compile times.

The switch matrix connects to the different kinds of interconnects across the device. An interconnect tile, shown in Figure 45 , is defined as a single switch matrix connected to a functional element, such as a CLB, IOB, or DCM. If a functional element spans across multiple switch matrices such as the block RAM or multipliers, then an interconnect tile is defined by the number of switch matrices connected to that functional element. A Spartan-3E device can be represented as an array of interconnect tiles where interconnect resources are for the channel between any two adjacent interconnect tile rows or columns as shown in Figure 46.


Figure 45: Four Types of Interconnect Tiles (CLBs, IOBs, DCMs, and Block RAM/Multiplier)


Figure 46: Array of Interconnect Tiles in Spartan-3E FPGA

There are four type of general-purpose interconnect available in each channel, as shown in Figure 47 and described below.

## Long Lines

Each set of 24 long line signals spans the die both horizontally and vertically and connects to one out of every six interconnect tiles. At any tile, four of the long lines drive or receive signals from a switch matrix. Because of their low capacitance, these lines are well-suited for carrying high-frequency signals with minimal loading effects (e.g. skew). If all global clock lines are already committed and additional clock signals remain to be assigned, long lines serve as a good alternative.

## Hex Lines

Each set of eight hex lines are connected to one out of every three tiles, both horizontally and vertically. Thirty-two hex lines are available between any given interconnect tile. Hex lines are only driven from one end of the route.

## Double Lines

Each set of eight double lines are connected to every other tile, both horizontally and vertically. in all four directions. Thirty-two double lines available between any given interconnect tile. Double lines are more connections and more flexibility, compared to long line and hex lines.

## Direct Connections

Direct connect lines route signals to neighboring tiles: vertically, horizontally, and diagonally. These lines most often drive a signal from a "source" tile to a double, hex, or long line and conversely from the longer interconnect back to a direct line accessing a "destination" tile.

## Global Controls (STARTUP_SPARTAN3E)

In addition to the general-purpose interconnect, Spartan-3E FPGAs have two global logic control signals, as described in Table 37. These signals are available to the FPGA application via the STARTUP_SPARTAN3E primitive.

Table 37: Spartan-3E Global Logic Control Signals

| Global <br> Control Input | Description |
| :---: | :--- |
| GSR | When driven High, asynchronously <br> places all registers and flip-flops in their <br> initial state (see Initialization, page 24). <br> Asserted automatically during the FPGA <br> configuration process (see Start-Up, <br> page 91). |
| GTS | When driven High, asynchronously <br> forces all I/O pins to a high-impedance <br> state (Hi-Z, three-state). |

The Global Set/Reset (GSR) signal replaces the global reset signal included in many ASIC-style designs. Use the GSR control instead of a separate global reset signal in the design to free up CLB inputs, resulting in a smaller, more efficient design. Similarly, the GSR signal is asserted automatically during the FPGA configuration process, guaranteeing that the FPGA starts-up in a known state.
The STARTUP_SPARTAN3E primitive also includes two other signals used specifically during configuration. The MBT signals are for Dynamically Loading Multiple Configuration Images Using MultiBoot Option, page 78. The CLK input is an alternate clock for configuration Start-Up, page 91.


Figure 47: Interconnect Types between Two Adjacent Interconnect Tiles


Figure 47: Interconnect Types between Two Adjacent Interconnect Tiles

## Configuration

## Differences from Spartan-3 FPGAs

In general, Spartan-3E FPGA configuration modes are a superset to those available in Spartan-3 FPGAs. Two new modes added in Spartan-3E FPGAs provide a glue-less configuration interface to industry-standard parallel NOR Flash and SPI serial Flash memories. Unlike Spartan-3 FPGAs, nearly all of the Spartan-3E configuration pins become available as user I/Os after configuration.

## Configuration Process

The function of a Spartan-3E FPGA is defined by loading application-specific configuration data into the FPGA's internal, reprogrammable CMOS configuration latches (CCLs), similar to the way a microprocessor's function is defined by its application program. For FPGAs, this configuration process uses a subset of the device pins, some of which are dedicated to configuration; other pins are merely
borrowed and returned to the application as general-purpose user I/Os after configuration completes.
Spartan-3E FPGAs offer several configuration options to minimize the impact of configuration on the overall system design. In some configuration modes, the FPGA generates a clock and loads itself from an external memory source, either serially or via a byte-wide data path. Alternatively, an external host such as a microprocessor downloads the FPGA's configuration data using a simple synchronous serial interface or via a byte-wide peripheral-style interface. Furthermore, multiple-FPGA designs share a single configuration memory source, creating a structure called a daisy chain.

Three FPGA pins-M2, M1, and M0-select the desired configuration mode. The mode pin settings appear in Table 38. The mode pin values are sampled during the start of configuration when the FPGA's INIT_B output goes High. After the FPGA completes configuration, the mode pins are available as user I/Os.

Table 38: Spartan-3E Configuration Mode Pin Settings

|  | Master Serial | SPI | BPI | Slave Parallel | Slave Serial | JTAG |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M[2:0] mode pin settings | <0:0:0> | <0:0:1> | $\begin{gathered} <0: 1: 0>=\text { Up } \\ <0: 1: 1>=\text { Down } \end{gathered}$ | <1:1:0> | <1:1:1> | <1:0:1> |
| Data width | Serial | Serial | Byte-wide | Byte-wide | Serial | Serial |
| Configuration memory source | Xilinx Platform Flash | Industry-standard SPI Serial Flash | Industry-standard parallel NOR Flash | Any source via microcontroller, CPU, Xilinx parallel Platform Flash, etc. | Any source via microcontroller, CPU, Xilinx Platform Flash, etc. | Any source via microcontroller, CPU, etc. and System Ace CF |
| Clock source | Internal oscillator | Internal oscillator | Internal oscillator | External clock on CCLK pin | External clock on CCLK pin | External clock on TCK pin |
| Total I/O pins borrowed during configuration | 8 | 13 | 46 | 21 | 8 | 0 |
| Configuration mode for downstream daisy-chained FPGAs | Slave Serial | Slave Serial | Slave Parallel | Slave Parallel or Memory Mapped | Slave Serial | JTAG |
| Self-configuring applications (no external download host) | $\checkmark$ | $\checkmark$ | $\checkmark$ | Possible using XCFxxP Platform Flash, which optionally generates CCLK | Possible using XCFxxP Platform Flash, which optionally generates CCLK |  |
| Uses low-cost, industry-standard Flash |  | $\checkmark$ | $\checkmark$ |  |  |  |

A specific Spartan-3E part type always requires a constant number of configuration bits, regardless of design complexity, as shown in Table 39. The configuration file size for a multiple-FPGA daisy-chain design equals the sum of the individual file sizes.

Table 39: Number of Bits to Program a Spartan-3E FPGA (Uncompressed Bitstreams)

| Device | Number of Configuration <br> Bits |
| :---: | :---: |
| XC3S100E | 581,344 |
| XC3S250E | $1,352,192$ |
| XC3S500E | $2,267,136$ |
| XC3S1200E | $3,832,320$ |
| XC3S1600E | $5,957,760$ |

## Pin Behavior During Configuration

Table 40 shows how various pins behave during the FPGA configuration process. The actual behavior depends on the values applied to the M2, M1, and M0 mode select pins and the HSWAP pin. The mode select pins determine which of the I/O pins are borrowed during configuration and how they function. In JTAG configuration mode, no user-I/O pins are borrowed for configuration.
All I/O pins are high impedance (floating, three-stated, $\mathrm{Hi}-\mathrm{Z}$ ) during the configuration process. These pins are indicated in Table 40 as shaded table entries or cells. If the HSWAP input is Low, these pins have a pull-up resistor to their associated $\mathrm{V}_{\mathrm{CCO}}$ supply that is active throughout configuration. After configuration, pull-up and pull-down resistors are available in the FPGA application as described in Pull-Up and Pull-Down Resistors, page 9.
Spartan-3E FPGAs have only six dedicated configuration pins, including the DONE and PROG_B pins, and the four JTAG boundary-scan pins: TDI, TDO, TMS, and TCK.

Table 40: Pin Behavior during Configuration

| Pin Name | Master <br> Serial | SPI (Serial <br> Flash) | BPI(Parallel <br> NOR Flash) | JTAG | Slave <br> Parallel | Slave Serial | Supply/ <br> I/O Bank |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TDI | TDI | TDI | TDI | TDI | TDI | TDI | VCCAUX |
| TMS | TMS | TMS | TMS | TMS | TMS | TMS | VCCAUX |
| TCK | TCK | TCK | TCK | TCK | TCK | TCK | VCCAUX |
| TDO | TDO | TDO | TDO | TDO | TDO | TDO | VCCAUX |
| PROG_B | PROG_B | PROG_B | PROG_B | PROG_B | PROG_B | PROG_B | VCCAUX |
| DONE | DONE | DONE | DONE | DONE | DONE | DONE | VCCAUX |
| HSWAP | HSWAP | HSWAP | HSWAP | HSWAP | HSWAP | HSWAP | 0 |
| M2 | 0 | 0 | 0 | 1 | 1 | 1 | 2 |
| M1 | 0 | 0 | 1 | 0 | 1 | 1 | 2 |
| M0 | 0 | 1 | $0=$ Up | 1 | 0 | 1 | 2 |
| CCLK | CCLK (O) | CCLK (O) | CCLK (O) |  | CCLK (I) | CCLK (I) | 2 |
| INIT_B | INIT_B | INIT_B | INIT_B |  | INIT_B | INIT_B | 2 |
| CSO_B |  | CSO_B | CSO_B |  | CSO_B |  | 2 |
| DOUT/BUSY | DOUT | DOUT | BUSY |  | BUSY | DOUT | 2 |
| MOSI/CSI_B |  | MOSI | CSI_B |  | CSI_B |  | 2 |
| D7 |  |  | D7 |  | D7 |  | 2 |
| D6 |  |  | D6 |  | D6 |  | 2 |
| D5 |  |  | D5 |  | D5 |  | 2 |
| D4 |  |  |  | D4 |  | 2 |  |

Table 40: Pin Behavior during Configuration (Continued)

| Pin Name | Master Serial | SPI (Serial Flash) | BPI (Parallel NOR Flash) | JTAG | Slave Parallel | Slave Serial | Supply/ I/O Bank |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D3 |  |  | D3 |  | D3 |  | 2 |
| D2 |  |  | D2 |  | D2 |  | 2 |
| D1 |  |  | D1 |  | D1 |  | 2 |
| D0/DIN | DIN | DIN | D0 |  | D0 | DIN | 2 |
| RDWR_B |  |  | RDWR_B |  | RDWR_B |  | 2 |
| A23 |  |  | A23 |  |  |  | 2 |
| A22 |  |  | A22 |  |  |  | 2 |
| A21 |  |  | A21 |  |  |  | 2 |
| A20 |  |  | A20 |  |  |  | 2 |
| A19/VS2 |  | VS2 | A19 |  |  |  | 2 |
| A18/VS1 |  | VS1 | A18 |  |  |  | 2 |
| A17/VS0 |  | VS0 | A17 |  |  |  | 2 |
| A16 |  |  | A16 |  |  |  | 1 |
| A15 |  |  | A15 |  |  |  | 1 |
| A14 |  |  | A14 |  |  |  | 1 |
| A13 |  |  | A13 |  |  |  | 1 |
| A12 |  |  | A12 |  |  |  | 1 |
| A11 |  |  | A11 |  |  |  | 1 |
| A10 |  |  | A10 |  |  |  | 1 |
| A9 |  |  | A9 |  |  |  | 1 |
| A8 |  |  | A8 |  |  |  | 1 |
| A7 |  |  | A7 |  |  |  | 1 |
| A6 |  |  | A6 |  |  |  | 1 |
| A5 |  |  | A5 |  |  |  | 1 |
| A4 |  |  | A4 |  |  |  | 1 |
| A3 |  |  | A3 |  |  |  | 1 |
| A2 |  |  | A2 |  |  |  | 1 |
| A1 |  |  | A1 |  |  |  | 1 |
| A0 |  |  | A0 |  |  |  | 1 |
| LDC0 |  |  | LDC0 |  | LDC0 |  | 1 |
| LDC1 |  |  | LDC1 |  | LDC1 |  | 1 |
| LDC2 |  |  | LDC2 |  | LDC2 |  | 1 |
| HDC |  |  | HDC |  | HDC |  | 1 |

Table 41 shows the default I/O standard setting for the various configuration pins during the configuration process. The configuration interface is designed primarily for 2.5 V operation when the VCCO_2 (and VCCO_1 in BPI mode) connects to 2.5 V .
The configuration pins also operate at other voltages by setting VCCO_2 (and VCCO_1 in BPI mode) to either 3.3 V or 1.8 V . The change on the VCCO supply also changes the I/O
drive characteristics. For example, with $\mathrm{VCCO}=3.3 \mathrm{~V}$, the output current when driving High, $\mathrm{I}_{\mathrm{OH}}$, increases to approximately 12 to 16 mA , while the current when driving Low, $\mathrm{I}_{\mathrm{OL}}$, remains 8 mA . At $\mathrm{VCCO}=1.8 \mathrm{~V}$, the output current when driving High, $\mathrm{I}_{\mathrm{OH}}$, decreases slightly to approximately 6 to 8 mA . Again, the current when driving Low, $\mathrm{I}_{\mathrm{OL}}$, remains 8 mA .

## Table 41: Default I/O Standard Setting During Configuration (VCCO_2 = 2.5V)

| Pin(s) | I/O Standard | Output Drive | Slew Rate |
| :---: | :---: | :---: | :---: |
| All, including CCLK | LVCMOS25 | 8 mA | Slow |

## Master Serial Mode

In Master Serial mode (M[2:0] = <0:0:0>), the Spartan-3E FPGA configures itself from an attached Xilinx Platform Flash PROM, as illustrated in Figure 48. The FPGA supplies the CCLK output clock from its internal oscillator to the
attached Platform Flash PROM. In response, the Platform Flash PROM supplies bit-serial data to the FPGA's DIN input and the FPGA accepts this data on each rising CCLK edge.


Figure 48: Master Serial Mode using Platform Flash PROM

The mode select pins, M[2:0], must all be Low when sampled, when the FPGA's INIT_B output goes High. After configuration, when the FPGA's DONE output goes High, the mode select pins are available as full-featured user-l/O pins.
(P) Similarly, the FPGA's HSWAP pin must be Low to enable pull-up resistors on all user-l/O pins during configuration or High to disable the pull-up resistors. The HSWAP control must remain at a constant logic level throughout

FPGA configuration. After configuration, when the FPGA's DONE output goes High, the HSWAP pin is available as full-featured user-I/O pin and is powered by the VCCO_0 supply.
The FPGA's DOUT pin is used in daisy-chain applications, described later. In a single-FPGA application, the FPGA's DOUT pin is not used but is actively driving during the configuration process.

## Table 42: Serial Master Mode Connections

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :--- | :--- | :--- | :--- | :--- |
| HSWAP | Input | User I/O Pull-Up Control. When Low <br> during configuration, enables pull-up <br> resistors in all I/O pins to respective I/O <br> bank VCco input. <br> 0: Pull-ups during configuration <br> 1: No pull-ups | Drive at valid logic level <br> throughout configuration. | User I/O |
| M[2:0] | Input | Mode Select. Selects the FPGA <br> configuration mode. | M2 = 0, M1 = 0, M0 = 0. <br> Sampled when INIT_B goes <br> High. | User I/O |
| DIN | Input | Serial Data Input. | Receives serial data from <br> PROM's DO output. | User I/O |
| CCLK | Output | Configuration Clock. Generated by <br> FPGA internal oscillator. Frequency <br> controlled by ConfigRate bitstream <br> generator option. If CCLK PCB trace is <br> long or has multiple connections, <br> terminate this output to maintain signal <br> integrity. | Drives PROM's CLK clock <br> input. | User I/O |
| DOUT | Output | Serial Data Output. |  |  |
| INIT_B | Open-drain <br> bidirectional I/O | Initialization Indicator. Active Low. Goes <br> Low at start of configuration during <br> Initialization memory clearing process. <br> Released at end of memory clearing, <br> when mode select pins are sampled. <br> Requires external 4.7 k pull-up resistor <br> to VCCO_2. | Connects to PROM's <br> OE/RESET input. FPGA <br> clears PROM's address <br> counter at start of <br> configuration, enables <br> outputs during configuration. <br> PROM also holds FPGA in <br> Initialization state until PROM <br> reaches Power-On Reset <br> (POR) state. If CRC error <br> detected during <br> configuration, FPGA drives <br> INIT_B Low. |  |

Table 42: Serial Master Mode Connections (Continued)

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :--- | :---: | :--- | :--- | :--- |
| DONE | Open-drain <br> bidirectional I/O | FPGA Configuration Done. Low during <br> configuration. Goes High when FPGA <br> successfully completes configuration. <br> Requires external 330 $\Omega$ pull-up resistor <br> to 2.5V. | Connects to PROM's <br> chip-enable (CE) input. <br> Enables PROM during <br> configuration. Disables <br> PROM after configuration. | Pulled High via <br> external pull-up. <br> When High, indicates <br> that the FPGA <br> successfully <br> configured. |
| PROG_B | Input | Program FPGA. Active Low. When <br> asserted Low for 300 ns or longer, forces <br> the FPGA to restart its configuration <br> process by clearing configuration <br> memory and resetting the DONE and <br> INIT_B pins once PROG_B returns High. <br> Requires external 4.7 kS pull-up resistor <br> to 2.5V. If driving externally, use an <br> open-drain or open-collector driver. | Must be High during <br> configuration to allow <br> configuration to start. <br> Connects to PROM's CF pin, <br> allowing JTAG PROM <br> programming algorithm to <br> reprogram the FPGA. | Drive PROG_B Low <br> and release to <br> reprogram FPGA. |

## Voltage Compatibility

The PROM's $\mathrm{V}_{\text {CCINT }}$ supply must be either 3.3 V for the serial XCFxxS Platform Flash PROMs or 1.8 V for the serial/parallel XCFxxP PROMs.
(V) The FPGA's VCCO_2 supply input and the Platform Flash PROM's $\mathrm{V}_{\mathrm{CCO}}$ supply input must be the same voltage, ideally +2.5 V . Both devices also support 1.8 V and 3.3 V interfaces but the FPGA's PROG_B and DONE pins require special attention as they are powered by the FPGA's VCCAUX supply, nominally 2.5 V . See application note XAPP453: "The 3.3V Configuration of Spartan-3 FPGAs" for additional information.

## Supported Platform Flash PROMs

Table 43 shows the smallest available Platform Flash PROM to program a single Spartan-3E FPGA. A multi-ple-FPGA daisy-chain application requires a Platform Flash PROM large enough to contain the sum of the various FPGA file sizes.

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

| Device | Number of <br> Configuration <br> Bits | Smallest Available <br> Platform Flash |
| :---: | :---: | :---: |
| XC3S100E | 581,344 | XCF01S |
| XC3S250E | $1,352,192$ | XCF02S |
| XC3S500E | $2,267,136$ | XCF04S |
| XC3S1200E | $3,832,320$ | XCF04S |
| XC3S1600E | $5,957,760$ | XCF08P <br> or $2 \times$ XCF04S |

The XC3S1600E requires an 8 Mbit PROM. There are two possible solutions. Either use a single 8 Mbit XCF08P parallel/serial PROM or cascade two 4 Mbit XCF04S serial PROMs. The two XCF04S PROMs use a 3.3V $\mathrm{V}_{\text {CCINT }}$ supply while the XCF08P requires a $1.8 \mathrm{~V} \mathrm{~V}_{\mathrm{CCINT}}$ supply. If the board does not already have a 1.8 V supply available, the two cascaded XCF04S PROM solution is recommended.

## CCLK Frequency

In Master Serial mode, the FPGA's internal oscillator generates the configuration clock frequency. The FPGA provides this clock on its CCLK output pin, driving the PROM's CLK input pin. The FPGA starts configuration at its lowest frequency and increases its frequency for the remainder of the configuration process if so specified in the configuration bitstream. The maximum frequency is specified using the ConfigRate bitstream generator option. Table 44 shows the maximum ConfigRate settings, approximately equal to MHz , for various Platform Flash devices and I/O voltages. For the serial XCFxxS PROMs, the maximum frequency also depends on the interface voltage.

## Table 44: Maximum ConfigRate Settings for Platform Flash

| Platform Flash <br> Part Number | I/O Voltage <br> (VCCO_2, VCCO) | Maximum <br> ConfigRate <br> Setting |
| :---: | :---: | :---: |
| XCF01S <br> XCF02S <br> XCF04S | 3.3 V or 2.5V | 25 |
| XCF08P <br> XCF16P <br> XCF32P | 1.8 V | 12 |



DS312-2 45021405
Figure 49: Daisy-Chaining from Master Serial Mode

## Daisy-Chaining

If the application requires multiple FPGAs with different configurations, then configure the FPGAs using a daisy chain, as shown in Figure 49. Use Master Serial mode ( $\mathrm{M}[2: 0]=<0: 0: 0>$ ) for the FPGA connected to the Platform Flash PROM and Slave Serial mode ( $\mathrm{M}[2: 0]=<1: 1: 1>$ ) for all other FPGAs in the daisy-chain. After the master FPGA-the FPGA on the left in the diagram-finishes loading its configuration data from the Platform Flash, the master device supplies data using its DOUT output pin to the next device in the daisy-chain, on the falling CCLK edge.

## JTAG Interface

Both the Spartan-3E FPGA and the Platform Flash PROM have a four-wire IEEE 1149.1/1532 JTAG port. Both devices share the TCK clock input and the TMS mode select input. The devices may connect in either order on the JTAG chain with the TDO output of one device feeding the TDI input of the following device in the chain. The TDO output of the last device in the JTAG chain drives the JTAG connector.
The JTAG interface on Spartan-3E FPGAs is powered by the 2.5 V VCCAUX supply. Consequently, the PROM's $\mathrm{V}_{\mathrm{CCJ}}$ supply input must also be 2.5 V . To create a 3.3 V JTAG interface, please refer to application note XAPP453: "The 3.3V Configuration of Spartan-3 FPGAs" for additional information.

## In-System Programming Support

Both the FPGA and the Platform Flash PROM are in-system programmable via the JTAG chain. Download support is
provided by the Xilinx iMPACT programming software and the associated Xilinx Parallel Cable IV, MultiPRO, or Platform Cable USB programming cables.

## Storing Additional User Data in Platform Flash

After configuration, the FPGA application can continue to use the Master Serial interface pins to communicate with the Platform Flash PROM. If desired, use a larger Platform Flash PROM to hold additional non-volatile application data, such as MicroBlaze processor code, or other user data such as serial numbers and Ethernet MAC IDs. The FPGA first configures from Platform Flash PROM. Then using FPGA logic after configuration, the FPGA copies MicroBlaze code from Platform Flash into external DDR SDRAM for code execution.
See XAPP694: "Reading User Data from Configuration PROMs" and XAPP482: "MicroBlaze Platform Flash/PROM Boot Loader and User Data Storage" for specific details on how to implement such an interface.

## SPI Serial Flash Mode

In SPI Serial Flash mode ( $\mathrm{M}[2: 0]=<0: 0: 0>$ ), the Spartan-3E FPGA configures itself from an attached industry-standard SPI serial Flash PROM, as illustrated in Figure 50 and Figure 52. The FPGA supplies the CCLK output clock from its internal oscillator to the clock input of the attached SPI Flash PROM.


Figure 50: SPI Flash PROM Interface for PROMs Supporting READ ( $0 \times 03$ ) and FAST_READ ( $0 \times 0 \mathrm{OB}$ )
(S) Although SPI is a standard four-wire interface, various available SPI Flash PROMs use different command protocols. The FPGA's variant select pins, VS[2:0], define how the FPGA communicates with the SPI Flash, including which SPI Flash command the FPGA issues to start the read operation and the number of dummy bytes inserted before the FPGA expects to receive valid data from the SPI Flash. Table 45 shows the available SPI Flash PROMs expected to operate with Spartan-3E FPGAs. Other compatible devices might work but have not been tested for suitability with Spartan-3E FPGAs. All other VS[2:0] values are reserved for future use.

Figure 50 shows the general connection diagram for those SPI Flash PROMs that support the 0x03 READ command or the 0x0B FAST READ commands.
Figure 51 shows the connection diagram for Atmel DataFlash serial PROMs, which also use an SPI-based protocol.
Figure 54 demonstrates how to configure multiple FPGAs with different configurations, all stored in a single SPI Flash. The diagram uses standard SPI Flash memories but the same general technique applies for Atmel DataFlash.


Figure 51: AtmeI SPI-based DataFlash Configuration Interface

## Table 45: Variant Select Codes for SPI Serial Flash PROMs

| VS2 | VS1 | VSO | SPI Read Command | Dummy Bytes | SPI Serial Flash Vendor | SPI Flash Family |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | FAST READ (0x0B) <br> (see Figure 50) | 1 | STMicroelectronics (ST) | M25Pxx |
|  |  |  |  |  | NexFlash | NX25Pxx |
|  |  |  |  |  | Silicon Storage Technology (SST) | $\frac{\text { SST25LFxxxA }}{\text { SST25VFxxxA }}$ |
|  |  |  |  |  | Programmable Microelectronics Corp. (PMC) | Pm25LVxxx |
| 1 | 0 | 1 | READ ( $0 \times 03$ ) <br> (see Figure 50) | 0 | STMicroelectronics (ST) | M25Pxx |
|  |  |  |  |  | NexFlash | NX25Pxx |
|  |  |  |  |  | Silicon Storage Technology (SST) | $\begin{aligned} & \frac{\text { SST25LFxxxA }}{\text { SST25VFxxxA }} \\ & \frac{\text { SST25VFxxx }}{} \end{aligned}$ |
|  |  |  |  |  | Programmable Microelectronics Corp. (PMC) | Pm25LVxxx |
| 1 | 1 | 0 | $\begin{aligned} & \text { READ ARRAY } \\ & \text { (0xE8) } \\ & \text { (see Figure 51) } \end{aligned}$ | 3 | Atmel Corporation | AT45DB DataFlash |
| Others |  |  | Reserved |  |  |  |

(W) Table 46 shows the connections between the SPI Flash PROM and the FPGA's SPI configuration interface. Each SPI Flash PROM vendor uses slightly different signal naming. The SPI Flash PROM's write protect and hold controls
are not used by the FPGA during configuration. However, the HOLD pin must be High during the configuration process. The PROM's write protect input must be High in order to write or program the Flash memory.

Table 46: SPI Flash PROM Connections and Pin Naming

| SPI Flash Pin | FPGA Connection | STMicro | NexFlash | Silicon Storage Technology | Atmel DataFlash |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DATA_IN | MOSI | D | DI | SI | SI |
| DATA_OUT | DIN | Q | DO | SO | SO |
| SELECT | CSO_B | $\overline{\mathrm{S}}$ | $\overline{\text { CS }}$ | CE\# | $\overline{\text { CS }}$ |
| CLOCK | CCLK | C | CLK | SCK | SCK |
| WR_PROTECT (W) | Not required for FPGA configuration. Must be High to program SPI Flash. Optional connection to FPGA user I/O after configuration. | $\bar{W}$ | $\overline{W P}$ | WP\# | $\overline{W P}$ |
| $\overline{\text { HOLD }}$ <br> (see Figure 50) | Not required for FPGA configuration but must be High during configuration. Optional connection to FPGA user I/O after configuration. Not applicable to Atmel DataFlash. | HOLD | HOLD | HOLD\# | N/A |

Table 46: SPI Flash PROM Connections and Pin Naming (Continued)

| SPI Flash Pin | FPGA Connection | STMicro | NexFlash | Silicon <br> Storage <br> Technology | Atmel <br> DataFlash |
| :--- | :--- | :--- | :--- | :---: | :---: |
|  | Only applicable to Atmel DataFlash. Not <br> required for FPGA configuration but must be <br> High during configuration. Optional <br> connection to FPGA user I/O after <br> configuration. Do not connect to FPGA's <br> (see Figure 51) <br> prograB as this will prevent direct | N/A | N/A | N/A | $\overline{\text { RESET }}$ |
| RDY/BUSY | Only applicable to Atmel DataFlash and only <br> available on certain packages. Not required <br> for FPGA configuration. Output from <br> DataFlash PROM. Optional connection to <br> FPGA user I/O after configuration. | N/A | N/A | N/A | RDY/BUSY |
| (see Figure 51) |  |  |  |  |  |

The mode select pins, M[2:0], and the variant select pins, VS[2:0] are sampled when the FPGA's INIT_B output goes High and must be at defined logic levels during this time. After configuration, when the FPGA's DONE output goes High, these pins are all available as full-featured user-l/O pins.
(P) Similarly, the FPGA's HSWAP pin must be Low to enable pull-up resistors on all user-I/O pins or High to dis-
able the pull-up resistors. The HSWAP control must remain at a constant logic level throughout FPGA configuration. After configuration, when the FPGA's DONE output goes High, the HSWAP pin is available as full-featured user-l/O pin and is powered by the VCCO_0 supply.
In a single-FPGA application, the FPGA's DOUT pin is not used but is actively driving during the configuration process.

Table 47: Serial Peripheral Interface (SPI) Connections

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :--- | :--- | :--- | :--- | :--- |
| HSWAP <br> P | Input | User I/O Pull-Up Control. When <br> Low during configuration, enables <br> pull-up resistors in all I/O pins to <br> respective I/O bank V <br> Cco input. <br> 0: Pull-ups during configuration <br> 1: No pull-ups | Drive at valid logic level <br> throughout configuration. | User I/O |
| M[2:0] | Input | Mode Select. Selects the FPGA <br> configuration mode. | M2 = 0, M1 = 0, M0 = 1. <br> Sampled when INIT_B goes <br> High. | User I/O |
| VS[2:0] <br> S | Input | Variant Select. Instructs the <br> FPGA how to communicate with <br> the attached SPI Flash PROM. | Must be at the logic levels <br> shown in Table 45. Sampled <br> when INIT_B goes High. | User I/O |
| MOSI | Output | Serial Data Output. | FPGA sends SPI Flash memory <br> read commands and starting <br> address to the PROM's serial <br> data input. | User I/O |
| DIN | Input | Serial Data Input. | FPGA receives serial data from <br> PROM's serial data output. | User I/O |

Table 47: Serial Peripheral Interface (SPI) Connections (Continued)

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :--- | :--- | :--- | :--- | :--- |
| CSO_B | Output | Chip Select Output. Active Low. | Connects to the SPI Flash <br> PROM's chip-select input. If <br> HSWAP = 1, connect this signal <br> to a 4.7 k $\Omega$ pull-up resistor to <br> $3.3 V$. | Drive CSO_B High after <br> configuration to disable the <br> SPI Flash and reclaim the <br> MOSI, DIN, and CCLK pins. <br> Optionally, re-use this pin <br> and MOSI, DIN, and CCLK <br> to continue communicating <br> with SPI Flash. |
| CCLK |  | Output | Configuration Clock. Generated <br> by FPGA internal oscillator. <br> Frequency controlled by <br> ConfigRate bitstream generator <br> option. If CCLK PCB trace is long <br> or has multiple connections, <br> terminate this output to maintain <br> signal integrity. | Drives PROM's clock input. |

## Voltage Compatibility

Available SPI Flash PROMs use a single 3.3 V supply voltage. All of the FPGA's SPI Flash interface signals are within

I/O Bank 2. Consequently, the FPGA's VCCO_2 supply voltage must also be 3.3 V to match the SPI Flash PROM.

## Power-On Precautions if 3.3V Supply is Last in Sequence

Spartan-3E FPGAs have a built-in power-on reset (POR) circuit, as shown in Figure 63. The FPGA waits for its three power supplies - VCCINT, VCCAUX, and VCCO to I/O Bank 2 (VCCO_2) - to reach their respective power-on thresholds before beginning the configuration process.

The SPI Flash PROM is powered by the same voltage supply feeding the FPGA's VCCO_2 voltage input, typically 3.3V. SPI Flash PROMs specify that they cannot be accessed until their VCC supply reaches its minimum data sheet voltage, followed by an additional delay. For some devices, this additional delay is as little as $10 \mu \mathrm{~s}$ as shown in Table 48. For other vendors, it is as much as 20 ms .

Table 48: Example Minimum Power-On to Select Times for Various SPI Flash PROMs

| Vendor | SPI Flash PROM <br> Part Number | Data Sheet Minimum Time from VCC, min. to Select = Low |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  |  | Symbol | Value | Units |
| STMicroelectronics | $\mathrm{T}_{\text {VSL }}$ | 10 | $\mu \mathrm{~s}$ |  |
| NexFlash | NX25xx | $\mathrm{T}_{\text {VSL }}$ | 10 | $\mu \mathrm{~s}$ |
| Silicon Storage Technology | SST25LFxx | $\mathrm{T}_{\text {PU-READ }}$ | 10 | $\mu \mathrm{~s}$ |
| Programmable <br> Microelectronics Corporation | Pm25LVxxx | $\mathrm{T}_{\text {VCS }}$ | 50 | $\mu \mathrm{~s}$ |
| Atmel Corporation | AT45DBxx |  | 20 | ms |

In many systems, the 3.3 V supply feeding the FPGA's VCCO_2 input is valid before the FPGA's other VCCINT and VCCAUX supplies, and consequently, there is no issue. However, if the 3.3 V supply feeding the FPGA's VCCO_2 supply is last in the sequence, a potential race occurs between the FPGA and the SPI Flash PROM, as shown in Figure 52.
If the FPGA's VCCINT and VCCAUX supplies are already valid, then the FPGA waits for VCCO_2 to reach its minimum threshold voltage before starting configuration. This threshold voltage is labeled as $\mathrm{V}_{\text {CCO2t }}$ in Module 3 and ranges from approximately 0.4 V to 1.0 V , substantially lower than the SPI Flash PROM's minimum voltage. Once all three FPGA supplies reach their respective Power On Reset (POR) thresholds, the FPGA starts the configuration process and begins initializing its internal configuration memory. Initialization requires approximately 1 ms ( $\mathrm{T}_{\mathrm{POR}}$,
minimum in Module 3), after which the FPGA deasserts INIT_B, selects the SPI Flash PROM, and starts sending the appropriate read command. The SPI Flash PROM must be ready for read operations at this time.
If the 3.3 V supply is last in the sequence and does not ramp fast enough, or if the SPI Flash PROM cannot be ready when required by the FPGA, delay the FPGA configuration process by holding either the FPGA's PROG_B input or INIT_B input Low, as highlighted in Figure 51. Release the FPGA when the SPI Flash PROM is ready. For example, a simple R-C delay circuit attached to the INIT_B pin forces the FPGA to wait for a preselected amount of time. Alternately, a Power Good signal from the 3.3V supply or a system reset signal accomplishes the same purpose. Use an open-drain or open-collector output when driving PROG_B or INIT_B.


Figure 52: SPI Flash PROM/FPGA Power-On Timing if 3.3V Supply is Last in Power-On Sequence

## SPI Flash PROM Density Requirements

Table 49 shows the smallest usable SPI Flash PROM to program a single Spartan-3E FPGA. Commercially available SPI Flash PROMs range in density from 1 Mbit to 128 Mbits. A multiple-FPGA daisy-chained application requires a SPI Flash PROM large enough to contain the sum of the FPGA file sizes. An application can also use a larger-density SPI Flash PROM to hold additional data beyond just FPGA configuration data. For example, the SPI Flash PROM can also store application code for a MicroBlaze ${ }^{\text {TM }}$ RISC processor core integrated in the Spartan-3E FPGA. See Using the SPI Flash Interface after Configuration.

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

| Device | Number of <br> Configuration <br> Bits | Smallest Usable <br> SPI Flash PROM |
| :---: | :---: | :---: |
| XC3S100E | 581,344 | 1 Mbit |
| XC3S250E | $1,352,192$ | 2 Mbit |
| XC3S500E | $2,267,136$ | 4 Mbit |
| XC3S1200E | $3,832,320$ | 4 Mbit |
| XC3S1600E | $5,957,760$ | 8 Mbit |

## CCLK Frequency

In SPI Flash mode, the FPGA's internal oscillator generates the configuration clock frequency. The FPGA provides this clock on its CCLK output pin, driving the PROM's clock input pin. The FPGA starts configuration at its lowest frequency and increases its frequency for the remainder of the configuration process if so specified in the configuration bitstream. The maximum frequency is specified using the ConfigRate bitstream generator option. The maximum frequency supported by the FPGA configuration logic depends on the tim-
ing for the SPI Flash device. Without examining the timing for a specific SPI Flash PROM, use ConfigRate $=12$, which is approximately 12 MHz . SPI Flash PROMs that support the FAST READ command support higher data rates. Some such PROMs support up to ConfigRate = 25 and beyond but require careful data sheet analysis.

## Using the SPI Flash Interface after Configuration

After the FPGA successfully completes configuration, all of the pins connected to the SPI Flash PROM are available as user-1/O pins.
If not using the SPI Flash PROM after configuration, drive CSO_B High to disable the PROM. The MOSI, DIN, and CCLK pins are then available to the FPGA application.
Because all the interface pins are user I/O after configuration, the FPGA application can continue to use the SPI Flash interface pins to communicate with the SPI Flash PROM, as shown in Figure 53. SPI Flash PROMs offer ran-dom-accessible, byte-addressable, read/write, non-volatile storage to the FPGA application.
SPI Flash PROMs are available in densities ranging from 1 Mbit up to 128 Mbits. However, a single Spartan-3E FPGA requires less than 6 Mbits. If desired, use a larger SPI Flash PROM to contain additional non-volatile application data, such as MicroBlaze processor code, or other user data such as serial numbers and Ethernet MAC IDs. In the example shown in Figure 53, the FPGA configures from SPI Flash PROM. Then using FPGA logic after configuration, the FPGA copies MicroBlaze code from SPI Flash into external DDR SDRAM for code execution. Similarly, the FPGA application can store non-volatile application data within the SPI Flash PROM.
The FPGA configuration data is stored starting at location 0 . Store any additional data beginning in the next available SPI Flash PROM sector or page. Do not mix configuration data and user data in the same sector or page.

Spartan-3E FPGA


Figure 53: Using the SPI Flash Interface After Configuration

Similarly, the SPI bus can be expanded to additional SPI peripherals. Because SPI is a common industry-standard interface, there are a variety of SPI-based peripherals available, including analog-to-digital (A/D) converters, digi-tal-to-analog (D/A) converters, CAN controllers, and temperature sensors.

The MOSI, DIN, and CCLK pins are common to all SPI peripherals. Connect the select input on each additional SPI peripheral to one of the FPGA user I/O pins. If HSWAP $=0$ during configuration, the FPGA holds the select line High. If HSWAP $=1$, connect the select line to +3.3 V via an external $4.7 \mathrm{k} \Omega$ pull-up resistor to avoid spurious read or write operations. After configuration, drive the select line Low to select the desired SPI peripheral. Refer to the individual SPI
peripheral data sheet for specific interface and communication protocol requirements.

## Daisy-Chaining

If the application requires multiple FPGAs with different configurations, then configure the FPGAs using a daisy chain, as shown in Figure 54. Use SPI Flash mode ( $\mathrm{M}[2: 0]=<0: 0: 1>$ ) for the FPGA connected to the Platform Flash PROM and Slave Serial mode ( $\mathrm{M}[2: 0]=<1: 1: 1>$ ) for all other FPGAs in the daisy-chain. After the master FPGA-the FPGA on the left in the diagram-finishes loading its configuration data from the SPI Flash PROM, the master device uses its DOUT output pin to supply data to the next device in the daisy-chain, on the falling CCLK edge.


Figure 54: Daisy-Chaining from SPI Flash Mode

## In-System Programming Support

(I) In a production application, the SPI Flash PROM is usually pre-programmed before it is mounted on the printed circuit board. In-system programming support is available from some third-party PROM programmers using a socket adapter with attached wires. To gain access to the SPI Flash signals, drive the FPGA's PROG_B input Low with an open-drain driver. This action places all FPGA I/O pins, including those attached to the SPI Flash, in high-impedance (Hi-Z). If the HSWAP input is High, the I/Os have pull-up resistors to the $\mathrm{V}_{\mathrm{CCO}}$ input on their respective I/O bank. The external programming hardware then has direct access to the SPI Flash pins. The programming access points are highlighted in the gray box in Figure 50, Figure 51, and Figure 54.

## Byte-Wide Peripheral Interface (BPI) Parallel Flash Mode

In Byte-wide Peripheral Interface (BPI) mode ( $\mathrm{M}[2: 0]=<0: 1: 0>$ or $<0: 1: 1>$ ), a Spartan-3E FPGA configures itself from an industry-standard parallel NOR Flash PROM, as illustrated in Figure 55. The FPGA generates up
to a 24-bit address lines to access an attached parallel Flash. Only 20 address lines are generated for Spartan-3E FPGAs in the TQ144 package. The BPI mode is not available for Spartan-3E FPGAs in the VQ100 package.
The interface is designed for standard parallel NOR Flash PROMs and supports both byte-wide (x8) and byte-wide/halfword (x8/x16) PROMs. The interface does not support halfword-only (x16) PROMs. The interface works equally wells with other memories that use a similar interface such as SRAM, NVRAM, EEPROM, EPROM, or masked ROM but is primarily designed for Flash memory.
There is another type of Flash memory called NAND Flash, which is commonly used in memory cards for digital cameras, etc. Spartan-3E FPGAs do not configure directly from NAND Flash memories.
The FPGA's internal oscillator controls the interface timing and the FPGA supplies the clock on the CCLK output pin. However, the CCLK signal is not used in single FPGA applications. Similarly, the FPGA drives three pins Low during configuration (LDC[2:0]) and one pin High during configuration (HDC) to the PROM's control inputs.


Figure 55: Byte-wide Peripheral Interface (BPI) Mode Configured from ParalleI NOR Flash PROMs
(A) During configuration, the value of the M0 mode pin determines how the FPGA generates addresses, as shown Table 50. When $\mathrm{MO}=0$, the FPGA generates addresses starting at 0 and increments the address on every falling CCLK edge. Conversely, when M0 $=1$, the FPGA generates addresses starting at 0xFF_FFFF (all ones) and decrements the address on every falling CCLK edge.

## Table 50: BPI Addressing Control

| M2 | M1 | M0 | Start Address | Addressing |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | 0 | Incrementing |
|  |  | 1 | 0xFF_FFFF | Decrementing |

This addressing flexibility allows the FPGA to share the parallel Flash PROM with an external or embedded processor.

Depending on the specific processor architecture, the processor boots either from the top or bottom of memory. The FPGA is flexible and boots from the opposite end of memory from the processor. Only the processor or the FPGA can boot at any given time. The FPGA can configure first, holding the processor in reset or the processor can boot first, asserting the FPGA's PROG_B pin.
The mode select pins, M[2:0], are sampled when the FPGA's INIT_B output goes High and must be at defined logic levels during this time. After configuration, when the FPGA's DONE output goes High, the mode pins are available as full-featured user-l/O pins.
(P) Similarly, the FPGA's HSWAP pin must be Low to enable pull-up resistors on all user-l/O pins or High to disable the pull-up resistors. The HSWAP control must remain at a constant logic level throughout FPGA configuration. After configuration, when the FPGA's DONE output goes

High, the HSWAP pin is available as full-featured user-l/O pin and is powered by the VCCO_0 supply.
The RDWR_B and CSI_B must be Low throughout the configuration process. After configuration, these pins also become user I/O.
In a single-FPGA application, the FPGA's CSO_B and CCLK pins are not used but are actively driving during the configuration process. The BUSY pin is not used but also
actively drives during configuration and is available as a user I/O after configuration.
After configuration, all of the interface pins except DONE and PROG_B are available as user I/Os. Furthermore, the bidirectional SelectMAP configuration peripheral interface (see Slave Parallel Mode) is available after configuration. To continue using SelectMAP mode, set the Persist bitstream generator option to Yes. An external host can then read and verify configuration data.

Table 51: Byte-Wide Peripheral Interface (BPI) Connections

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :---: | :---: | :---: | :---: | :---: |
| HSWAP (P) | Input | User I/O Pull-Up Control. When Low during configuration, enables pull-up resistors in all I/O pins to respective I/O bank $\mathrm{V}_{\mathrm{CCO}}$ input. <br> 0 : Pull-ups during configuration 1: No pull-ups | Drive at valid logic level throughout configuration. | User I/O |
| M[2:0] <br> (A) | Input | Mode Select. Selects the FPGA configuration mode. | $M 2=0, M 1=1$. Set $M 0=0$ to start at address 0 , increment addresses. Set $\mathrm{MO}=1$ to start at address 0xFFFFFFF and decrement addresses. Sampled when INIT_B goes High. | User I/O |
| CSI_B | Input | Chip Select Input. Active Low. | Must be Low throughout configuration. | User I/O. If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| RDWR_B | Input | Read/Write Control. Active Low write enable. Read functionality typically only used after configuration, if bitstream option Persist=Yes. | Must be Low throughout configuration. | User I/O. If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| LDC0 | Output | PROM Chip Enable | Connect to PROM chip-select input (CE\#). FPGA drives this signal Low throughout configuration. | User I/O |
| LDC1 | Output | PROM Output Enable | Connect to PROM output-enable input (OE\#). FPGA drives this signal Low throughout configuration. | User I/O |
| HDC | Output | PROM Write Enable | Connect to PROM write-enable input (WE\#). FPGA drives this signal High throughout configuration. | User I/O |
| LDC2 <br> (D) | Output | PROM Byte Mode | This signal is not used for $x 8$ PROMs. For PROMs with a x8/x16 data width control, connect to PROM byte-mode input (BYTE\#). See Precautions Using x8/x16 Flash PROMs. FPGA drives this signal Low throughout configuration. | User I/O. Drive this pin High after configuration to use a x8/x16 PROM in x16 mode. |

Table 51: Byte-Wide Peripheral Interface (BPI) Connections (Continued)

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :---: | :---: | :---: | :---: | :---: |
| A[23:0] | Output | Address | Connect to PROM address inputs. High order address lines may not be available in all packages and not all may be required. Number of address lines required depends on the size of the attached Flash PROM. FPGA address generation controlled by M0 mode pin. <br> Addresses presented on falling CCLK edge. <br> Only 20 address lines are available in TQ144 package. | User I/O |
| D[7:0] | Input | Data Input | FPGA receives byte-wide data on these pins in response the address presented on $\mathrm{A}[23: 0]$. Data captured by FPGA | User I/O If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| CSO_B | Output | Chip Select Output. Active Low. | Not used in single FPGA applications. In a daisy-chain configuration, this pin connects to the CSI_B pin of the next FPGA in the chain. Actively drives. | User I/O |
| BUSY | Output | Busy Indicator. Typically only used after configuration, if bitstream option Persist=Yes. | Not used during configuration but actively drives. | User I/O. If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| CCLK | Output | Configuration Clock. Generated by FPGA internal oscillator. Frequency controlled by ConfigRate bitstream generator option. If CCLK PCB trace is long or has multiple connections, terminate this output to maintain signal integrity. | Not used in single FPGA applications but actively drives. In a daisy-chain configuration, drives the CCLK inputs of all other FPGAs in the daisy-chain. | User I/O If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| INIT_B | Open-drain bidirectional I/O | Initialization Indicator. Active Low. Goes Low at start of configuration during Initialization memory clearing process. Released at end of memory clearing, when mode select pins are sampled. In daisy-chain applications, this signal requires an external $4.7 \mathrm{k} \Omega$ pull-up resistor to VCCO_2. | Active during configuration. If CRC error detected during configuration, FPGA drives INIT_B Low. | User I/O |

Table 51: Byte-Wide Peripheral Interface (BPI) Connections (Continued)

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :--- | :---: | :--- | :--- | :--- |
| DONE | Open-drain <br> bidirectional I/O | FPGA Configuration Done. Low <br> during configuration. Goes High <br> when FPGA successfully <br> completes configuration. Requires <br> external $330 \Omega$ pull-up resistor to <br> 2.5 V. | Low indicates that the FPGA is <br> not yet configured. | Pulled High via external <br> pull-up. When High, <br> indicates that the FPGA <br> successfully configured. |
| PROG_B | Input | Program FPGA. Active Low. <br> When asserted Low for 300 ns or <br> longer, forces the FPGA to restart <br> its configuration process by <br> clearing configuration memory and <br> resetting the DONE and INIT_B <br> pins once PROG_B returns High. <br> Requires external 4.7 k $\Omega$ pull-up <br> resistor to 2.5V. If driving <br> externally, use an open-drain or <br> open-collector driver. | Must be High to allow <br> 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. |

## 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.3 V supply voltage. Consequently, in most cases, the FPGA's VCCO_1 and VCCO_2 supply voltages must also be 3.3 V to match the parallel Flash PROM. There are some 1.8 V parallel Flash PROMs available and the FPGA interfaces with these devices if the VCCO_1 and VCCO_2 supplies are also 1.8 V .

## Supported ParalleI NOR Flash PROM Densities

Table 52 indicates the smallest usable parallel Flash PROM to program a single Spartan-3E FPGA. Parallel Flash density is specified in bits but addressed as bytes. The FPGA presents up to 24 address lines during configuration but not all are required for single FPGA applications. Table 52
shows the minimum required number of address lines between the FPGA and parallel Flash PROM. The actual number of address line required depends on the density 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 may also use a larger-density parallel Flash PROM to hold additional data beyond just FPGA configuration data. For example, the parallel Flash PROM could also contain the application code for a MicroBlaze RISC processor core implemented within the Spar-tan-3E FPGA. After configuration, the MicroBlaze processor could execute directly from external Flash or could copy the code to other, faster system memory before executing the code.

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

| Device | Uncompressed <br> File Sizes (bits) | Smallest Usable Parallel <br> Flash PROM | Minimum Required Address <br> Lines |
| :---: | :---: | :---: | :---: |
| XC3S100E | 581,344 | 1 Mbit | $\mathrm{A}[16: 0]$ |
| XC3S250E | $1,352,192$ | 2 Mbit | $\mathrm{A}[17: 0]$ |
| XC3S500E | $2,267,136$ | 4 Mbit | $\mathrm{A}[18: 0]$ |
| XC3S1200E | $3,832,320$ | 4 Mbit | $\mathrm{A}[18: 0]$ |
| XC3S1600E | $5,957,760$ | 8 Mbit | $\mathrm{A}[19: 0]$ |

## CCLK Frequency

In BPI mode, the FPGA's internal oscillator generates the configuration clock frequency that controls all the interface timing. The FPGA starts configuration at its lowest frequency and increases its frequency for the remainder of the configuration process if so specified in the configuration bit-
stream. The maximum frequency is specified using the ConfigRate bitstream generator option. Table 53 shows the maximum ConfigRate settings, approximately equal to MHz , for various PROM read access times. Despite using slower ConfigRate settings, BPI mode is equally fast as the other configuration modes. In BPI mode, data is accessed
at the ConfigRate frequency and internally serialized with an 8 X clock frequency.
Table 53: Maximum ConfigRate Settings for Parallel
Flash PROMs

| Flash Read Access Time | Maximum ConfigRate <br> Setting |
| :---: | :---: |
| $\leq 200 \mathrm{~ns}$ | 3 |
| $\leq 90 \mathrm{~ns}$ | 6 |

## Using the BPI Interface after Configuration

After the FPGA successfully completes configuration, all of the pins connected to the parallel Flash PROM are available as user l/Os.
If not using the parallel Flash PROM after configuration, drive LDC0 High to disable the PROM's chip-select input. The remainder of the BPI pins then become available to the FPGA application, including all 24 address lines, the eight data lines, and the LDC2, LDC1, and HDC control pins.
Because all the interface pins are user I/Os after configuration, the FPGA application can continue to use the interface pins to communicate with the parallel Flash PROM. Parallel Flash PROMs are available in densities ranging from 1 Mbit up to 128 Mbits and beyond. However, a single Spartan-3E FPGA requires less than 6 Mbits for configuration. If desired, use a larger parallel Flash PROM to contain additional non-volatile application data, such as MicroBlaze processor code, or other user data such as serial numbers, Ethernet MAC IDs, etc. In such an example, the FPGA configures from parallel Flash PROM. Then using FPGA logic after configuration, a MicroBlaze processor embedded within the FPGA can either execute code directly from parallel Flash PROM or copy the code to external DDR SDRAM and execute from DDR SDRAM. Similarly, the FPGA application can store non-volatile application data within the parallel Flash PROM.
The FPGA configuration data is stored starting at either at location 0 or the top of memory (addresses all ones) or at both locations for MultiBoot mode. Store any additional data beginning in other available parallel Flash PROM sectors. Do not mix configuration data and user data in the same sector.
Similarly, the parallel Flash PROM interface can be expanded to additional parallel peripherals.
The address, data, and LDC1 (OE\#) and HDC (WE\#) control signals are common to all parallel peripherals. Connect the chip-select input on each additional peripheral to one of the FPGA user I/O pins. If HSWAP $=0$ during configuration, the FPGA holds the chip-select line High via an internal pull-up resistor. If HSWAP $=1$, connect the select line to +3.3 V via an external $4.7 \mathrm{k} \Omega$ pull-up resistor to avoid spuri-
ous read or write operations. After configuration, drive the select line Low to select the desired peripheral. Refer to the individual peripheral data sheet for specific interface and communication protocol requirements.
The FPGA optionally supports a 16-bit peripheral interface by driving the LDC2 (BYTE\#) control pin High after configuration. See Precautions Using x8/x16 Flash PROMs for additional information.
The FPGA provides up to 24 address lines during configuration, addressing up to 128 Mbits ( 16 Mbytes). If using a larger parallel PROM, connect the upper address lines to FPGA user I/O. During configuration, the upper address lines will be pulled High if $H S W A P=0$. Otherwise, use external pull-up or pull-down resistors on these address lines to define their values during configuration.

## Precautions Using x8/x16 Flash PROMs

(D) Most low- to mid-density PROMs are byte-wide (x8) only. Many higher-density Flash PROMs support both byte-wide (x8) and halfword-wide (x16) data paths and include a mode input called BYTE\# that switches between x 8 or x 16 . During configuration, Spartan-3E FPGAs only support byte-wide data. However, after configuration, the FPGA supports either x8 or x16 modes. In x16 mode, up to eight additional user I/O pins are required for the upper data bits, D[15:8].
Connecting a Spartan-3E FPGA to a $\times 8 / \times 16$ Flash PROM is simple, but does require a precaution. Various Flash PROM vendors use slightly different interfaces to support both $\times 8$ and $\times 16$ modes. Some vendors (Intel, Micron, some STMicroelectronics devices) use a straightforward interface with pin naming that matches the FPGA connections. However, the PROM's A0 pin is wasted in x16 applications and a separate FPGA user-1/O pin is required for the D15 data line. Fortunately, the FPGA AO pin is still available as a user I/O after configuration, even though it connects to the Flash PROM.
Other vendors (AMD, Atmel, Silicon Storage Technology, some STMicroelectronics devices) use a pin-efficient interface but change the function of one pin, called IO15/A-1, depending if the PROM is in $x 8$ or $x 16$ mode. In $x 8$ mode, BYTE\# $=0$, this pin is the least-significant address line. The AO address line selects the halfword location. The A-1 address line selects the byte location. When in x16 mode, BYTE\# $=1$, the IO15/A-1 pin becomes the most-significant data bit, D15 because byte addressing is not required in this mode. Check to see if the Flash PROM has a pin named "IO15/A-1" or "DQ15/A-1". If so, be careful to connect x8/x16 Flash PROMs correctly, as shown in Table 54. Also, remember that the D[14:8] data connections require FPGA user I/O pins but that the D15 data is already connected for the FPGA's A0 pin.

Table 54: FPGA Connections to Flash PROM with "IO15/A-1" Pin

| FPGA Pin | Connection to Flash PROM with <br> IO15/A-1 Pin | x8 Flash PROM Interface After <br> FPGA Configuration | x16 Flash PROM Interface After <br> FPGA Configuration |
| :--- | :--- | :--- | :--- |
| LDC2 | BYTE\# | Drive LDC2 Low or leave <br> unconnected and tie PROM <br> BYTE\# input to GND | Drive LCD2 High |
| LDC1 | OE\# | Active-Low Flash PROM <br> output-enable control | Active-Low Flash PROM <br> output-enable control |
| LDC0 | CS\# | Active-Low Flash PROM <br> chip-select control | Active-Low Flash PROM <br> chip-select control |
| HDC | WE\# | Flash PROM write-enable <br> control | Flash PROM write-enable control |
| A[23:1] | A[n:0] | A[n:0] | A[n:0] |
| A0 | IO15/A-1 | IO15/A-1 is least-significant <br> address input | IO15/A-1 is most-significant data <br> line, IO15 |
| D[7:0] | IO[7:0] | IO[7:0] | IO[7:0] |
| User I/O | Upper data lines IO[14:8] not <br> required unless used as x16 Flash <br> interface after configuration | Upper data lines IO[14:8] not <br> required | IO[14:8] |

## Daisy-Chaining

If the application requires multiple FPGAs with different configurations, then configure the FPGAs using a daisy chain, as shown in Figure 56. Use BPI mode ( $\mathrm{M}[2: 0]=<0: 1: 0>$ or $<0: 1: 1>$ ) for the FPGA connected to the parallel NOR Flash PROM and Slave Parallel mode ( $\mathrm{M}[2: 0]=<1: 1: 0>$ ) for all other FPGAs in the daisy-chain. After the master FPGA-the FPGA on the left in the diagram-finishes loading its configuration data from the parallel Flash PROM, the master device continues generating addresses to the Flash PROM and asserts its CSO_B output Low, enabling the
next FPGA in the daisy-chain. The next FPGA then receives parallel configuration data from the Flash PROM. The master FPGA's CCLK output synchronizes data capture.
The downstream devices in Slave Parallel mode also actively drive their LDC[2:0] and HDC outputs during configuration, although these signal are not used for configuration. These pins are in I/O Bank 1, powered by VCCO_1. Because these pins do not connect elsewhere in the configuration circuit, the voltage on VCCO_1 can be whatever is required by the end application.


Figure 56: Daisy-Chaining from BPI Flash Mode

## In-System Programming Support

(I) In a production application, the parallel Flash PROM is usually preprogrammed before it is mounted on the printed circuit board. In-system programming support is available from third-party boundary-scan tool vendors and from some third-party PROM programmers using a socket adapter with attached wires. To gain access to the parallel Flash signals, drive the FPGA's PROG_B input Low with an open-drain driver. This action places all FPGA I/O pins, including those attached to the parallel Flash, in high-impedance (Hi-Z). If the HSWAP input is High, the I/Os have pull-up resistors to the $\mathrm{V}_{\mathrm{CCO}}$ input on their respective I/O bank. The external programming hardware then has direct access to the parallel Flash pins. The programming access points are highlighted in the gray boxes in Figure 55 and Figure 56.
The FPGA itself can also be used as a parallel Flash PROM programmer during development and test phases. Initially, an FPGA-based programmer is downloaded into the FPGA via JTAG. Then the FPGA performs the Flash PROM programming algorithms and receives programming data from the host via the FPGA's JTAG interface. See Chapter 11 in "Embedded System Tools Reference Manual".

## Dynamically Loading Multiple Configuration Images Using MultiBoot Option

After the FPGA configures itself using BPI mode from one end of the parallel Flash PROM, then the FPGA can trigger a MultiBoot event and reconfigure itself from the opposite end of the parallel Flash PROM. MultiBoot is only available when using BPI mode and only for applications with a single Spartan-3E FPGA.
By default, MultiBoot mode is disabled. To trigger a MultiBoot event, assert a Low pulse lasting at least 300 ns on the MultiBoot Trigger (MBT) input to the STARTUP_SPARTAN3E library primitive. Figure 57 shows an example usage. At power up, the FPGA loads itself from the attached parallel Flash PROM. In this example, the M0 mode pin is Low so the FPGA starts at address 0 and increments through the Flash PROM memory locations. After the FPGA completes configuration, the application loaded into the FPGA performs a board-level or system test using FPGA logic. If the test is successful, the FPGA triggers a MultiBoot event, causing the FPGA to reconfigure from the opposite end of the Flash PROM memory. This second configuration contains the FPGA application for normal operation.


Figure 57: Use MultiBoot to Load Alternate Configuration Images

Similarly, the general FPGA application could trigger a MultiBoot event at any time to reload the diagnostics design.
In another potential application, the initial design loaded into the FPGA image contains a "golden" or "fail-safe" configuration image, which then communicates with the outside world and checks for a newer image. If there is a new configuration revision and the new image verifies as good, the "golden" configuration triggers a MultiBoot event to load the new image.
When a MultiBoot event is triggered, the FPGA then again drives its configuration pins as described in Table 51. How-
ever, the FPGA does not assert the PROG_B pin. The system design must ensure that no other device drives on these same pins during the reconfiguration process. The FPGA's DONE, LDC[2:0], or HDC pins can temporarily disable any conflicting drivers during reconfiguration.

## Slave Parallel Mode

In Slave Parallel mode ( $\mathrm{M}[2: 0]=<1: 1: 0>$ ), an external host such as a microprocessor or microcontroller writes byte-wide configuration data into the FPGA, using a typical peripheral interface as shown in Figure 58.


Figure 58: Slave Parallel Configuration Mode

The external download host starts the configuration process by pulsing PROG_B and monitoring that the INIT_B pin goes High, indicating that the FPGA is ready to receive its first data. The host asserts the active-Low chip-select signal (CSI_B) and the active-Low Write signal (RDWR_B). The host then continues supplying data and clock signals until either the FPGA's DONE pin goes High, indicating a successful configuration, or until the FPGA's INIT_B pin goes Low, indicating a configuration error.
The FPGA captures data on the rising CCLK edge. If the CCLK frequency exceeds 50 MHz , then the host must also monitor the FPGA's BUSY output. If the FPGA asserts BUSY High, the host must hold the data for an additional clock cycle, until BUSY returns Low. If the CCLK frequency
is 50 MHz or below, the BUSY pin may be ignored but actively drives during configuration.
The configuration process requires more clock cycles than indicated from the configuration file size. Additional clocks are required during the FPGA's start-up sequence, especially if the FPGA is programmed to wait for selected Digital Clock Managers (DCMs) to lock to their respective clock inputs (see Start-Up, page 91).
If the Slave Parallel interface is only used to configure the FPGA, never to read data back, then the RDWR_B signal can also be eliminated from the interface. However, RDWR_B must remain Low during configuration.

After configuration, all of the interface pins except DONE and PROG_B are available as user I/Os. Alternatively, the bidirectional SelectMAP configuration interface is available after configuration. To continue using SelectMAP mode, set the Persist bitstream generator option to Yes. The external host can then read and verify configuration data.

The Slave Parallel mode is also used with BPI mode to create multi-FPGA daisy-chains. The lead FPGA is set for BPI mode configuration; all the downstream daisy-chain FPGAs are set for Slave Parallel configuration, as highlighted in Figure 56.

## Table 55: Slave Parallel Mode Connections

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :---: | :---: | :---: | :---: | :---: |
| HSWAP | Input | User I/O Pull-Up Control. When Low during configuration, enables pull-up resistors in all I/O pins to respective I/O bank $V_{C C O}$ input. <br> 0 : Pull-ups during configuration <br> 1: No pull-ups | Drive at valid logic level throughout configuration. | User I/O |
| M[2:0] | Input | Mode Select. Selects the FPGA configuration mode. | $M 2=1, M 1=1, M 0=0 \text { Sampled }$ when INIT_B goes High. | User I/O |
| D[7:0] | Input | Data Input. | Byte-wide data provided by host. FPGA captures data on rising CCLK edge. | User I/O. If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| BUSY | Output | Busy Indicator. | If CCLK frequency is $<50 \mathrm{MHz}$, this pin may be ignored. When High, indicates that the FPGA is not ready to receive additional configuration data. Host must hold data an additional clock cycle. | User I/O. If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| CSI_B | Input | Chip Select Input. Active Low. | Must be Low throughout configuration. | User I/O. If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| RDWR_B | Input | Read/Write Control. Active Low write enable. | Must be Low throughout configuration. | User I/O. If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| CCLK | Input | Configuration Clock. If CCLK PCB trace is long or has multiple connections, terminate this output to maintain signal integrity. | External clock. | User I/O If bitstream option Persist=Yes, becomes part of SelectMap parallel peripheral interface. |
| LDC[2:0] | Output | Low During Configuration. | These pins are not used during configuration. Low throughout configuration. | User I/O |
| HDC | Output | High During Configuration. | This pin is not used during configuration. High throughout configuration. | User I/O |

Table 55: Slave Parallel Mode Connections (Continued)

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :---: | :---: | :---: | :---: | :---: |
| CSO_B | Output | Chip Select Output. Active Low. | Not used in single FPGA applications. In a daisy-chain configuration, this pin connects to the CSI_B pin of the next FPGA in the chain. Actively drives. | User I/O |
| INIT_B | Open-drain bidirectional I/O | Initialization Indicator. Active Low. Goes Low at start of configuration during Initialization memory clearing process. Released at end of memory clearing, when mode select pins are sampled. In daisy-chain applications, this signal requires an external $4.7 \mathrm{k} \Omega$ pull-up resistor to VCCO_2. | Active during configuration. If CRC error detected during configuration, FPGA drives INIT_B Low. | User I/O |
| DONE | Open-drain bidirectional I/O | FPGA Configuration Done. Low during configuration. Goes High when FPGA successfully completes configuration. Requires external $330 \Omega$ pull-up resistor to 2.5 V . | Low indicates that the FPGA is not yet configured. | Pulled High via external pull-up. When High, indicates that the FPGA successfully configured. |
| PROG_B | Input | Program FPGA. Active Low. When asserted Low for 300 ns or longer, forces the FPGA to restart its configuration process by clearing configuration memory and resetting the DONE and INIT_B pins once PROG_B returns High. Requires external $4.7 \mathrm{k} \Omega$ pull-up resistor to 2.5 V . If driving externally, use an open-drain or open-collector driver. | Must be High to allow configuration to start. | Drive PROG_B Low and release to reprogram FPGA. |

## Voltage Compatibility

(V) 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.8 \mathrm{~V}, 2.5 \mathrm{~V}$, or 3.3 V to match the requirements of the external host, ideally 2.5 V . Using 1.8 V or 3.3 V requires additional design considerations as the DONE and PROG_B pins are powered by the FPGA's 2.5 V VCCAUX supply. See application note XAPP453: "The 3.3V Configuration of Spartan-3 FPGAs" for additional information.
The LDC[2:0] and HDC signal are active in I/O Bank 1 but are not used in the interface. Consequently, VCCO_1 can be set the appropriate voltage for the application.

## Daisy-Chaining

If the application requires multiple FPGAs with different configurations, then configure the FPGAs using a daisy chain. Use Slave Parallel mode ( $\mathrm{M}[2: 0]=<1: 1: 0>$ ) for all FPGAs in the daisy-chain. The schematic in Figure 59 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.


Figure 59: Daisy-Chaining using Slave Parallel Mode

## Slave Serial Mode

In Slave Serial mode (M[2:0] = <1:1:1>), an external host such as a microprocessor or microcontroller writes serial configuration data into the FPGA, using the synchronous serial interface shown in Figure 60. The serial configuration data is presented on the FPGA's DIN input pin with sufficient setup time before each rising edge of the externally generated CCLK clock input.
The intelligent host starts the configuration process by pulsing PROG_B and monitoring that the INIT_B pin goes High,
indicating that the FPGA is ready to receive its first data. The host then continues supplying data and clock signals until either the DONE pin goes High, indicating a successful configuration, or until the INIT_B pin goes Low, indicating a configuration error. The configuration process requires more clock cycles than indicated from the configuration file size. Additional clocks are required during the FPGA's start-up sequence, especially if the FPGA is programmed to wait for selected Digital Clock Managers (DCMs) to lock to their respective clock inputs (see Start-Up, page 91).


Figure 60: Slave Serial Configuration

The mode select pins, M[2:0], are sampled when the FPGA's INIT_B output goes High and must be at defined logic levels during this time. After configuration, when the FPGA's DONE output goes High, the mode pins are available as full-featured user-l/O pins.
(P) Similarly, the FPGA's HSWAP pin must be Low to enable pull-up resistors on all user-I/O pins or High to disable the pull-up resistors. The HSWAP control must remain at a constant logic level throughout FPGA configuration. After configuration, when the FPGA's DONE output goes High, the HSWAP pin is available as full-featured user-1/O pin and is powered by the VCCO_0 supply.

Table 56: Slave Serial Mode Connections

| Pin Name | FPGA Direction | Description | During Configuration | After Configuration |
| :--- | :---: | :--- | :--- | :--- |
| HSWAP | Input | User I/O Pull-Up Control. When <br> Low during configuration, enables <br> pull-up resistors in all I/O pins to <br> respective I/O bank V ${ }_{\text {Cco input. }}$ <br> 0: Pull-up during configuration <br> 1: No pull-ups | Drive at valid logic level <br> throughout configuration. | User I/O |
| M[2:0] | Input | Mode Select. Selects the FPGA <br> configuration mode. | M2 = 1, M1 = 1, M0 = 1 Sampled <br> when INIT_B goes High. | User I/O |
| DIN | Input | Data Input. | Serial data provided by host. <br> FPGA captures data on rising <br> CCLK edge. | User I/O |
| CCLK | Input | Configuration Clock. If CCLK <br> PCB trace is long or has multiple <br> connections, terminate this output <br> to maintain signal integrity. | External clock. |  |
| INIT_B | Open-drain <br> bidirectional I/O | Initialization Indicator. Active <br> Low. Goes Low at start of <br> configuration during Initialization <br> memory clearing process. <br> Released at end of memory <br> clearing, when mode select pins <br> are sampled. In daisy-chain <br> applications, this signal requires <br> an external 4.7 k pull-up resistor <br> to VCCO_2. | Active during configuration. If <br> CRC error detected during <br> configuration, FPGA drives <br> INIT_B Low. | User I/O |

## Voltage Compatibility

(V) Most Slave Serial interface signals are within the FPGA's I/O Bank 2, supplied by the VCCO_2 supply input. The VCCO 2 voltage can be $3.3 \mathrm{~V}, 2.5 \mathrm{~V}$, or 1.8 V to match the requirements of the external host, ideally 2.5 V . Using 3.3 V or 1.8 V requires additional design considerations as the DONE and PROG_B pins are powered by the FPGA's 2.5V VCCAUX supply. See application note XAPP453: "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, as shown in Figure 61. Use Slave Serial mode ( $\mathrm{M}[2: 0]=<1: 1: 1>$ ) for all FPGAs in the daisy-chain. After the lead FPGA is filled with its configuration data, the lead FPGA passes configuration data via its DOUT output pin to the next FPGA on the falling CCLK edge.


Figure 61: Daisy-Chaining using Slave Serial Mode

## JTAG Mode

The Spartan-3E FPGA has a dedicated four-wire IEEE 1149.1/1532 JTAG port that is always available any time the FPGA is powered and regardless of the mode pin settings. However, when the FPGA mode pins are set for JTAG mode ( $\mathrm{M}[2: 0]=<1: 0: 1>$ ), the FPGA waits to be configured via the JTAG port after a power-on event or when PROG_B is asserted. Selecting the JTAG mode simply disables the
other configuration modes. No other pins are required as part of the configuration interface.
Figure 62 illustrates a JTAG-only configuration interface. The JTAG interface is easily cascaded to any number of FPGAs by connecting the TDO output of one device to the TDI input of the next device in the chain. The TDO output of the last device in the chain loops back to the port connector.


Figure 62: JTAG Configuration Mode

## Voltage Compatibility

The 2.5V VCCAUX supply powers the JTAG interface. All of the user I/Os are separately powered by their respective VCCO_\# supplies.
When connecting the Spartan-3E JTAG port to a 3.3V interface, the JTAG input pins must be current-limited to 10 mA or less using series resistors. Similarly, the TDO pin is a CMOS output powered from +2.5 V . The TDO output can directly drive a 3.3 V input but with reduced noise immunity. See application note XAPP453: "The 3.3V Configuration of Spartan-3 FPGAs" for additional information.

## 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

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 $\mathrm{V}_{\mathrm{CCINT}}$, VcCAUX , and the $\mathrm{V}_{\text {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 63 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 64. Figure 65 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.


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


Figure 64: General Configuration Process


Figure 65: Boundary-Scan Configuration Flow Diagram

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

Configuration data is then 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 be releasing the DONE pin, allowing it to go High.
The FPGA configuration sequence can also be initiated by asserting the PROG_B. Once release, the FPGA begins clearing its internal configuration memory, and progresses through the remainder of the configuration process.

## Start-Up

At the end of configuration, the Global Set/Reset (GSR) signal is pulsed, placing all flip-flops in a known state. After configuration completes, the FPGA switches over to the user application loaded into the FPGA. The sequence and timing of how the FPGA switches over is programmable as is the clock source controlling the sequence.
The default start-up sequence appears in Figure 66, where the Global Three-State signal (GTS) is released one clock cycle after DONE goes High. This sequence allows the DONE signal to enable or disable any external logic used during configuration before the user application in the FPGA starts driving output signals. One clock cycle later, the Global Write Enable (GWE) signal is released. This allows signals to propagate within the FPGA before any clocked storage elements such as flip-flops and block ROM are enabled.


Figure 66: Default Start-Up Sequence

The relative timing of configuration events is programmed via the Bitstream Generator (BitGen) options in the Xilinx development software. For example, the GTS and GWE events can be programmed to wait for all the DONE pins to High on all the devices in a multiple-FPGA daisy-chain, forcing the FPGAs to start synchronously. Similarly, the start-up sequence can be paused at any stage, waiting for selected DCMs to lock to their respective input clock signals. See also Stabilizing DCM Clocks Before User Mode, page 48.
The start-up sequence can by synchronized to a clock within the FPGA application using the STARTUP_SPARTAN3E library primitive and by setting the StartupCIk bitstream generator option. The FPGA application can optionally assert the Global Set/Reset (GSR) and Global Three-State signal (GTS) signals via the STARTUP_SPARTAN3E primitive.

## Readback

Using Slave Parallel mode, configuration data from the FPGA can be read back. Readback is supported only in the Slave Parallel and JTAG modes.

Along with the configuration data, it is possible to read back the contents of all registers, distributed RAM, and block RAM resources. This capability is used for real-time debugging.
To synchronously control when registers values are captured for readback, using the CAPTURE_SPARTAN3 library primitive, which applies for both Spartan-3 and Spartan-3E FPGA families.

## Bitstream Generator (BitGen) Options

Various Spartan-3E FPGA functions are controlled by specific bits in the configuration bitstream image. These values are specified when creating the bitstream image with the Bitstream Generator (BitGen) software.
Table 57 provides a list of all BitGen options for Spartan-3E FPGAs.

## Table 57: Spartan-3E FPGA Bitstream Generator (BitGen) Options

| Option Name | Pins/Function Affected | Values <br> (default) | Description |
| :---: | :---: | :---: | :---: |
| ConfigRate | CCLK, <br> Configuration | $\begin{gathered} 3, \underline{\boldsymbol{6}} \\ 12,25 \end{gathered}$ | Sets the approximate frequency, in MHz, of the internal oscillator using for Master Serial, SPI, and BPI configuration modes. The internal oscillator powers up at its lowest frequency and the new setting is loaded as part of the configuration bitstream. The software default value is $6(\sim 6 \mathrm{MHz})$. |
| StartupClk | Configuration, Startup | Cclk | Default. The CCLK signal (internally or externally generated) controls the startup sequence when the FPGA transitions from configuration mode to the user mode. See Start-Up, page 91. |
|  |  | UserCIk | A clock signal from within the FPGA application controls the startup sequence when the FPGA transitions from configuration mode to the user mode. See Start-Up, page 91. The FPGA application supplies the user clock on the CLK pin on the STARTUP_SPARTAN3E primitive. |
|  |  | Jtag | The JTAG TCK input controls the startup sequence when the FPGA transitions from configuration mode to the user mode. See Start-Up, page 91. |
| UnusedPin | Unused I/O Pins | Pulldown | Default. All unused I/O pins have a pull-down resistor to GND. |
|  |  | Pullup | All unused I/O pins have a pull-up resistor to the VCCO_\# supply for its associated I/O bank. |
|  |  | Pullnone | All unused I/O pins are left floating (Hi-Z, high-impedance, three-state). Use external pull-up or pull-down resistors or logic to apply a valid signal level. |
| DONE_cycle | DONE pin, Configuration Startup | $\begin{gathered} 1,2,3,4 \\ 5,6 \end{gathered}$ | Selects the Configuration Startup phase that activates the FPGA's DONE pin. See Start-Up, page 91. |

## Table 57: Spartan-3E FPGA Bitstream Generator (BitGen) Options (Continued)

| Option Name | Pins/Function Affected | Values (default) | Description |
| :---: | :---: | :---: | :---: |
| GWE_cycle | All flip-flops, LUT RAMs, and SRL16 shift registers, Block RAM, Configuration Startup | $\begin{gathered} 1,2,3,4 \\ 5, \underline{6} \end{gathered}$ | Selects the Configuration Startup phase that asserts the internal write-enable signal to all flip-flops, LUT RAMs and shift registers (SRL16). It also enables block RAM read and write operations. See Start-Up, page 91. |
|  |  | Done | Waits for the DONE pin input to go High before asserting the internal write-enable signal to all flip-flops, LUT RAMs and shift registers (SRL16). Block RAM read and write operations are enabled at this time. |
|  |  | Keep | Retains the current GWE_cycle setting for partial reconfiguration applications. |
| GTS_cycle | All I/O pins, Configuration | $\begin{gathered} 1,2,3,4 \\ \underline{5}, 6 \end{gathered}$ | Selects the Configuration Startup phase that releases the internal three-state control, holding all I/O buffers in high-impedance (Hi-Z). Output buffers actively drive, if so configured, after this point. See Start-Up, page 91. |
|  |  | Done | Waits for the DONE pin input to go High before releasing the internal three-state control, holding all I/O buffers in high-impedance (Hi-Z). Output buffers actively drive, if so configured, after this point. |
|  |  | Keep | Retains the current GTS_cycle setting for partial reconfiguration applications. |
| LCK_cycle | DCMs, Configuration Startup | NoWait | The FPGA does not wait for selected DCMs to lock before completing configuration. |
|  |  | $\begin{gathered} 0,1,2,3 \\ 4,5,6 \end{gathered}$ | If one or more DCMs in the design have the STARTUP_WAIT attribute set to TRUE, the FPGA waits for such DCMs to acquire their respective input clock and assert their LOCKED output. This setting selects the Configuration Startup phase where the FPGA waits for the DCMs to lock. |
| DonePin | DONE pin | Pullup | Internally connects a pull-up resistor between DONE pin and VCCAUX. An external $330 \Omega$ pull-up resistor to VCCAUX is still recommended. |
|  |  | Pullnone | No internal pull-up resistor on DONE pin. An external $330 \Omega$ pull-up resistor to VCCAUX is required. |
| DriveDone | DONE pin | No | When configuration completes, the DONE pin stops driving Low and relies on an external $330 \Omega$ pull-up resistor to VCCAUX for a valid logic High. |
|  |  | Yes | When configuration completes, the DONE pin actively drives High. When using this option, an external pull-up resistor is no longer required. Only one device in an FPGA daisy-chain should use this setting. |
| DonePipe | DONE pin | No | The input path from DONE pin input back to the Startup sequencer is not pipelined. |
|  |  | Yes | This option adds a pipeline register stage between the DONE pin input and the Startup sequencer. Used for high-speed daisy-chain configurations when DONE cannot rise in a single CCLK cycle. Releases GWE and GTS signals on the first rising edge of StartupClk after the DONE pin input goes High. |
| ProgPin | PROG_B pin | Pullup | Internally connects a pull-up resistor or between PROG_B pin and VCCAUX. An external $4.7 \mathrm{k} \Omega$ pull-up resistor to VCCAUX is still recommended. |
|  |  | Pullnone | No internal pull-up resistor on PROG_B pin. An external $4.7 \mathrm{k} \Omega$ pull-up resistor to VCCAUX is required. |
| TckPin | JTAG TCK pin | Pullup | Internally connects a pull-up resistor between JTAG TCK pin and VCCAUX. |
|  |  | Pulldown | Internally connects a pull-down resistor between JTAG TCK pin and GND. |
|  |  | Pullnone | No internal pull-up resistor on JTAG TCK pin. |
| TdiPin | JTAG TDI pin | Pullup | Internally connects a pull-up resistor between JTAG TDI pin and VCCAUX. |
|  |  | Pulldown | Internally connects a pull-down resistor between JTAG TDI pin and GND. |
|  |  | Pullnone | No internal pull-up resistor on JTAG TDI pin. |

Table 57: Spartan-3E FPGA Bitstream Generator (BitGen) Options (Continued)

| Option Name | Pins/Function Affected | Values (default) | Description |
| :---: | :---: | :---: | :---: |
| TdoPin | JTAG TDO pin | Pullup | Internally connects a pull-up resistor between JTAG TDO pin and VCCAUX. |
|  |  | Pulldown | Internally connects a pull-down resistor between JTAG TDO pin and GND. |
|  |  | Pullnone | No internal pull-up resistor on JTAG TDO pin. |
| TmsPin | JTAG TMS pin | Pullup | Internally connects a pull-up resistor between JTAG TMS pin and VCCAUX. |
|  |  | Pulldown | Internally connects a pull-down resistor between JTAG TMS pin and GND. |
|  |  | Pullnone | No internal pull-up resistor on JTAG TMS pin. |
| UserID | JTAG User ID register | User string | The 32-bit JTAG User ID register value is loaded during configuration. The default value is all ones, 0xFFFF_FFFF hexadecimal. To specify another value, enter an 8-character hexadecimal value. |
| Security | JTAG, SelectMAP, Readback, Partial reconfiguration | None | Readback and partial reconfiguration are available via the JTAG port or via the SelectMAP interface, if the Persist option is set to Yes. |
|  |  | Level1 | Readback function is disabled. Partial reconfiguration is still available via the JTAG port or via the SelectMAP interface, if the Persist option is set to Yes. |
|  |  | Level | Readback function is disabled. Partial reconfiguration is disabled. |
| CRC | Configuration | Enable | Default. Enable CRC checking on the FPGA bitstream. If error detected, FPGA asserts INIT_B Low and DONE pin stays Low. |
|  |  | Disable | Turn off CRC checking. |
| Persist | SelectMAP interface pins, BPI mode, Slave mode, Configuration | No | All BPI and Slave mode configuration pins are available as user-l/O after configuration. |
|  |  | Yes | This option is required for Readback and partial reconfiguration using the SelectMAP interface. The SelectMAP interface pins (see Slave Parallel Mode, page 79) are reserved after configuration and are not available as user-1/O. |

## Powering Spartan-3E FPGAs

## Voltage Supplies

Like Spartan-3 FPGAs, Spartan-3E FPGAs have multiple voltage supply inputs, as shown in Table 58. There are two supply inputs for internal logic functions, $\mathrm{V}_{\mathrm{CCINT}}$ and
$\mathrm{V}_{\text {CCAUX }}$. Each of the four I/O banks has a separate $\mathrm{V}_{\text {CCO }}$ supply input that powers the output buffers within the associated I/O bank. All of the $\mathrm{V}_{\mathrm{CCO}}$ connections to a specific I/O bank must be connected and must connect to the same voltage.

## Table 58: Spartan-3E Voltage Supplies

| Supply Input | Description | Nominal Supply Voltage |
| :---: | :---: | :---: |
| VCCINT | Internal core supply voltage. Supplies all internal logic functions such as CLBs, block RAM, multipliers, etc. Input to Power-On Reset (POR) circuit. | 1.2 V |
| VCCAUX | Auxiliary supply voltage. Supplies Digital Clock Managers (DCMs), differential drivers, dedicated configuration pins, JTAG interface. Input to Power-On Reset (POR) circuit. | 2.5 V |
| VCCO_0 | Supplies the output buffers in I/O Bank 0, the bank along the top edge of the FPGA. | Selectable, 3.3V, 3.0V, <br> $2.5 \mathrm{~V}, 1.8,1.5 \mathrm{~V}$, or 1.2 V . |
| VCCO_1 | Supplies the output buffers in I/O Bank 1, the bank along the right edge of the FPGA. In Byte-Wide Peripheral Interface (BPI) Parallel Flash Mode, connects to the save voltage as the Flash PROM. | Selectable, 3.3V, 3.0V, $2.5 \mathrm{~V}, 1.8,1.5 \mathrm{~V}$, or 1.2 V . |
| VCCO_2 | Supplies the output buffers in I/O Bank 2 the bank along the bottom edge of the FPGA. Connects to the same voltage as the FPGA configuration source. Input to Power-On Reset (POR) circuit. | Selectable, 3.3V, 3.0V, $2.5 \mathrm{~V}, 1.8,1.5 \mathrm{~V}$, or 1.2 V . |
| VCCO_3 | Supplies the output buffers in I/O Bank 0, the bank along the top edge of the FPGA. | Selectable, $3.3 \mathrm{~V}, 3.0 \mathrm{~V}$, <br> $2.5 \mathrm{~V}, 1.8,1.5 \mathrm{~V}$, or 1.2 V . |

In a 3.3V-only application, all four $\mathrm{V}_{\mathrm{CcO}}$ supplies connect to $3.3 V$. However, Spartan-3E FPGAs provide the ability to bridge between different I/O voltages and standards by applying different voltages to the $\mathrm{V}_{\mathrm{CCO}}$ inputs of different banks. Refer to I/O Banking Rules for which I/O standards can be intermixed within a single I/O bank.
Each I/O bank also has an separate, optional input voltage reference supply, called VREF. If the I/O bank includes an I/O standard that requires a voltage reference such as HSTL or SSTL, then all VREF pins within the I/O bank must be connected to the same voltage.

## Voltage Regulators

Various power supply manufacturers offer complete power solutions for Xilinx FPGAs including some with integrated
three-rail regulators specifically designed for Spartan-3 and Spartan-3E FPGAs. The Xilinx Power Corner web site provides links to vendor solution guides and Xilinx power estimation and analysis tools.

## Power Distribution System (PDS) Design and Decoupling/Bypass Capacitors

Good power distribution system (PDS) design is important for all FPGA designs, but especially so for high performance applications, greater than 100 MHz . Proper design results in better overall performance, lower clock and DCM jitter, and a generally more robust system. Before designing the printed circuit board (PCB) for the FPGA design, please review XAPP623: "Power Distribution System (PDS) Design: Using Bypass/Decoupling Capacitors".

## 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 | Updated Figure 42. Modified title on Table 33 and Table 39. |

## The Spartan-3E Family Data Sheet

DS312-1, Spartan-3E FPGA Family: Introduction and Ordering Information (Module 1)
DS312-2, Spartan-3E FPGA Family: Functional Description (Module 2)
DS312-3, Spartan-3E FPGA Family: DC and Switching Characteristics (Module 3)
DS312-4, Spartan-3E FPGA Family: Pinout Descriptions (Module 4)

# Spartan-3E FPGA Family: DC and Switching Characteristics 

## DC Electrical Characteristics

In this section, specifications may be designated as Advance, Preliminary, or Production. These terms are defined as follows:
Advance: Initial estimates are based on simulation, early characterization, and/or extrapolation from the characteristics of other families. Values are subject to change. Use as estimates, not for production.
Preliminary: Based on characterization. Further changes are not expected.
Production: These specifications are approved once the silicon has been characterized over numerous production lots. Parameter values are considered stable with no future changes expected.

## Advance Product Specification

## Table 1: Absolute Maximum Ratings

| Symbol | Description | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CCINT }}$ | Internal supply voltage |  | -0.5 | 1.32 | V |
| $\mathrm{V}_{\text {CCAUX }}$ | Auxiliary supply voltage |  | -0.5 | 3.00 | V |
| $\mathrm{V}_{\text {CCO }}$ | Output driver supply voltage |  | -0.5 | 3.75 | V |
| $\mathrm{V}_{\text {REF }}$ | Input reference voltage |  | -0.5 | $\mathrm{V}_{\mathrm{CCO}}+0.5^{(3)}$ | V |
| $\mathrm{V}_{\text {IN }}{ }^{(2)}$ | Voltage applied to all User I/O pins and Dual-Purpose pins | Driver in a high-impedance state | -0.5 | $\mathrm{V}_{\mathrm{CCO}}+0.5^{(3)}$ | V |
|  | Voltage applied to all Dedicated pins |  | -0.5 | $\mathrm{V}_{\text {CCAUX }}+0.5^{(4)}$ | V |
| $\mathrm{V}_{\text {ESD }}$ | Electrostatic Discharge Voltage | Human body model | -2000 | +2000 | V |
|  |  | Charged device model | -500 | +500 | V |
|  |  | Machine model | -200 | +200 | V |
| $\mathrm{T}_{J}$ | Junction temperature |  | - | 125 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {STG }}$ | Storage temperature |  | -65 | 150 | ${ }^{\circ} \mathrm{C}$ |

## Notes:

1. Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. These are stress ratings only; functional operation of the device at these or any other conditions beyond those listed under the Recommended Operating Conditions is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time adversely affects device reliability.
2. As a rule, the $V_{I N}$ limits apply to both the $D C$ and $A C$ components of signals. Simple application solutions are available that show how to handle overshoot/undershoot as well as achieve PCI compliance. Refer to the following application notes: "Virtex ${ }^{\text {TM }}$-II Pro and Spartan-3 3.3V PCI Reference Design" (XAPP653) and "Using 3.3V I/O Guidelines in a Virtex-II Pro Design" (XAPP659).
3. Each of the User I/O and Dual-Purpose pins is associated with one of the four banks' $\mathrm{V}_{\mathrm{CcO}}$ rails. Meeting the $\mathrm{V}_{\mathbb{I N}}$ max limit ensures that the internal diode junctions that exist between these pins and their associated $\mathrm{V}_{\mathrm{CcO}}$ rails do not turn on. Table 4 specifies the $\mathrm{V}_{\text {cco }}$ range used to determine the max limit. When $\mathrm{V}_{\mathrm{CCO}}$ is at its maximum recommended operating level ( 3.45 V ), $\mathrm{V}_{\text {IN }}$ max is 3.95 V . The maximum voltage that avoids oxide stress is $\mathrm{V}_{\mathrm{INX}}=4.05 \mathrm{~V}$. As long as the $\mathrm{V}_{\mathrm{IN}}$ max specification is met, oxide stress is not possible.
4. All Dedicated pins (PROG_B, DONE, TCK, TDI, TDO, and TMS) draw power from the $\mathrm{V}_{\text {ccaux }}$ rail ( 2.5 V ). Meeting the $\mathrm{V}_{\text {IN }}$ max limit ensures that the internal diode junctions that exist between each of these pins and the $V_{c c a u x}$ rail do not turn on. Table 4 specifies the $V_{\text {ccaux }}$ range used to determine the max limit. When $\mathrm{V}_{\text {CCAU }}$ is at its maximum recommended operating level ( 2.625 V ), $\mathrm{V}_{\text {IN }} \mathrm{max}<3.125 \mathrm{~V}$. As long as the $\mathrm{V}_{\text {IN }}$ max specification is met, oxide stress is not possible.
5. For soldering guidelines, see "Device Packaging and Thermal Characteristics" at www.xilinx.com/bvdocs/userguides/ug112.pdf. Also see "Implementation and Solder Reflow Guidelines for Pb-Free Packages" at www.xilinx.com/bvdocs/appnotes/xapp427.pdf.

Table 2: Supply Voltage Thresholds for Power-On Reset

| Symbol | Description | Min | Max | Units |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CCINTT }}$ | Threshold for the $\mathrm{V}_{\text {CCINT }}$ supply | 0.4 | 1.0 | V |
| $\mathrm{~V}_{\text {CCAUXT }}$ | Threshold for the $\mathrm{V}_{\text {CCAUX }}$ supply | 0.8 | 2.0 | V |
| $\mathrm{~V}_{\text {CCO2T }}$ | Threshold for the $\mathrm{V}_{\text {CCO }}$ Bank 2 supply | 0.4 | 1.0 | V |

## Notes:

1. $\mathrm{V}_{\text {CCINT }}, \mathrm{V}_{\text {CCAUX }}$, and $\mathrm{V}_{\text {CCO }}$ supplies may be applied in any order.
2. To ensure successful power-on, $\mathrm{V}_{\mathrm{CCINT}}, \mathrm{V}_{\mathrm{CCO}}$ Bank 2 , and $\mathrm{V}_{\mathrm{CCAUX}}$ supplies must rise through their respective threshold-voltage ranges with no dips at any point.

Table 3: Power Voltage Levels Necessary for Preserving RAM Contents

| Symbol | Description | Min | Units |
| :---: | :--- | :---: | :---: |
| $\mathrm{V}_{\text {DRINT }}$ | $\mathrm{V}_{\text {CCINT }}$ level required to retain RAM data | 1.0 | V |
| $\mathrm{~V}_{\text {DRAUX }}$ | $\mathrm{V}_{\text {CCAUX }}$ level required to retain RAM data | 2.0 | V |
| $\mathrm{~V}_{\text {DRO }}$ | $\mathrm{V}_{\text {CCO }}$ level required to retain RAM data | 1.0 | V |

## Notes:

1. RAM contents include configuration data.

## Table 4: General Recommended Operating Conditions

| Symbol | Description |  | Min | Nom | Max | Units |
| :---: | :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{J}$ | Junction temperature | Commercial | 0 | - | 85 | ${ }^{\circ} \mathrm{C}$ |
|  |  | Industrial | -40 | - | 100 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\text {CCINT }}$ | Internal supply voltage | 1.140 | 1.200 | 1.260 | V |  |
| $\mathrm{~V}_{\text {CCO }}{ }^{(1)}$ | Output driver supply voltage | 1.140 | - | 3.450 | V |  |
| $\mathrm{~V}_{\text {CCAUX }}{ }^{(2)}$ | Auxiliary supply voltage | 2.375 | 2.500 | 2.625 | V |  |

## Notes:

1. The $\mathrm{V}_{\mathrm{CcO}}$ range given here spans the lowest and highest operating voltages of all supported I/O standards. The recommended $\mathrm{V}_{\mathrm{CCO}}$ range specific to each of the single-ended I/O standards is given in Table 7, and that specific to the differential standards is given in Table 9.
2. Only during DCM operation, it is recommended that the rate of change of $V_{C C A U X}$ not exceed $10 \mathrm{mV} / \mathrm{ms}$.

Table 5: General DC Characteristics of User I/O, Dual-Purpose, and Dedicated Pins

| Symbol | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{l}^{(2)}$ | Leakage current at User I/O, Dual-Purpose, and Dedicated pins | Driver is in a high-impedance state, $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CCO}}$ max, sample-tested | -10 | - | +10 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {RPU }}{ }^{(3)}$ | Current through pull-up resistor at User I/O, Dual-Purpose, and Dedicated pins | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}, \mathrm{~V}_{\text {CCO }}=3.3 \mathrm{~V}$ |  |  |  | mA |
|  |  | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}, \mathrm{~V}_{\text {CCO }}=3.0 \mathrm{~V}$ |  |  |  | mA |
|  |  | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}, \mathrm{~V}_{\text {CCO }}=2.5 \mathrm{~V}$ |  |  |  | mA |
|  |  | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}, \mathrm{~V}_{\text {CCO }}=1.8 \mathrm{~V}$ |  |  |  | mA |
|  |  | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}, \mathrm{~V}_{\text {CCO }}=1.5 \mathrm{~V}$ |  |  |  | mA |
|  |  | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CCO}}=1.2 \mathrm{~V}$ |  |  |  | mA |
| $\mathrm{I}_{\text {RPD }}{ }^{(3)}$ | Current through pull-down resistor at User I/O, Dual-Purpose, and Dedicated pins | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CCO}}$ |  |  |  | mA |
| $\mathrm{I}_{\text {REF }}$ | $\mathrm{V}_{\text {REF }}$ current per pin | All $\mathrm{V}_{\text {CCO }}$ levels | -10 | - | +10 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input capacitance |  | 3 | - | 10 | pF |

## Notes:

1. The numbers in this table are based on the conditions set forth in Table 4.
2. The $I_{L}$ specification applies to every $/ / O$ pin throughout power-on as long as the voltage on that pin stays between the absolute $\mathbb{V}_{\text {IN }}$ minimum and maximum values (Table 1). For hot-swap applications, at the time of card connection, be sure to keep all I/O voltages within this range before applying $\mathrm{V}_{\mathrm{cco}}$ power. Also consider applying $\mathrm{V}_{\mathrm{cco}}$ power before the connection of data lines occurs. When the FPGA is completely unpowered, the impedance at the I/O pins is high.
3. This parameter is based on characterization. The pull-up resistance $R_{P U}=V_{C C O} / I_{\text {RPU }}$. The pull-down resistance $R_{P D}=V_{\mathbb{I N}} / I_{\text {RPD }}$.

## Table 6: Quiescent Supply Current Characteristics

| Symbol | Description | Device | Typ ${ }^{(4)}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\text {CCINTQ }}$ | Quiescent $\mathrm{V}_{\text {CCINT }}$ supply current | XC3S100E | 15 |  | mA |
|  |  | XC3S250E | 38 |  | mA |
|  |  | XC3S500E | 68 |  | mA |
|  |  | XC3S1200E | 98 |  | mA |
|  |  | XC3S1600E | 108 |  | mA |
| $\mathrm{I}_{\text {ccoo }}$ | Quiescent $\mathrm{V}_{\text {cco }}$ supply current | XC3S100E | 1.0 |  | mA |
|  |  | XC3S250E | 1.5 |  | mA |
|  |  | XC3S500E | 1.7 |  | mA |
|  |  | XC3S1200E | 1.8 |  | mA |
|  |  | XC3S1600E | 2.2 |  | mA |
| I ccauxa | Quiescent $\mathrm{V}_{\text {CCAUX }}$ supply current | XC3S100E | 10 |  | mA |
|  |  | XC3S250E | 15 |  | mA |
|  |  | XC3S500E | 25 |  | mA |
|  |  | XC3S1200E | 35 |  | mA |
|  |  | XC3S1600E | 45 |  | mA |

## Notes:

1. The numbers in this table are based on the conditions set forth in Table 4. Quiescent supply current is measured with all I/O drivers in a high-impedance state and with all pull-up/pull-down resistors at the I/O pads disabled. For typical values, the ambient temperature $\left(T_{A}\right)$ is $25^{\circ} \mathrm{C}$ with $\mathrm{V}_{\mathrm{CCINT}}=1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{CCO}}=2.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{CCAUX}}=2.5 \mathrm{~V}$. The FPGA is programmed with a "blank" configuration data file (i.e., a design with no functional elements instantiated). For conditions other than those described above, (e.g., a design including functional elements), measured quiescent current levels may be higher than the values in the table.
2. There are two recommended ways to estimate the total power consumption (quiescent plus dynamic) for a specific design: a) The Spartan-3E Web Power Tool, a future web-based application, provides quick, approximate, typical estimates, and does not require a netlist of the design. b) XPower, which will be included in a future release of the Xilinx development software, takes a netlist as input to provide more accurate maximum and typical estimates.
3. The maximum numbers in this table indicate the minimum current each power rail requires in order for the FPGA to power-on successfully.
4. All typical quiescent current values are early estimates.

Table 7: Recommended Operating Conditions for User I/Os Using Single-Ended Standards

| IOSTANDARD Attribute | $\mathrm{V}_{\text {Cco }}$ for Drivers ${ }^{(2)}$ |  |  | $V_{\text {REF }}$ |  |  | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min (V) | Nom (V) | Max (V) | Min (V) | Nom (V) | Max (V) | Max (V) | Min (V) |
| HSTL_I_18 | 1.7 | 1.8 | 1.9 | 0.8 | 0.9 | 1.1 | $\mathrm{V}_{\text {REF }}-0.1$ | $\mathrm{V}_{\text {REF }}+0.1$ |
| HSTL_III_18 | 1.7 | 1.8 | 1.9 | - | 1.1 | - | $\mathrm{V}_{\text {REF }}-0.1$ | $\mathrm{V}_{\text {REF }}+0.1$ |
| LVCMOS12 ${ }^{(4)}$ | 1.1 | 1.2 | 1.3 | - | - | - | 0.38 | 0.8 |
| LVCMOS15 ${ }^{(4)}$ | 1.4 | 1.5 | 1.6 | - | - | - | 0.38 | 0.8 |
| LVCMOS18 ${ }^{(4)}$ | 1.65 | 1.8 | 1.95 | - | - | - | 0.38 | 0.8 |
| LVCMOS25(4,5) | 2.3 | 2.5 | 2.7 | - | - | - | 0.7 | 1.7 |
| LVCMOS33 ${ }^{(4)}$ | 3.0 | 3.3 | 3.45 | - | - | - | 0.8 | 2.0 |
| LVTTL | 3.0 | 3.3 | 3.45 | - | - | - | 0.8 | 2.0 |
| PCl33_3 ${ }^{(7)}$ | - | 3.0 | - | - | - | - | 0.9 | 1.5 |
| PCI66_3 ${ }^{(7)}$ | - | 3.0 | - | - | - | - | 0.9 | 1.5 |
| PCIX ${ }^{(7)}$ | - | TBD | - | - | - | - | TBD | TBD |
| SSTL18_I | 1.70 | 1.80 | 1.90 | 0.833 | 0.900 | 0.969 | $\mathrm{V}_{\text {REF }}-0.125$ | $\mathrm{V}_{\text {REF }}+0.125$ |
| SSTL2_I | 2.3 | 2.5 | 2.7 | 1.15 | 1.25 | 1.35 | $\mathrm{V}_{\text {REF }}-0.15$ | $\mathrm{V}_{\text {REF }}+0.15$ |

## Notes:

1. Descriptions of the symbols used in this table are as follows:
$V_{\text {CCO }}$-- the supply voltage for output drivers
$\mathrm{V}_{\text {REF }}$-- the reference voltage for setting the input switching threshold
$V_{\text {IL }}$-- the input voltage that indicates a Low logic level
$\mathrm{V}_{\mathrm{IH}}-$ - the input voltage that indicates a High logic level
2. The $\mathrm{V}_{\mathrm{CCO}}$ rails supply only output drivers, not input circuits.
3. For device operation, the maximum signal voltage ( $\mathrm{V}_{\mathbb{I H}} \max$ ) may be as high as $\mathrm{V}_{\mathbb{I N}}$ max. See Table 1.
4. There is approximately 100 mV of hysteresis on inputs using any LVCMOS standard.
5. All Dedicated pins (PROG_B, DONE, TCK, TDI, TDO, and TMS) use the LVCMOS25 standard and draw power from the $\mathrm{V}_{\text {CCAUX }}$ rail ( 2.5 V ). The Dual-Purpose configuration pins use the LVCMOS25 standard before the User mode. When using these pins as part of a standard 2.5 V configuration interface, apply 2.5 V to the $\mathrm{V}_{\mathrm{cco}}$ lines of Banks 0,1 , and 2 at power-on as well as throughout configuration.
6. The Global Clock Inputs (GCLK0-GCLK15, RHCLK0-RHCLK7, and LHCLKO-LHCLK7) are Dual-Purpose pins to which any signal standard may be assigned.
7. For more information, see "Virtex-II Pro and Spartan-3 3.3V PCI Reference Design" (XAPP653).

Table 8: DC Characteristics of User I/Os Using Single-Ended Standards

| IOSTANDARD Attribute |  | Test Conditions |  | Logic Level Characteristics |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{gathered} \mathrm{I}_{\mathrm{OL}} \\ (\mathrm{~mA}) \end{gathered}$ | $\begin{gathered} \mathrm{I}_{\mathrm{OH}} \\ (\mathrm{~mA}) \end{gathered}$ | $\begin{gathered} \mathrm{V}_{\mathrm{OL}} \\ \operatorname{Max}(\mathrm{~V}) \end{gathered}$ | $\begin{gathered} \mathrm{V}_{\mathrm{OH}} \\ \operatorname{Min}(\mathrm{~V}) \end{gathered}$ |
| HSTL_I_18 |  | 8 | -8 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ |
| HSTL_III_18 |  | 24 | -8 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ |
| LVCMOS12 ${ }^{(3)}$ | 2 | 2 | -2 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ |
| LVCMOS15 ${ }^{(3)}$ | 2 | 2 | -2 | 0.4 | $\mathrm{V}_{\mathrm{CCO}}-0.4$ |
|  | 4 | 4 | -4 |  |  |
|  | 6 | 6 | -6 |  |  |
| LVCMOS18 ${ }^{(3)}$ | 2 | 2 | -2 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ |
|  | 4 | 4 | -4 |  |  |
|  | 6 | 6 | -6 |  |  |
|  | 8 | 8 | -8 |  |  |
| LVCMOS25 ${ }^{(3,4)}$ | 2 | 2 | -2 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ |
|  | 4 | 4 | -4 |  |  |
|  | 6 | 6 | -6 |  |  |
|  | 8 | 8 | -8 |  |  |
|  | 12 | 12 | -12 |  |  |
| LVCMOS33 ${ }^{(3)}$ | 2 | 2 | -2 | 0.4 | $\mathrm{V}_{\text {CCO }}-0.4$ |
|  | 4 | 4 | -4 |  |  |
|  | 6 | 6 | -6 |  |  |
|  | 8 | 8 | -8 |  |  |
|  | 12 | 12 | -12 |  |  |
|  | 16 | 16 | -16 |  |  |
| $\operatorname{LVTTL}^{(3)}$ | 2 | 2 | -2 | 0.4 | 2.4 |
|  | 4 | 4 | -4 |  |  |
|  | 6 | 6 | -6 |  |  |
|  | 8 | 8 | -8 |  |  |
|  | 12 | 12 | -12 |  |  |
|  | 16 | 16 | -16 |  |  |
| PCl33_3 ${ }^{(5)}$ |  | 1.5 | -0.5 | $0.10 \mathrm{~V}_{\text {cco }}$ | $0.90 \mathrm{~V}_{\text {cco }}$ |
| PCI66_3 ${ }^{(5)}$ |  | 1.5 | -0.5 | $0.10 \mathrm{~V}_{\text {CCO }}$ | $0.90 \mathrm{~V}_{\text {cco }}$ |
| PCIX |  | TBD | TBD | TBD | TBD |
| SSTL18_I |  | 6.7 | -6.7 | $\mathrm{V}_{\mathrm{TT}}-0.475$ | $\mathrm{V}_{\mathrm{TT}}+0.475$ |

Table 8: DC Characteristics of User I/Os Using Single-Ended Standards (Continued)

|  | Test Conditions |  | Logic Level Characteristics |  |
| :--- | :---: | :---: | :---: | :---: |
|  | $\mathrm{I}_{\mathrm{OL}}$ <br> $(\mathrm{mA})$ | $\mathrm{I}_{\mathrm{OH}}$ <br> $(\mathrm{mA})$ | $\mathrm{V}_{\mathrm{OL}}$ <br> IOSTANDARD Attribute | 8.1 |

## Notes:

1. The numbers in this table are based on the conditions set forth in Table 4 and Table 7.
2. Descriptions of the symbols used in this table are as follows:
$\mathrm{I}_{\mathrm{OL}}-$ - the output current condition under which $\mathrm{V}_{\mathrm{OL}}$ is tested
$\mathrm{I}_{\mathrm{OH}}-$ - the output current condition under which $\mathrm{V}_{\mathrm{OH}}$ is tested
$\mathrm{V}_{\mathrm{OL}}$-- the output voltage that indicates a Low logic level
$\mathrm{V}_{\mathrm{OH}}-$ - the output voltage that indicates a High logic level
$\mathrm{V}_{\mathrm{IL}}$-- the input voltage that indicates a Low logic level
$\mathrm{V}_{1 \mathrm{H}^{--}}$the input voltage that indicates a High logic level
$\mathrm{V}_{\mathrm{CCO}}-$ - the supply voltage for output drivers
$\mathrm{V}_{\text {REF }}$-- the reference voltage for setting the input switching threshold
$V_{T T}$-- the voltage applied to a resistor termination
3. For the LVCMOS and LVTTL standards: the same $\mathrm{V}_{\mathrm{OL}}$ and $\mathrm{V}_{\mathrm{OH}}$ limits apply for both the Fast and Slow slew attributes.
4. All Dedicated output pins (DONE and TDO) as well as Dual-Purpose totem-pole output pins (CCLK, D0-D7, BUSY/DOUT, CSO_B, MOSI, HDC, LDC0-LDC2, and A0-A23) exhibit the characteristics of LVCMOS25 with Slow slew rate; all have 8 mA drive except CCLK, which has 12 mA drive.
5. Tested according to the relevant PCI specifications. For more information, see "Virtex-II Pro and Spartan-3 3.3V PCI Reference Design" (XAPP653).

$\mathrm{V}_{\text {ICM }}=$ Input common mode voltage $=\frac{\mathrm{V}_{\text {INP }}+\mathrm{V}_{\text {INN }}}{2}$
$\mathrm{V}_{\mathrm{ID}}=$ Differential input voltage $=\left|\mathrm{V}_{\mathrm{INP}}-\mathrm{V}_{\mathrm{INN}}\right|$

Figure 1: Differential Input Voltages

Table 9: Recommended Operating Conditions for User I/Os Using Differential Signal Standards

| IOSTANDARD <br> Attribute | $\mathrm{V}_{\text {cco }}$ for Drivers ${ }^{(1)}$ |  |  | $V_{\text {ID }}$ |  |  | $V_{\text {ICM }}$ |  |  | $\mathrm{V}_{\mathrm{IH}}$ |  | $\mathrm{V}_{\text {IL }}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min <br> (V) | Nom (V) | Max <br> (V) | $\begin{gathered} \operatorname{Min} \\ (\mathrm{mV}) \end{gathered}$ | $\begin{aligned} & \text { Nom } \\ & \text { (mV) } \end{aligned}$ | $\begin{aligned} & \operatorname{Max} \\ & (\mathrm{mV}) \end{aligned}$ | Min <br> (V) | Nom (V) | Max <br> (V) | Min <br> (V) | Max <br> (V) | Min <br> (V) | Max (V) |
| LVDS_25 | 2.375 | 2.50 | 2.625 | 100 | 350 | 600 | 0.30 | 1.25 | 2.20 | - | - | - | - |
| BLVDS_25 | 2.375 | 2.50 | 2.625 | 100 | 350 | 600 | 0.30 | 1.25 | 2.20 | - | - | - | - |
| MINI_LVDS_25 | 2.375 | 2.50 | 2.625 | 200 | - | 600 | 0.30 | - | 2.2 |  |  |  |  |
| LVPECL_25 ${ }^{(2)}$ | Inputs Only |  |  | 100 | 800 | 1000 | 0.3 | 1.2 | 2.2 | 0.8 | 2.0 | 0.5 | 1.7 |
| RSDS_25 | 2.375 | 2.50 | 2.625 | 100 | 200 | - | 0.3 | 1.20 | 1.4 | - | - | - | - |

## Notes:

1. The $\mathrm{V}_{\mathrm{CCO}}$ rails supply only differential output drivers, not input circuits.
2. Spartan-3E devices support this standard for inputs only, not for outputs.
3. $V_{\text {REF }}$ inputs are not used for any of the differential I/O standards.


$$
\begin{aligned}
\mathrm{V}_{\mathrm{OCM}} & =\text { Output common mode voltage }=\frac{\mathrm{V}_{\text {OUTP }}+\mathrm{V}_{\text {OUTN }}}{2} \\
\mathrm{~V}_{\mathrm{OD}} & =\text { Output differential voltage }=\left|\mathrm{V}_{\text {OUTP }}-\mathrm{V}_{\text {OUTN }}\right| \\
\mathrm{V}_{\mathrm{OH}} & =\text { Output voltage indicating a High logic level } \\
\mathrm{V}_{\mathrm{OL}} & =\text { Output voltage indicating a Low logic level }
\end{aligned}
$$

Figure 2: Differential Output Voltages

Table 10: DC Characteristics of User I/Os Using Differential Signal Standards

| IOSTANDARD Attribute | $\mathrm{V}_{\mathrm{OD}}$ |  |  | $\Delta \mathbf{V}_{\text {OD }}$ |  | $\mathrm{V}_{\text {OCM }}$ |  |  | $\Delta \mathrm{V}_{\text {OCM }}$ |  | $\mathrm{V}_{\mathrm{OH}}$ <br> Min <br> (V) | $\mathrm{V}_{\mathrm{OL}}$ <br> Max <br> (V) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { Min } \\ & (\mathrm{mV}) \end{aligned}$ | $\begin{aligned} & \text { Typ } \\ & \text { (mV) } \end{aligned}$ | $\begin{aligned} & \operatorname{Max} \\ & (\mathrm{mV}) \end{aligned}$ | $\begin{aligned} & \operatorname{Min} \\ & (\mathrm{mV}) \end{aligned}$ | $\begin{aligned} & \operatorname{Max} \\ & (\mathrm{mV}) \end{aligned}$ | Min <br> (V) | Typ (V) | Max (V) | $\begin{aligned} & \operatorname{Min} \\ & (\mathrm{mV}) \end{aligned}$ | $\begin{aligned} & \operatorname{Max} \\ & (\mathrm{mV}) \end{aligned}$ |  |  |
| LVDS_25 | 250 | 350 | 450 | - | - | 1.125 | - | 1.375 | - | - | 1.25 | 1.25 |
| BLVDS_25 | 250 | 350 | 450 | - | - | - | 1.20 | - | - | - | - | - |
| MINI_LVDS_25 | 300 | - | 600 | - | 50 | 1.0 | - | 1.4 | - | 50 | 1.15 | 1.25 |
| RSDS_25 | 100 | - | 400 | - | - | 1.1 | - | 1.4 | - | - | 1.15 | 1.35 |

## Notes:

1. The numbers in this table are based on the conditions set forth in Table 4 and Table 9.
2. Output voltage measurements for all differential standards are made with a termination resistor $\left(\mathrm{R}_{T}\right)$ of $100 \Omega$ across the N and P pins of the differential signal pair.
3. At any given time, no more than two differential standards may be assigned to each bank.

## Switching Characteristics

All Spartan-3E FPGAs ship in two speed grades: -4 and the higher performance -5 . Switching characteristics in this document may be designated as Advance, Preliminary, or Production, as shown in Table 11. Each category is defined as follows:
Advance: These specifications are based on simulations only and are typically available soon after establishing FPGA specifications. Although speed grades with this designation are considered relatively stable and conservative, some under-reporting might still occur.
Preliminary: These specifications are based on complete early silicon characterization. Devices and speed grades with this designation are intended to give a better indication of the expected performance of production silicon. The probability of under-reporting preliminary delays is greatly reduced compared to Advance data.
Production: These specifications are approved once enough production silicon of a particular device family member has been characterized to provide full correlation between speed files and devices over numerous production lots. There is no under-reporting of delays, and customers receive formal notification of any subsequent changes. Typically, the slowest speed grades transition to Production before faster speed grades.
Production-quality systems must use FPGA designs compiled using a speed file designated as Production status. FPGAs designs using a less mature speed file designation should only be used during system prototyping or pre-production qualification. FPGA designs with speed files designated as Preview, Advance, or Preliminary should not be used in a production-quality system.
Whenever a speed file designation changes, as a device matures toward Production status, Xilinx recommends rerunning the Xilinx ISE software on the FPGA design. This ensures that the FPGA design incorporates the latest timing information and software updates.
All specified limits are representative of worst-case supply voltage and junction temperature conditions. Unless otherwise noted, the following applies: Parameter values apply to all Spartan-3E devices. All parameters representing voltages are measured with respect to GND.
Timing parameters and their representative values are selected for inclusion below either because they are important as general design requirements or they indicate fundamental device performance characteristics. The Spartan-3E speed files (v1.10), part of the Xilinx Development Software, are the original source for many but not all of the values. The speed grade designations for these files are shown in Table 11. For more complete, more precise, and worst-case
data, use the values reported by the Xilinx static timing analyzer (TRACE in the Xilinx development software) and back-annotated to the simulation netlist.

Table 11: Spartan-3E v1.10 Speed Grade Designations

| Device | Preview | Advance | Preliminary | Production |
| :---: | :---: | :--- | :--- | :--- |
| XC3S100E | -4 |  |  |  |
| XC3S250E | -4 |  |  |  |
| XC3S500E | -4 |  |  |  |
| XC3S1200E | -4 |  |  |  |
| XC3S1600E | -4 |  |  | Production |
| System <br> Usage | Prototyping Only |  |  |  |

## Digital Clock Manager (DCM) Timing

For specification purposes, the DCM consists of three key components: the Delay-Locked Loop (DLL), the Digital Frequency Synthesizer (DFS), and the Phase Shifter (PS).
Aspects of DLL operation play a role in all DCM applications. All such applications inevitably use the CLKIN and the CLKFB inputs connected to either the CLKO or the CLK2X feedback, respectively. Thus, specifications in the DLL tables (Table 12 and Table 13) apply to any application that only employs the DLL component. When the DFS and/or the PS components are used together with the DLL, then the specifications listed in the DFS and PS tables supersede any corresponding ones in the DLL tables. (See Table 14 and Table 15 for the DFS; tables for the PS are not yet available.) DLL specifications that do not change with the addition of DFS or PS functions are presented in Table 12 and Table 13.
All DCM clock output signals exhibit an approximate duty cycle of $50 \%$.
Period jitter and cycle-cycle jitter are two (of many) different ways of characterizing clock jitter. Both specifications describe statistical variation from a mean value.
Period jitter is the worst-case deviation from the average clock period of all clock cycles in the collection of clock periods sampled (usually from 100,000 to more than a million samples for specification purposes). In a histogram of period jitter, the mean value is the clock period.
Cycle-cycle jitter is the worst-case difference in clock period between adjacent clock cycles in the collection of clock periods sampled. In a histogram of cycle-cycle jitter, the mean value is zero.

Table 12: Recommended Operating Conditions for the DLL

| Symbol |  | Description | Speed Grade |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | -5 | -4 |  |  |
|  |  | Min | Max | Min | Max |  |
| Input Frequency Ranges |  |  |  |  |  |  |  |
| $\mathrm{F}_{\text {CLKIN }}$ | CLKIN_FREQ_DLL |  | Frequency for the CLKIN input | 5 | 326 | $5{ }^{(2)}$ | 280 | MHz |

## Notes:

1. DLL specifications apply when any of the DLL outputs (CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, or CLKDV) are in use.
2. Use of the DFS permits lower F CLKIN frequencies. See Table 14.

## Table 13: Switching Characteristics for the DLL

| Symbol | Description | Speed Grade |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | -5 |  | -4 |  |  |
|  |  | Min | Max | Min | Max |  |
| Output Frequency Ranges |  |  |  |  |  |  |
| CLKOUT_FREQ_1X | Frequency for the CLK0 and CLK180 outputs | 5 | 326 | 5 | 280 | MHz |
|  | Frequency for the CLK90 and CLK270 outputs | 5 | 165 | 5 | 165 | MHz |
| CLKOUT_FREQ_2X | Frequency for the CLK2X and CLK2X180 outputs | 10 | 400 | 10 | 330 | MHz |

## Notes:

1. The numbers in this table are based on the operating conditions set forth in Table 4 and Table 12.
2. DLL specifications apply when any of the DLL outputs (CLK0, CLK90, CLK180, CLK270, CLK2X, CLK2X180, or CLKDV) are in use.

Table 14: Recommended Operating Conditions for the DFS

| Symbol |  | Description | Speed Grade |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | -5 | -4 |  |  |
|  |  | Min | Max | Min | Max |  |
| Input Frequency Ranges ${ }^{(2)}$ |  |  |  |  |  |  |  |
| $\mathrm{F}_{\text {CLKIN }}$ | CLKIN_FREQ_FX |  | Frequency for the CLKIN input | 0.2 | 326 | 0.2 | 326 | MHz |

## Notes:

1. DFS specifications apply when either of the DFS outputs (CLKFX or CLKFX180) are in use.
2. If both DFS and DLL outputs are used on the same DCM, follow the more restrictive CLKIN_FREQ_DLL specifications in Table 12.

Table 15: Switching Characteristics for the DFS

| Symbol | Description | Speed Grade |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | -5 |  | -4 |  |  |
|  |  | Min | Max | Min | Max |  |
| Output Frequency Ranges |  |  |  |  |  |  |
| CLKOUT_FREQ_FX | Frequency for the CLKFX and CLKFX180 outputs | 5 | 326 | 5 | 280 | MHz |

## Notes:

1. The numbers in this table are based on the operating conditions set forth in Table 4 and Table 14.
2. DFS specifications apply when either of the DFS outputs (CLKFX or CLKFX180) is in use.

## Configuration and JTAG Timing



## Notes:

1. The $\mathrm{V}_{\mathrm{CCINT}}, \mathrm{V}_{\mathrm{CCAUX}}$, and $\mathrm{V}_{\mathrm{CCO}}$ supplies may be applied in any order.
2. The Low-going pulse on PROG_B is optional after power-on but necessary for reconfiguration without a power cycle.
3. The rising edge of INIT_B samples the voltage levels applied to the mode pins ( $\mathrm{M} 0-\mathrm{M} 2$ ).

Figure 3: Waveforms for Power-On and the Beginning of Configuration
Table 16: Power-On Timing and the Beginning of Configuration

| Symbol | Description | Device | All Speed Grades |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |
| $\mathrm{T}_{\mathrm{POR}}{ }^{(2)}$ | The time from the application of $\mathrm{V}_{\mathrm{CCINT}}, \mathrm{V}_{\mathrm{CCAUX}}$, and $\mathrm{V}_{\mathrm{CCO}}$ Bank 2 supply voltage ramps (whichever occurs last) to the rising transition of the INIT_B pin | XC3S100E | - | 5 | ms |
|  |  | XC3S250E | - | 5 | ms |
|  |  | XC3S500E | - | 5 | ms |
|  |  | XC3S1200E | - | 5 | ms |
|  |  | XC3S1600E | - | 7 | ms |
| TPROG | The width of the low-going pulse on the PROG_B pin | All | 0.3 | - | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\mathrm{PL}}{ }^{(2)}$ | The time from the rising edge of the PROG_B pin to the rising transition on the INIT_B pin | XC3S100E | - | 2 | ms |
|  |  | XC3S250E | - | 2 | ms |
|  |  | XC3S500E | - | 2 | ms |
|  |  | XC3S1200E | - | 2 | ms |
|  |  | XC3S1600E | - | 3 | ms |
| $\mathrm{T}_{\text {ICCK }}{ }^{(3)}$ | The time from the rising edge of the INIT_B pin to the generation of the configuration clock signal at the CCLK output pin | All | 0.5 | 4.0 | $\mu \mathrm{s}$ |

## Notes:

1. The numbers in this table are based on the operating conditions set forth in Table 4. This means power must be applied to all $\mathrm{V}_{\mathrm{CCINT}}, \mathrm{V}_{\mathrm{CCO}}$, and $V_{\text {CCAUX }}$ lines.
2. Power-on reset and the clearing of configuration memory occurs during this period.
3. This specification applies only to the Master Serial, SPI, BPI-Up, and BPI-Down modes.


Figure 4: Waveforms for Master and Slave Serial Configuration
Table 17: Timing for the Master and Slave Serial Configuration Modes

| Symbol | Description |  | Slave/ Master | All Speed Grades |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |
| Clock-to-Output Times |  |  |  |  |  |  |
| T CcO | The time from the falling transition on the CCLK pin to data appearing at the DOUT pin |  |  | Both | 1.5 | 12.0 | ns |
| Setup Times |  |  |  |  |  |  |
| $\mathrm{T}_{\text {DCC }}$ | The time from the setup of data at the DIN pin to the rising transition at the CCLK pin |  | Both | 10.0 | - | ns |
| Hold Times |  |  |  |  |  |  |
| $\mathrm{T}_{\text {CCD }}$ | The time from the rising transition at the CCLK pin to the point when data is last held at the DIN pin |  | Both | 0 | - | ns |
| Clock Timing |  |  |  |  |  |  |
| $\mathrm{T}_{\text {CCH }}$ | The High pulse width at the CCLK input pin |  | Slave | 5.0 | - | ns |
| $\mathrm{T}_{\text {CCL }}$ | The Low pulse width at the CCLK input pin |  |  | 5.0 | - | ns |
| $\mathrm{F}_{\text {CCSER }}$ | Frequency of the clock signal at the CCLK input pin | No bitstream compression |  | - | $66^{(2)}$ | MHz |
|  |  | With bitstream compression |  | - | 20 | MHz |
| $\Delta \mathrm{F}_{\text {CCSER }}$ | Variation from the CCLK output frequency set using the ConfigRate BitGen option |  | Master | -50\% | +50\% | - |

## Notes:

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


> DS312-3_02_020805

## Notes:

1. It is possible to abort configuration by pulling CS_B Low in a given CCLK cycle, then switching RDWR B Low or High in any subsequent cycle for which CS_B remains Low. The RDWR_B pin asynchronously controls the driver impedance of the D0-D7 bus. When RDWR_B switches High, be careful to avoid contention on the D0-D7 bus.

Figure 5: Waveforms for Slave Parallel Configuration

Table 18: Timing for the Slave Parallel Configuration Mode

| Symbol | Description | All Speed Grades |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| Clock-to-Output Times |  |  |  |  |
| T SMCKBY | The time from the rising transition on the CCLK pin to a signal transition at the BUSY pin | - | 12.0 | ns |
| Setup Times |  |  |  |  |
| $\mathrm{T}_{\text {SMDCC }}$ | The time from the setup of data at the D0-D7 pins to the rising transition at the CCLK pin | 10.0 | - | ns |
| TSMCSCC | The time from the setup of a logic level at the CS_B pin to the rising transition at the CCLK pin | 10.0 | - | ns |
| $\mathrm{T}_{\text {SMCCW }}{ }^{(2)}$ | The time from the setup of a logic level at the RDWR_B pin to the rising transition at the CCLK pin | 10.0 | - | ns |

Table 18: Timing for the Slave Parallel Configuration Mode (Continued)

| Symbol | Description |  |  | All Speed Grades |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Max |  |
| Hold Times |  |  |  |  |  |  |
| $\mathrm{T}_{\text {SMCCD }}$ | The time from the rising transition at the CCLK pin to the point when data is last held at the D0-D7 pins |  |  | 0 | - | ns |
| $\mathrm{T}_{\text {SMCCCS }}$ | The time from the rising transition at the CCLK pin to the point when a logic level is last held at the CS_B pin |  |  | 0 | - | ns |
| $\mathrm{T}_{\text {SMWCC }}$ | The time from the rising transition at the CCLK pin to the point when a logic level is last held at the RDWR_B pin |  |  | 0 | - | ns |
| Clock Timing |  |  |  |  |  |  |
| $\mathrm{T}_{\mathrm{CCH}}$ | The High pulse width at the CCLK input pin |  |  | 5 | - | ns |
| $\mathrm{T}_{\text {CCL }}$ | The Low pulse width at the CCLK input pin |  |  | 5 | - | ns |
| $\mathrm{F}_{\text {CCPAR }}$ | Frequency of the clock signal at the CCLK input pin | No bitstream | Not using the BUSY pin ${ }^{(2)}$ | - | 50 | MHz |
|  |  | compression | Using the BUSY pin | - | 66 | MHz |
|  |  | With bitstream compression |  | - | 20 | MHz |

## Notes:

1. The numbers in this table are based on the operating conditions set forth in Table 4.
2. In the Slave Parallel mode, it is necessary to use the BUSY pin when the CCLK frequency exceeds this maximum specification.
3. Some Xilinx documents may refer to Parallel modes as "SelectMAP" modes.


Figure 6: JTAG Waveforms

Table 19: Timing for the JTAG Test Access Port

| Symbol | Description | All Speed Grades |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| Clock-to-Output Times |  |  |  |  |
| $\mathrm{T}_{\text {TCKTDO }}$ | The time from the falling transition on the TCK pin to data appearing at the TDO pin | 1.0 | 11.0 | ns |
| Setup Times |  |  |  |  |
| $\mathrm{T}_{\text {TDITCK }}$ | The time from the setup of data at the TDI pin to the rising transition at the TCK pin | 7.0 | - | ns |
| $\mathrm{T}_{\text {TMSTCK }}$ | The time from the setup of a logic level at the TMS pin to the rising transition at the TCK pin | 7.0 | - | ns |
| Hold Times |  |  |  |  |
| $\mathrm{T}_{\text {TCKTDI }}$ | The time from the rising transition at the TCK pin to the point when data is last held at the TDI pin | 0 | - | ns |
| $\mathrm{T}_{\text {TCKTMS }}$ | The time from the rising transition at the TCK pin to the point when a logic level is last held at the TMS pin | 0 | - | ns |
| Clock Timing |  |  |  |  |
| $\mathrm{T}_{\text {CCH }}$ | The High pulse width at the TCK pin | 5 | - | ns |
| $\mathrm{T}_{\mathrm{CCL}}$ | The Low pulse width at the TCK pin | 5 | - | ns |
| $\mathrm{F}_{\text {TCK }}$ | Frequency of the TCK signal | - | 33 | MHz |

## Notes:

1. The numbers in this table are based on the operating conditions set forth in Table 4.

## Revision History

The following table shows the revision history for this document.

| Date | Version |  | Revision |
| :---: | :---: | :--- | :--- |
| $03 / 01 / 05$ | 1.0 | Initial Xilinx release. |  |

The Spartan-3E Family Data Sheet
DS312-1, Spartan-3E FPGA Family: Introduction and Ordering Information (Module 1)
DS312-2, Spartan-3E FPGA Family: Functional Description (Module 2)
DS312-3, Spartan-3E FPGA Family: DC and Switching Characteristics (Module 3)
DS312-4, Spartan-3E FPGA Family: Pinout Descriptions (Module 4)

## Spartan-3E FPGA Family: Pinout Descriptions

## Introduction

This section describes the various pins on a Spartan ${ }^{\text {TM }}$-3E FPGA and how they connect within the supported component packages.

## Advance Product Specification

## Pin Types

A majority of the pins on a Spartan-3E FPGA are gen-eral-purpose, user-defined I/O pins. There are, however, up to 11 different functional types of pins on Spartan-3E packages, as outlined in Table 1. In the package footprint drawings that follow, the individual pins are color-coded according to pin type as in the table.

## Table 1: Types of Pins on Spartan-3E FPGAs

| Type / Color Code | Description | Pin Name(s) in Type |
| :---: | :---: | :---: |
| I/O | Unrestricted, general-purpose user-I/O pin. Most pins can be paired together to form differential I/Os. | $\begin{aligned} & \text { IO } \\ & \text { IO_Lxxy_\# } \end{aligned}$ |
| INPUT | Unrestricted, general-purpose input-only pin. This pin does not have an output structure. | $\begin{aligned} & \text { IP } \\ & \text { IP_Lxxy_\# } \end{aligned}$ |
| DUAL | Dual-purpose pin used in some configuration modes during the configuration process and then usually available as a user I/O after configuration. If the pin is not used during configuration, this pin behaves as an I/O-type pin. Some of the dual-purpose pins are also global or edge clock inputs (GCLK). | M[2:0] <br> HSWAP <br> CCLK <br> MOSI/CSI_B <br> D[7:1] <br> D0/DIN <br> CSO_B <br> RDWR B <br> BUSY/DOUT <br> INIT_B <br> A[23:20] <br> A19/VS2 <br> A18/VS1 <br> A17/VS0 <br> A[16:0] <br> LDC[2:0] <br> HDC |
| VREF | Dual-purpose pin that is either a user-I/O pin or, along with all other VREF pins in the same bank, provides a reference voltage input for certain I/O standards. If used for a reference voltage within a bank, all VREF pins within the bank must be connected. | IP/VREF_\# IP_Lxx_\#/VREF_\# |
| $\begin{aligned} & \text { GCLK } \\ & \text { LHCLK } \\ & \text { RHCLK } \end{aligned}$ | Either a user-I/O pin or an input to a specific clock buffer driver. Every package has 16 global clock inputs that optionally clock the entire device. The RHCLK inputs optionally clock the right-hand side of the device. The LHCLK inputs optionally clock the left-hand side of the device. Some of the clock pins are shared with the dual-purpose configuration pins and are considered DUAL-type. | $\begin{aligned} & \text { GCLK[15:0], } \\ & \text { LHCLK[7:0], } \\ & \text { RHCLK[7:0] } \end{aligned}$ |
| CONFIG | Dedicated configuration pin. Not available as a user-I/O pin. Every package has two dedicated configuration pins. These pins are powered by VCCAUX. | DONE, PROG_B |

Table 1: Types of Pins on Spartan-3E FPGAs

| Type / <br> Color Code | Description | Pin Name(s) in Type |
| :--- | :--- | :--- |
| JTAG | Dedicated JTAG pin. Not available as a user-I/O pin. Every package has four <br> dedicated JTAG pins. These pins are powered by VCCAUX. | TDI, TMS, TCK, TDO |
| GND | Dedicated ground pin. The number of GND pins depends on the package used. <br> All must be connected. | GND |
| VCCAUX | Dedicated auxiliary power supply pin. The number of VCCAUX pins depends on <br> the package used. All must be connected to +2.5V. | VCCAUX |
| VCCINT | Dedicated internal core logic power supply pin. The number of VCCINT pins <br> depends on the package used. All must be connected to +1.2V. | VCCINT |
| VCCO | Along with all the other VCCO pins in the same bank, this pin supplies power to <br> the output buffers within the I/O bank and sets the input threshold voltage for <br> some I/O standards. | VCCO_\# |
| N.C. | This package pin is not connected in this specific device/package combination <br> but may be connected in larger devices in the same package. | N.C. |

## Notes:

1. \# = I/O bank number, an integer between 0 and 3 .

I/Os with Lxxy_\# are part of a differential output pair. 'L' indicates differential output capability. The " $x$ " field is a two-digit integer, unique to each bank that identifies a differential pin-pair. The ' $y$ ' field is either ' $P$ ' for the true signal or ' N ' for the inverted signal in the differential pair. The ' $\#$ ' field is the I/O bank number.

## Differential Pair Labeling

A pin supports differential standards if the pin is labeled in the format "Lxxy_\#". The pin name suffix has the following
significance. Figure 1 provides a specific example showing a differential input to and a differential output from Bank 1.
' L ' indicates that the pin is part of a differential pair.
"xx" is a two-digit integer, unique for each bank, that identifies a differential pin-pair.
' $y$ ' is replaced by ' $P$ ' for the true signal or ' $N$ ' for the inverted. These two pins form one differential pin-pair.
'\#' is an integer, 0 through 3, indicating the associated I/O bank.


Figure 1: Differential Pair Labeling

## Package Overview

Table 2 shows the eight low-cost, space-saving production package styles for the Spartan-3E family. Each package style is available as a standard and an environmen-tally-friendly lead-free ( Pb -free) option. The Pb -free packages include an extra ' $G$ ' in the package style name. For example, the standard "VQ100" package becomes "VQG100" when ordered as the Pb-free option. The
mechanical dimensions of the standard and Pb -free packages are similar, as shown in the mechanical drawings provided in Table 4.
Not all Spartan-3E densities are available in all packages. For a specific package, however, there is a common footprint that supports all the devices available in that package. See the footprint diagrams that follow.

## Table 2: Spartan-3E Family Package Options

| Package | Leads | Type | Maximum <br> I/O | Pitch <br> $(\mathbf{m m})$ | Area (mm) | Height <br> $(\mathbf{m m})$ |
| :--- | :---: | :--- | :---: | :---: | :---: | :---: |
| VQ100 / VQG100 | 100 | Very-thin Quad Flat Pack (VQFP) | 66 | 0.5 | $16 \times 16$ | 1.20 |
| CP132 / CPG132 | 132 | Chip-Scale Package (CSP) | 92 | 0.5 | $8 \times 8$ | 1.10 |
| TQ144 / TQG144 | 144 | Thin Quad Flat Pack (TQFP) | 108 | 0.5 | $22 \times 22$ | 1.60 |
| PQ208 / PQG208 | 208 | Plastic Quad Flat Pack (PQFP) | 158 | 0.5 | $30.6 \times 30.6$ | 4.10 |
| FT256 / FTG256 | 256 | Fine-pitch, Thin Ball Grid Array (FBGA) | 190 | 1.0 | $17 \times 17$ | 1.55 |
| FG320 / FGG320 | 320 | Fine-pitch Ball Grid Array (FBGA) | 250 | 1.0 | $19 \times 19$ | 2.00 |
| FG400 / FGG400 | 400 | Fine-pitch Ball Grid Array (FBGA) | 304 | 1.0 | $21 \times 21$ | 2.60 |
| FG484 / FGG484 | 484 | Fine-pitch Ball Grid Array (FBGA) | 376 | 1.0 | $23 \times 23$ | 2.60 |

## Selecting the Right Package Option

Spartan-3 FPGAs are available in both quad-flat pack (QFP) and ball grid array (BGA) packaging options. While QFP packaging offers the lowest absolute cost, the BGA
packages are superior in almost every other aspect, as summarized in Table 3. Consequently, Xilinx recommends using BGA packaging whenever possible.

## Table 3: QFP and BGA Comparison

| Characteristic | Quad Flat Pack (QFP) | Ball Grid Array (BGA) |
| :--- | :---: | :---: |
| Maximum User I/O | 158 | 376 |
| Packing Density (Logic/Area) | Good | Better |
| Signal Integrity | Fair | Better |
| Simultaneous Switching Output (SSO) Support | Limited | Better |
| Thermal Dissipation | Fair | Better |
| Minimum Printed Circuit Board (PCB) Layers | 4 | 6 |
| Hand Assembly/Rework | Possible | Difficult |

## Mechanical Drawings

Detailed mechanical drawings for each package type are available from the Xilinx website at the specified location in Table 4.

Table 4: Xilinx Package Mechanical Drawings

| Package | Web Link (URL) |
| :--- | :--- |
| VQ100 / VQG100 | http://www.xilinx.com/bvdocs/packages/va100.pdf |
| CP132 / CPG132 | http://www.xilinx.com/bvdocs/packages/cp132.pdf |
| TQ144 / TQG144 | $\underline{\text { http://www.xilinx.com/bvdocs/packages/tq144.pdf }}$ |
| PQ208 / PQG208 | $\underline{\text { http://www.xilinx.com/bvdocs/packages/pq208.pdf }}$ |
| FT256 / FTG256 | $\underline{\text { http://www.xilinx.com/bvdocs/packages/tt256.pdf }}$ |
| FG320 / FGG320 | $\underline{\text { http://www.xilinx.com/bvdocs/packages/fg320.pdf }}$ |
| FG400 / FGG400 | $\underline{\text { http://www.xilinx.com/bvdocs/packages/fg400.pdf }}$ |
| FG484 / FGG484 | $\underline{\text { http://www.xilinx.com/bvdocs/packages/fg484.pdf }}$ |

## Package Pins by Type

Each package has three separate voltage supply inputs-VCCINT, VCCAUX, and VCCO-and a common ground return, GND. The numbers of pins dedicated to these functions vary by package, as shown in Table 5.

Table 5: Power and Ground Supply Pins by Package

| Package | VCCINT | VCCAUX | VCCO | GND |
| :--- | :---: | :---: | :---: | :---: |
| VQ100 | 4 | 4 | 8 | 12 |
| CP132 | 6 | 4 | 8 | 16 |
| TQ144 | 4 | 4 | 9 | 13 |
| PQ208 | 4 | 8 | 12 | 20 |
| FT256 | 8 | 8 | 16 | 28 |
| FG320 | 8 | 8 | 20 | 28 |
| FG400 | 16 | 8 | 24 | 42 |
| FG484 | 16 | 10 | 28 | 48 |

A majority of package pins are user-defined I/O or input pins. However, the numbers and characteristics of these I/O depend on the device type and the package in which it is available, as shown in Table 6. The table shows the maximum number of single-ended I/O pins available, assuming that all I/O-, INPUT-, DUAL-, VREF-, and GCLK-type pins are used as general-purpose I/O. Likewise, the table shows the maximum number of differential pin-pairs available on the package. Finally, the table shows how the total maximum user-l/Os are distributed by pin type, including the number of unconnected-i.e., N.C.-pins on the device.

Table 6: Maximum User I/O by Package

| Device | Package | Maximum User I/Os | Maximum Differential Pairs | All Possible I/Os by Type |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | I/O | INPUT | DUAL | VREF | GCLK | N.C. |
| XC3S100E | VQ100 | 66 | 30 | 16 | 1 | 21 | 4 | 24 | 0 |
| XC3S250E |  | 66 | 30 | 16 | 1 | 21 | 4 | 24 | 0 |
| XC3S250E | CP132 | 92 | 41 | 22 | 0 | 46 | 8 | 16 | 0 |
| XC3S500E |  | 92 | 41 | 22 | 0 | 46 | 8 | 16 | 0 |
| XC3S100E | TQ144 | 108 | 40 | 22 | 19 | 42 | 9 | 16 | 0 |
| XC3S250E |  | 108 | 40 | 20 | 21 | 42 | 9 | 16 | 0 |
| XC3S250E | PQ208 | 158 | 65 | 58 | 25 | 46 | 13 | 16 | 0 |
| XC3S500E |  | 158 | 65 | 58 | 25 | 46 | 13 | 16 | 0 |
| XC3S250E | FT256 | 172 | 68 | 62 | 33 | 46 | 15 | 16 | 16 |
| XC3S500E |  | 190 | 77 | 76 | 33 | 46 | 19 | 16 | 0 |
| XC3S1200E |  | 190 | 77 | 78 | 31 | 46 | 19 | 16 | 0 |
| XC3S500E | FG320 | 232 | 92 | 102 | 48 | 46 | 20 | 16 | 18 |
| XC3S1200E |  | 250 | 99 | 120 | 47 | 46 | 21 | 16 | 0 |
| XC3S1600E |  | 250 | 99 | 119 | 48 | 46 | 21 | 16 | 0 |
| XC3S1200E | FG400 | 304 | 124 | 156 | 62 | 46 | 24 | 16 | 0 |
| XC3S1600E |  | 304 | 124 | 156 | 62 | 46 | 24 | 16 | 0 |
| XC3S1600E | FG484 | 376 | 156 | 214 | 72 | 46 | 28 | 16 | 0 |

Electronic versions of the package pinout tables and footprints are available for download from the Xilinx web site. Download the files from the following location: Using a spreadsheet program, the data can be sorted and reformat-
ted according to any specific needs. Similarly, the ASCII-text file is easily parsed by most scripting programs.
http://www.xilinx.com/bvdocs/publications/s3e_pin.zip

## VQ100: 100-lead Very-thin Quad Flat Package

The XC3S100E and the XC3S250E devices are available in the 100 -lead very-thin quad flat package, VQ100. Both devices share a common footprint for this package as shown in Table 7 and Figure 2.
Table 7 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 VQ100 package does not support the Byte-wide Peripheral Interface (BPI) configuration mode. Consequently, the VQ100 footprint has fewer DUAL-type pins than other packages.
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/bvdocs/publications/s3e_pin.zip.

## Pinout Table

Table 7 shows the pinout for production Spartan-3E FPGAs in the VQ100 package. The XC3S100 engineering samples have a slightly different pinout, as described in Table 9.

Table 7: VQ100 Package Pinout

| Bank | XC3S100E <br> XC3S250E <br> Pin Name | VQ100 <br> Pin <br> Number | Type |
| :---: | :--- | :---: | :---: |
| 0 | IO | P92 | I/O |
| 0 | IO_L01N_0 | P79 | I/O |
| 0 | IO_L01P_0 | P78 | I/O |
| 0 | IO_L02N_0/GCLK5 | P84 | GCLK |
| 0 | IO_L02P_0/GCLK4 | P83 | GCLK |
| 0 | IO_L03N_0/GCLK7 | P86 | GCLK |
| 0 | IO_L03P_0/GCLK6 | P85 | GCLK |
| 0 | IO_L05N_0/GCLK11 | P91 | GCLK |
| 0 | IO_L05P_0/GCLK10 | P90 | GCLK |
| 0 | IO_L06N_0/VREF_0 | P95 | VREF |
| 0 | IO_L06P_0 | P94 | I/O |
| 0 | IO_L07N_0/HSWAP | P99 | DUAL |
| 0 | IO_L07P_0 | P98 | I/O |
| 0 | IP_L04N_0/GCLK9 | P89 | GCLK |
| 0 | IP_L04P_0/GCLK8 | P88 | GCLK |
| 0 | VCCO_0 | P82 | VCCO |

Table 7: VQ100 Package Pinout

| Bank | XC3S100E <br> XC3S250E <br> Pin Name | $\begin{aligned} & \text { VQ100 } \\ & \text { Pin } \\ & \text { Number } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | VCCO_0 | P97 | VCCO |
| 1 | IO_L01N_1 | P54 | I/O |
| 1 | IO_L01P_1 | P53 | I/O |
| 1 | IO_L02N_1 | P58 | I/O |
| 1 | IO_L02P_1 | P57 | I/O |
| 1 | IO_L03N_1/RHCLK1 | P61 | RHCLK |
| 1 | IO_L03P_1/RHCLK0 | P60 | RHCLK |
| 1 | IO_L04N_1/RHCLK3 | P63 | RHCLK |
| 1 | IO_L04P_1/RHCLK2 | P62 | RHCLK |
| 1 | IO_L05N_1/RHCLK5 | P66 | RHCLK |
| 1 | IO_L05P_1/RHCLK4 | P65 | RHCLK |
| 1 | IO_L06N_1/RHCLK7 | P68 | RHCLK |
| 1 | IO_L06P_1/RHCLK6 | P67 | RHCLK |
| 1 | IO_L07N_1 | P71 | I/O |
| 1 | $1 O^{\prime}$ L07P_1 | P70 | I/O |
| 1 | IP/VREF_1 | P69 | VREF |
| 1 | VCCO_1 | P55 | VCCO |
| 1 | VCCO_1 | P73 | VCCO |
| 2 | IO/D5 | P34 | DUAL |
| 2 | IO/M1 | P42 | DUAL |
| 2 | IO_L01N_2/INIT_B | P25 | DUAL |
| 2 | IO_L01P_2/CSO_B | P24 | DUAL |
| 2 | IO_L02N_2/MOSI/CSI_B | P27 | DUAL |
| 2 | IO_L02P_2/DOUT/BUSY | P26 | DUAL |
| 2 | IO_L03N_2/D6/GCLK13 | P33 | DUAL/GCLK |
| 2 | IO_L03P_2/D7/GCLK12 | P32 | DUAL/GCLK |
| 2 | IO_L04N_2/D3/GCLK15 | P36 | DUAL/GCLK |
| 2 | IO_L04P_2/D4/GCLK14 | P35 | DUAL/GCLK |
| 2 | IO_L06N_2/D1/GCLK3 | P41 | DUAL/GCLK |
| 2 | IO_L06P_2/D2/GCLK2 | P40 | DUAL/GCLK |
| 2 | IO_L07N_2/DIN/D0 | P44 | DUAL |
| 2 | IO_L07P_2/M0 | P43 | DUAL |
| 2 | 1 O _L08N_2/VS1 | P48 | DUAL |
| 2 | IO_L08P_2/VS2 | P47 | DUAL |

Table 7: VQ100 Package Pinout

| Bank | XC3S100E <br> XC3S250E <br> Pin Name | $\begin{aligned} & \text { VQ100 } \\ & \text { Pin } \\ & \text { Number } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 2 | IO_L09N_2/CCLK | P50 | DUAL |
| 2 | IO_L09P_2/VS0 | P49 | DUAL |
| 2 | IP/VREF_2 | P30 | VREF |
| 2 | IP_L05N_2/M2/GCLK1 | P39 | DUAL/GCLK |
| 2 | $\begin{aligned} & \text { IP_L05P_2/RDWR_B/ } \\ & \text { GCLK0 } \end{aligned}$ | P38 | DUAL/GCLK |
| 2 | VCCO_2 | P31 | VCCO |
| 2 | VCCO_2 | P45 | VCCO |
| 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/LHCLK1 | P10 | LHCLK |
| 3 | IO_L03P_3/LHCLK0 | P9 | LHCLK |
| 3 | IO_L04N_3/LHCLK3 | P12 | LHCLK |
| 3 | IO_L04P_3/LHCLK2 | P11 | LHCLK |
| 3 | IO_L05N_3/LHCLK5 | P16 | LHCLK |
| 3 | IO_L05P_3/LHCLK4 | P15 | LHCLK |
| 3 | IO_L06N_3/LHCLK7 | P18 | LHCLK |
| 3 | IO_L06P_3/LHCLK6 | P17 | LHCLK |
| 3 | IO_L07N_3 | P23 | I/O |
| 3 | IO_L07P_3 | P22 | I/O |
| 3 | IP | P13 | INPUT |
| 3 | VCCO_3 | P8 | VCCO |
| 3 | VCCO_3 | P20 | VCCO |
| GND | GND | P7 | GND |
| GND | GND | P14 | GND |
| GND | GND | P19 | GND |
| GND | GND | P29 | GND |
| GND | GND | P37 | GND |
| GND | GND | P52 | GND |
| GND | GND | P59 | GND |
| GND | GND | P64 | GND |
| GND | GND | P72 | GND |
| GND | GND | P81 | GND |

Table 7: VQ100 Package Pinout

| Bank | XC3S100E <br> XC3S250E <br> Pin Name | $\begin{aligned} & \text { VQ100 } \\ & \text { Pin } \\ & \text { Number } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| GND | GND | P87 | GND |
| GND | GND | P93 | GND |
| VCCAUX | DONE | P51 | CONFIG |
| VCCAUX | PROG_B | P1 | CONFIG |
| VCCAUX | TCK | P77 | JTAG |
| VCCAUX | TDI | P100 | JTAG |
| VCCAUX | TDO | P76 | JTAG |
| VCCAUX | TMS | P75 | JTAG |
| VCCAUX | VCCAUX | P21 | VCCAUX |
| VCCAUX | VCCAUX | P46 | VCCAUX |
| VCCAUX | VCCAUX | P74 | VCCAUX |
| VCCAUX | VCCAUX | P96 | VCCAUX |
| VCCINT | VCCINT | P6 | VCCINT |
| VCCINT | VCCINT | P28 | VCCINT |
| VCCINT | VCCINT | P56 | VCCINT |
| VCCINT | VCCINT | P80 | VCCINT |

## User I/Os by Bank

Table 8 indicates how the 66 available user-I/O pins are distributed between the four I/O banks on the VQ100 package.

Table 8: User I/Os Per Bank for XC3S100E and XC3S250E in the VQ100 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 | 15 | 5 | 0 | 1 | 1 | 8 |
| Right | 1 | 15 | 6 | 0 | 0 | 1 | 8 |
| Bottom | 2 | 19 | 0 | 0 | 18 | 1 | 0 |
| Left | 3 | 17 | 5 | 1 | 2 | 1 | 8 |
| TOTAL |  | $\mathbf{6 6}$ | $\mathbf{1 6}$ | $\mathbf{1}$ | $\mathbf{2 1}$ | $\mathbf{4}$ | $\mathbf{2 4}$ |

## Footprint Migration Differences

The production XC3S100E and XC3S250E FPGAs have identical footprints in the VQ100 package. Designs can migrate between the XC3S100E and XC3S250E without further consideration.
The pinout changed slightly between the XC3S100E engineering samples and the production devices, as shown in Table 9. In the engineering samples, the mode select pins M1 and M0 overlap with two global clock inputs feeding the bottom-edge global buffers and DCMs. In the production devices, the mode pins are swapped with parallel mode data pins, D1 and D2. This way, these two mode pins do not interfere with global clock inputs.

Table 9: XC3S100E Pinout Changes between Production Devices and Engineering Samples

| VQ100 Pin | XC3S100E <br> Production <br> Devices | XC3S100E <br> Engineering <br> Samples |
| :---: | :---: | :---: |
| P40 | D2/GCLK2 | M1/GCLK2 |
| P41 | D1/GCLK3 | M0/GCLK3 |
| P42 | M1 | D2 |
| P43 | M0 | D1 |

## VQ100 Footprint

In Figure 2, note pin 1 indicator in top-left corner and logo orientation. The engineering sample footprint is slightly different.


Figure 2: VQ100 Package Production Footprint (top view). Engineering Samples have slightly different footprint.

| 16 | I/O: Unrestricted, general-purpose user I/O | 21 | DUAL: Configuration pin, then possible user-1/O | 4 | VREF: User I/O or input voltage reference for bank |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | INPUT: Unrestricted, general-purpose input pin | 24 | GCLK: User I/O, input, or global buffer input | 8 | VCCO: Output voltage supply for bank |
| 2 | CONFIG: Dedicated configuration pins | 4 | JTAG: Dedicated JTAG port pins | 4 | VCCINT: Internal core supply voltage (+1.2V) |
| 0 | N.C.: Not connected | 12 | GND: Ground | 4 | VCCAUX: Auxiliary supply voltage (+2.5V) |

## CP132: 132-ball Chip-scale Package

The XC3S250E and the XC3S500E FPGAs are available in the 132 -lead chip-scale package, CP132. Both devices share a common footprint for this package as shown in Table 10 and Figure 3.
Table 10 lists all the CP132 package pins. They are sorted by bank number and then by pin name. 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.
Physically, the D14 and K2 balls on the XC3S250E FPGA are not connected but should be connected to VCCINT to maintain density migration compatibility.
An electronic version of this package pinout table and footprint diagram is available for download from the Xilinx website at http://www.xilinx.com/bvdocs/publications/s3e_pin.zip.

## Pinout Table

Table 10: CP132 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | $\begin{gathered} \text { CP132 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | IO_L01N_0 | C12 | I/O |
| 0 | $1 O_{0}$ L01P_0 | A13 | I/O |
| 0 | 1 O _L02N_0 | A12 | I/O |
| 0 | 1 O | B12 | I/O |
| 0 | IO_L03N_0/VREF_0 | B11 | VREF |
| 0 | IO_L03P_0 | C11 | I/O |
| 0 | IO_L04N_0/GCLK5 | C9 | GCLK |
| 0 | IO_L04P_0/GCLK4 | A10 | GCLK |
| 0 | IO_L05N_0/GCLK7 | A9 | GCLK |
| 0 | IO_L05P_0/GCLK6 | B9 | GCLK |
| 0 | IO_L07N_0/GCLK11 | B7 | GCLK |
| 0 | IO_L07P_0/GCLK10 | A7 | GCLK |
| 0 | IO_L08N_0/VREF_0 | C6 | VREF |
| 0 | 1 O _L08P_0 | B6 | I/O |
| 0 | 1 O _L09N_0 | C5 | I/O |
| 0 | 1 O _L09P_0 | B5 | I/O |
| 0 | 1 O _L10N_0 | C4 | I/O |
| 0 | IO_L10P_0 | B4 | I/O |
| 0 | IO_L11N_0/HSWAP | B3 | DUAL |
| 0 | IO_L11P_0 | A3 | I/O |

Table 10: CP132 Package Pinout

| Bank | XC3S250E XC3S500E Pin Name | $\begin{gathered} \text { CP132 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | IP_L06N_0/GCLK9 | C8 | GCLK |
| 0 | IP_L06P_0/GCLK8 | B8 | GCLK |
| 0 | VCCO_0 | A6 | vcco |
| 0 | vCCO_0 | B10 | vcco |
| 1 | IO/A0 | F12 | DUAL |
| 1 | IO/VREF_1 | K13 | VREF |
| 1 | IO_L01N_1/A15 | N14 | DUAL |
| 1 | $10 . L 01 P$ _1/A16 | N13 | DUAL |
| 1 | 1 O _L02N_1/A13 | M13 | DUAL |
| 1 | $10 . L 02 P$ _1/A14 | M12 | DUAL |
| 1 | 1 O _L03N_1/A11 | L14 | DUAL |
| 1 | $10 . L 03 P$ _1/A12 | L13 | DUAL |
| 1 | IO_L04N_1/A9/RHCLK1 | J12 | RHCLK/ DUAL |
| 1 | IO_L04P_1/A10/RHCLK0 | K14 | RHCLK DUAL |
| 1 | IO_LO5N_1/A7/RHCLK3/ TRDY1 | J14 | RHCLK/ DUAL |
| 1 | IO_L05P_1/A8/RHCLK2 | J13 | $\begin{gathered} \text { RHCLK/ } \\ \text { DUAL } \end{gathered}$ |
| 1 | IO_L06N_1/A5/RHCLK5 | H12 | RHCLK DUAL |
| 1 | IO_L06P_1/A6/RHCLK4/ IRDY1 | H13 | RHCLK DUAL |
| 1 | IO_L07N_1/A3/RHCLK7 | G13 | RHCLK DUAL |
| 1 | IO_L07P_1/A4/RHCLK6 | G14 | RHCLK/ DUAL |
| 1 | IO_L08N_1/A1 | F13 | DUAL |
| 1 | IO_L08P_1/A2 | F14 | DUAL |
| 1 | IO_L09N_1/LDC0 | D12 | DUAL |
| 1 | IO_L09P_1/HDC | D13 | DUAL |
| 1 | IO_L10N_1/LDC2 | C13 | DUAL |
| 1 | IO_L10P_1/LDC1 | C14 | DUAL |
| 1 | IP/VREF_1 | G12 | VREF |
| 1 | VCCO_1 | E13 | vcco |
| 1 | VCCO_1 | M14 | vcco |
| 2 | IO/D5 | P4 | DUAL |

Table 10: CP132 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | $\begin{gathered} \text { CP132 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 2 | IO/M1 | N7 | DUAL |
| 2 | IO/VREF_2 | P11 | VREF |
| 2 | IO_L01N_2/INIT_B | N1 | DUAL |
| 2 | IO_L01P_2/CSO_B | M2 | DUAL |
| 2 | IO_L02N_2/MOSI/CSI_B | N2 | DUAL |
| 2 | IO_L02P_2/DOUT/BUSY | P1 | DUAL |
| 2 | IO_L03N_2/D6/GCLK13 | N4 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L03P_2/D7/GCLK12 | M4 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L04N_2/D3/GCLK15 | N5 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L04P_2/D4/GCLK14 | M5 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L06N_2/D1/GCLK3 | P7 | DUAL GCLK |
| 2 | IO_L06P_2/D2/GCLK2 | P6 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L07N_2/DIN/D0 | N8 | DUAL |
| 2 | IO_L07P_2/M0 | P8 | DUAL |
| 2 | IO_L08N_2/A22 | M9 | DUAL |
| 2 | IO_L08P_2/A23 | N9 | DUAL |
| 2 | 1O_L09N_2/A20 | M10 | DUAL |
| 2 | IO_L09P_2/A21 | N10 | DUAL |
| 2 | IO_L10N_2/VS1/A18 | M11 | DUAL |
| 2 | IO_L10P_2/VS2/A19 | N11 | DUAL |
| 2 | IO_L11N_2/CCLK | N12 | DUAL |
| 2 | IO_L11P_2/VS0/A17 | P12 | DUAL |
| 2 | IP/VREF_2 | N3 | VREF |
| 2 | IP_L05N_2/M2/GCLK1 | N6 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | $\begin{aligned} & \text { IP_L05P_2/RDWR_B/ } \\ & \text { GCLK0 } \end{aligned}$ | M6 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | VCCO_2 | M8 | VCCO |
| 2 | VCCO_2 | P3 | VCCO |
| 3 | 10 | J3 | I/O |
| 3 | IO/VREF_3 | K3 | VREF |
| 3 | IO_L01N_3 | B1 | I/O |

Table 10: CP132 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | CP132 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| 3 | IO_L01P_3 | B2 | I/O |
| 3 | IO_LO2N_3 | C2 | I/O |
| 3 | IO_L02P_3 | C3 | I/O |
| 3 | IO_L03N_3 | D1 | I/O |
| 3 | IO_L03P_3 | D2 | I/O |
| 3 | IO_L04N_3/LHCLK1 | F2 | LHCLK |
| 3 | IO_L04P_3/LHCLK0 | F3 | LHCLK |
| 3 | IO_L05N_3/LHCLK3/RDY2 | G1 | LHCLK |
| 3 | IO_L05P_3/LHCLK2 | F1 | LHCLK |
| 3 | IO_L06N_3/LHCLK5 | H1 | LHCLK |
| 3 | IO_L06P_3/LHCLK4/TRDY2 | G3 | LHCLK |
| 3 | IO_L07N_3/LHCLK7 | H3 | LHCLK |
| 3 | IO_L07P_3/LHCLK6 | H2 | LHCLK |
| 3 | IO_L08N_3 | L2 | I/O |
| 3 | IO_L08P_3 | L1 | I/O |
| 3 | IO_L09N_3 | M1 | I/O |
| 3 | IO_L09P_3 | L3 | I/O |
| 3 | IP/VREF_3 | E2 | VREF |
| 3 | VCCO_3 | E1 | VCCO |
| 3 | VCCO_3 | J2 | VCCO |
|  |  | A4 | GND |


| GND | GND | A4 | GND |
| :---: | :--- | :---: | :---: |
| GND | GND | A8 | GND |
| GND | GND | C1 | GND |
| GND | GND | C7 | GND |
| GND | GND | C10 | GND |
| GND | GND | E3 | GND |
| GND | GND | E14 | GND |
| GND | GND | G2 | GND |
| GND | GND | H14 | GND |
| GND | GND | J1 | GND |
| GND | GND | K12 | GND |
| GND | GND | M3 | GND |
| GND | GND | M7 | GND |
| GND | GND | P5 | GND |

Table 10: CP132 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | CP132 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| GND | GND | P10 | GND |
| GND | GND | P14 | GND |
| VCCAUX | DONE | P13 | CONFIG |
| VCCAUX | PROG_B | A1 | CONFIG |
| VCCAUX | TCK | B13 | JTAG |
| VCCAUX | TDI | A2 | JTAG |
| VCCAUX | TDO | B14 | JTAG |
| VCCAUX | TMS | A5 | VCCAUX |
| VCCAUX | VCCAUX | K12 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX |  |
| VCCAUX | VCCAUX |  |  |

Table 10: CP132 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | CP132 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| VCCAUX | VCCAUX | P9 | VCCAUX |
| VCCINT | VCCINT | A11 | VCCINT |
| VCCINT | VCCINT | D3 | VCCINT |
| VCCINT | VCCINT | D14 | VCCINT |
| VCCINT | VCCINT | K2 | VCCINT |
| VCCINT | VCCINT | L12 | VCCINT |
| VCCINT | VCCINT | P2 | VCCINT |

## User I/Os by Bank

Table 20 indicates how the 92 available user-l/O pins are distributed between the four I/O banks on the CP132 package.

Table 11: User I/Os Per Bank for the XC3S250E and XC3S500E in the CP132 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 11 | 0 | 1 | 2 | 8 |
| Right | 1 |  | 0 | 0 | 21 | 2 | 0 |
| Bottom | 2 |  | 0 | 0 | 24 | 2 | 0 |
| Left | 3 |  | 11 | 0 | 0 | 2 | 8 |
| TOTAL |  | $\mathbf{9 2}$ | $\mathbf{2 2}$ | $\mathbf{0}$ | $\mathbf{4 6}$ | $\mathbf{8}$ | $\mathbf{1 6}$ |

## Footprint Migration Differences

The production XC3S250E and XC3S500E FPGAs have identical footprints in the CP132 package. Designs can
migrate between the XC3S250E and XC3S500E without further consideration.

## CP132 Footprint



Figure 3: CP132 Package Footprint (top view)

| 22 | I/O: Unrestricted, general-purpose user I/O |
| :---: | :---: |
| 0 | INPUT: Unrestricted, general-purpose input pin |
| 2 | CONFIG: Dedicated configuration pins |
| 0 | N.C.: Not connected |


| 42 | DUAL: Configuration pin, then <br> possible user I/O | 8 | VREF: User I/O or input <br> voltage reference for bank |
| :---: | :--- | :---: | :--- |
| 16 | GCLK: User I/O, input, or <br> global buffer input | 8 | vcco: Output voltage supply <br> for bank |
| 4 | JTAG: Dedicated JTAG port <br> pins | 6 | vcCINT: Internal core supply <br> voltage $(+1.2 \mathrm{~V})$ |
| 16 | GND: Ground | 4 | vCCAUX: Auxiliary supply <br> voltage $(+2.5 \mathrm{~V})$ |

## 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 12 and Figure 4.
Table 12 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/bvdocs/publications/s3e_pin.zip.

## Pinout Table

Table 12 shows the pinout for production Spartan-3E FPGAs in the VQ100 package. The XC3S100 engineering samples have a slightly different pinout, as described in Table 15.

## Table 12: TQ144 Package Pinout

| Bank | XC3S100E Pin Name | XC3S250E Pin Name | TQ144 Pin | Type |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 10 | 10 | 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 | 1/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 |

Table 12: TQ144 Package Pinout (Continued)

| Bank | XC3S100E Pin Name | XC3S250E Pin Name | TQ144 Pin | Type |
| :---: | :---: | :---: | :---: | :---: |
| 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 |
| 1 | IO_L02P_1/A14 | IO_L02P_1/A14 | P76 | DUAL |
| 1 | IO_L03N_1/A11 | IO_L03N_1/A11 | P82 | DUAL |
| 1 | IO_L03P_1/A12 | IO_L03P_1/A12 | P81 | DUAL |
| 1 | IO_L04N_1/A9/RHCLK1 | IO_L04N_1/A9/RHCLK1 | P86 | RHCLK/DUAL |
| 1 | IO_L04P_1/A10/RHCLK0 | IO_L04P_1/A10/RHCLK0 | P85 | RHCLK/DUAL |
| 1 | IO_L05N_1/A7/RHCLK3/TRDY1 | IO_L05N_1/A7/RHCLK3 | P88 | RHCLK/DUAL |
| 1 | IO_L05P_1/A8/RHCLK2 | IO_L05P_1/A8/RHCLK2 | P87 | RHCLK/DUAL |
| 1 | IO_L06N_1/A5/RHCLK5 | IO_L06N_1/A5/RHCLK5 | P92 | RHCLK/DUAL |
| 1 | IO_L06P_1/A6/RHCLK4/IRDY1 | IO_L06P_1/A6/RHCLK4 | P91 | RHCLK/DUAL |
| 1 | IO_L07N_1/A3/RHCLK7 | IO_L07N_1/A3/RHCLK7 | P94 | RHCLK/DUAL |
| 1 | IO_L07P_1/A4/RHCLK6 | IO_L07P_1/A4/RHCLK6 | P93 | RHCLK/DUAL |
| 1 | IO_L08N_1/A1 | IO_L08N_1/A1 | P97 | DUAL |
| 1 | IO_L08P_1/A2 | IO_L08P_1/A2 | P96 | DUAL |
| 1 | IO_L09N_1/LDC0 | IO_L09N_1/LDC0 | P104 | DUAL |
| 1 | IO_L09P_1/HDC | IO_L09P_1/HDC | P103 | DUAL |
| 1 | IO_L10N_1/LDC2 | IO_L10N_1/LDC2 | P106 | DUAL |
| 1 | IO_L10P_1/LDC1 | IO_L10P_1/LDC1 | P105 | DUAL |
| 1 | IP | IP | P78 | INPUT |
| 1 | IP | IP | P84 | INPUT |
| 1 | IP | IP | P89 | INPUT |
| 1 | IP | IP | P101 | INPUT |
| 1 | IP | IP | P107 | INPUT |
| 1 | IP/VREF_1 | IP/VREF_1 | P95 | VREF |
| 1 | VCCO_1 | VCCO_1 | P79 | VCCO |
| 1 | VCCO_1 | VCCO_1 | P100 | VCCO |
| 2 | IO/D5 | IO/D5 | P52 | DUAL |
| 2 | IO/M1 | IO/M1 | P60 | DUAL |
| 2 | IP/VREF_2 | IO/VREF_2 | P66 | 100E: VREF(INPUT) 250E: VREF(I/O) |

Table 12: TQ144 Package Pinout (Continued)

| Bank | XC3S100E Pin Name | XC3S250E Pin Name | TQ144 Pin | Type |
| :---: | :---: | :---: | :---: | :---: |
| 2 | IO_L01N_2/INIT_B | IO_L01N_2/INIT_B | P40 | DUAL |
| 2 | IO_L01P_2/CSO_B | IO_L01P_2/CSO_B | P39 | DUAL |
| 2 | IO_L02N_2/MOSI/CSI_B | IO_L02N_2/MOSI/CSI_B | P44 | DUAL |
| 2 | IO_L02P_2/DOUT/BUSY | IO_L02P_2/DOUT/BUSY | P43 | DUAL |
| 2 | IO_L04N_2/D6/GCLK13 | IO_L04N_2/D6/GCLK13 | P51 | DUAL/GCLK |
| 2 | IO_L04P_2/D7/GCLK12 | IO_L04P_2/D7/GCLK12 | P50 | DUAL/GCLK |
| 2 | IO_L05N_2/D3/GCLK15 | IO_L05N_2/D3/GCLK15 | P54 | DUAL/GCLK |
| 2 | IO_L05P_2/D4/GCLK14 | IO_L05P_2/D4/GCLK14 | P53 | DUAL/GCLK |
| 2 | IO_L07N_2/D1/GCLK3 | IO_L07N_2/D1/GCLK3 | P59 | DUAL/GCLK |
| 2 | IO_L07P_2/D2/GCLK2 | IO_L07P_2/D2/GCLK2 | P58 | DUAL/GCLK |
| 2 | IO_L08N_2/DIN/D0 | IO_L08N_2/DIN/D0 | P63 | DUAL |
| 2 | IO_L08P_2/M0 | IO_L08P_2/M0 | P62 | DUAL |
| 2 | IO_L09N_2/VS1/A18 | IO_L09N_2/VS1/A18 | P68 | DUAL |
| 2 | IO_L09P_2/VS2/A19 | IO_L09P_2/VS2/A19 | P67 | DUAL |
| 2 | IO_L10N_2/CCLK | IO_L10N_2/CCLK | P71 | DUAL |
| 2 | IO_L10P_2/VS0/A17 | IO_L10P_2/VS0/A17 | P70 | DUAL |
| 2 | IP | IP | P38 | INPUT |
| 2 | IP | IP | P41 | INPUT |
| 2 | IP | IP | P69 | INPUT |
| 2 | IP_L03N_2/VREF_2 | IP_L03N_2/VREF_2 | P48 | VREF |
| 2 | IP_L03P_2 | IP_L03P_2 | P47 | INPUT |
| 2 | IP_L06N_2/M2/GCLK1 | IP_L06N_2/M2/GCLK1 | P57 | DUAL/GCLK |
| 2 | IP_L06P_2/RDWR_B/GCLK0 | IP_L06P_2/RDWR_B/GCLK0 | P56 | DUAL/GCLK |
| 2 | VCCO_2 | VCCO_2 | P42 | VCCO |
| 2 | VCCO_2 | VCCO_2 | P49 | VCCO |
| 2 | VCCO_2 | VCCO_2 | P64 | VCCO |
| 3 | IP/VREF_3 | IO/VREF_3 | P31 | 100E: VREF(INPUT) 250E: VREF(I/O) |
| 3 | IO_L01N_3 | IO_L01N_3 | P3 | I/O |
| 3 | IO_L01P_3 | IO_L01P_3 | P2 | I/O |
| 3 | IO_L02N_3/VREF_3 | IO_L02N_3/VREF_3 | P5 | VREF |
| 3 | IO_L02P_3 | IO_L02P_3 | P4 | I/O |
| 3 | IO_L03N_3 | IO_L03N_3 | P8 | I/O |
| 3 | IO_L03P_3 | IO_L03P_3 | P7 | I/O |
| 3 | IO_L04N_3/LHCLK1 | IO_L04N_3/LHCLK1 | P15 | LHCLK |
| 3 | IO_L04P_3/LHCLK0 | IO_L04P_3/LHCLK0 | P14 | LHCLK |

Table 12: TQ144 Package Pinout (Continued)

| Bank | XC3S100E Pin Name | XC3S250E Pin Name | TQ144 Pin | Type |
| :---: | :---: | :---: | :---: | :---: |
| 3 | IO_L05N_3/LHCLK3/IRDY2 | IO_L05N_3/LHCLK3 | P17 | LHCLK |
| 3 | IO_L05P_3/LHCLK2 | IO_L05P_3/LHCLK2 | P16 | LHCLK |
| 3 | IO_L06N_3/LHCLK5 | IO_L06N_3/LHCLK5 | P21 | LHCLK |
| 3 | IO_L06P_3/LHCLK4/TRDY2 | IO_L06P_3/LHCLK4 | P20 | LHCLK |
| 3 | IO_L07N_3/LHCLK7 | IO_L07N_3/LHCLK7 | P23 | LHCLK |
| 3 | IO_L07P_3/LHCLK6 | IO_L07P_3/LHCLK6 | P22 | LHCLK |
| 3 | IO_L08N_3 | IO_L08N_3 | P26 | I/O |
| 3 | IO_L08P_3 | 1 O _L08P_3 | P25 | I/O |
| 3 | IO_L09N_3 | IO_L09N_3 | P33 | I/O |
| 3 | IO_L09P_3 | IO_L09P_3 | P32 | I/O |
| 3 | IO_L10N_3 | IO_L10N_3 | P35 | I/O |
| 3 | IO_L10P_3 | IO_L10P_3 | P34 | I/O |
| 3 | IP | IP | P6 | INPUT |
| 3 | 10 | IP | P10 | 100E: I/O 250E: INPUT |
| 3 | IP | IP | P18 | INPUT |
| 3 | IP | IP | P24 | INPUT |
| 3 | 10 | IP | P29 | 100E: I/O 250E: INPUT |
| 3 | IP | IP | P36 | INPUT |
| 3 | IP/VREF_3 | IP/VREF_3 | P12 | VREF |
| 3 | VCCO_3 | VCCO_3 | P13 | VCCO |
| 3 | VCCO_3 | VCCO_3 | P28 | VCCO |
| GND | GND | GND | P11 | GND |
| GND | GND | GND | P19 | GND |
| GND | GND | GND | P27 | GND |
| GND | GND | GND | P37 | GND |
| GND | GND | GND | P46 | GND |
| GND | GND | GND | P55 | GND |
| GND | GND | GND | P61 | GND |
| GND | GND | GND | P73 | GND |
| GND | GND | GND | P90 | GND |
| GND | GND | GND | P99 | GND |
| GND | GND | GND | P118 | GND |
| GND | GND | GND | P127 | GND |
| GND | GND | GND | P133 | GND |

Table 12: TQ144 Package Pinout (Continued)

| Bank | XC3S100E Pin Name | XC3S250E Pin Name | TQ144 Pin | Type |
| :---: | :--- | :--- | :---: | :---: |
| VCCAUX | DONE | DONE | P72 | CONFIG |
| VCCAUX | PROG_B | PROG_B | P1 | CONFIG |
| VCCAUX | TCK | TCK | P110 | JTAG |
| VCCAUX | TDI | TDI | P144 | JTAG |
| VCCAUX | TDO | TDO | P109 | JTAG |
| VCCAUX | TMS | TMS | P108 | JTAG |
| VCCAUX | VCCAUX | VCCAUX | P65 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | P137 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | P9 | VCCAUX |
| VCCAUX | VCCAUX | VCCINT | P45 | VCCINT |
| VCCINT | VCCINT | VCCINT | P80 | VCCINT |
| VCCINT | VCCINT | VCCINT | P115 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT |  |
| VCCINT | VCCINT |  |  |  |

## User I/Os by Bank

Table 13 and Table 14 indicate how the 108 available user-1/O pins are distributed between the four I/O banks on the TQ144 package.

Table 13: User I/Os Per Bank for the XC3S100E in the TQ144 Package

| Package Edge | I/O Bank | $\underset{\text { I/O }}{\substack{\text { Maximum }}}$ | All Possible I/O Pins by Type |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | I/O | INPUT | DUAL | VREF | GCLK |
| Top | 0 | 26 | 9 | 6 | 1 | 2 | 8 |
| Right | 1 | 28 | 0 | 5 | 21 | 2 | 0 |
| Bottom | 2 | 26 | 0 | 4 | 20 | 2 | 0 |
| Left | 3 | 28 | 13 | 4 | 0 | 3 | 8 |
| TOTAL |  | 108 | 22 | 19 | 42 | 9 | 16 |

Table 14: User I/Os Per Bank for the XC3S250E in TQ144 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 9 | 6 | 1 | 2 | 8 |
| Right | 1 |  | 0 | 5 | 21 | 2 | 0 |
| Bottom | 2 |  | 0 | 4 | 20 | 2 | 0 |
| Left | 3 |  | 11 | 6 | 0 | 3 | 8 |
| TOTAL |  | $\mathbf{1 0 8}$ | $\mathbf{2 0}$ | $\mathbf{2 1}$ | $\mathbf{4 2}$ | $\mathbf{9}$ | $\mathbf{1 6}$ |

## Footprint Migration Differences

Table 15 summarizes any footprint and functionality differences between the XC3S100E and the XC3S250E FPGAs that may affect easy migration between devices. There are four such pins. All other pins not listed in Table 15 unconditionally migrate between Spartan-3E devices available in the TQ144 package.

The arrows indicate the direction for easy migration. For example, a left-facing arrow indicates that the pin on the XC3S250E unconditionally migrates to the pin on the XC3S100E. It may be possible to migrate the opposite direction depending on the I/O configuration. For example, an $I / O$ pin (Type $=I / O$ ) can migrate to an input-only pin $($ Type $=I N P U T)$ if the $I / O$ pin is configured as an input.

## Table 15: TQ144 Footprint Migration Differences

| TQ144 Pin | Bank | XC3S100E Type | Migration | XC3S250E Type |
| :---: | :---: | :--- | :---: | :---: |
| P10 | 3 | I/O | $\leftarrow$ | INPUT |
| P29 | 3 | I/O | $\leftarrow$ | INPUT |
| P31 | 3 | VREF(INPUT) | $\rightarrow$ | VREF(I/O) |
| P66 | 2 | VREF(INPUT) | $\boldsymbol{\rightarrow}$ | VREF(I/O) |
| DIFFERENCES |  |  | $\mathbf{4}$ |  |

Legend:
$\rightarrow \quad$ This pin can unconditionally migrate from the device on the left to the device on the right. Migration in the other direction may be possible depending on how the pin is configured for the device on the right.
$\leftarrow \quad$ This pin can unconditionally migrate from the device on the right to the device on the left. Migration in the other direction may be possible depending on how the pin is configured for the device on the left.

The pinout changed slightly between the XC3S100E engineering samples and the production devices, as shown in Table 16. In the engineering samples, the mode select pins M1 and M0 overlap with two global clock inputs feeding the bottom edge global buffers and DCMs. In the production devices, the mode pins are swapped with parallel mode data pins, D1 and D2. This way, these two mode pins do not interfere with global clock inputs.

Table 16: XC3S100E Pinout Changes between Production Devices and Engineering Samples

| TQ144 Pin | XC3S100E <br> Production <br> Devices | XC3S100E <br> Engineering <br> Samples |
| :---: | :---: | :---: |
| P58 | D2/GCLK2 | M1/GCLK2 |
| P59 | D1/GCLK3 | M0/GCLK3 |
| P60 | M1 | D2 |
| P62 | M0 | D1 |

## TQ144 Footprint

Note pin 1 indicator in top-left corner and logo orientation. Double arrows $(\leftarrow \rightarrow)$ indicates a pinout migration difference
between the XC3S100E and XC3S250E. Engineering sample footprint is slightly different.


Figure 4: TQ144 Package Production Footprint (top view)

| 20 | I/O: Unrestricted, general-purpose user I/O | 42 | DUAL: Configuration pin, then possible user I/O | 9 | VREF: User I/O or input voltage reference for bank |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 21 | INPUT: Unrestricted, general-purpose input pin | 16 | GCLK: User I/O, input, or global buffer input | 9 | VCCO: Output voltage supply for bank |
| 2 | CONFIG: Dedicated configuration pins | 4 | JTAG: Dedicated JTAG port pins | 4 | VCCINT: Internal core supply voltage (+1.2V) |
| 0 | N.C.: Not connected | 13 | GND: Ground | 4 | VCCAUX: Auxiliary supply voltage (+2.5V) |

## PQ208: 208-pin Plastic Quad Flat Package

The 208-pin plastic quad flat package, PQ208, supports two different Spartan-3E FPGAs, including the XC3S250E and the XC3S500E.
Table 17 lists all the PQ208 package pins. They are sorted by bank number and then by pin name. Pairs of 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.
An electronic version of this package pinout table and footprint diagram is available for download from the Xilinx website at http://www.xilinx.com/bvdocs/publications/s3e_pin.zip.

## Pinout Table

Table 17: PQ208 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | $\begin{aligned} & \text { PQ208 } \\ & \text { Pin } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | 10 | P187 | I/O |
| 0 | IO/VREF_0 | P179 | VREF |
| 0 | IO_L01N_0 | P161 | I/O |
| 0 | IO_L01P_0 | P160 | I/O |
| 0 | IO_L02N_0/VREF_0 | P163 | VREF |
| 0 | IO_L02P_0 | P162 | I/O |
| 0 | IO_L03N_0 | P165 | I/O |
| 0 | IO_L03P_0 | P164 | I/O |
| 0 | IO_L04N_0/VREF_0 | P168 | VREF |
| 0 | IO_L04P_0 | P167 | I/O |
| 0 | IO_L05N_0 | P172 | I/O |
| 0 | IO_L05P_0 | P171 | I/O |
| 0 | IO_L07N_0/GCLK5 | P178 | GCLK |
| 0 | IO_L07P_0/GCLK4 | P177 | GCLK |
| 0 | IO_L08N_0/GCLK7 | P181 | GCLK |
| 0 | IO_L08P_0/GCLK6 | P180 | GCLK |
| 0 | IO_L10N_0/GCLK11 | P186 | GCLK |
| 0 | IO_L10P_0/GCLK10 | P185 | GCLK |
| 0 | IO_L11N_0 | P190 | 1/O |
| 0 | IO_L11P_0 | P189 | 1/O |
| 0 | IO_L12N_0/VREF_0 | P193 | VREF |
| 0 | IO_L12P_0 | P192 | I/O |
| 0 | IO_L13N_0 | P197 | I/O |

Table 17: PQ208 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | $\begin{aligned} & \text { PQ208 } \\ & \text { Pin } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | IO_L13P_0 | P196 | I/O |
| 0 | IO_L14N_O/VREF_0 | P200 | VREF |
| 0 | IO_L14P_0 | P199 | I/O |
| 0 | IO_L15N_0 | P203 | I/O |
| 0 | IO_L15P_0 | P202 | I/O |
| 0 | IO_L16N_0/HSWAP | P206 | DUAL |
| 0 | IO_L16P_0 | P205 | I/O |
| 0 | IP | P159 | INPUT |
| 0 | IP | P169 | INPUT |
| 0 | IP | P194 | INPUT |
| 0 | IP | P204 | INPUT |
| 0 | IP_L06N_0 | P175 | INPUT |
| 0 | IP_L06P_0 | P174 | INPUT |
| 0 | IP_L09N_0/GCLK9 | P184 | GCLK |
| 0 | IP_L09P_0/GCLK8 | P183 | GCLK |
| 0 | VCCO_0 | P176 | vcco |
| 0 | VCCO_0 | P191 | VCCO |
| 0 | VCCO_0 | P201 | vcco |
| 1 | IO_L01N_1/A15 | P107 | DUAL |
| 1 | IO_L01P_1/A16 | P106 | DUAL |
| 1 | 1 O _L02N_1/A13 | P109 | DUAL |
| 1 | IO_L02P_1/A14 | P108 | DUAL |
| 1 | IO_L03N_1/VREF_1 | P113 | VREF |
| 1 | IO_L03P_1 | P112 | I/O |
| 1 | IO_L04N_1 | P116 | I/O |
| 1 | IO_L04P_1 | P115 | I/O |
| 1 | 1 O _L05N_1/A11 | P120 | DUAL |
| 1 | IO_L05P_1/A12 | P119 | DUAL |
| 1 | IO_L06N_1/VREF_1 | P123 | VREF |
| 1 | IO_L06P_1 | P122 | I/O |
| 1 | IO_L07N_1/A9/RHCLK1 | P127 | RHCLK/DUAL |
| 1 | IO_L07P_1/A10/RHCLK0 | P126 | RHCLK/DUAL |
| 1 | IO_L08N_1/A7/RHCLK3 | P129 | RHCLK/DUAL |
| 1 | IO_L08P_1/A8/RHCLK2 | P128 | RHCLK/DUAL |

Table 17: PQ208 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | $\begin{aligned} & \text { PQ208 } \\ & \text { Pin } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 1 | IO_L09N_1/A5/RHCLK5 | P133 | RHCLK/DUAL |
| 1 | IO_L09P_1/A6/RHCLK4 | P132 | RHCLK/DUAL |
| 1 | IO_L10N_1/A3/RHCLK7 | P135 | RHCLK/DUAL |
| 1 | IO_L10P_1/A4/RHCLK6 | P134 | RHCLK/DUAL |
| 1 | IO_L11N_1/A1 | P138 | DUAL |
| 1 | IO_L11P_1/A2 | P137 | DUAL |
| 1 | IO_L12N_1/A0 | P140 | DUAL |
| 1 | IO_L12P_1 | P139 | I/O |
| 1 | IO_L13N_1 | P145 | I/O |
| 1 | IO_L13P_1 | P144 | I/O |
| 1 | IO_L14N_1 | P147 | I/O |
| 1 | IO_L14P_1 | P146 | I/O |
| 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 |

Table 17: PQ208 Package Pinout

| Bank | XC3S250E XC3S500E Pin Name | $\begin{aligned} & \text { PQ208 } \\ & \text { Pin } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 2 | IO_L04N_2 | P63 | I/O |
| 2 | IO_L04P_2 | P62 | I/O |
| 2 | IO_L05N_2 | P65 | 1/0 |
| 2 | IO_L05P_2 | P64 | I/O |
| 2 | IO_L06N_2 | P69 | 1/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 | 1 O _L14N_2/A22 | P94 | DUAL |
| 2 | IO_L14P_2/A23 | P93 | DUAL |
| 2 | 1 O L15N_2/A20 | P97 | DUAL |
| 2 | IO_L15P_2/A21 | P96 | DUAL |
| 2 | IO_L16N_2/VS1/A18 | P100 | DUAL |
| 2 | IO_L16P_2/VS2/A19 | P99 | DUAL |
| 2 | IO_L17N_2/CCLK | P103 | DUAL |
| 2 | IO_L17P_2/VS0/A17 | P102 | DUAL |
| 2 | IP | P54 | INPUT |
| 2 | IP | P91 | INPUT |
| 2 | IP | P101 | INPUT |
| 2 | IP_LO2N_2 | P58 | INPUT |
| 2 | IP_L02P_2 | P57 | INPUT |
| 2 | IP_LO7N_2/VREF_2 | P72 | VREF |
| 2 | IP_L07P_2 | P71 | INPUT |
| 2 | IP_L10N_2/M2/GCLK1 | P81 | DUAL/GCLK |
| 2 | IP_L10P_2/RDWR_B/ GCLK0 | P80 | DUAL/GCLK |
| 2 | VCCO_2 | P59 | vcco |

Table 17: PQ208 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | $\begin{aligned} & \text { PQ208 } \\ & \text { Pin } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 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 |
| 3 | IO_L14P_3 | P41 | I/O |
| 3 | IO_L15N_3 | P48 | I/O |
| 3 | IO_L15P_3 | P47 | I/O |
| 3 | IO_L16N_3 | P50 | I/O |

Table 17: PQ208 Package Pinout

| Bank | XC3S250E XC3S500E Pin Name | $\begin{aligned} & \text { PQ208 } \\ & \text { Pin } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 3 | IO_L16P_3 | P49 | I/O |
| 3 | IP | P6 | INPUT |
| 3 | IP | P14 | INPUT |
| 3 | IP | P26 | INPUT |
| 3 | IP | P32 | INPUT |
| 3 | IP | P43 | INPUT |
| 3 | IP | P51 | INPUT |
| 3 | IP/VREF_3 | P20 | VREF |
| 3 | VCCO_3 | P21 | vCCO |
| 3 | VCCO_3 | P38 | vcco |
| 3 | VCCO_3 | P46 | VCCO |
| GND | GND | P10 | GND |
| GND | GND | P17 | GND |
| GND | GND | P27 | GND |
| GND | GND | P37 | GND |
| GND | GND | P52 | GND |
| GND | GND | P53 | GND |
| GND | GND | P70 | GND |
| GND | GND | P79 | GND |
| GND | GND | P85 | GND |
| GND | GND | P95 | GND |
| GND | GND | P105 | GND |
| GND | GND | P121 | GND |
| GND | GND | P131 | GND |
| GND | GND | P141 | GND |
| GND | GND | P156 | GND |
| GND | GND | P173 | GND |
| GND | GND | P182 | GND |
| GND | GND | P188 | GND |
| GND | GND | P198 | GND |
| GND | GND | P208 | GND |
| VCCAUX | DONE | P104 | CONFIG |
| vCCAUX | PROG_B | P1 | CONFIG |
| vccaux | TCK | P158 | JTAG |

Table 17: PQ208 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | PQ208 <br> Pin | Type |
| :---: | :--- | :---: | :---: |
| VCCAUX | TDI | P207 | JTAG |
| VCCAUX | TDO | P157 | JTAG |
| VCCAUX | TMS | P155 | JTAG |
| VCCAUX | VCCAUX | P7 | VCCAUX |
| VCCAUX | VCCAUX | P44 | VCCAUX |
| VCCAUX | VCCAUX | P66 | VCCAUX |
| VCCAUX | VCCAUX | P92 | VCCAUX |
| VCCAUX | VCCAUX | P149 | VCCAUX |
| VCCAUX | VCCAUX | P166 | VCCAUX |
| VCCAUX | VCCAUX | P195 | VCCAUX |
| VCCAUX | VCCAUX | VCCINT |  |
| VCCINT | VCCINT |  |  |

Table 17: PQ208 Package Pinout

| Bank | XC3S250E <br> XC3S500E <br> Pin Name | PQ208 <br> Pin | Type |
| :---: | :--- | :---: | :---: |
| VCCINT | VCCINT | P67 | VCCINT |
| VCCINT | VCCINT | P117 | VCCINT |
| VCCINT | VCCINT | P170 | VCCINT |

## User I/Os by Bank

Table 18 indicates how the 158 available user-I/O pins are distributed between the four I/O banks on the PQ208 package.

## Footprint Migration Differences

The XC3S250E and XC3S500E FPGAs have identical footprints in the PQ208 package. Designs can migrate between the XC3S250E and XC3S500E without further consideration.

Table 18: User I/Os Per Bank for the XC3S250E and XC3S500E in the PQ208 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 18 | 6 | 1 | 5 | 8 |
| Right | 1 |  | 9 | 7 | 21 | 3 | 0 |
| Bottom | 2 |  | 8 | 6 | 24 | 2 | 0 |
| Left | 3 |  | 23 | 6 | 0 | 3 | 8 |
| TOTAL |  | $\mathbf{1 5 8}$ | $\mathbf{5 8}$ | $\mathbf{2 5}$ | $\mathbf{4 6}$ | $\mathbf{1 3}$ | $\mathbf{1 6}$ |

## PQ208 Footprint (Left)



Figure 5: PQ208 Footprint (Left)

## PQ208 Footprint (Right)



Figure 6: PQ208 Footprint (Right)

## FT256: 256-ball Fine-pitch, Thin Ball Grid Array

The 256-lead fine-pitch, thin ball grid array package, FT256, supports three different Spartan-3E FPGAs, including the XC3S250E, the XC3S500E, and the XC3S1200E.
Table 19 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 highlighted rows indicate pinout differences between the XC3S250E, the XC3S500E, and the XC3S1200E FPGAs. The XC3S250E has 18 unconnected balls, indicated as N.C. (No Connection) in Table 19 and with the black diamond character $(\boldsymbol{)}$ ) in both Table 19 and in Figure 7.

If the table row is highlighted in tan, then this is an instance where an unconnected pin on the XC3S250E FPGA maps to a VREF pin on the XC3S500E and XC3S1200E FPGA. If the FPGA application uses an I/O standard that requires a VREF voltage reference, connect the highlighted pin to the VREF voltage supply, even though this does not actually connect to the XC3S250E FPGA. This VREF connection on the board allows future migration to the larger devices without modifying the printed-circuit board.
All other balls have nearly identical functionality on all three devices. Table 23 summarizes the Spartan-3E footprint migration differences for the FT256 package.
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/bvdocs/publications/s3e_pin.zip.

## Pinout Table

Table 19: FT256 Package Pinout

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 10 | 10 | 10 | A7 | I/O |
| 0 | 10 | 10 | 10 | A12 | I/O |
| 0 | 10 | 10 | 10 | B4 | I/O |
| 0 | IP | IP | 10 | B6 | 250E: INPUT 500E: INPUT 1200E: I/O |
| 0 | IP | IP | 10 | B10 | 250E: INPUT <br> 500E: INPUT <br> 1200E: I/O |
| 0 | IO/VREF_0 | IO/VREF_0 | IO/VREF_0 | D9 | VREF |
| 0 | IO_L01N_0 | IO_L01N_0 | IO_L01N_0 | A14 | I/O |
| 0 | $1 O^{\prime}$ L01P_0 | IO_L01P_0 | 1O_L01P_0 | B14 | I/O |
| 0 | IO_L03N_0/VREF_0 | IO_L03N_0/VREF_0 | IO_L03N_0/VREF_0 | A13 | VREF |
| 0 | IO_L03P_0 | 1O_L03P_0 | 1O_L03P_0 | B13 | I/O |
| 0 | IO_L04N_0 | IO_L04N_0 | IO_L04N_0 | E11 | I/O |
| 0 | 1 O _L04P_0 | 1O_L04P_0 | 1O_L04P_0 | D11 | I/O |
| 0 | IO_L05N_0/VREF_0 | IO_L05N_0/VREF_0 | IO_L05N_0/VREF_0 | B11 | VREF |
| 0 | IO_L05P_0 | 1O_L05P_0 | 1O_L05P_0 | C11 | I/O |
| 0 | IO_L06N_0 | IO_L06N_0 | IO_L06N_0 | E10 | I/O |
| 0 | IO_L06P_0 | 1O_L06P_0 | 1O_L06P_0 | D10 | I/O |
| 0 | IO_L08N_0/GCLK5 | IO_L08N_0/GCLK5 | IO_L08N_0/GCLK5 | F9 | GCLK |
| 0 | IO_L08P_0/GCLK4 | IO_L08P_0/GCLK4 | IO_L08P_0/GCLK4 | E9 | GCLK |
| 0 | IO_L09N_0/GCLK7 | IO_L09N_0/GCLK7 | IO_L09N_0/GCLK7 | A9 | GCLK |

Table 19: FT256 Package Pinout (Continued)

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | IO_L09P_0/GCLK6 | IO_L09P_0/GCLK6 | IO_L09P_0/GCLK6 | A10 | GCLK |
| 0 | IO_L11N_0/GCLK11 | IO_L11N_0/GCLK11 | IO_L11N_0/GCLK11 | D8 | GCLK |
| 0 | IO_L11P_0/GCLK10 | IO_L11P_0/GCLK10 | IO_L11P_0/GCLK10 | C8 | GCLK |
| 0 | IO_L12N_0 | IO_L12N_0 | IO_L12N_0 | F8 | I/O |
| 0 | IO_L12P_0 | IO_L12P_0 | IO_L12P_0 | E8 | I/O |
| 0 | N.C. ( $\downarrow$ ) | IO_L13N_0 | IO_L13N_0 | C7 | $\begin{gathered} \text { 250E: N.C. } \\ \text { 500E: I/O } \\ \text { 1200E: I/O } \end{gathered}$ |
| 0 | N.C. ( ${ }^{\text {) }}$ | IO_L13P_0 | 10_L13P_0 | B7 | $\begin{gathered} \text { 250E: N.C. } \\ \text { 500E: I/O } \\ \text { 1200E: I/O } \end{gathered}$ |
| 0 | IO_L14N_0/VREF_0 | IO_L14N_0/VREF_0 | IO_L14N_0/VREF_0 | D7 | VREF |
| 0 | IO_L14P_0 | IO_L14P_0 | IO_L14P_0 | E7 | I/O |
| 0 | IO_L15N_0 | IO_L15N_0 | IO_L15N_0 | D6 | I/O |
| 0 | IO_L15P_0 | IO_L15P_0 | IO_L15P_0 | C6 | I/O |
| 0 | IO_L17N_0/VREF_0 | IO_L17N_0/VREF_0 | IO_L17N_0/VREF_0 | A4 | VREF |
| 0 | IO_L17P_0 | IO_L17P_0 | IO_L17P_0 | A5 | I/O |
| 0 | IO_L18N_0 | IO_L18N_0 | IO_L18N_0 | C4 | I/O |
| 0 | IO_L18P_0 | IO_L18P_0 | IO_L18P_0 | C5 | I/O |
| 0 | IO_L19N_0/HSWAP | IO_L19N_0/HSWAP | IO_L19N_0/HSWAP | B3 | DUAL |
| 0 | IO_L19P_0 | IO_L19P_0 | IO_L19P_0 | C3 | I/O |
| 0 | IP | IP | IP | A3 | INPUT |
| 0 | IP | IP | IP | C13 | INPUT |
| 0 | IP_L02N_0 | IP_L02N_0 | IP_L02N_0 | C12 | INPUT |
| 0 | IP_L02P_0 | IP_L02P_0 | IP_L02P_0 | D12 | INPUT |
| 0 | IP_L07N_0 | IP_L07N_0 | IP_L07N_0 | C9 | INPUT |
| 0 | IP_L07P_0 | IP_L07P_0 | IP_L07P_0 | C10 | INPUT |
| 0 | IP_L10N_0/GCLK9 | IP_L10N_0/GCLK9 | IP_L10N_0/GCLK9 | B8 | GCLK |
| 0 | IP_L10P_0/GCLK8 | IP_L10P_0/GCLK8 | IP_L10P_0/GCLK8 | A8 | GCLK |
| 0 | IP_L16N_0 | IP_L16N_0 | IP_L16N_0 | E6 | INPUT |
| 0 | IP_L16P_0 | IP_L16P_0 | IP_L16P_0 | D5 | INPUT |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | B5 | VCCO |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | B12 | VCCO |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | F7 | VCCO |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | F10 | VCCO |
| 1 | IO_L01N_1/A15 | IO_L01N_1/A15 | IO_L01N_1/A15 | R15 | DUAL |

Table 19: FT256 Package Pinout (Continued)

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | IO_L01P_1/A16 | IO_L01P_1/A16 | IO_L01P_1/A16 | R16 | DUAL |
| 1 | IO_L02N_1/A13 | IO_L02N_1/A13 | IO_L02N_1/A13 | P15 | DUAL |
| 1 | IO_L02P_1/A14 | IO_L02P_1/A14 | IO_L02P_1/A14 | P16 | DUAL |
| 1 | N.C. ( $\downarrow$ ) | IO_L03N_1/VREF_1 | IO_L03N_1/VREF_1 | N15 | 250E: N.C. <br> 500E: VREF <br> 1200E: VREF |
| 1 | N.C. ( $\downarrow$ ) | IO_L03P_1 | IO_L03P_1 | N14 | $\begin{gathered} \text { 250E: N.C. } \\ \text { 500E: I/O } \\ \text { 1200E: I/O } \end{gathered}$ |
| 1 | IO_L04N_1/VREF_1 | IO_L04N_1/VREF_1 | IO_L04N_1/VREF_1 | M16 | VREF |
| 1 | IO_L04P_1 | IO_L04P_1 | IO_L04P_1 | N16 | I/O |
| 1 | N.C. ( $\downarrow$ ) | IO_L05N_1 | IO_L05N_1 | L13 | $\begin{aligned} & \text { 250E: N.C. } \\ & \text { 500E: I/O } \\ & \text { 1200E: I/O } \end{aligned}$ |
| 1 | N.C. ( $\downarrow$ ) | IO_L05P_1 | IO_L05P_1 | L12 | $\begin{gathered} \text { 250E: N.C. } \\ \text { 500E: I/O } \\ \text { 1200E: I/O } \end{gathered}$ |
| 1 | IO_L06N_1 | IO_L06N_1 | IO_L06N_1 | L15 | I/O |
| 1 | IO_L06P_1 | IO_L06P_1 | IO_L06P_1 | L14 | I/O |
| 1 | IO_L07N_1/A11 | IO_L07N_1/A11 | IO_L07N_1/A11 | K12 | DUAL |
| 1 | IO_L07P_1/A12 | IO_L07P_1/A12 | IO_L07P_1/A12 | K13 | DUAL |
| 1 | IO_L08N_1/VREF_1 | IO_L08N_1/VREF_1 | IO_L08N_1/VREF_1 | K14 | VREF |
| 1 | IO_L08P_1 | IO_L08P_1 | IO_L08P_1 | K15 | I/O |
| 1 | IO_L09N_1/A9/RHCLK1 | IO_L09N_1/A9/RHCLK1 | IO_L09N_1/A9/RHCLK1 | J16 | RHCLK/DUAL |
| 1 | IO_L09P_1/A10/RHCLK0 | IO_L09P_1/A10/RHCLK0 | IO_L09P_1/A10/RHCLK0 | K16 | RHCLK/DUAL |
| 1 | IO_L10N_1/A7/RHCLK3/ TRDY1 | IO_L10N_1/A7/RHCLK3/ TRDY1 | IO_L10N_1/A7/RHCLK3/ TRDY1 | J13 | RHCLK/DUAL |
| 1 | IO_L10P_1/A8/RHCLK2 | IO_L10P_1/A8/RHCLK2 | IO_L10P_1/A8/RHCLK2 | J14 | RHCLK/DUAL |
| 1 | IO_L11N_1/A5/RHCLK5 | IO_L11N_1/A5/RHCLK5 | IO_L11N_1/A5/RHCLK5 | H14 | RHCLK/DUAL |
| 1 | $\begin{aligned} & \text { IO_L11P_1/A6/RHCLK4/ } \\ & \text { IRDY1 } \end{aligned}$ | $\begin{aligned} & \text { IO_L11P_1/A6/RHCLK4/ } \\ & \text { IRDY1 } \end{aligned}$ | $\begin{aligned} & \text { IO_L11P_1/A6/RHCLK4/ } \\ & \text { IRDY1 } \end{aligned}$ | H15 | RHCLK/DUAL |
| 1 | IO_L12N_1/A3/RHCLK7 | IO_L12N_1/A3/RHCLK7 | IO_L12N_1/A3/RHCLK7 | H11 | RHCLK/DUAL |
| 1 | IO_L12P_1/A4/RHCLK6 | IO_L12P_1/A4/RHCLK6 | IO_L12P_1/A4/RHCLK6 | H12 | RHCLK/DUAL |
| 1 | IO_L13N_1/A1 | IO_L13N_1/A1 | IO_L13N_1/A1 | G16 | DUAL |
| 1 | IO_L13P_1/A2 | IO_L13P_1/A2 | IO_L13P_1/A2 | G15 | DUAL |
| 1 | IO_L14N_1/A0 | IO_L14N_1/A0 | IO_L14N_1/A0 | G14 | DUAL |
| 1 | IO_L14P_1 | IO_L14P_1 | IO_L14P_1 | G13 | I/O |
| 1 | IO_L15N_1 | IO_L15N_1 | IO_L15N_1 | F15 | I/O |

Table 19: FT256 Package Pinout (Continued)

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | IO_L15P_1 | IO_L15P_1 | IO_L15P_1 | F14 | I/O |
| 1 | IO_L16N_1 | IO_L16N_1 | IO_L16N_1 | F12 | I/O |
| 1 | IO_L16P_1 | IO_L16P_1 | IO_L16P_1 | F13 | I/O |
| 1 | N.C. ( $)^{\text {( }}$ | IO_L17N_1 | IO_L17N_1 | E16 | $\begin{aligned} & \text { 250E: N.C. } \\ & \text { 500E: I/O } \\ & \text { 1200E: I/O } \end{aligned}$ |
| 1 | N.C. ( ) . | IO_L17P_1 | IO_L17P_1 | E13 | $\begin{aligned} & \text { 250E: N.C. } \\ & \text { 500E: I/O } \\ & \text { 1200E: I/O } \end{aligned}$ |
| 1 | IO_L18N_1/LDC0 | IO_L18N_1/LDC0 | IO_L18N_1/LDC0 | D14 | DUAL |
| 1 | IO_L18P_1/HDC | IO_L18P_1/HDC | IO_L18P_1/HDC | D15 | DUAL |
| 1 | IO_L19N_1/LDC2 | IO_L19N_1/LDC2 | IO_L19N_1/LDC2 | C15 | DUAL |
| 1 | IO_L19P_1/LDC1 | IO_L19P_1/LDC1 | IO_L19P_1/LDC1 | C16 | DUAL |
| 1 | IP | IP | IP | B16 | INPUT |
| 1 | IP | IP | IP | E14 | INPUT |
| 1 | IP | IP | IP | G12 | INPUT |
| 1 | IP | IP | IP | H16 | INPUT |
| 1 | IP | IP | IP | J11 | INPUT |
| 1 | IP | IP | IP | J12 | INPUT |
| 1 | IP | IP | IP | M13 | INPUT |
| 1 | 10 | 10 | IP | M14 | 250E: I/O <br> 500E: I/O <br> 1200E: INPUT |
| 1 | IO/VREF_1 | IP/VREF_1 | IP/VREF_1 | D16 | 250E: VREF(I/O) <br> 500E: <br> VREF(INPUT) 1200E: VREF(INPUT) |
| 1 | IP/VREF_1 | IP/VREF_1 | IP/VREF_1 | H13 | VREF |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | E15 | VCCO |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | G11 | VCCO |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | K11 | VCCO |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | M15 | VCCO |
| 2 | IP | IP | 10 | M7 | 250E: INPUT <br> 500E: INPUT <br> 1200E: I/O |
| 2 | IP | IP | 10 | T12 | 250E: INPUT <br> 500E: INPUT <br> 1200E: I/O |

Table 19: FT256 Package Pinout (Continued)

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 2 | IO/D5 | IO/D5 | IO/D5 | T8 | DUAL |
| 2 | IO/M1 | IO/M1 | IO/M1 | T10 | DUAL |
| 2 | IO/VREF_2 | IO/VREF_2 | IO/VREF_2 | P13 | VREF |
| 2 | IO/VREF_2 | IO/VREF_2 | IO/VREF_2 | R4 | VREF |
| 2 | IO_L01N_2/INIT_B | IO_L01N_2/INIT_B | IO_L01N_2/INIT_B | P4 | DUAL |
| 2 | IO_L01P_2/CSO_B | IO_L01P_2/CSO_B | IO_L01P_2/CSO_B | P3 | DUAL |
| 2 | IO_L03N_2/MOSI/CSI_B | IO_L03N_2/MOSI/CSI_B | IO_L03N_2/MOSI/CSI_B | N5 | DUAL |
| 2 | IO_L03P_2/DOUT/BUSY | IO_L03P_2/DOUT/BUSY | IO_L03P_2/DOUT/BUSY | P5 | DUAL |
| 2 | 1 O _L04N_2 | IO_L04N_2 | 1 O _L04N_2 | T5 | I/O |
| 2 | $1 O^{\prime}$ L04P_2 | IO_L04P_2 | 1 O L04P_2 | T4 | I/O |
| 2 | IO_L05N_2 | IO_L05N_2 | 1 O _L05N_2 | N6 | I/O |
| 2 | IO_L05P_2 | IO_L05P_2 | 1 O L05P_2 | M6 | I/O |
| 2 | IO_L06N_2 | IO_L06N_2 | 1 O _L06N_2 | P6 | I/O |
| 2 | IO_L06P_2 | IO_L06P_2 | 1 O _06P_2 | R6 | I/O |
| 2 | N.C. ( $\downarrow$ ) | 1 O _L07N_2 | 1 O _L07N_2 | P7 | $\begin{aligned} & \text { 250E: N.C. } \\ & \text { 500E: I/O } \\ & \text { 1200E: I/O } \end{aligned}$ |
| 2 | N.C. ( ) | IO_L07P_2 | IO_L07P_2 | N7 | $\begin{aligned} & \text { 250E: N.C. } \\ & \text { 500E: I/O } \\ & \text { 1200E: I/O } \end{aligned}$ |
| 2 | IO_L09N_2/D6/GCLK13 | IO_L09N_2/D6/GCLK13 | IO_L09N_2/D6/GCLK13 | L8 | DUAL/GCLK |
| 2 | IO_L09P_2/D7/GCLK12 | IO_L09P_2/D7/GCLK12 | IO_L09P_2/D7/GCLK12 | M8 | DUAL/GCLK |
| 2 | IO_L10N_2/D3/GCLK15 | IO_L10N_2/D3/GCLK15 | IO_L10N_2/D3/GCLK15 | P8 | DUAL/GCLK |
| 2 | IO_L10P_2/D4/GCLK14 | IO_L10P_2/D4/GCLK14 | IO_L10P_2/D4/GCLK14 | N8 | DUAL/GCLK |
| 2 | IO_L12N_2/D1/GCLK3 | IO_L12N_2/D1/GCLK3 | IO_L12N_2/D1/GCLK3 | N9 | DUAL/GCLK |
| 2 | IO_L12P_2/D2/GCLK2 | IO_L12P_2/D2/GCLK2 | IO_L12P_2/D2/GCLK2 | P9 | DUAL/GCLK |
| 2 | IO_L13N_2/DIN/D0 | IO_L13N_2/DIN/D0 | IO_L13N_2/DIN/D0 | M9 | DUAL |
| 2 | IO_L13P_2/M0 | IO_L13P_2/M0 | IO_L13P_2/M0 | L9 | DUAL |
| 2 | N.C. ( $\downarrow$ ) | IO_L14N_2/VREF_2 | IO_L14N_2/VREF_2 | R10 | 250E: N.C. <br> 500E: VREF <br> 1200E: VREF |
| 2 | N.C. ( ) | IO_L14P_2 | IO_L14P_2 | P10 | $\begin{aligned} & \text { 250E: N.C. } \\ & \text { 500E: I/O } \\ & \text { 1200E: I/O } \end{aligned}$ |
| 2 | IO_L15N_2 | IO_L15N_2 | IO_L15N_2 | M10 | I/O |
| 2 | IO_L15P_2 | IO_L15P_2 | IO_L15P_2 | N10 | I/O |
| 2 | IO_L16N_2/A22 | IO_L16N_2/A22 | IO_L16N_2/A22 | P11 | DUAL |

Table 19: FT256 Package Pinout (Continued)

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 2 | IO_L16P_2/A23 | IO_L16P_2/A23 | IO_L16P_2/A23 | R11 | DUAL |
| 2 | IO_L18N_2/A20 | IO_L18N_2/A20 | IO_L18N_2/A20 | N12 | DUAL |
| 2 | IO_L18P_2/A21 | IO_L18P_2/A21 | IO_L18P_2/A21 | P12 | DUAL |
| 2 | IO_L19N_2/VS1/A18 | IO_L19N_2/VS1/A18 | IO_L19N_2/VS1/A18 | R13 | DUAL |
| 2 | IO_L19P_2/VS2/A19 | IO_L19P_2/VS2/A19 | IO_L19P_2/VS2/A19 | T13 | DUAL |
| 2 | IO_L20N_2/CCLK | IO_L20N_2/CCLK | IO_L20N_2/CCLK | R14 | DUAL |
| 2 | IO_L20P_2/VS0/A17 | IO_L20P_2/VS0/A17 | IO_L20P_2/VS0/A17 | P14 | DUAL |
| 2 | IP | IP | IP | T2 | INPUT |
| 2 | IP | IP | IP | T14 | INPUT |
| 2 | IP_L02N_2 | IP_L02N_2 | IP_L02N_2 | R3 | INPUT |
| 2 | IP_L02P_2 | IP_L02P_2 | IP_L02P_2 | T3 | INPUT |
| 2 | IP_L08N_2/VREF_2 | IP_L08N_2/VREF_2 | IP_L08N_2/VREF_2 | T7 | VREF |
| 2 | IP_L08P_2 | IP_L08P_2 | IP_L08P_2 | R7 | INPUT |
| 2 | IP_L11N_2/M2/GCLK1 | IP_L11N_2/M2/GCLK1 | IP_L11N_2/M2/GCLK1 | R9 | DUAL/GCLK |
| 2 | $\begin{aligned} & \text { IP_L11P_2/RDWR_B/ } \\ & \text { GCLKO } \end{aligned}$ | $\begin{aligned} & \text { IP_L11P_2/RDWR_B/ } \\ & \text { GCLK0 } \end{aligned}$ | $\begin{aligned} & \text { IP_L11P_2/RDWR_B/ } \\ & \text { GCLK0 } \end{aligned}$ | T9 | DUAL/GCLK |
| 2 | IP_L17N_2 | IP_L17N_2 | IP_L17N_2 | M11 | INPUT |
| 2 | IP_L17P_2 | IP_L17P_2 | IP_L17P_2 | N11 | INPUT |
| 2 | VCCO_2 | VCCO_2 | VCCO_2 | L7 | VCCO |
| 2 | VCCO_2 | VCCO_2 | VCCO_2 | L10 | VCCO |
| 2 | VCCO_2 | VCCO_2 | VCCO_2 | R5 | VCCO |
| 2 | VCCO_2 | VCCO_2 | VCCO_2 | R12 | VCCO |
| 3 | IO_L01N_3 | IO_L01N_3 | IO_L01N_3 | B2 | I/O |
| 3 | IO_L01P_3 | IO_L01P_3 | IO_L01P_3 | B1 | I/O |
| 3 | IO_L02N_3/VREF_3 | IO_L02N_3/VREF_3 | IO_L02N_3/VREF_3 | C2 | VREF |
| 3 | IO_L02P_3 | IO_L02P_3 | 1O_L02P_3 | C1 | I/O |
| 3 | IO_L03N_3 | IO_L03N_3 | IO_L03N_3 | E4 | I/O |
| 3 | IO_L03P_3 | 1O_L03P_3 | 1O_L03P_3 | E3 | I/O |
| 3 | N.C. ( $)^{\text {) }}$ | IO_L04N_3/VREF_3 | IO_L04N_3/VREF_3 | F4 | 250E: N.C. <br> 500E: VREF <br> 1200E: VREF |
| 3 | N.C. ( ) | IO_L04P_3 | IO_L04P_3 | F3 | $\begin{gathered} \text { 250E: N.C. } \\ \text { 500E: I/O } \\ \text { 1200E: I/O } \end{gathered}$ |
| 3 | IO_L05N_3 | 1O_L05N_3 | IO_L05N_3 | E1 | I/O |
| 3 | IO_L05P_3 | IO_L05P_3 | 1O_L05P_3 | D1 | I/O |

Table 19: FT256 Package Pinout (Continued)

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | IO_L06N_3 | IO_L06N_3 | IO_L06N_3 | G4 | I/O |
| 3 | IO_L06P_3 | IO_L06P_3 | IO_L06P_3 | G5 | I/O |
| 3 | IO_L07N_3 | IO_L07N_3 | IO_L07N_3 | G2 | I/O |
| 3 | IO_L07P_3 | IO_L07P_3 | IO_L07P_3 | G3 | I/O |
| 3 | IO_L08N_3/LHCLK1 | IO_L08N_3/LHCLK1 | IO_L08N_3/LHCLK1 | H6 | LHCLK |
| 3 | IO_L08P_3/LHCLK0 | IO_L08P_3/LHCLK0 | IO_L08P_3/LHCLK0 | H5 | LHCLK |
| 3 | IO_L09N_3/LHCLK3/ IRDY2 | IO_L09N_3/LHCLK3/ IRDY2 | IO_L09N_3/LHCLK3/ IRDY2 | H4 | LHCLK |
| 3 | IO_L09P_3/LHCLK2 | IO_L09P_3/LHCLK2 | IO_L09P_3/LHCLK2 | H3 | LHCLK |
| 3 | IO_L10N_3/LHCLK5 | IO_L10N_3/LHCLK5 | IO_L10N_3/LHCLK5 | J3 | LHCLK |
| 3 | IO_L10P_3/LHCLK4/ TRDY2 | IO_L10P_3/LHCLK4/ TRDY2 | IO_L10P_3/LHCLK4/ TRDY2 | J2 | LHCLK |
| 3 | IO_L11N_3/LHCLK7 | IO_L11N_3/LHCLK7 | IO_L11N_3/LHCLK7 | J4 | LHCLK |
| 3 | IO_L11P_3/LHCLK6 | IO_L11P_3/LHCLK6 | IO_L11P_3/LHCLK6 | J5 | LHCLK |
| 3 | IO_L12N_3 | IO_L12N_3 | IO_L12N_3 | K1 | I/O |
| 3 | IO_L12P_3 | IO_L12P_3 | IO_L12P_3 | J1 | I/O |
| 3 | IO_L13N_3 | IO_L13N_3 | IO_L13N_3 | K3 | I/O |
| 3 | IO_L13P_3 | IO_L13P_3 | IO_L13P_3 | K2 | I/O |
| 3 | N.C. ( ${ }^{\text {) }}$ | IO_L14N_3/VREF_3 | IO_L14N_3/VREF_3 | L2 | 250E: N.C. <br> 500E: VREF <br> 1200E: VREF |
| 3 | N.C. ( ) | IO_L14P_3 | IO_L14P_3 | L3 | $\begin{gathered} \text { 250E: N.C. } \\ \text { 500E: I/O } \\ \text { 1200E: I/O } \end{gathered}$ |
| 3 | IO_L15N_3 | IO_L15N_3 | IO_L15N_3 | L5 | I/O |
| 3 | IO_L15P_3 | IO_L15P_3 | IO_L15P_3 | K5 | I/O |
| 3 | IO_L16N_3 | IO_L16N_3 | IO_L16N_3 | N1 | I/O |
| 3 | IO_L16P_3 | IO_L16P_3 | IO_L16P_3 | M1 | I/O |
| 3 | N.C. ( $\downarrow$ ) | IO_L17N_3 | IO_L17N_3 | L4 | $\begin{gathered} \text { 250E: N.C. } \\ \text { 500E: I/O } \\ \text { 1200E: I/O } \end{gathered}$ |
| 3 | N.C. ( $)^{\text {) }}$ | IO_L17P_3 | IO_L17P_3 | M4 | $\begin{gathered} \text { 250E: N.C. } \\ \text { 500E: I/O } \\ \text { 1200E: I/O } \end{gathered}$ |
| 3 | IO_L18N_3 | IO_L18N_3 | IO_L18N_3 | P1 | I/O |
| 3 | IO_L18P_3 | IO_L18P_3 | IO_L18P_3 | P2 | I/O |
| 3 | IO_L19N_3 | IO_L19N_3 | IO_L19N_3 | R1 | I/O |
| 3 | IO_L19P_3 | IO_L19P_3 | IO_L19P_3 | R2 | I/O |

Table 19: FT256 Package Pinout (Continued)

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | IP | IP | IP | D2 | INPUT |
| 3 | IP | IP | IP | F2 | INPUT |
| 3 | 10 | 10 | IP | F5 | 250E: I/O <br> 500E: I/O <br> 1200E: INPUT |
| 3 | IP | IP | IP | H1 | INPUT |
| 3 | IP | IP | IP | J6 | INPUT |
| 3 | IP | IP | IP | K4 | INPUT |
| 3 | IP | IP | IP | M3 | INPUT |
| 3 | IP | IP | IP | N3 | INPUT |
| 3 | IP/VREF_3 | IP/VREF_3 | IP/VREF_3 | G1 | VREF |
| 3 | IO/VREF_3 | IO/VREF_3 | IP/VREF_3 | N2 | 250E: VREF(I/O) <br> 500E: VREF(//O) <br> 1200E: <br> VREF(INPUT) |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | E2 | VCCO |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | G6 | VCCO |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | K6 | VCCO |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | M2 | VCCO |
| GND | GND | GND | GND | A1 | GND |
| GND | GND | GND | GND | A16 | GND |
| GND | GND | GND | GND | B9 | GND |
| GND | GND | GND | GND | F6 | GND |
| GND | GND | GND | GND | F11 | GND |
| GND | GND | GND | GND | G7 | GND |
| GND | GND | GND | GND | G8 | GND |
| GND | GND | GND | GND | G9 | GND |
| GND | GND | GND | GND | G10 | GND |
| GND | GND | GND | GND | H2 | GND |
| GND | GND | GND | GND | H7 | GND |
| GND | GND | GND | GND | H8 | GND |
| GND | GND | GND | GND | H9 | GND |
| GND | GND | GND | GND | H10 | GND |
| GND | GND | GND | GND | J7 | GND |
| GND | GND | GND | GND | J8 | GND |
| GND | GND | GND | GND | J9 | GND |

Table 19: FT256 Package Pinout (Continued)

| Bank | XC3S250E Pin Name | XC3S500E Pin Name | XC3S1200E Pin Name | $\begin{gathered} \text { FT256 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| GND | GND | GND | GND | J10 | GND |
| GND | GND | GND | GND | J15 | GND |
| GND | GND | GND | GND | K7 | GND |
| GND | GND | GND | GND | K8 | GND |
| GND | GND | GND | GND | K9 | GND |
| GND | GND | GND | GND | K10 | GND |
| GND | GND | GND | GND | L6 | GND |
| GND | GND | GND | GND | L11 | GND |
| GND | GND | GND | GND | R8 | GND |
| GND | GND | GND | GND | T1 | GND |
| GND | GND | GND | GND | T16 | GND |
| VCCAUX | DONE | DONE | DONE | T15 | CONFIG |
| VCCAUX | PROG_B | PROG_B | PROG_B | D3 | CONFIG |
| VCCAUX | TCK | TCK | TCK | A15 | JTAG |
| VCCAUX | TDI | TDI | TDI | A2 | JTAG |
| VCCAUX | TDO | TDO | TDO | C14 | JTAG |
| VCCAUX | TMS | TMS | TMS | B15 | JTAG |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | A6 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | A11 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | F1 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | F16 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | L1 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | L16 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | T6 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | T11 | VCCAUX |
| VCCINT | VCCINT | VCCINT | VCCINT | D4 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | D13 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | E5 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | E12 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | M5 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | M12 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | N4 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | N13 | VCCINT |

## User I/Os by Bank

Table 20, Table 21, and Table 22 indicate how the available user-I/O pins are distributed between the four I/O banks on the FT256 package.

The XC3S250E FPGA in the FT256 package has 18 unconnected balls, labeled with an "N.C." type. These pins are also indicated with the black diamond ( $\leqslant$ ) symbol in Figure 7.

Table 20: User I/Os Per Bank on XC3S250E in the FT256 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 20 | 10 | 1 | 5 | 8 |
| Right | 1 |  | 10 | 7 | 21 | 4 | 0 |
| Bottom | 2 |  | 8 | 9 | 24 | 3 | 0 |
| Left | 3 |  | 24 | 7 | 0 | 3 | 8 |
| TOTAL |  | $\mathbf{1 7 2}$ | $\mathbf{6 2}$ | $\mathbf{3 3}$ | $\mathbf{4 6}$ | $\mathbf{1 5}$ | $\mathbf{1 6}$ |

Table 21: User I/Os Per Bank on XC3S500E in the FT256 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 22 | 10 | 1 | 5 | 8 |
| Right | 1 |  | 15 | 7 | 21 | 5 | 0 |
| Bottom | 2 |  | 11 | 9 | 24 | 4 | 0 |
| Left | 3 |  | 28 | 7 | 0 | 5 | 8 |
| TOTAL |  |  | $\mathbf{7 6}$ | $\mathbf{3 3}$ | $\mathbf{4 6}$ | $\mathbf{1 9}$ | $\mathbf{1 6}$ |

Table 22: User I/Os Per Bank on XC3S1200E in the FT256 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 24 | 8 | 1 | 5 | 8 |
| Right | 1 |  | 14 | 8 | 21 | 5 | 0 |
| Bottom | 2 |  | 13 | 7 | 24 | 4 | 0 |
| Left | 3 |  | 27 | 8 | 0 | 5 | 8 |
| TOTAL |  | $\mathbf{1 9 0}$ | $\mathbf{7 8}$ | $\mathbf{3 1}$ | $\mathbf{4 6}$ | $\mathbf{1 9}$ | $\mathbf{1 6}$ |

## Footprint Migration Differences

Table 23 summarizes any footprint and functionality differences between the XC3S250E, the XC3S500E, and the XC3S1200E FPGAs that may affect easy migration between devices in the FG256 package. There are 26 such balls. All other pins not listed in Table 23 unconditionally migrate between Spartan-3E devices available in the FT256 package.
The XC3S250E is duplicated on both the left and right sides of the table to show migrations to and from the XC3S500E
and the XC3S1200E. The arrows indicate the direction for easy migration. A double-ended arrow $(\leftarrow \rightarrow$ ) indicates that the two pins have identical functionality. A left-facing arrow $(\leftarrow)$ indicates that the pin on the device on the right unconditionally migrates to the pin on the device on the left. It may be possible to migrate the opposite direction depending on the I/O configuration. For example, an I/O pin (Type $=I / O$ ) can migrate to an input-only pin (Type $=$ INPUT) if the I/O pin is configured as an input.

Table 23: FT256 Footprint Migration Differences

| FT256 <br> Ball | Bank | XC3S250E <br> Type | Migration | XC3S500E <br> Type | Migration | XC3S1200E <br> Type | Migration | XC3S250E <br> Type |
| :---: | :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| B6 | 0 | INPUT | $\leftarrow \rightarrow$ | INPUT | $\rightarrow$ | I/O | $\leftarrow$ | INPUT |
| B7 | 0 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| B10 | 0 | INPUT | $\leftarrow \rightarrow$ | INPUT | $\rightarrow$ | I/O | $\leftarrow$ | INPUT |
| C7 | 0 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| D16 | 1 | VREF(I/O) | $\leftarrow$ | VREF(INPUT) | $\leftarrow \rightarrow$ | VREF(INPUT) | $\rightarrow$ | VREF(I/O) |
| E13 | 1 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| E16 | 1 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| F3 | 3 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| F4 | 3 | N.C. | $\rightarrow$ | VREF | $\leftarrow \rightarrow$ | VREF | $\leftarrow$ | N.C. |
| F5 | 3 | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | INPUT | $\rightarrow$ | I/O |
| L2 | 3 | N.C. | $\rightarrow$ | VREF | $\leftarrow \rightarrow$ | VREF | $\leftarrow$ | N.C. |
| L3 | 3 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| L4 | 3 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| L12 | 1 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| L13 | 1 | N.C. | $\rightarrow$ | I/O | $\leftarrow$ | N.C. |  |  |
| M4 | 3 | N.C. | $\rightarrow$ | I/O | I/O | $\leftarrow$ | N.C. |  |
| M7 | 2 | INPUT | $\leftarrow \rightarrow$ | INPUT | $\leftarrow$ | I/O | $\leftarrow$ | INPUT |
| M14 | 1 | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | INPUT | $\rightarrow$ | I/O |
| N2 | 3 | VREF(I/O) | $\leftarrow \rightarrow$ | VREF(I/O) | $\leftarrow$ | VREF(INPUT) | $\rightarrow$ | VREF(I/O) |
| N7 | 2 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| N14 | 1 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| N15 | 1 | N.C. | $\rightarrow$ | VREF | $\leftarrow \rightarrow$ | VREF | $\leftarrow$ | N.C. |
| P7 | 2 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| P10 | 2 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | N.C. |  |
| R10 | 2 | N.C. | $\rightarrow$ | VREF | $\leftarrow \rightarrow$ | VREF | $\leftarrow$ | N.C. |
| T12 | 2 | INPUT | $\leftarrow \rightarrow$ | INPUT | $\boldsymbol{7}$ | I/O | INPUT |  |
|  | DIFFERENCES | 19 |  |  | $\mathbf{2 6}$ |  |  |  |
| L |  |  |  |  |  |  |  |  |

## Legend:

$\longleftrightarrow \quad$ This pin is identical on both the device on the left and the right.
$\rightarrow \quad$ This pin can unconditionally migrate from the device on the left to the device on the right. Migration in the other direction may be possible depending on how the pin is configured for the device on the right.
$\leftarrow \quad$ This pin can unconditionally migrate from the device on the right to the device on the left. Migration in the other direction may be possible depending on how the pin is configured for the device on the left.

## FT256 Footprint



Figure 7: FT256 Package Footprint (top view)

| 2 | CONFIG: Dedicated configuration pins | 4 | JTAG: Dedicated JTAG port pins | 8 | VCCINT: Internal core supply voltage (+1.2V) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 28 | GND: Ground | 16 | VCCO: Output voltage supply for bank | 8 | VCCAUX: Auxiliary supply voltage (+2.5V) |
| $\begin{gathered} 6 \\ \leftarrow \rightarrow \end{gathered}$ | Migration Difference: For flexible package migration, use these pins as inputs. | 18 | Unconnected pins on XC3S250E |  |  |

## FG320: 320-ball Fine-pitch Ball Grid Array

The 320-lead fine-pitch ball grid array package, FG320, supports three different Spartan-3E FPGAs, including the XC3S500E, the XC3S1200E, and the XC3S1600E, as shown in Table 24 and Figure 8.
The FG320 package is an $18 \times 18$ array of solder balls minus the four center balls.
Table 24 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 highlighted rows indicate pinout differences between the XC3S500E, the XC3S1200E, and the XC3S1600E FPGAs. The XC3S500E has 18 unconnected balls, indicated as N.C. (No Connection) in Table 24 and with the black diamond character ( ) in both Table 24 and in Figure 8.

If the table row is highlighted in tan, then this is an instance where an unconnected pin on the XC3S500E FPGA maps to a VREF pin on the XC3S1200E and XC3S1600E FPGA. If the FPGA application uses an I/O standard that requires a VREF voltage reference, connect the highlighted pin to the VREF voltage supply, even though this does not actually connect to the XC3S500E FPGA. This VREF connection on the board allows future migration to the larger devices without modifying the printed-circuit board.
All other balls have nearly identical functionality on all three devices. Table 23 summarizes the Spartan-3E footprint migration differences for the FG320 package.
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/bvdocs/publications/s3e_pin.zip.

## Pinout Table

## Table 24: FG320 Package Pinout

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | IP | 10 | 10 | A7 | ```500E: INPUT 1200E: I/O 1600E: I/O``` |
| 0 | 10 | 10 | 10 | A8 | I/O |
| 0 | 10 | 10 | 10 | A11 | I/O |
| 0 | 10 | 10 | 10 | C4 | I/O |
| 0 | IP | 10 | 10 | D13 | $\begin{gathered} \text { 500E: INPUT } \\ \text { 1200E: I/O } \\ \text { 1600E: I/O } \end{gathered}$ |
| 0 | 10 | 10 | 10 | E13 | I/O |
| 0 | 10 | 10 | 10 | G9 | I/O |
| 0 | IO/VREF_0 | IO/VREF_0 | IO/VREF_0 | B11 | VREF |
| 0 | IO_L01N_0 | IO_L01N_0 | IO_L01N_0 | A16 | I/O |
| 0 | $1 O^{\prime}$ L01P_0 | 1 O _L01P_0 | IO_L01P_0 | B16 | I/O |
| 0 | IO_L03N_0/VREF_0 | IO_L03N_0/VREF_0 | IO_L03N_0/VREF_0 | C14 | VREF |
| 0 | IO_L03P_0 | IO_L03P_0 | IO_L03P_0 | D14 | I/O |
| 0 | 1 O _L04N_0 | 1 O _L04N_0 | IO_L04N_0 | A14 | 1/O |
| 0 | IO_L04P_0 | 1 O _L04P_0 | IO_L04P_0 | B14 | I/O |
| 0 | IO_L05N_0/VREF_0 | IO_L05N_0/VREF_0 | IO_L05N_0/VREF_0 | B13 | VREF |
| 0 | IO_L05P_0 | IO_L05P_0 | IO_L05P_0 | A13 | I/O |
| 0 | IO_L06N_0 | IO_L06N_0 | IO_L06N_0 | E12 | 1/O |
| 0 | IO_L06P_0 | IO_L06P_0 | IO_L06P_0 | F12 | I/O |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | IO_L08N_0 | IO_L08N_0 | IO_L08N_0 | F11 | I/O |
| 0 | 1O_L08P_0 | IO_L08P_0 | IO_L08P_0 | E11 | I/O |
| 0 | IO_L09N_0 | IO_L09N_0 | 1 O _L09N_0 | D11 | I/O |
| 0 | 1O_L09P_0 | IO_L09P_0 | IO_L09P_0 | C11 | I/O |
| 0 | IO_L11N_0/GCLK5 | IO_L11N_0/GCLK5 | IO_L11N_0/GCLK5 | E10 | GCLK |
| 0 | IO_L11P_0/GCLK4 | IO_L11P_0/GCLK4 | IO_L11P_0/GCLK4 | D10 | GCLK |
| 0 | IO_L12N_0/GCLK7 | IO_L12N_0/GCLK7 | IO_L12N_0/GCLK7 | A10 | GCLK |
| 0 | IO_L12P_0/GCLK6 | IO_L12P_0/GCLK6 | IO_L12P_0/GCLK6 | B10 | GCLK |
| 0 | IO_L14N_0/GCLK11 | IO_L14N_0/GCLK11 | IO_L14N_0/GCLK11 | D9 | GCLK |
| 0 | IO_L14P_0/GCLK10 | IO_L14P_0/GCLK10 | IO_L14P_0/GCLK10 | C9 | GCLK |
| 0 | IO_L15N_0 | IO_L15N_0 | IO_L15N_0 | F9 | I/O |
| 0 | IO_L15P_0 | IO_L15P_0 | IO_L15P_0 | E9 | I/O |
| 0 | IO_L17N_0 | IO_L17N_0 | IO_L17N_0 | F8 | I/O |
| 0 | IO_L17P_0 | IO_L17P_0 | IO_L17P_0 | E8 | I/O |
| 0 | IO_L18N_0/VREF_0 | IO_L18N_0/VREF_0 | IO_L18N_0/VREF_0 | D7 | VREF |
| 0 | 1O_L18P_0 | IO_L18P_0 | IO_L18P_0 | C7 | I/O |
| 0 | IO_L19N_0/VREF_0 | IO_L19N_0/VREF_0 | IO_L19N_0/VREF_0 | E7 | VREF |
| 0 | IO_L19P_0 | IO_L19P_0 | IO_L19P_0 | F7 | I/O |
| 0 | 1 O _L20N_0 | IO_L20N_0 | 1 O _L20N_0 | A6 | I/O |
| 0 | 1O_L20P_0 | IO_L20P_0 | IO_L20P_0 | B6 | I/O |
| 0 | N.C. ( $\downarrow$ ) | 1 O | 1 O _L21N_0 | E6 | 500E: N.C. <br> 1200E: I/O <br> 1600E: I/O |
| 0 | N.C. ( ) | $1 O^{\prime}$ L21P_0 | $10 \_L 21$ P_0 | D6 | 500E: N.C. <br> 1200E: I/O <br> 1600E: I/O |
| 0 | IO_L23N_0/VREF_0 | IO_L23N_0/VREF_0 | IO_L23N_0/VREF_0 | D5 | VREF |
| 0 | IO_L23P_0 | IO_L23P_0 | IO_L23P_0 | C5 | I/O |
| 0 | IO_L24N_0 | IO_L24N_0 | IO_L24N_0 | B4 | I/O |
| 0 | IO_L24P_0 | IO_L24P_0 | IO_L24P_0 | A4 | I/O |
| 0 | IO_L25N_0/HSWAP | IO_L25N_0/HSWAP | IO_L25N_0/HSWAP | B3 | DUAL |
| 0 | IO_L25P_0 | IO_L25P_0 | IO_L25P_0 | C3 | I/O |
| 0 | IP | IP | IP | A3 | INPUT |
| 0 | N.C. ( ) | 10 | IP | A12 | 500E: N.C. <br> 1200E: I/O 1600E: INPUT |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | IP | IP | IP | C15 | INPUT |
| 0 | IP_L02N_0 | IP_L02N_0 | IP_L02N_0 | A15 | INPUT |
| 0 | IP_L02P_0 | IP_L02P_0 | IP_L02P_0 | B15 | INPUT |
| 0 | IP_L07N_0 | IP_L07N_0 | IP_L07N_0 | D12 | INPUT |
| 0 | IP_L07P_0 | IP_L07P_0 | IP_L07P_0 | C12 | INPUT |
| 0 | IP_L10N_0 | IP_L10N_0 | IP_L10N_0 | G10 | INPUT |
| 0 | IP_L10P_0 | IP_L10P_0 | IP_L10P_0 | F10 | INPUT |
| 0 | IP_L13N_0/GCLK9 | IP_L13N_0/GCLK9 | IP_L13N_0/GCLK9 | B9 | GCLK |
| 0 | IP_L13P_0/GCLK8 | IP_L13P_0/GCLK8 | IP_L13P_0/GCLK8 | B8 | GCLK |
| 0 | IP_L16N_0 | IP_L16N_0 | IP_L16N_0 | D8 | INPUT |
| 0 | IP_L16P_0 | IP_L16P_0 | IP_L16P_0 | C8 | INPUT |
| 0 | IP_L22N_0 | IP_L22N_0 | IP_L22N_0 | B5 | INPUT |
| 0 | IP_L22P_0 | IP_L22P_0 | IP_L22P_0 | A5 | INPUT |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | A9 | VCCO |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | C6 | VCCO |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | C13 | VCCO |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | G8 | VCCO |
| 0 | VCCO_0 | VCCO_0 | VCCO_0 | G11 | VCCO |
| 1 | N.C. ( $)^{\text {) }}$ | 10 | 10 | P16 | $\begin{aligned} & \text { 500E: N.C. } \\ & \text { 1200E: I/O } \\ & \text { 1600E: I/O } \end{aligned}$ |
| 1 | IO_L01N_1/A15 | IO_L01N_1/A15 | IO_L01N_1/A15 | T17 | DUAL |
| 1 | IO_L01P_1/A16 | IO_L01P_1/A16 | IO_L01P_1/A16 | U18 | DUAL |
| 1 | IO_L02N_1/A13 | IO_L02N_1/A13 | IO_L02N_1/A13 | T18 | DUAL |
| 1 | IO_L02P_1/A14 | IO_L02P_1/A14 | IO_L02P_1/A14 | R18 | DUAL |
| 1 | IO_L03N_1/VREF_1 | IO_L03N_1/VREF_1 | IO_L03N_1/VREF_1 | R16 | VREF |
| 1 | IO_L03P_1 | IO_L03P_1 | IO_L03P_1 | R15 | I/O |
| 1 | N.C. ( $)^{\text {) }}$ | IO_L04N_1 | IO_L04N_1 | N14 | 500E: N.C. <br> 1200E: I/O <br> 1600E: INPUT |
| 1 | N.C. ( ) | IO_L04P_1 | IO_L04P_1 | N15 | 500E: N.C. <br> 1200E: I/O <br> 1600E: INPUT |
| 1 | IO_L05N_1/VREF_1 | IO_L05N_1/VREF_1 | IO_L05N_1/VREF_1 | M13 | VREF |
| 1 | IO_L05P_1 | IO_L05P_1 | IO_L05P_1 | M14 | I/O |
| 1 | IO_L06N_1 | IO_L06N_1 | IO_L06N_1 | P18 | I/O |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | IO_L06P_1 | IO_L06P_1 | IO_L06P_1 | P17 | I/O |
| 1 | IO_L07N_1 | IO_L07N_1 | IO_L07N_1 | M16 | I/O |
| 1 | IO_L07P_1 | IO_L07P_1 | IO_L07P_1 | M15 | I/O |
| 1 | IO_L08N_1 | 1O_L08N_1 | IO_L08N_1 | M18 | I/O |
| 1 | IO_L08P_1 | IO_L08P_1 | IO_L08P_1 | N18 | I/O |
| 1 | IO_L09N_1/A11 | IO_L09N_1/A11 | IO_L09N_1/A11 | L15 | DUAL |
| 1 | IO_L09P_1/A12 | IO_L09P_1/A12 | IO_L09P_1/A12 | L16 | DUAL |
| 1 | IO_L10N_1/VREF_1 | IO_L10N_1/VREF_1 | IO_L10N_1/VREF_1 | L17 | VREF |
| 1 | IO_L10P_1 | IO_L10P_1 | IO_L10P_1 | L18 | I/O |
| 1 | IO_L11N_1/A9/RHCLK1 | IO_L11N_1/A9/RHCLK1 | IO_L11N_1/A9/RHCLK1 | K12 | RHCLK/DUAL |
| 1 | IO_L11P_1/A10/RHCLK0 | IO_L11P_1/A10/RHCLK0 | IO_L11P_1/A10/RHCLK0 | K13 | RHCLK/DUAL |
| 1 | IO_L12N_1/A7/RHCLK3/ TRDY1 | $\begin{aligned} & \text { IO_L12N_1/A7/RHCLK3/ } \\ & \text { TRDY1 } \end{aligned}$ | $\begin{aligned} & \text { IO_L12N_1/A7/RHCLK3/ } \\ & \text { TRDY1 } \end{aligned}$ | K14 | RHCLK/DUAL |
| 1 | IO_L12P_1/A8/RHCLK2 | IO_L12P_1/A8/RHCLK2 | IO_L12P_1/A8/RHCLK2 | K15 | RHCLK/DUAL |
| 1 | IO_L13N_1/A5/RHCLK5 | IO_L13N_1/A5/RHCLK5 | IO_L13N_1/A5/RHCLK5 | J16 | RHCLK/DUAL |
| 1 | $\begin{aligned} & \text { IO_L13P_1/A6/RHCLK4/ } \\ & \text { IRDY1 } \end{aligned}$ | IO_L13P_1/A6/RHCLK4/ IRDY1 | $\begin{aligned} & \text { IO_L13P_1/A6/RHCLK4/ } \\ & \text { IRDY1 } \end{aligned}$ | J17 | RHCLK/DUAL |
| 1 | IO_L14N_1/A3/RHCLK7 | IO_L14N_1/A3/RHCLK7 | IO_L14N_1/A3/RHCLK7 | J14 | RHCLK/DUAL |
| 1 | IO_L14P_1/A4/RHCLK6 | IO_L14P_1/A4/RHCLK6 | IO_L14P_1/A4/RHCLK6 | J15 | RHCLK/DUAL |
| 1 | IO_L15N_1/A1 | IO_L15N_1/A1 | IO_L15N_1/A1 | J13 | DUAL |
| 1 | IO_L15P_1/A2 | IO_L15P_1/A2 | IO_L15P_1/A2 | J12 | DUAL |
| 1 | IO_L16N_1/A0 | IO_L16N_1/A0 | IO_L16N_1/A0 | H17 | DUAL |
| 1 | IO_L16P_1 | IO_L16P_1 | IO_L16P_1 | H16 | I/O |
| 1 | IO_L17N_1 | IO_L17N_1 | IO_L17N_1 | H15 | I/O |
| 1 | IO_L17P_1 | IO_L17P_1 | IO_L17P_1 | H14 | I/O |
| 1 | IO_L18N_1 | IO_L18N_1 | IO_L18N_1 | G16 | I/O |
| 1 | IO_L18P_1 | IO_L18P_1 | IO_L18P_1 | G15 | I/O |
| 1 | IO_L19N_1 | IO_L19N_1 | IO_L19N_1 | F17 | I/O |
| 1 | IO_L19P_1 | IO_L19P_1 | IO_L19P_1 | F18 | 1/O |
| 1 | IO_L20N_1 | IO_L20N_1 | IO_L20N_1 | G13 | I/O |
| 1 | IO_L20P_1 | IO_L20P_1 | 10_L20P_1 | G14 | I/O |
| 1 | IO_L21N_1 | IO_L21N_1 | IO_L21N_1 | F14 | I/O |
| 1 | IO_L21P_1 | 1O_L21P_1 | IO_L21P_1 | F15 | I/O |
| 1 | N.C. ( ${ }^{\text {) }}$ | IO_L22N_1 | IO_L22N_1 | E16 | $\begin{aligned} & \text { 500E: N.C. } \\ & \text { 1200E: I/O } \\ & \text { 1600E: I/O } \end{aligned}$ |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | N.C. ( ) | $1 O^{\prime}$ L22P_1 | IO_L22P_1 | E15 | $\begin{aligned} & \text { 500E: N.C. } \\ & \text { 1200E: I/O } \\ & \text { 1600E: I/O } \end{aligned}$ |
| 1 | IO_L23N_1/LDC0 | IO_L23N_1/LDC0 | IO_L23N_1/LDC0 | D16 | DUAL |
| 1 | IO_L23P_1/HDC | IO_L23P_1/HDC | IO_L23P_1/HDC | D17 | DUAL |
| 1 | IO_L24N_1/LDC2 | IO_L24N_1/LDC2 | IO_L24N_1/LDC2 | C17 | DUAL |
| 1 | IO_L24P_1/LDC1 | IO_L24P_1/LDC1 | IO_L24P_1/LDC1 | C18 | DUAL |
| 1 | IP | IP | IP | B18 | INPUT |
| 1 | 10 | IP | IP | E17 | 500E: I/O 1200E: INPUT 1600E: INPUT |
| 1 | IP | IP | IP | E18 | INPUT |
| 1 | IP | IP | IP | G18 | INPUT |
| 1 | IP | IP | IP | H13 | INPUT |
| 1 | IP | IP | IP | K17 | INPUT |
| 1 | IP | IP | IP | K18 | INPUT |
| 1 | IP | IP | IP | L13 | INPUT |
| 1 | IP | IP | IP | L14 | INPUT |
| 1 | IP | IP | IP | N17 | INPUT |
| 1 | 10 | IP | IP | P15 | 500E: I/O 1200E: INPUT 1600E: INPUT |
| 1 | IP | IP | IP | R17 | INPUT |
| 1 | IP/VREF_1 | IP/VREF_1 | IP/VREF_1 | D18 | VREF |
| 1 | IP/VREF_1 | IP/VREF_1 | IP/VREF_1 | H18 | VREF |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | F16 | VCCO |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | H12 | VCCO |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | J18 | VCCO |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | L12 | VCCO |
| 1 | VCCO_1 | VCCO_1 | VCCO_1 | N16 | VCCO |
| 2 | 10 | 10 | 10 | P9 | I/O |
| 2 | 10 | 10 | 10 | R11 | I/O |
| 2 | IP | 10 | 10 | U6 | $\begin{gathered} \text { 500E: INPUT } \\ \text { 1200E: I/O } \\ \text { 1600E: I/O } \end{gathered}$ |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 2 | IP | 10 | 10 | U13 | $\begin{gathered} \text { 500E: INPUT } \\ \text { 1200E: I/O } \\ \text { 1600E: I/O } \end{gathered}$ |
| 2 | N.C. ( $\downarrow$ ) | 10 | 10 | V7 | 500E: N.C. <br> 1200E: I/O <br> 1600E: I/O |
| 2 | IO/D5 | IO/D5 | IO/D5 | R9 | DUAL |
| 2 | IO/M1 | IO/M1 | IO/M1 | V11 | DUAL |
| 2 | IO/VREF_2 | IO/VREF_2 | IO/VREF_2 | T15 | VREF |
| 2 | IO/VREF_2 | IO/VREF_2 | IO/VREF_2 | U5 | VREF |
| 2 | IO_L01N_2/INIT_B | IO_L01N_2/INIT_B | IO_L01N_2/INIT_B | T3 | DUAL |
| 2 | IO_L01P_2/CSO_B | IO_L01P_2/CSO_B | IO_L01P_2/CSO_B | U3 | DUAL |
| 2 | IO_L03N_2/MOSI/CSI_B | IO_L03N_2/MOSI/CSI_B | IO_L03N_2/MOSI/CSI_B | T4 | DUAL |
| 2 | IO_L03P_2/DOUT/BUSY | IO_L03P_2/DOUT/BUSY | IO_L03P_2/DOUT/BUSY | U4 | DUAL |
| 2 | 1 O | IO_L04N_2 | IO_L04N_2 | T5 | I/O |
| 2 | IO_L04P_2 | IO_L04P_2 | IO_L04P_2 | R5 | I/O |
| 2 | IO_L05N_2 | IO_L05N_2 | IO_L05N_2 | P6 | I/O |
| 2 | IO_L05P_2 | IO_L05P_2 | IO_L05P_2 | R6 | I/O |
| 2 | N.C. ( $\downarrow$ ) | IO_L06N_2/VREF_2 | IO_L06N_2/VREF_2 | V6 | 500E: N.C. <br> 1200E: VREF <br> 1600E: VREF |
| 2 | N.C. ( ) | IO_L06P_2 | 1O_L06P_2 | V5 | $\begin{aligned} & \text { 500E: N.C. } \\ & \text { 1200E: I/O } \\ & \text { 1600E: I/O } \end{aligned}$ |
| 2 | 1 O | IO_L07N_2 | IO_L07N_2 | P7 | I/O |
| 2 | IO_L07P_2 | IO_L07P_2 | IO_L07P_2 | N7 | I/O |
| 2 | IO_L09N_2 | IO_L09N_2 | IO_L09N_2 | N8 | I/O |
| 2 | IO_L09P_2 | IO_L09P_2 | IO_L09P_2 | P8 | I/O |
| 2 | IO_L10N_2 | IO_L10N_2 | IO_L10N_2 | T8 | I/O |
| 2 | IO_L10P_2 | IO_L10P_2 | IO_L10P_2 | R8 | I/O |
| 2 | IO_L12N_2/D6/GCLK13 | IO_L12N_2/D6/GCLK13 | IO_L12N_2/D6/GCLK13 | M9 | DUAL/GCLK |
| 2 | IO_L12P_2/D7/GCLK12 | IO_L12P_2/D7/GCLK12 | IO_L12P_2/D7/GCLK12 | N9 | DUAL/GCLK |
| 2 | IO_L13N_2/D3/GCLK15 | IO_L13N_2/D3/GCLK15 | IO_L13N_2/D3/GCLK15 | V9 | DUAL/GCLK |
| 2 | IO_L13P_2/D4/GCLK14 | IO_L13P_2/D4/GCLK14 | IO_L13P_2/D4/GCLK14 | U9 | DUAL/GCLK |
| 2 | IO_L15N_2/D1/GCLK3 | IO_L15N_2/D1/GCLK3 | IO_L15N_2/D1/GCLK3 | P10 | DUAL/GCLK |
| 2 | IO_L15P_2/D2/GCLK2 | IO_L15P_2/D2/GCLK2 | IO_L15P_2/D2/GCLK2 | R10 | DUAL/GCLK |
| 2 | IO_L16N_2/DIN/D0 | IO_L16N_2/DIN/D0 | IO_L16N_2/DIN/D0 | N10 | DUAL |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 2 | IO_L16P_2/M0 | IO_L16P_2/M0 | IO_L16P_2/M0 | M10 | DUAL |
| 2 | IO_L18N_2 | IO_L18N_2 | IO_L18N_2 | N11 | I/O |
| 2 | IO_L18P_2 | IO_L18P_2 | IO_L18P_2 | P11 | I/O |
| 2 | IO_L19N_2/VREF_2 | IO_L19N_2/VREF_2 | IO_L19N_2/VREF_2 | V13 | VREF |
| 2 | IO_L19P_2 | IO_L19P_2 | IO_L19P_2 | V12 | I/O |
| 2 | 1 O | 1 O | IO_L20N_2 | R12 | I/O |
| 2 | IO_L20P_2 | IO_L20P_2 | IO_L20P_2 | T12 | I/O |
| 2 | N.C. ( $\downarrow$ ) | IO_L21N_2 | IO_L21N_2 | P12 | 500E: N.C. <br> 1200E: I/O <br> 1600E: I/O |
| 2 | N.C. ( $\downarrow$ ) | 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 | 1 O | R13 | DUAL |
| 2 | IO_L22P_2/A23 | IO_L22P_2/A23 | 1O_L22P_2/A23 | P13 | DUAL |
| 2 | 1 O | IO_L24N_2/A20 | 1 O | 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 | $\begin{aligned} & \text { IP_L14P_2/RDWR_B/ } \\ & \text { GCLK0 } \end{aligned}$ | $\begin{aligned} & \text { IP_L14P_2/RDWR_B/ } \\ & \text { GCLK0 } \end{aligned}$ | $\begin{aligned} & \text { IP_L14P_2/RDWR_B/ } \\ & \text { GCLK0 } \end{aligned}$ | 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 |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 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. ( $\downarrow$ ) | 10 | 10 | D4 | $\begin{aligned} & \text { 500E: N.C. } \\ & \text { 1200E: I/O } \\ & \text { 1600E: I/O } \end{aligned}$ |
| 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 | 1O_L03P_3 | IO_L03P_3 | IO_L03P_3 | E2 | I/O |
| 3 | N.C. ( $\downarrow$ ) | IO_L04N_3 | IO_L04N_3 | E3 | $\begin{aligned} & \text { 500E: N.C. } \\ & \text { 1200E: I/O } \\ & \text { 1600E: I/O } \end{aligned}$ |
| 3 | N.C. ( $)^{\text {) }}$ | IO_L04P_3 | IO_L04P_3 | E4 | $\begin{aligned} & \text { 500E: N.C. } \\ & \text { 1200E: I/O } \\ & \text { 1600E: I/O } \end{aligned}$ |
| 3 | IO_L05N_3 | IO_L05N_3 | IO_L05N_3 | F2 | I/O |
| 3 | IO_L05P_3 | IO_L05P_3 | IO_L05P_3 | F1 | I/O |
| 3 | IO_L06N_3/VREF_3 | IO_L06N_3/VREF_3 | IO_L06N_3/VREF_3 | G4 | VREF |
| 3 | IO_L06P_3 | IO_L06P_3 | IO_L06P_3 | G3 | I/O |
| 3 | IO_L07N_3 | IO_L07N_3 | IO_L07N_3 | G5 | I/O |
| 3 | IO_L07P_3 | IO_L07P_3 | IO_L07P_3 | G6 | I/O |
| 3 | IO_L08N_3 | IO_L08N_3 | IO_L08N_3 | H5 | I/O |
| 3 | IO_L08P_3 | IO_L08P_3 | IO_L08P_3 | H6 | I/O |
| 3 | IO_L09N_3 | IO_L09N_3 | IO_L09N_3 | H3 | I/O |
| 3 | IO_L09P_3 | IO_L09P_3 | IO_L09P_3 | H4 | I/O |
| 3 | IO_L10N_3 | IO_L10N_3 | IO_L10N_3 | H1 | I/O |
| 3 | IO_L10P_3 | IO_L10P_3 | IO_L10P_3 | H2 | I/O |
| 3 | IO_L11N_3/LHCLK1 | IO_L11N_3/LHCLK1 | IO_L11N_3/LHCLK1 | J4 | LHCLK |
| 3 | IO_L11P_3/LHCLK0 | IO_L11P_3/LHCLK0 | IO_L11P_3/LHCLK0 | J5 | LHCLK |
| 3 | IO_L12N_3/LHCLK3/ IRDY2 | IO_L12N_3/LHCLK3/ IRDY2 | IO_L12N_3/LHCLK3/ IRDY2 | J2 | LHCLK |
| 3 | IO_L12P_3/LHCLK2 | IO_L12P_3/LHCLK2 | IO_L12P_3/LHCLK2 | J1 | LHCLK |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | IO_L13N_3/LHCLK5 | IO_L13N_3/LHCLK5 | IO_L13N_3/LHCLK5 | K4 | LHCLK |
| 3 | IO_L13P_3/LHCLK4/ TRDY2 | IO_L13P_3/LHCLK4/ TRDY2 | IO_L13P_3/LHCLK4/ TRDY2 | K3 | LHCLK |
| 3 | IO_L14N_3/LHCLK7 | IO_L14N_3/LHCLK7 | IO_L14N_3/LHCLK7 | K5 | LHCLK |
| 3 | IO_L14P_3/LHCLK6 | IO_L14P_3/LHCLK6 | IO_L14P_3/LHCLK6 | K6 | LHCLK |
| 3 | IO_L15N_3 | IO_L15N_3 | IO_L15N_3 | L2 | I/O |
| 3 | IO_L15P_3 | IO_L15P_3 | IO_L15P_3 | L1 | I/O |
| 3 | IO_L16N_3 | IO_L16N_3 | IO_L16N_3 | L4 | I/O |
| 3 | IO_L16P_3 | IO_L16P_3 | IO_L16P_3 | L3 | I/O |
| 3 | IO_L17N_3/VREF_3 | IO_L17N_3/VREF_3 | IO_L17N_3/VREF_3 | L5 | VREF |
| 3 | IO_L17P_3 | IO_L17P_3 | IO_L17P_3 | L6 | I/O |
| 3 | IO_L18N_3 | IO_L18N_3 | IO_L18N_3 | M3 | I/O |
| 3 | IO_L18P_3 | IO_L18P_3 | IO_L18P_3 | M4 | I/O |
| 3 | IO_L19N_3 | IO_L19N_3 | IO_L19N_3 | M6 | I/O |
| 3 | IO_L19P_3 | IO_L19P_3 | IO_L19P_3 | M5 | I/O |
| 3 | IO_L20N_3 | IO_L20N_3 | IO_L20N_3 | N5 | I/O |
| 3 | IO_L20P_3 | IO_L20P_3 | IO_L20P_3 | N4 | I/O |
| 3 | IO_L21N_3 | IO_L21N_3 | IO_L21N_3 | P1 | I/O |
| 3 | IO_L21P_3 | IO_L21P_3 | 1 O _L21P_3 | P2 | 1/O |
| 3 | N.C. ( $\downarrow$ ) | IO_L22N_3 | IO_L22N_3 | P4 | 500E: N.C. <br> 1200E: I/O <br> 1600E: I/O |
| 3 | N.C. ( ) | IO_L22P_3 | $10 \_L 22 P$ _3 | P3 | 500E: N.C. <br> 1200E: I/O <br> 1600E: I/O |
| 3 | IO_L23N_3 | IO_L23N_3 | IO_L23N_3 | R2 | I/O |
| 3 | 10_L23P_3 | 10_L23P_3 | 1 O -L23P_3 | R3 | 1/O |
| 3 | IO_L24N_3 | IO_L24N_3 | IO_L24N_3 | T1 | I/O |
| 3 | IO_L24P_3 | IO_L24P_3 | 1 O _L24P_3 | T2 | I/O |
| 3 | IP | IP | IP | D3 | INPUT |
| 3 | 10 | IP | IP | F4 | 500E: I/O <br> 1200E: INPUT <br> 1600E: INPUT |
| 3 | IP | IP | IP | F5 | INPUT |
| 3 | IP | IP | IP | G1 | INPUT |
| 3 | IP | IP | IP | J7 | INPUT |
| 3 | IP | IP | IP | K2 | INPUT |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | IP | IP | IP | K7 | INPUT |
| 3 | IP | IP | IP | M1 | INPUT |
| 3 | IP | IP | IP | N1 | INPUT |
| 3 | IP | IP | IP | N2 | INPUT |
| 3 | IP | IP | IP | R1 | INPUT |
| 3 | IP | IP | IP | U1 | INPUT |
| 3 | IP/VREF_3 | IP/VREF_3 | IP/VREF_3 | J6 | VREF |
| 3 | IO/VREF_3 | IP/VREF_3 | IP/VREF_3 | R4 | 500E: VREF(I/O) <br> 1200E: VREF(INPUT) 1600E: VREF(INPUT) |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | F3 | VCCO |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | H7 | VCCO |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | K1 | VCCO |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | L7 | VCCO |
| 3 | VCCO_3 | VCCO_3 | VCCO_3 | N3 | VCCO |
| GND | GND | GND | GND | A1 | GND |
| GND | GND | GND | GND | A18 | GND |
| GND | GND | GND | GND | B2 | GND |
| GND | GND | GND | GND | B17 | GND |
| GND | GND | GND | GND | C10 | GND |
| GND | GND | GND | GND | G7 | GND |
| GND | GND | GND | GND | G12 | GND |
| GND | GND | GND | GND | H8 | GND |
| GND | GND | GND | GND | H9 | GND |
| GND | GND | GND | GND | H10 | GND |
| GND | GND | GND | GND | H11 | GND |
| GND | GND | GND | GND | J3 | GND |
| GND | GND | GND | GND | J8 | GND |
| GND | GND | GND | GND | J11 | GND |
| GND | GND | GND | GND | K8 | GND |
| GND | GND | GND | GND | K11 | GND |
| GND | GND | GND | GND | K16 | GND |
| GND | GND | GND | GND | L8 | GND |
| GND | GND | GND | GND | L9 | GND |

Table 24: FG320 Package Pinout (Continued)

| Bank | XC3S500E Pin Name | XC3S1200E Pin Name | XC3S1600E Pin Name | $\begin{gathered} \text { FG320 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: |
| GND | GND | GND | GND | L10 | GND |
| GND | GND | GND | GND | L11 | GND |
| GND | GND | GND | GND | M7 | GND |
| GND | GND | GND | GND | M12 | GND |
| GND | GND | GND | GND | T9 | GND |
| GND | GND | GND | GND | U2 | GND |
| GND | GND | GND | GND | U17 | GND |
| GND | GND | GND | GND | V1 | GND |
| GND | GND | GND | GND | V18 | GND |
| VCCAUX | DONE | DONE | DONE | V17 | CONFIG |
| VCCAUX | PROG_B | PROG_B | PROG_B | B1 | CONFIG |
| VCCAUX | TCK | TCK | TCK | A17 | JTAG |
| VCCAUX | TDI | TDI | TDI | A2 | JTAG |
| VCCAUX | TDO | TDO | TDO | C16 | JTAG |
| VCCAUX | TMS | TMS | TMS | D15 | JTAG |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | B7 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | B12 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | G2 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | G17 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | M2 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | M17 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | U7 | VCCAUX |
| VCCAUX | VCCAUX | VCCAUX | VCCAUX | U12 | VCCAUX |
| VCCINT | VCCINT | VCCINT | VCCINT | E5 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | E14 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | F6 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | F13 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | N6 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | N13 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | P5 | VCCINT |
| VCCINT | VCCINT | VCCINT | VCCINT | P14 | VCCINT |

## User I/Os by Bank

Table 25, Table 26, and Table 27 indicate how the available user-I/O pins are distributed between the four I/O banks on the FG320 package.

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

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 29 | 14 | 1 | 6 | 8 |
| Right | 1 |  | 22 | 10 | 21 | 5 | 0 |
| Bottom | 2 |  | 17 | 13 | 24 | 4 | 0 |
| Left | 3 |  | 34 | 11 | 0 | 5 | 8 |
| TOTAL |  | $\mathbf{2 3 2}$ | $\mathbf{1 0 2}$ | $\mathbf{4 8}$ | $\mathbf{4 6}$ | $\mathbf{2 0}$ | $\mathbf{1 6}$ |

Table 26: User I/Os Per Bank for XC3S1200E in the FG320 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 34 | 12 | 1 | 6 | 8 |
| Right | 1 |  | 25 | 12 | 21 | 5 | 0 |
| Bottom | 2 |  | 23 | 11 | 24 | 5 | 0 |
| Left | 3 |  | 38 | 12 | 0 | 5 | 8 |
| TOTAL |  | $\mathbf{2 5 0}$ | $\mathbf{1 2 0}$ | $\mathbf{4 7}$ | $\mathbf{4 6}$ | $\mathbf{2 1}$ | $\mathbf{1 6}$ |

Table 27: User I/Os Per Bank for XC3S1600E in the FG320 Package

| Package <br> Edge | $\mathbf{I} / \mathbf{O}$ Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 33 | 13 | 1 | 6 | 8 |
| Right | 1 |  | 25 | 12 | 21 | 5 | 0 |
| Bottom | 2 |  | 23 | 11 | 24 | 5 | 0 |
| Left | 3 |  | 38 | 12 | 0 | 5 | 8 |
| TOTAL |  | $\mathbf{2 5 0}$ | $\mathbf{1 1 9}$ | $\mathbf{4 8}$ | $\mathbf{4 6}$ | $\mathbf{2 1}$ | $\mathbf{1 6}$ |

## Footprint Migration Differences

Table 28 summarizes any footprint and functionality differences between the XC3S500E, the XC3S1200E, and the XC3S1600E FPGAs that may affect easy migration between devices available in the FG320 package. There are 26 such balls. All other pins not listed in Table 28 unconditionally migrate between Spartan-3E devices available in the FG320 package.

The XC3S500E is duplicated on both the left and right sides of the table to show migrations to and from the XC3S1200E and the XC3S1600E. The arrows indicate the direction for easy migration. A double-ended arrow $(\leftarrow \rightarrow)$ indicates that the two pins have identical functionality. A left-facing arrow $(\leftarrow)$ indicates that the pin on the device on the right unconditionally migrates to the pin on the device on the left. It may be possible to migrate the opposite direction depending on the I/O configuration. For example, an I/O pin (Type = I/O)
can migrate to an input-only pin (Type $=$ INPUT $)$ if the I/O pin is configured as an input.
Table 28: FG320 Footprint Migration Differences

| Pin | Bank | XC3S500E | Migration | XC3S1200E | Migration | XC3S1600E | Migration | XC3S500E |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A7 | 0 | INPUT | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | INPUT |
| A12 | 0 | N.C. | $\rightarrow$ | I/O | $\leftarrow$ | INPUT | $\leftarrow$ | N.C. |
| D4 | 3 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| D6 | 0 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| D13 | 0 | INPUT | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | INPUT |
| E3 | 3 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| E4 | 3 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| E6 | 0 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | N.C. |
| E15 | 1 | N.C. | $\rightarrow$ | I/O | $\leftarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| E16 | 1 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | N.C. |
| E17 | 1 | I/O | $\leftarrow$ | INPUT | $\leftrightarrow$ | INPUT | $\leftarrow$ | I/O |
| F4 | 3 | I/O | $\leftarrow$ | INPUT | $\leftrightarrow$ | INPUT | $\leftarrow$ | I/O |
| N12 | 2 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| N14 | 1 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| N15 | 1 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | N.C. |
| P3 | 3 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| P4 | 3 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow \rightarrow$ | I/O | $\leftarrow$ | N.C. |
| P12 | 2 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | N.C. |
| P15 | 1 | I/O | $\leftarrow$ | INPUT | $\leftrightarrow \rightarrow$ | INPUT | $\rightarrow$ | I/O |
| P16 | 1 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | N.C. |
| R4 | 3 | VREF(I/O) | $\leftarrow$ | VREF(INPUT) | $\leftrightarrow$ | VREF(INPUT) | $\rightarrow$ | VREF(I/O) |
| U6 | 2 | INPUT | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | INPUT |
| U13 | 2 | INPUT | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | INPUT |
| V5 | 2 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | N.C. |
| V6 | 2 | N.C. | $\rightarrow$ | VREF | $\leftrightarrow \rightarrow$ | VREF | $\leftarrow$ | N.C. |
| V7 | 2 | N.C. | $\rightarrow$ | I/O | $\leftrightarrow$ | I/O | $\leftarrow$ | N.C. |
| DIFFERENCES |  |  | 26 |  | 1 |  | 26 |  |

Legend:
$\longleftrightarrow \quad$ This pin is identical on both the device on the left and the right.
$\rightarrow \quad$ This pin can unconditionally migrate from the device on the left to the device on the right. Migration in the other direction may be possible depending on how the pin is configured for the device on the right.
$\leftarrow \quad$ This pin can unconditionally migrate from the device on the right to the device on the left. Migration in the other direction may be possible depending on how the pin is configured for the device on the left.

FG320 Footprint


Figure 8: FG320 Package Footprint (top view)

|  | I/O: Unrestricted, general-purpose user I/O | 46 | DUAL: Configuration pin, then possible user-1/O |  | VREF: User I/O or input voltage reference for bank |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | INPUT: Unrestricted, general-purpose input pin | 16 | GCLK: User I/O, input, or global buffer input | 20 | VCCO: Output voltage supply for bank |
| 2 | CONFIG: Dedicated configuration pins | 4 | JTAG: Dedicated JTAG port pins | 8 | VCCINT: Internal core supply voltage ( +1.2 V ) |
| 0 | N.C.: Not connected | 28 | GND: Ground | 8 | VCCAUX: Auxiliary supply voltage (+2.5V) |

## FG400: 400-ball Fine-pitch Ball Grid Array

The 400-ball fine-pitch ball grid array, FG400, supports two different Spartan-3E FPGAs, including the XC3S1200E and the XC3S1600E. Both devices share a common footprint for this package as shown in Table 29 and Figure 9.
Table 29 lists all the FG400 package pins. They are sorted by bank number and then by pin name. Pairs of 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.
An electronic version of this package pinout table and footprint diagram is available for download from the Xilinx website at http://www.xilinx.com/bvdocs/publications/s3e_pin.zip.

## Pinout Table

Table 29: FG400 Package Pinout

| Bank | XC3S1200E <br> XC3S1600E <br> Pin Name | FG400 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| 0 | IO | A3 | I/O |
| 0 | IO | A8 | I/O |
| 0 | IO | A12 | I/O |
| 0 | IO | C7 | I/O |
| 0 | IO | C10 | I/O |
| 0 | IO | E8 | I/O |
| 0 | IO | E13 | I/O |
| 0 | IO | I/O |  |
| 0 | IO | F13 | I/O |
| 0 | IO | F14 | I/O |
| 0 | IO | I/O |  |
| 0 | IO/VREF_0 | C11 | VREF |
| 0 | IO_L01N_0 | B17 | I/O |
| 0 | IO_L01P_0 | C17 | I/O |
| 0 | IO_L03N_O/VREF_0 | A18 | VREF |
| 0 | IO_L03P_0 | A19 | I/O |
| 0 | IO_L04N_O | A17 | I/O |
| 0 | IO_L04P_O | A16 | I/O |
| 0 | IO_L06N_0 | A15 | I/O |
| 0 | IO_L06P_0 | B15 | I/O |
| 0 | IO_L07N_0 | C14 | I/O |
| 0 | IO_L07P_0 | D14 | I/O |
| 0 | IO_L09N_O/VREF_0 | A13 | VREF |
|  |  |  |  |
|  |  |  |  |

Table 29: FG400 Package Pinout

| Bank | XC3S1200E XC3S1600E Pin Name | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | IO_L09P_0 | A14 | I/O |
| 0 | IO_L10N_0 | B13 | I/O |
| 0 | IO_L10P_0 | C13 | I/O |
| 0 | IO_L11N_0 | C12 | 1/0 |
| 0 | IO_L11P_0 | D12 | 1/O |
| 0 | IO_L12N_0 | E12 | I/O |
| 0 | IO_L12P_0 | F12 | I/O |
| 0 | IO_L14N_0/GCLK5 | G11 | GCLK |
| 0 | IO_L14P_0/GCLK4 | F11 | GCLK |
| 0 | IO_L15N_0/GCLK7 | E10 | GCLK |
| 0 | IO_L15P_0/GCLK6 | E11 | GCLK |
| 0 | IO_L17N_0/GCLK11 | A9 | GCLK |
| 0 | IO_L17P_0/GCLK10 | A10 | GCLK |
| 0 | IO_L18N_0 | F9 | I/O |
| 0 | IO_L18P_0 | E9 | 1/O |
| 0 | IO_L20N_0 | C9 | I/O |
| 0 | IO_L20P_0 | D9 | I/O |
| 0 | IO_L21N_0/VREF_0 | B8 | VREF |
| 0 | IO_L21P_0 | B9 | I/O |
| 0 | IO_L23N_0/VREF_0 | F7 | VREF |
| 0 | IO_L23P_0 | F8 | I/O |
| 0 | IO_L24N_0 | A6 | I/O |
| 0 | IO_L24P_0 | A7 | I/O |
| 0 | IO_L26N_0 | B5 | I/O |
| 0 | IO_L26P_0 | B6 | 1/0 |
| 0 | IO_L27N_0 | D6 | I/O |
| 0 | IO_L27P_0 | C6 | I/O |
| 0 | IO_L29N_0/VREF_0 | C5 | VREF |
| 0 | IO_L29P_0 | D5 | 1/0 |
| 0 | IO_L30N_0 | A2 | I/O |
| 0 | IO_L30P_0 | B2 | I/O |
| 0 | IO_L31N_0/HSWAP | D4 | DUAL |
| 0 | IO_L31P_0 | C4 | I/O |

Table 29: FG400 Package Pinout

| Bank | $\begin{aligned} & \text { XC3S1200E } \\ & \text { XC3S1600E } \\ & \text { Pin Name } \end{aligned}$ | $\begin{aligned} & \text { FG400 } \\ & \text { Ball } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | IP | B18 | INPUT |
| 0 | IP | E5 | INPUT |
| 0 | IP_L02N_0 | C16 | INPUT |
| 0 | IP_L02P_0 | D16 | INPUT |
| 0 | IP_L05N_0 | D15 | INPUT |
| 0 | IP_L05P_0 | C15 | INPUT |
| 0 | IP_L08N_0 | E14 | INPUT |
| 0 | IP_L08P_0 | E15 | INPUT |
| 0 | IP_L10N_0 | G14 | INPUT |
| 0 | IP_L10P_0 | G13 | INPUT |
| 0 | IP_L13N_0 | B11 | INPUT |
| 0 | IP_L13P_0 | B12 | INPUT |
| 0 | IP_L16N_0/GCLK9 | G10 | GCLK |
| 0 | IP_L16P_0/GCLK8 | H10 | GCLK |
| 0 | IP_L19N_0 | G9 | INPUT |
| 0 | IP_L19P_0 | G8 | INPUT |
| 0 | IP_L22N_0 | C8 | INPUT |
| 0 | IP_L22P_0 | D8 | INPUT |
| 0 | IP_L25N_0 | E6 | INPUT |
| 0 | IP_L25P_0 | E7 | INPUT |
| 0 | IP_L28N_0 | A4 | INPUT |
| 0 | IP_L28P_0 | A5 | INPUT |
| 0 | VCCO_0 | B4 | VCCO |
| 0 | VCCO_0 | B10 | VCCO |
| 0 | VCCO_0 | B16 | VCCO |
| 0 | VCCO_0 | D7 | VCCO |
| 0 | VCCO_0 | D13 | VCCO |
| 0 | VCCO_0 | F10 | VCCO |
| 1 | IO_L01N_1/A15 | U18 | DUAL |
| 1 | IO_L01P_1/A16 | U17 | DUAL |
| 1 | IO_L02N_1/A13 | T18 | DUAL |
| 1 | IO_L02P_1/A14 | T17 | DUAL |
| 1 | IO_L03N_1/VREF_1 | V19 | VREF |
| 1 | $1 O_{\text {_L03P_1 }}$ | U19 | I/O |

Table 29: FG400 Package Pinout

| Bank | $\begin{aligned} & \text { XC3S1200E } \\ & \text { XC3S1600E } \\ & \text { Pin Name } \end{aligned}$ | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 1 | IO_L04N_1 | W20 | I/O |
| 1 | IO_L04P_1 | V20 | I/O |
| 1 | IO_L05N_1 | R18 | I/O |
| 1 | IO_L05P_1 | R17 | I/O |
| 1 | IO_L06N_1 | T20 | I/O |
| 1 | IO_L06P_1 | U20 | I/O |
| 1 | IO_L07N_1 | P18 | I/O |
| 1 | IO_L07P_1 | P17 | I/O |
| 1 | IO_L08N_1/VREF_1 | P20 | VREF |
| 1 | IO_L08P_1 | R20 | I/O |
| 1 | IO_L09N_1 | P16 | I/O |
| 1 | IO_L09P_1 | N16 | I/O |
| 1 | IO_L10N_1 | N19 | I/O |
| 1 | IO_L10P_1 | N18 | I/O |
| 1 | IO_L11N_1 | N15 | I/O |
| 1 | IO_L11P_1 | M15 | I/O |
| 1 | IO_L12N_1/A11 | M18 | DUAL |
| 1 | IO_L12P_1/A12 | M17 | DUAL |
| 1 | IO_L13N_1/VREF_1 | L19 | VREF |
| 1 | IO_L13P_1 | M19 | I/O |
| 1 | IO_L14N_1/A9/RHCLK1 | L16 | RHCLK/ DUAL |
| 1 | IO_L14P_1/A10/RHCLK0 | M16 | RHCLK/ DUAL |
| 1 | IO_L15N_1/A7/RHCLK3/ TRDY1 | L14 | RHCLK/ DUAL |
| 1 | IO_L15P_1/A8/RHCLK2 | L15 | RHCLK/ DUAL |
| 1 | IO_L16N_1/A5/RHCLK5 | K14 | RHCLK/ DUAL |
| 1 | IO_L16P_1/A6/RHCLK4/ IRDY1 | K13 | RHCLK/ DUAL |
| 1 | IO_L17N_1/A3/RHCLK7 | J20 | RHCLK/ DUAL |
| 1 | IO_L17P_1/A4/RHCLK6 | K20 | RHCLK/ DUAL |
| 1 | IO_L18N_1/A1 | K16 | DUAL |
| 1 | IO_L18P_1/A2 | J16 | DUAL |

Table 29: FG400 Package Pinout

| Bank | XC3S1200E XC3S1600E Pin Name | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 1 | IO_L19N_1/A0 | J13 | DUAL |
| 1 | IO_L19P_1 | J14 | I/O |
| 1 | IO_L20N_1 | J17 | I/O |
| 1 | IO_L20P_1 | J18 | I/O |
| 1 | IO_L21N_1 | H19 | I/O |
| 1 | $1 O_{-}$L21P_1 | J19 | I/O |
| 1 | IO_L22N_1 | H15 | I/O |
| 1 | IO_L22P_1 | H16 | I/O |
| 1 | IO_L23N_1 | H18 | I/O |
| 1 | IO_L23P_1 | H17 | I/O |
| 1 | IO_L24N_1/VREF_1 | H20 | VREF |
| 1 | IO_L24P_1 | G20 | I/O |
| 1 | IO_L25N_1 | G16 | I/O |
| 1 | IO_L25P_1 | F16 | I/O |
| 1 | IO_L26N_1 | F19 | I/O |
| 1 | IO_L26P_1 | F20 | I/O |
| 1 | IO_L27N_1 | F18 | I/O |
| 1 | IO_L27P_1 | F17 | I/O |
| 1 | IO_L28N_1 | D20 | I/O |
| 1 | IO_L28P_1 | E20 | I/O |
| 1 | IO_L29N_1/LDC0 | D18 | DUAL |
| 1 | IO_L29P_1/HDC | E18 | DUAL |
| 1 | IO_L30N_1/LDC2 | C19 | DUAL |
| 1 | IO_L30P_1/LDC1 | C20 | DUAL |
| 1 | IP | B20 | INPUT |
| 1 | IP | G15 | INPUT |
| 1 | IP | G18 | INPUT |
| 1 | IP | H14 | INPUT |
| 1 | IP | J15 | INPUT |
| 1 | IP | L18 | INPUT |
| 1 | IP | M20 | INPUT |
| 1 | IP | N14 | INPUT |
| 1 | IP | N20 | INPUT |
| 1 | IP | P15 | INPUT |

Table 29: FG400 Package Pinout

| Bank | $\|c\|$ <br> XC3S1200E <br> XC3S1600E <br> Pin Name | FG400 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| 1 | IP | R16 | INPUT |
| 1 | IP | R19 | INPUT |
| 1 | IP/VREF_1 | E19 | VREF |
| 1 | IP/VREF_1 | K18 | VREF |
| 1 | VCCO_1 | D19 | VCCO |
| 1 | VCCO_1 | G17 | VCCO |
| 1 | VCCO_1 | K15 | VCCO |
| 1 | VCCO_1 | K19 | VCCO |
| 1 | VCCO_1 | N17 | VCCO |
| 1 | VCCO_1 | T19 | VCCO |
| 2 |  | P8 |  |


| 2 | 10 | P8 | I/O |
| :---: | :---: | :---: | :---: |
| 2 | 10 | P13 | I/O |
| 2 | 10 | R9 | I/O |
| 2 | 10 | R13 | I/O |
| 2 | 10 | W15 | I/O |
| 2 | 10 | Y5 | I/O |
| 2 | 10 | Y7 | I/O |
| 2 | 10 | Y13 | I/O |
| 2 | IO/D5 | N11 | DUAL |
| 2 | IO/M1 | T11 | DUAL |
| 2 | IO/VREF_2 | Y3 | VREF |
| 2 | IO/VREF_2 | Y17 | VREF |
| 2 | IO_L01N_2/INIT_B | V4 | DUAL |
| 2 | IO_L01P_2/CSO_B | U4 | DUAL |
| 2 | IO_LO3N_2/MOSI/CSI_B | V5 | DUAL |
| 2 | IO_LO3P_2/DOUT/BUSY | U5 | DUAL |
| 2 | IO_L04N_2 | Y4 | I/O |
| 2 | IO_L04P_2 | W4 | I/O |
| 2 | IO_L06N_2 | T6 | I/O |
| 2 | IO_L06P_2 | T5 | I/O |
| 2 | IO_L07N_2 | U7 | I/O |
| 2 | IO_L07P_2 | V7 | I/O |
| 2 | IO_L09N_2/VREF_2 | R7 | VREF |
| 2 | IO_L09P_2 | T7 | I/O |

Table 29: FG400 Package Pinout

| Bank | $\begin{aligned} & \text { XC3S1200E } \\ & \text { XC3S1600E } \\ & \text { Pin Name } \end{aligned}$ | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 2 | IO_L10N_2 | V8 | I/O |
| 2 | IO_L10P_2 | W8 | I/O |
| 2 | IO_L12N_2 | U9 | I/O |
| 2 | IO_L12P_2 | V9 | I/O |
| 2 | IO_L13N_2 | Y8 | I/O |
| 2 | IO_L13P_2 | Y9 | I/O |
| 2 | IO_L15N_2/D6/GCLK13 | W10 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L15P_2/D7/GCLK12 | W9 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L16N_2/D3/GCLK15 | P10 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L16P_2/D4/GCLK14 | R10 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L18N_2/D1/GCLK3 | V11 | DUAL/ GCLK |
| 2 | IO_L18P_2/D2/GCLK2 | V10 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IO_L19N_2/DIN/D0 | Y12 | DUAL |
| 2 | IO_L19P_2/M0 | Y11 | DUAL |
| 2 | IO_L21N_2 | U12 | I/O |
| 2 | 10_L21P_2 | V12 | I/O |
| 2 | IO_L22N_2/VREF_2 | W12 | VREF |
| 2 | 10_L22P_2 | W13 | I/O |
| 2 | IO_L24N_2 | U13 | I/O |
| 2 | IO_L24P_2 | V13 | I/O |
| 2 | IO_L25N_2 | P14 | I/O |
| 2 | 1O_L25P_2 | R14 | I/O |
| 2 | $1 O^{\prime}$ L27N_2/A22 | Y14 | DUAL |
| 2 | IO_L27P_2/A23 | Y15 | DUAL |
| 2 | IO_L28N_2 | T15 | I/O |
| 2 | 1O_L28P_2 | U15 | I/O |
| 2 | IO_L30N_2/A20 | V16 | DUAL |
| 2 | IO_L30P_2/A21 | U16 | DUAL |
| 2 | IO_L31N_2/VS1/A18 | Y18 | DUAL |
| 2 | IO_L31P_2/VS2/A19 | W18 | DUAL |
| 2 | IO_L32N_2/CCLK | W19 | DUAL |

Table 29: FG400 Package Pinout

| Bank | XC3S1200E <br> XC3S1600E <br> Pin Name | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 2 | IO_L32P_2/VS0/A17 | Y19 | DUAL |
| 2 | IP | T16 | INPUT |
| 2 | IP | W3 | INPUT |
| 2 | IP_L02N_2 | Y2 | INPUT |
| 2 | IP_LO2P_2 | W2 | INPUT |
| 2 | IP_L05N_2 | V6 | INPUT |
| 2 | IP_L05P_2 | U6 | INPUT |
| 2 | IP_L08N_2 | Y6 | INPUT |
| 2 | IP_L08P_2 | W6 | INPUT |
| 2 | IP_L11N_2 | R8 | INPUT |
| 2 | IP_L11P_2 | T8 | INPUT |
| 2 | IP_L14N_2/VREF_2 | T10 | VREF |
| 2 | IP_L14P_2 | T9 | INPUT |
| 2 | IP_L17N_2/M2/GCLK1 | P12 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IP_L17P_2/RDWR_B/ GCLK0 | P11 | $\begin{aligned} & \text { DUAL/ } \\ & \text { GCLK } \end{aligned}$ |
| 2 | IP_L20N_2 | T12 | INPUT |
| 2 | IP_L20P_2 | R12 | INPUT |
| 2 | IP_L23N_2VREF_2 | T13 | VREF |
| 2 | IP_L23P_2 | T14 | INPUT |
| 2 | IP_L26N_2 | V14 | INPUT |
| 2 | IP_L26P_2 | V15 | INPUT |
| 2 | IP_L29N_2 | W16 | INPUT |
| 2 | IP_L29P_2 | Y16 | INPUT |
| 2 | VCCO_2 | R11 | vcco |
| 2 | VCCO_2 | U8 | vcco |
| 2 | VCCO_2 | U14 | vcco |
| 2 | VCCO_2 | W5 | vcco |
| 2 | VCCO_2 | W11 | vcco |
| 2 | VCCO_2 | W17 | vcco |
| 3 | IO_L01N_3 | D2 | I/O |
| 3 | IO_L01P_3 | D3 | 1/O |
| 3 | IO_LO2N_3/VREF_3 | E3 | VREF |
| 3 | IO_L02P_3 | E4 | I/O |

Table 29: FG400 Package Pinout

| Bank | XC3S1200E XC3S1600E Pin Name | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 3 | IO_L03N_3 | C1 | I/O |
| 3 | IO_L03P_3 | B1 | I/O |
| 3 | IO_L04N_3 | E1 | I/O |
| 3 | IO_L04P_3 | D1 | I/O |
| 3 | IO_L05N_3 | F3 | I/O |
| 3 | IO_L05P_3 | F4 | I/O |
| 3 | IO_L06N_3 | F1 | I/O |
| 3 | IO_L06P_3 | F2 | I/O |
| 3 | IO_L07N_3 | G4 | I/O |
| 3 | IO_L07P_3 | G3 | I/O |
| 3 | IO_L08N_3 | G5 | I/O |
| 3 | 1O_L08P_3 | H5 | I/O |
| 3 | IO_L09N_3/VREF_3 | H3 | VREF |
| 3 | IO_L09P_3 | H2 | I/O |
| 3 | IO_L10N_3 | H7 | I/O |
| 3 | IO_L10P_3 | H6 | I/O |
| 3 | IO_L11N_3 | J4 | I/O |
| 3 | $1 O_{-L 11 P}$ _3 | J3 | I/O |
| 3 | IO_L12N_3 | J1 | I/O |
| 3 | IO_L12P_3 | J2 | I/O |
| 3 | IO_L13N_3 | J6 | I/O |
| 3 | IO_L13P_3 | K6 | I/O |
| 3 | IO_L14N_3/LHCLK1 | K2 | LHCLK |
| 3 | IO_L14P_3/LHCLK0 | K3 | LHCLK |
| 3 | IO_L15N_3/LHCLK3/IRDY2 | L7 | LHCLK |
| 3 | IO_L15P_3/LHCLK2 | K7 | LHCLK |
| 3 | IO_L16N_3/LHCLK5 | L1 | LHCLK |
| 3 | IO_L16P_3/LHCLK4/TRDY2 | M1 | LHCLK |
| 3 | IO_L17N_3/LHCLK7 | L3 | LHCLK |
| 3 | IO_L17P_3/LHCLK6 | M3 | LHCLK |
| 3 | IO_L18N_3 | M7 | I/O |
| 3 | IO_L18P_3 | M8 | I/O |
| 3 | IO_L19N_3 | M4 | I/O |
| 3 | IO_L19P_3 | M5 | I/O |

Table 29: FG400 Package Pinout

| Bank | XC3S1200E XC3S1600E Pin Name | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 3 | IO_L20N_3/VREF_3 | N6 | VREF |
| 3 | IO_L20P_3 | M6 | I/O |
| 3 | IO_L21N_3 | N2 | 1/O |
| 3 | IO_L21P_3 | N1 | 1/O |
| 3 | IO_L22N_3 | P7 | I/O |
| 3 | IO_L22P_3 | N7 | 1/0 |
| 3 | $10 \_$L23N_3 | N4 | I/O |
| 3 | IO_L23P_3 | N3 | I/O |
| 3 | IO_L24N_3 | R1 | 1/O |
| 3 | IO_L24P_3 | P1 | I/O |
| 3 | IO_L25N_3 | R5 | I/O |
| 3 | IO_L25P_3 | P5 | 1/O |
| 3 | $10 \_$L26N_3 | T2 | I/O |
| 3 | IO_L26P_3 | R2 | 1/0 |
| 3 | IO_L27N_3 | R4 | I/O |
| 3 | $10 . L 27 P$ _3 | R3 | 1/0 |
| 3 | IO_L28N_3/VREF_3 | T1 | VREF |
| 3 | IO_L28P_3 | U1 | I/O |
| 3 | $10 \_$L29N_3 | T3 | I/O |
| 3 | 10_L29P_3 | U3 | 1/0 |
| 3 | IO_L30N_3 | V1 | I/O |
| 3 | IO_L30P_3 | V2 | I/O |
| 3 | IP | F5 | INPUT |
| 3 | IP | G1 | INPUT |
| 3 | IP | G6 | INPUT |
| 3 | IP | H1 | INPUT |
| 3 | IP | J5 | INPUT |
| 3 | IP | L5 | INPUT |
| 3 | IP | L8 | INPUT |
| 3 | IP | M2 | INPUT |
| 3 | IP | N5 | INPUT |
| 3 | IP | P3 | INPUT |
| 3 | IP | T4 | INPUT |
| 3 | IP | W1 | INPUT |

Table 29: FG400 Package Pinout

| Bank | $\begin{aligned} & \text { XC3S1200E } \\ & \text { XC3S1600E } \\ & \text { Pin Name } \end{aligned}$ | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 3 | IP/VREF_3 | K5 | VREF |
| 3 | IP/VREF_3 | P6 | VREF |
| 3 | VCCO_3 | E2 | VCCO |
| 3 | VCCO_3 | H4 | VCCO |
| 3 | VCCO_3 | L2 | VCCO |
| 3 | VCCO_3 | L6 | VCCO |
| 3 | VCCO_3 | P4 | VCCO |
| 3 | VCCO_3 | U2 | VCCO |
| GND | GND | A1 | GND |
| GND | GND | A11 | GND |
| GND | GND | A20 | GND |
| GND | GND | B7 | GND |
| GND | GND | B14 | GND |
| GND | GND | C3 | GND |
| GND | GND | C18 | GND |
| GND | GND | D10 | GND |
| GND | GND | F6 | GND |
| GND | GND | F15 | GND |
| GND | GND | G2 | GND |
| GND | GND | G12 | GND |
| GND | GND | G19 | GND |
| GND | GND | H8 | GND |
| GND | GND | J9 | GND |
| GND | GND | J11 | GND |
| GND | GND | K1 | GND |
| GND | GND | K8 | GND |
| GND | GND | K10 | GND |
| GND | GND | K12 | GND |
| GND | GND | K17 | GND |
| GND | GND | L4 | GND |
| GND | GND | L9 | GND |
| GND | GND | L11 | GND |
| GND | GND | L13 | GND |
| GND | GND | L20 | GND |

Table 29: FG400 Package Pinout

| Bank | $\begin{aligned} & \text { XC3S1200E } \\ & \text { XC3S1600E } \\ & \text { Pin Name } \end{aligned}$ | $\begin{gathered} \text { FG400 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| GND | GND | M10 | GND |
| GND | GND | M12 | GND |
| GND | GND | N13 | GND |
| GND | GND | P2 | GND |
| GND | GND | P9 | GND |
| GND | GND | P19 | GND |
| GND | GND | R6 | GND |
| GND | GND | R15 | GND |
| GND | GND | U11 | GND |
| GND | GND | V3 | GND |
| GND | GND | V18 | GND |
| GND | GND | W7 | GND |
| GND | GND | W14 | GND |
| GND | GND | Y1 | GND |
| GND | GND | Y10 | GND |
| GND | GND | Y20 | GND |
| VCCAUX | DONE | V17 | CONFIG |
| VCCAUX | PROG_B | C2 | CONFIG |
| VCCAUX | TCK | D17 | JTAG |
| VCCAUX | TDI | B3 | JTAG |
| VCCAUX | TDO | B19 | JTAG |
| VCCAUX | TMS | E17 | JTAG |
| VCCAUX | VCCAUX | D11 | VCCAUX |
| VCCAUX | VCCAUX | H12 | VCCAUX |
| VCCAUX | VCCAUX | J7 | VCCAUX |
| VCCAUX | VCCAUX | K4 | VCCAUX |
| VCCAUX | VCCAUX | L17 | VCCAUX |
| VCCAUX | VCCAUX | M14 | VCCAUX |
| VCCAUX | VCCAUX | N9 | VCCAUX |
| VCCAUX | VCCAUX | U10 | VCCAUX |
| VCCINT | VCCINT | H9 | VCCINT |
| VCCINT | VCCINT | H11 | VCCINT |
| VCCINT | VCCINT | H13 | VCCINT |
| VCCINT | VCCINT | J8 | VCCINT |

Table 29: FG400 Package Pinout

| Bank | XC3S1200E <br> XC3S1600E <br> Pin Name | FG400 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| VCCINT | VCCINT | J 10 | VCCINT |
| VCCINT | VCCINT | J 12 | VCCINT |
| VCCINT | VCCINT | K9 | VCCINT |
| VCCINT | VCCINT | K11 | VCCINT |
| VCCINT | VCCINT | L10 | VCCINT |
| VCCINT | VCCINT | M9 | VCCINT |
| VCCINT | VCCINT | M11 | VCCINT |
| VCCINT | VCCINT |  |  |

Table 29: FG400 Package Pinout

| Bank | XC3S1200E <br> XC3S1600E <br> Pin Name | FG400 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| VCCINT | VCCINT | M13 | VCCINT |
| VCCINT | VCCINT | N8 | VCCINT |
| VCCINT | VCCINT | N10 | VCCINT |
| VCCINT | VCCINT | N12 | VCCINT |

## User I/Os by Bank

Table 30 indicates how the 304 available user-I/O pins are distributed between the four I/O banks on the FG400 package.

Table 30: User I/Os Per Bank for the XC3S250E and XC3S500E in the FG400 Package

| Package <br> Edge | I/O Bank | Maximum <br> I/O | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top | 0 |  | 43 | 20 | 1 | 6 | 8 |
| Right | 1 |  | 35 | 12 | 21 | 6 | 0 |
| Bottom | 2 |  | 30 | 18 | 24 | 6 | 0 |
| Left | 3 |  | 48 | 12 | 0 | 6 | 8 |
| TOTAL |  | $\mathbf{3 0 4}$ | $\mathbf{1 5 6}$ | $\mathbf{6 2}$ | $\mathbf{4 6}$ | $\mathbf{2 4}$ | $\mathbf{1 6}$ |

## Footprint Migration Differences

The XC3S1200E and XC3S1600E FPGAs have identical footprints in the FG400 package. Designs can migrate
between the XC3S1200E and XC3S1600E FPGAs without further consideration.

FG400 Footprint
Left Half of Package (top view)

I/O: Unrestricted, general-purpose user I/O

62 reference resistor input for bank DUAL: Configuration pin, then possible user I/O

VREF: User I/O or input voltage reference for bank

GCLK: User I/O, input, or clock buffer input


CONFIG: Dedicated configuration pins

JTAG: Dedicated JTAG port pins

GND: Ground

VCCO: Output voltage supply for bank

VCCINT: Internal core supply voltage (+1.2V)

8 VCCAUX: Auxiliary supply
voltage (+2.5V)
N.C.: Not connected

|  |  | 1 | Bank 0 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
|  | A | GND | $\begin{gathered} \text { I/O } \\ \text { L30N_0 } \end{gathered}$ | I/O | $\begin{aligned} & \text { INPUT } \\ & \text { L28N_0 } \end{aligned}$ | $\begin{aligned} & \text { INPUT } \\ & \text { L28P_0 } \end{aligned}$ | $\begin{gathered} \text { I/O } \\ \text { L24N_0 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L24P_0 } \end{gathered}$ | I/O |  |  |
| B |  | $\begin{gathered} \text { I/O } \\ \text { L03P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L30P_0 } \end{gathered}$ | TDI | VCCO_0 | $\begin{gathered} \text { I/O } \\ \text { L26N_0 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L26P_0 } \end{gathered}$ | GND | I/O L21N_0 VREF_0 | $\begin{gathered} \text { I/O } \\ \text { L21P_0 } \end{gathered}$ | vcco_o |
| C |  | $\begin{gathered} \text { I/O } \\ \text { LO3N_3 } \end{gathered}$ | PROG_B | GND | $\begin{gathered} \text { I/O } \\ \text { L31P_0 } \end{gathered}$ | $\begin{aligned} & \text { I/O } \\ & \text { L29N_0 } \\ & \text { VREF_O } \end{aligned}$ | $\begin{gathered} \text { I/O } \\ \text { L27P_0 } \end{gathered}$ | I/O | $\begin{aligned} & \text { INPUT } \\ & \text { L22N_0 } \end{aligned}$ | $\begin{gathered} \text { I/O } \\ \text { L2ON_O } \end{gathered}$ | I/O |
| D |  | $\begin{gathered} \text { I/O } \\ \text { L04P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L01N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L01P_3 } \end{gathered}$ | I/O L31N_0 HSWAP | $\begin{gathered} \text { I/O } \\ \text { L29P_0 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L27N_0 } \end{gathered}$ | VCCO_0 | $\begin{aligned} & \text { INPUT } \\ & \text { L22P_0 } \end{aligned}$ | $\begin{gathered} \text { I/O } \\ \text { L2OP_O } \end{gathered}$ | GND |
| E |  | $\begin{gathered} \text { I/O } \\ \text { LO4N_3 } \end{gathered}$ | VCCO_3 | $\begin{gathered} \text { I/O } \\ \text { LO2N_3 } \\ \text { VREF_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { LO2P_3 } \end{gathered}$ | INPUT | $\begin{aligned} & \text { INPUT } \\ & \text { L25N_0 } \end{aligned}$ | $\begin{aligned} & \text { INPUT } \\ & \text { L25P_O } \end{aligned}$ | I/O | $\begin{gathered} \text { L/O } \\ \text { L18P_0 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L15N_0 } \\ \text { GCLK7 } \end{gathered}$ |
|  | F | $\begin{gathered} \text { I/O } \\ \text { LO6N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L06P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L05N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L05P_3 } \end{gathered}$ | INPUT | GND | $\begin{gathered} \text { I/O } \\ \text { L23N_0 } \\ \text { VREF_0 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L23P_O } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L18N_0 } \end{gathered}$ | vcco_o |
| G |  | INPUT | GND | $\begin{gathered} \text { I/O } \\ \text { LO7P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { LOTN_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L08N_3 } \end{gathered}$ | INPUT | I/O | $\begin{aligned} & \text { INPUT } \\ & \text { L19P_0 } \end{aligned}$ | INPUT L19N_0 | INPUT L16N 0 GCLK9 |
|  | HJ | INPUT | $\begin{gathered} \text { I/O } \\ \text { LO9P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { LO9N_3 } \\ \text { VREF_3 } \end{gathered}$ | VCCO_3 | $\begin{gathered} \text { I/O } \\ \text { L08P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L10P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L10N_3 } \end{gathered}$ | GND | VCCINT | INPUT L16P_0 GCLK8 |
|  |  | $\begin{gathered} \text { I/O } \\ \text { L12N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L12P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L11P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L11N_3 } \end{gathered}$ | INPUT | $\begin{gathered} \text { I/O } \\ \text { L13N_3 } \end{gathered}$ | VCCAUX | VCCINT | GND | VCCINT |
| $\begin{aligned} & \boldsymbol{m} \\ & \underline{\underline{C}} \\ & \boldsymbol{\infty} \end{aligned}$ | K | GND | $\begin{gathered} \text { I/O } \\ \text { L14N_3 } \\ \text { LHCLK1 } \end{gathered}$ | $\begin{aligned} & \text { l/O } \\ & \text { L14P_3 } \\ & \text { LHCLKO } \end{aligned}$ | vCCAUX | INPUT VREF_3 | $\begin{gathered} \text { I/O } \\ \text { L13P_3 } \end{gathered}$ | $\begin{aligned} & \text { I/O } \\ & \text { L15P_3 } \\ & \text { LHCLK2 } \end{aligned}$ | GND | VCCINT | GND |
|  | L |  | VCCO_3 |  | GND | INPUT | VCCO_3 |  | INPUT | GND | VCCINT |
| M |  |  | INPUT |  | $\begin{gathered} \text { I/O } \\ \text { L19N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L19P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L2OP_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L18N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L18P_3 } \end{gathered}$ | VCCINT | GND |
|  | N | $\stackrel{\text { I/O }}{\text { L21P_3 }}$ | $\begin{gathered} \text { I/O } \\ \text { L21N_3 } \end{gathered}$ | $\stackrel{\text { I/O }}{\text { L23P_3 }}$ | $\begin{gathered} \mathbf{I} / \mathbf{O} \\ \text { L23N_3 } \end{gathered}$ | INPUT | $\begin{gathered} \text { I/O } \\ \text { L2ON_3 } \\ \text { VREF_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L22P_3 } \end{gathered}$ | VCCINT | VCCAUX | VCCINT |
| P |  | $\begin{gathered} \text { I/O } \\ \text { L24P_3 } \end{gathered}$ | GND | INPUT | VCCO_3 | $\begin{gathered} \text { I/O } \\ \text { L25P_3 } \end{gathered}$ | INPUT VREF_3 | $\begin{gathered} \text { I/O } \\ \text { L22N_3 } \end{gathered}$ | I/O | GND | I/O <br> L16N_2 D3 GCLK15 |
| R |  | $\begin{gathered} \text { I/O } \\ \text { L24N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L26P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L27P_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L27N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L25N_3 } \end{gathered}$ | GND | I/O L09N_2 VREF_2 | INPUT <br> L11N 2 | I/O |  |
| T |  | $\begin{gathered} \text { I/O } \\ \text { L28N_3 } \\ \text { VREF_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L26N_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L29N_3 } \end{gathered}$ | INPUT | $\stackrel{\text { I/O }}{\text { L06P_2 }}$ | $\begin{gathered} \text { I/O } \\ \text { LO6N_2 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L09P_2 } \end{gathered}$ | $\begin{aligned} & \text { INPUT } \\ & \text { L11P } 2 \end{aligned}$ | INPUT <br> L14P 2 | INPUT L14N_2 VREF_2 |
| U |  | $\begin{gathered} \text { I/O } \\ \text { L28P_3 } \end{gathered}$ | VCCO_3 | $\begin{gathered} \text { I/O } \\ \text { L29P_3 } \end{gathered}$ |  | $\begin{gathered} \text { I/O } \\ \text { LO3P } 2 \\ \text { DOUT } \\ \text { BUSY } \\ \hline \end{gathered}$ | INPUT <br> L05P_2 | $\begin{gathered} \text { I/O } \\ \text { LO7N_2 } \end{gathered}$ | VCCO_2 | $\begin{gathered} \text { I/O } \\ \text { L12N_2 } \end{gathered}$ | vCCAUX |
|  | V | $\begin{gathered} \text { I/O } \\ \text { L3ON_3 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L30P_3 } \end{gathered}$ | GND | I/O L01N_2 INIT_B |  | INPUT LO5N 2 | $\begin{gathered} \text { I/O } \\ \text { LO7P_2 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L10N_2 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L12P_2 } \end{gathered}$ |  |
|  |  | INPUT | $\begin{aligned} & \text { INPUT } \\ & \text { L02P_2 } \end{aligned}$ | INPUT | $\begin{gathered} \text { I/O } \\ \text { L04P_2 } \end{gathered}$ | VCCO_2 | INPUT <br> L08P_2 | GND | $\begin{gathered} \text { I/O } \\ \text { L10P_2 } \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { I/O } \\ \text { L15P_2 } \\ \text { D7 } \\ \text { GCLK12 } \\ \hline \end{array}$ | $\begin{gathered} \text { I/O } \\ \text { L15N_2 } \\ \text { D6- } \\ \text { GCLK13 } \\ \hline \end{gathered}$ |
| Y |  | GND | INPUT LO2N_2 | I/O <br> VREF_2 | $\begin{gathered} \text { I/O } \\ \text { L04N_2 } \end{gathered}$ | I/O | INPUT <br> L08N_2 | I/O | $\begin{gathered} \text { I/O } \\ \text { L13N_2 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L13P_2 } \end{gathered}$ | GND |
|  |  |  | Bank 2 |  |  |  |  |  |  | DS312-4_08_031105 |  |

Figure 9: FG400 Package Footprint (top view)

| Bank 0 |  |  |  |  |  |  |  |  |  | A |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |  |
| GND | 1/0 | $\begin{aligned} & \text { I/O } \\ & \text { LO9N_0 } \\ & \text { VREF_O } \end{aligned}$ | $\begin{aligned} & \text { I/O } \\ & \text { LO9P_O } \end{aligned}$ | $\begin{gathered} \text { I/O } \\ \text { LO6N_0 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L04P_0 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { LO4N_0 } \end{gathered}$ | $\begin{aligned} & \text { I/O } \\ & \text { LOSN_0 } \\ & \text { VREF_O } \end{aligned}$ | $\begin{gathered} \text { I/O } \\ \text { L03P_0 } \end{gathered}$ | GND |  |
| INPUT <br> L13N_0 | INPUT L13P_0 | $\begin{aligned} & \text { I/O } \\ & \text { Lion_o } \end{aligned}$ | GND | $\begin{gathered} \text { L/O } \\ \text { LO6P_O } \end{gathered}$ | VCCO_0 | $\begin{aligned} & \text { I/O } \\ & \text { L01N_O } \end{aligned}$ | INPUT | TDO | INPUT | B |
| $\begin{gathered} \text { I/O } \\ \text { VREF_0 } \end{gathered}$ | L1/0 | L1/O | L/O | INPUT | INPUT LO2N_0 | $\begin{gathered} \text { I/O } \\ \text { L01P_O } \end{gathered}$ | GND | $\begin{gathered} \text { I/O } \\ \text { L30N_1 } \\ \text { LDC2 } \end{gathered}$ | $\begin{gathered} \hline \text { I/O } \\ \text { L30P-1 } \\ \text { LDC1 } \end{gathered}$ | C |
| vCCAUX | $\stackrel{\text { L/O }}{\text { L11P_O }}$ | vcco_o | $\begin{aligned} & \text { L/O } \\ & \text { LOTP_O } \end{aligned}$ | INPUT LO5N_0 | INPUT LO2P_0 | TCK | $\begin{gathered} \text { I/O } \\ \text { L29N_1 } \\ \text { LDC0 } \end{gathered}$ | VCCO_1 | $\begin{aligned} & \text { I/O } \\ & \text { L28N_1 } \end{aligned}$ | D |
| $\begin{aligned} & \text { I/O } \\ & \text { L15P_0 } \\ & \text { GCLKK6 } \end{aligned}$ | $\stackrel{\text { I/O }}{\text { L12N_0 }}$ | 1/0 | INPUT L08N_0 | INPUT L08P_0 | 1/0 | TMS | $\begin{aligned} & \mathbf{I / O} \\ & { }_{\text {L29P_1 }}{ }^{\text {HDC }} \end{aligned}$ | INPUT VREF_1 | $\begin{gathered} \text { L/O } \\ \text { L28P_1 } \end{gathered}$ | E |
| $\begin{gathered} \text { IIO } \\ \text { L14P-0 } \\ \text { GCLKK } \end{gathered}$ | $\stackrel{\text { L/O }}{\text { L12P_O }}$ | 1/0 | 1/0 | GND | $\stackrel{\text { I/O }}{\text { L25P_1 }}$ | $\stackrel{\text { I/O }}{\text { L27P_1 }}$ | $\begin{gathered} \text { I/O } \\ \text { L27N_1 } \end{gathered}$ | $\begin{gathered} \mathbf{I / O} \\ \text { L26N_1 } \end{gathered}$ | ${ }_{\text {L26P_1 }}^{\text {L26 }}$ | F |
| $\begin{gathered} \text { I/O } \\ \text { L14N0 } \\ \text { GCLK55 } \end{gathered}$ | GND | $\begin{aligned} & \text { INPUT } \\ & \text { L10P_0 } \end{aligned}$ | INPUT L10N_0 | INPUT | $\begin{gathered} \text { I/O } \\ \text { L25N_1 } \end{gathered}$ | vcco_1 | INPUT | GND | $\stackrel{\text { I/O }}{\text { L24P_1 }}$ | G |
| VCCINT | vccaux | VCCINT | INPUT | $\begin{gathered} \text { L22N_O } \end{gathered}$ | $\stackrel{\text { I/O }}{\text { L22P_1 }}$ | $\stackrel{\mathrm{I} / \mathbf{O}}{\mathrm{L} 23 \mathrm{P} \_1}$ | $\begin{gathered} \text { I/O } \\ \text { L23N_1 } \end{gathered}$ | $\stackrel{\text { I/O }}{\text { L21N_1 }}$ | $\begin{aligned} & \text { I/O } \\ & \text { L24N_1 } \\ & \text { RREF_1 }_{2}^{2} \end{aligned}$ | H |
| GND | VCCINT | $\begin{gathered} \text { I/O } \\ \text { L19N_1 } \\ \hline \text { A0 } \\ \hline \end{gathered}$ | $\stackrel{\text { L/O }}{\text { L19P_1 }}$ | INPUT | $\begin{gathered} \mathbf{I / O} \\ \mathrm{LLP}_{\text {A2 }} 1 \end{gathered}$ | $\begin{aligned} & \text { I/O } \\ & \text { L20N_1 } \end{aligned}$ | $\begin{gathered} \text { I/O } \\ \text { L20P_1 } \end{gathered}$ | $\stackrel{\mathrm{I} / \mathrm{O}}{\mathrm{~L} 21 \mathrm{P}_{-} 1}$ |  | J |
| VCCINT | GND |  |  | VCCO_1 | $\begin{gathered} \text { I/O } \\ \text { L18N_1 }_{\text {A1 }} \end{gathered}$ | GND | INPUT VREF_1 | VCCO_1 | $\begin{array}{\|c\|} \hline \text { I/O } \\ \text { LITP }^{\text {AT }} \\ \text { RHCLK6 } \\ \hline \end{array}$ | $\text { K } \underset{\underset{\sim}{x}}{ }$ |
| GND | VCCINT | GND |  | I/O <br> L15P_1 <br> RHCLK2 |  | vCCAux | INPUT | $\begin{gathered} \text { I/O } \\ \text { L13N_1 } \\ \text { VREF_1 } \end{gathered}$ | GND | L |
| VCCINT | GND | VCCINT | vccaux | $\stackrel{\text { I/O }}{\text { L11P_1 }}$ |  | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{~L}_{1} 12 \mathrm{P}-1 \\ \mathrm{~A} 12^{2} \end{gathered}$ | $\begin{gathered} \mathbf{I / O} \\ \mathrm{LLRN}_{12 \mathrm{~N}} \mathbf{A 1 1} \end{gathered}$ | $\underset{\text { L13P_1 }}{\mathbf{I} \mathbf{O}}$ | INPUT | M |
| $\begin{gathered} \text { I/O } \\ \text { D5 } \end{gathered}$ | VCCINT | GND | INPUT | $\stackrel{\text { I/O }}{\text { L11N_1 }}$ | $\begin{gathered} \text { I/O } \\ \text { LO9P_1 } \end{gathered}$ | vcco_1 | $\begin{aligned} & \text { L10P_O } \end{aligned}$ | $\begin{aligned} & \text { I/O } \\ & \text { L10N_1 } \end{aligned}$ | INPUT | N |
|  |  | 1/0 | $\begin{gathered} \text { I/O } \\ \text { L25N_2 } \end{gathered}$ | INPUT | $\begin{gathered} \mathbf{I} \mathbf{O} \\ \text { L09N_1 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { LO7P_1 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { LOTN_1 } \end{gathered}$ | GND | $\begin{gathered} \text { I/O } \\ \text { Lo8N_1 } \\ \text { VREF_1 } \\ \hline \end{gathered}$ | P |
| VCCO_2 | INPUT L20P_2 | 1/0 | $\begin{aligned} & \text { I/O } \\ & \text { L25P__ } \end{aligned}$ | GND | INPUT | $\begin{gathered} \text { I/O } \\ \text { L05P_1 } \end{gathered}$ | $\begin{aligned} & \text { I/O } \\ & \text { LO5N_1 } \end{aligned}$ | INPUT | $\begin{aligned} & \text { L/O } \\ & \text { L08P_1 } \end{aligned}$ | R |
| $\begin{aligned} & \text { I/O } \\ & \text { M1 } \end{aligned}$ | INPUT L20N_2 | $\begin{aligned} & \text { INPUT } \\ & \text { L23N_2 } \\ & \text { VREF_2 } \end{aligned}$ | INPUT L23P_2 | $\begin{gathered} \text { I/O } \\ \text { L28N_2 } \end{gathered}$ | INPUT | $\begin{gathered} \text { I/O } \\ \text { LO2P_1 } \\ \text { A14 } \end{gathered}$ | $\begin{aligned} & \text { I/O } \\ & \text { Lo2N-1 } \\ & \text { A13 } \end{aligned}$ | VCCO_1 | $\stackrel{\text { I/O }}{\text { LO6N_1 }}$ | T |
| GND | $\begin{gathered} \text { I/O } \\ \text { L21N_2 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L24N_2 } \end{gathered}$ | VCCO_2 | $\stackrel{\text { L/O }}{\text { L28P__ }}$ | $\begin{gathered} \text { I/O } \\ \text { L30P_2 } \\ \text { A21 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { L01P_1 } \\ \text { A16 } \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { LO1N_1 } \\ \text { A15 } \end{gathered}$ | $\stackrel{\text { I/O }}{\text { LO3P_1 }}$ | ${ }_{\text {LO6P_1 }}^{\text {LO }}$ | U |
|  | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \mathrm{~L} 21 \mathrm{P} \_2 \end{gathered}$ | $\stackrel{\mathrm{l} / \mathrm{O}}{\text { L24P_2 }}$ | INPUT L26N_2 | INPUT | $\begin{gathered} \text { I/O } \\ \text { L30N_2 } \\ \text { A20 } \end{gathered}$ | DONE | GND | $\begin{aligned} & \text { I/O } \\ & \text { LO3N_1 } \\ & \text { VREF_1 } \end{aligned}$ | $\stackrel{\text { I/O }}{\text { L04P_1 }}$ | V |
| VCCO_2 | $\begin{gathered} \hline \text { I/O } \\ \text { L22N_2 } \\ \text { VREF_2 } \end{gathered}$ | $\stackrel{\mathrm{I} / \mathrm{O}}{\text { L22P_2 }}$ | GND | 1/0 | INPUT L29N_2 | VCCO_2 |  | $\begin{gathered} \text { I/O } \\ \text { L32N2 }^{2} \\ \text { CCLLK } \end{gathered}$ | $\stackrel{\text { I/O }}{\text { LO4N_1 }}$ | W |
| $\begin{gathered} \text { I/O } \\ \text { L19P_2 } \\ \text { M0 } \\ \hline \end{gathered}$ | $\begin{gathered} \text { I/O } \\ \text { Li9N } \\ \text { LiN } \\ \text { DO } \\ \hline \end{gathered}$ | 1/0 | $\begin{gathered} \text { I/O } \\ \text { L27N_2 } \\ \text { A222 } \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { 1/O } \\ \text { L27P_2 } \\ \text { A23 } \\ \hline \end{array}$ | INPUT L29P_2 | $\begin{gathered} \text { I/O } \\ \text { VREF_2 } \end{gathered}$ | $\begin{array}{\|c} 1 / 0 \\ \text { L31N } \\ \text { VSI } \\ \text { A18 } \\ \hline \end{array}$ | $\begin{gathered} \mathrm{I} / \mathrm{O} \\ \text { L32P-2 } \\ \text { VSO } \\ \text { V17 } \\ \hline \end{gathered}$ | GND | Y |
| Bank 2 |  |  |  |  |  |  |  |  | DS312-4_09_031105 |  |

Right Half of Package (top view)

## FG484: 484-ball Fine-pitch Ball Grid Array

The 484-ball fine-pitch ball grid array, FG484, supports the XC3S1600E FPGA.
Table 31 lists all the FG484 package pins. They are sorted by bank number and then by pin name. Pairs of 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.
An electronic version of this package pinout table and footprint diagram is available for download from the Xilinx website at http://www.xilinx.com/bvdocs/publications/s3e_pin.zip.

## Pinout Table

Table 31: FG484 Package Pinout

| Bank | XC3S1600E <br> Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | 10 | B6 | I/O |
| 0 | 10 | B13 | I/O |
| 0 | 10 | C5 | I/O |
| 0 | 10 | C14 | I/O |
| 0 | 10 | E16 | I/O |
| 0 | 10 | F9 | I/O |
| 0 | 10 | F16 | I/O |
| 0 | 10 | G8 | I/O |
| 0 | 10 | H10 | I/O |
| 0 | 10 | H15 | I/O |
| 0 | 10 | J11 | I/O |
| 0 | IO/VREF_0 | G12 | VREF |
| 0 | IO_L01N_0 | C18 | I/O |
| 0 | $1 O_{\text {_L01P_0 }}$ | C19 | I/O |
| 0 | 1 O _L03N_0/VREF_0 | A20 | VREF |
| 0 | IO_L03P_0 | A21 | I/O |
| 0 | 1 O _L04N_0 | A19 | I/O |
| 0 | 1 O _L04P_0 | A18 | I/O |
| 0 | IO_L06N_0 | C16 | I/O |
| 0 | IO_L06P_0 | D16 | I/O |
| 0 | 1 O _L07N_0 | A16 | I/O |
| 0 | 1 O _L07P_0 | A17 | I/O |
| 0 | IO_L09N_0/VREF_0 | B15 | VREF |
| 0 | IO_L09P_0 | C15 | I/O |
| 0 | IO_L10N_0 | G15 | I/O |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{aligned} & \text { FG484 } \\ & \text { Ball } \end{aligned}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | IO_L10P_0 | F15 | I/O |
| 0 | IO_L11N_0 | D14 | I/O |
| 0 | IO_L11P_0 | E14 | I/O |
| 0 | IO_L12N_O/VREF_0 | A14 | VREF |
| 0 | IO_L12P_0 | A15 | I/O |
| 0 | IO_L13N_0 | H14 | I/O |
| 0 | IO_L13P_0 | G14 | I/O |
| 0 | IO_L15N_0 | G13 | I/O |
| 0 | IO_L15P_0 | F13 | I/O |
| 0 | IO_L16N_0 | J13 | I/O |
| 0 | IO_L16P_0 | H13 | I/O |
| 0 | IO_L18N_0/GCLK5 | E12 | GCLK |
| 0 | IO_L18P_0/GCLK4 | F12 | GCLK |
| 0 | IO_L19N_0/GCLK7 | C12 | GCLK |
| 0 | IO_L19P_0/GCLK6 | B12 | GCLK |
| 0 | IO_L21N_0/GCLK11 | B11 | GCLK |
| 0 | IO_L21P_0/GCLK10 | C11 | GCLK |
| 0 | IO_L22N_0 | D11 | I/O |
| 0 | IO_L22P_0 | E11 | I/O |
| 0 | IO_L24N_0 | A9 | I/O |
| 0 | IO_L24P_0 | A10 | I/O |
| 0 | IO_L25N_0/VREF_0 | D10 | VREF |
| 0 | IO_L25P_0 | C10 | I/O |
| 0 | IO_L27N_0 | H8 | 1/0 |
| 0 | IO_L27P_0 | H9 | I/O |
| 0 | IO_L28N_0 | C9 | I/O |
| 0 | IO_L28P_0 | B9 | I/O |
| 0 | IO_L29N_0 | E9 | I/O |
| 0 | IO_L29P_0 | D9 | I/O |
| 0 | IO_L30N_0 | B8 | 1/0 |
| 0 | IO_L30P_0 | A8 | I/O |
| 0 | IO_L32N_0/VREF_0 | F7 | VREF |
| 0 | IO_L32P_0 | F8 | I/O |
| 0 | IO_L33N_0 | A6 | I/O |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | IO_L33P_0 | A7 | I/O |
| 0 | IO_L35N_0 | A4 | I/O |
| 0 | IO_L35P_0 | A5 | I/O |
| 0 | IO_L36N_0 | E7 | I/O |
| 0 | IO_L36P_0 | D7 | I/O |
| 0 | IO_L38N_0/VREF_0 | D6 | VREF |
| 0 | 1O_L38P_0 | D5 | I/O |
| 0 | IO_L39N_0 | B4 | I/O |
| 0 | IO_L39P_0 | B3 | I/O |
| 0 | IO_L40N_0/HSWAP | D4 | DUAL |
| 0 | IO_L40P_0 | C4 | I/O |
| 0 | IP | B19 | INPUT |
| 0 | IP | E6 | INPUT |
| 0 | IP_L02N_0 | D17 | INPUT |
| 0 | IP_L02P_0 | D18 | INPUT |
| 0 | IP_L05N_0 | C17 | INPUT |
| 0 | IP_L05P_0 | B17 | INPUT |
| 0 | IP_L08N_0 | E15 | INPUT |
| 0 | IP_L08P_0 | D15 | INPUT |
| 0 | IP_L14N_0 | D13 | INPUT |
| 0 | IP_L14P_0 | C13 | INPUT |
| 0 | IP_L17N_0 | A12 | INPUT |
| 0 | IP_L17P_0 | A13 | INPUT |
| 0 | IP_L20N_0/GCLK9 | H11 | GCLK |
| 0 | IP_L20P_0/GCLK8 | H12 | GCLK |
| 0 | IP_L23N_0 | F10 | INPUT |
| 0 | IP_L23P_0 | F11 | INPUT |
| 0 | IP_L26N_0 | G9 | INPUT |
| 0 | IP_L26P_0 | G10 | INPUT |
| 0 | IP_L31N_0 | C8 | INPUT |
| 0 | IP_L31P_0 | D8 | INPUT |
| 0 | IP_L34N_0 | C7 | INPUT |
| 0 | IP_L34P_0 | C6 | INPUT |
| 0 | IP_L37N_0 | A3 | INPUT |
| 0 | IP_L37P_0 | A2 | INPUT |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 0 | VCCO_0 | B5 | vCCO |
| 0 | vCCO_0 | B10 | vcco |
| 0 | vcco_0 | B14 | vcco |
| 0 | VCCO_0 | B18 | vCCO |
| 0 | VCCO_0 | E8 | vCCO |
| 0 | vCCO_0 | F14 | vcco |
| 0 | VCCO_0 | G11 | VCCO |
| 1 | IO_L01N_1/A15 | Y22 | DUAL |
| 1 | IO_L01P_1/A16 | AA22 | DUAL |
| 1 | 1 O _L02N_1/A13 | W21 | DUAL |
| 1 | IO_L02P_1/A14 | Y21 | DUAL |
| 1 | IO_LO3N_1/VREF_1 | W20 | VREF |
| 1 | IO_L03P_1 | V20 | I/O |
| 1 | IO_L04N_1 | U19 | 1/0 |
| 1 | IO_L04P_1 | V19 | 1/0 |
| 1 | IO_L05N_1 | V22 | I/O |
| 1 | IO_L05P_1 | W22 | 1/0 |
| 1 | IO_L06N_1 | T19 | I/O |
| 1 | IO_L06P_1 | T18 | I/O |
| 1 | IO_LO7N_1/VREF_1 | U20 | VREF |
| 1 | IO_L07P_1 | U21 | I/O |
| 1 | IO_L08N_1 | T22 | I/O |
| 1 | IO_L08P_1 | U22 | 1/0 |
| 1 | IO_L09N_1 | R19 | I/O |
| 1 | IO_L09P_1 | R18 | I/O |
| 1 | IO_L10N_1 | R16 | 1/0 |
| 1 | IO_L10P_1 | T16 | I/O |
| 1 | IO_L11N_1 | R21 | I/O |
| 1 | IO_L11P_1 | R20 | I/O |
| 1 | IO_L12N_1/VREF_1 | P18 | VREF |
| 1 | IO_L12P_1 | P17 | I/O |
| 1 | IO_L13N_1 | P22 | 1/0 |
| 1 | IO_L13P_1 | R22 | I/O |
| 1 | IO_L14N_1 | P15 | I/O |
| 1 | IO_L14P_1 | P16 | 1/0 |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 1 | IO_L15N_1 | N18 | I/O |
| 1 | IO_L15P_1 | N19 | I/O |
| 1 | IO_L16N_1/A11 | N16 | DUAL |
| 1 | IO_L16P_1/A12 | N17 | DUAL |
| 1 | IO_L17N_1/VREF_1 | M20 | VREF |
| 1 | IO_L17P_1 | N20 | I/O |
| 1 | IO_L18N_1/A9/RHCLK1 | M22 | RHCLK/ DUAL |
| 1 | IO_L18P_1/A10/RHCLK0 | N22 | RHCLK/ DUAL |
| 1 | IO_L19N_1/A7/RHCLK3/ TRDY1 | M16 | RHCLK/ DUAL |
| 1 | IO_L19P_1/A8/RHCLK2 | M15 | RHCLK/ DUAL |
| 1 | IO_L20N_1/A5/RHCLK5 | L21 | RHCLK/ DUAL |
| 1 | IO_L20P_1/A6/RHCLK4/ IRDY1 | L20 | RHCLK/ DUAL |
| 1 | IO_L21N_1/A3/RHCLK7 | L19 | RHCLK DUAL |
| 1 | IO_L21P_1/A4/RHCLK6 | L18 | RHCLK/ DUAL |
| 1 | IO_L22N_1/A1 | K22 | DUAL |
| 1 | IO_L22P_1/A2 | L22 | DUAL |
| 1 | IO_L23N_1/A0 | K17 | DUAL |
| 1 | $1 O^{\prime}$ L23P_1 | K16 | I/O |
| 1 | IO_L24N_1 | K19 | I/O |
| 1 | IO_L24P_1 | K18 | I/O |
| 1 | IO_L25N_1 | K15 | I/O |
| 1 | $1 O_{1}$ L25P_1 | J15 | I/O |
| 1 | IO_L26N_1 | J20 | I/O |
| 1 | IO_L26P_1 | J21 | I/O |
| 1 | 1 O _27N_1 | J17 | I/O |
| 1 | $1 O_{1}$ L27P_1 | J18 | I/O |
| 1 | IO_L28N_1/VREF_1 | H21 | VREF |
| 1 | $1 O_{1}$ L28P_1 | H22 | I/O |
| 1 | IO_L29N_1 | H20 | I/O |
| 1 | $1 O^{\prime}$ L29P_1 | H19 | I/O |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 1 | IO_L30N_1 | H17 | I/O |
| 1 | IO_L30P_1 | G17 | 1/0 |
| 1 | IO_L31N_1 | F22 | 1/0 |
| 1 | IO_L31P_1 | G22 | I/O |
| 1 | IO_L32N_1 | F20 | I/O |
| 1 | IO_L32P_1 | G20 | I/O |
| 1 | IO_L33N_1 | G18 | I/O |
| 1 | IO_L33P_1 | G19 | I/O |
| 1 | IO_L34N_1 | D22 | I/O |
| 1 | IO_L34P_1 | E22 | I/O |
| 1 | IO_L35N_1 | F19 | I/O |
| 1 | IO_L35P_1 | F18 | I/O |
| 1 | IO_L36N_1 | E20 | I/O |
| 1 | IO_L36P_1 | E19 | I/O |
| 1 | IO_L37N_1/LDC0 | C21 | DUAL |
| 1 | IO_L37P_1/HDC | C22 | DUAL |
| 1 | IO_L38N_1/LDC2 | B21 | DUAL |
| 1 | IO_L38P_1/LDC1 | B22 | DUAL |
| 1 | IP | D20 | INPUT |
| 1 | IP | F21 | INPUT |
| 1 | IP | G16 | INPUT |
| 1 | IP | H16 | INPUT |
| 1 | IP | J16 | INPUT |
| 1 | IP | J22 | INPUT |
| 1 | IP | K20 | INPUT |
| 1 | IP | L15 | INPUT |
| 1 | IP | M18 | INPUT |
| 1 | IP | N15 | INPUT |
| 1 | IP | N21 | INPUT |
| 1 | IP | P20 | INPUT |
| 1 | IP | R15 | INPUT |
| 1 | IP | T17 | INPUT |
| 1 | IP | T20 | INPUT |
| 1 | IP | U18 | INPUT |
| 1 | IP/VREF_1 | D21 | VREF |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 1 | IP/VREF_1 | L17 | VREF |
| 1 | VCCO_1 | E21 | VCCO |
| 1 | VCCO_1 | H18 | VCCO |
| 1 | VCCO_1 | K21 | VCCO |
| 1 | VCCO_1 | L16 | VCCO |
| 1 | VCCO_1 | P21 | VCCO |
| 1 | VCCO_1 | R17 | VCCO |
| 1 | VCCO_1 | V21 | VCCO |
| 2 | 10 | Y8 | I/O |
| 2 | 10 | Y9 | I/O |
| 2 | 10 | AA10 | I/O |
| 2 | 10 | AB5 | I/O |
| 2 | 10 | AB13 | I/O |
| 2 | 10 | AB14 | I/O |
| 2 | 10 | AB16 | I/O |
| 2 | 10 | AB18 | I/O |
| 2 | IO/D5 | AB11 | DUAL |
| 2 | IO/M1 | AA12 | DUAL |
| 2 | IO/VREF_2 | AB4 | VREF |
| 2 | IO/VREF_2 | AB21 | VREF |
| 2 | IO_L01N_2/INIT_B | AB3 | DUAL |
| 2 | IO_L01P_2/CSO_B | AA3 | DUAL |
| 2 | IO_L03N_2/MOSI/CSI_B | Y5 | DUAL |
| 2 | IO_L03P_2/DOUT/BUSY | W5 | DUAL |
| 2 | 1 O _L04N_2 | W6 | I/O |
| 2 | 1 O _04P_2 | V6 | I/O |
| 2 | 1 O _L06N_2 | W7 | I/O |
| 2 | IO_L06P_2 | Y7 | I/O |
| 2 | 1 O L07N_2 | U7 | I/O |
| 2 | 1 O _07P_2 | V7 | I/O |
| 2 | IO_L09N_2/VREF_2 | V8 | VREF |
| 2 | IO_L09P_2 | W8 | I/O |
| 2 | IO_L10N_2 | T8 | I/O |
| 2 | IO_L10P_2 | U8 | I/O |
| 2 | IO_L11N_2 | AB8 | I/O |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 2 | IO_L11P_2 | AA8 | I/O |
| 2 | IO_L12N_2 | W9 | I/O |
| 2 | IO_L12P_2 | v9 | I/O |
| 2 | IO_L13N_2/VREF_2 | R9 | VREF |
| 2 | IO_L13P_2 | T9 | I/O |
| 2 | IO_L14N_2 | AB9 | I/O |
| 2 | IO_L14P_2 | AB10 | 1/O |
| 2 | IO_L16N_2 | U10 | I/O |
| 2 | IO_L16P_2 | T10 | I/O |
| 2 | IO_L17N_2 | R10 | I/O |
| 2 | IO_L17P_2 | P10 | I/O |
| 2 | IO_L19N_2/D6/GCLK13 | U11 | DUAL GCLK |
| 2 | IO_L19P_2/D7/GCLK12 | V11 | DUAL GCLK |
| 2 | IO_L20N_2/D3/GCLK15 | T11 | DUAL GCLK |
| 2 | IO_L20P_2/D4/GCLK14 | R11 | DUAL GCLK |
| 2 | IO_L22N_2/D1/GCLK3 | W12 | DUAL GCLK |
| 2 | IO_L22P_2/D2/GCLK2 | Y12 | DUAL GCLK |
| 2 | 1 O _L23N_2/DIN/D0 | U12 | DUAL |
| 2 | IO_L23P_2/M0 | V12 | DUAL |
| 2 | IO_L25N_2 | Y13 | I/O |
| 2 | IO_L25P_2 | W13 | I/O |
| 2 | IO_L26N_2/VREF_2 | U14 | VREF |
| 2 | IO_L26P_2 | U13 | I/O |
| 2 | IO_L27N_2 | T14 | I/O |
| 2 | IO_L27P_2 | R14 | I/O |
| 2 | IO_L28N_2 | Y14 | I/O |
| 2 | IO_L28P_2 | AA14 | I/O |
| 2 | IO_L29N_2 | W14 | I/O |
| 2 | IO_L29P_2 | V14 | I/O |
| 2 | IO_L30N_2 | AB15 | I/O |
| 2 | IO_L30P_2 | AA15 | I/O |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type | Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 2 | IO_L32N_2 | W15 | I/O | 2 | IP_L37N_2 | AA19 | INPUT |
| 2 | IO_L32P_2 | Y15 | I/O | 2 | IP_L37P_2 | AB19 | INPUT |
| 2 | IO_L33N_2 | U16 | I/O | 2 | VCCO_2 | T12 | VCCO |
| 2 | IO_L33P_2 | V16 | I/O | 2 | VCCO_2 | U9 | VCCO |
| 2 | 1 O L35N_2/A22 | AB17 | DUAL | 2 | VCCO_2 | V15 | VCCO |
| 2 | IO_L35P_2/A23 | AA17 | DUAL | 2 | VCCO_2 | AA5 | VCCO |
| 2 | 1 O _L36N_2 | W17 | I/O | 2 | VCCO_2 | AA9 | VCCO |
| 2 | IO_L36P_2 | Y17 | I/O | 2 | VCCO_2 | AA13 | VCCO |
| 2 | 1 O | Y18 | DUAL | 2 | VCCO_2 | AA18 | VCCO |
| 2 | IO_L38P_2/A21 | W18 | DUAL | 3 | IO_L01N_3 | C1 | I/O |
| 2 | IO_L39N_2/VS1/A18 | AA20 | DUAL | 3 | 1 O _L01P_3 | C2 | I/O |
| 2 | IO_L39P_2/VS2/A19 | AB20 | DUAL | 3 | IO_LO2N_3/VREF_3 | D2 | VREF |
| 2 | IO_L40N_2/CCLK | W19 | DUAL | 3 | 1 O _L02P_3 | D3 | I/O |
| 2 | IO_L40P_2/VS0/A17 | Y19 | DUAL | 3 | 1 O _L03N_3 | E3 | I/O |
| 2 | IP | V17 | INPUT | 3 | $10 \_$L03P_3 | E4 | I/O |
| 2 | IP | AB2 | INPUT | 3 | 1 O _L04N_3 | E1 | I/O |
| 2 | IP_L02N_2 | AA4 | INPUT | 3 | $10 \_$L04P_3 | D1 | I/O |
| 2 | IP_L02P_2 | Y4 | INPUT | 3 | IO_L05N_3 | F4 | I/O |
| 2 | IP_L05N_2 | Y6 | INPUT | 3 | $10 \_$L05P_3 | F3 | I/O |
| 2 | IP_L05P_2 | AA6 | INPUT | 3 | IO_L06N_3 | G5 | I/O |
| 2 | IP_L08N_2 | AB7 | INPUT | 3 | $10 \_$L06P_3 | G4 | I/O |
| 2 | IP_L08P_2 | AB6 | INPUT | 3 | 1 O _L07N_3 | F1 | I/O |
| 2 | IP_L15N_2 | Y10 | INPUT | 3 | 1 O _L07P_3 | G1 | I/O |
| 2 | IP_L15P_2 | W10 | INPUT | 3 | IO_L08N_3/VREF_3 | G6 | VREF |
| 2 | IP_L18N_2/VREF_2 | AA11 | VREF | 3 | 1 O _L08P_3 | G7 | I/O |
| 2 | IP_L18P_2 | Y11 | INPUT | 3 | IO_L09N_3 | H4 | I/O |
| 2 | IP_L21N_2/M2/GCLK1 | P12 | DUAL/ | 3 | IO_L09P_3 | H5 | I/O |
|  |  |  |  | 3 | IO_L10N_3 | H2 | I/O |
| 2 | $\begin{aligned} & \text { IP_L21P_2/RDWR_B/ } \\ & \text { GCLKO } \end{aligned}$ | R12 | DUAL/ GCLK | 3 | IO_L10P_3 | H3 | I/O |
| 2 | IP_L24N_2 | R13 | INPUT | 3 | IO_L11N_3 | H1 | I/O |
| 2 | IP_L24P_2 | T13 | INPUT | 3 | IO_L11P_3 | J1 | I/O |
| 2 | IP_L31N_2/VREF_2 | T15 | VREF | 3 | IO_L12N_3 | J6 | 1/O |
| 2 | IP_L31P_2 | U15 | INPUT | 3 | $1 O_{-}$L12P_3 | J5 | I/O |
| 2 | IP_L34N_2 | Y16 | INPUT | 3 | IO_L13N_3/VREF_3 | J3 | VREF |
| 2 | IP_L34P_2 | W16 | INPUT | 3 | $1 O_{-}$L13P_3 | K3 | I/O |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 3 | IO_L14N_3 | J8 | I/O |
| 3 | IO_L14P_3 | K8 | I/O |
| 3 | IO_L15N_3 | K4 | I/O |
| 3 | IO_L15P_3 | K5 | I/O |
| 3 | IO_L16N_3 | K1 | I/O |
| 3 | IO_L16P_3 | L1 | I/O |
| 3 | IO_L17N_3 | L7 | I/O |
| 3 | IO_L17P_3 | K7 | I/O |
| 3 | IO_L18N_3/LHCLK1 | L5 | LHCLK |
| 3 | IO_L18P_3/LHCLK0 | M5 | LHCLK |
| 3 | IO_L19N_3/LHCLK3/IRDY2 | M8 | LHCLK |
| 3 | IO_L19P_3/LHCLK2 | L8 | LHCLK |
| 3 | IO_L20N_3/LHCLK5 | N1 | LHCLK |
| 3 | IO_L20P_3/LHCLK4/TRDY2 | M1 | LHCLK |
| 3 | IO_L21N_3/LHCLK7 | M4 | LHCLK |
| 3 | IO_L21P_3/LHCLK6 | M3 | LHCLK |
| 3 | IO_L22N_3 | N6 | I/O |
| 3 | IO_L22P_3 | N7 | I/O |
| 3 | IO_L23N_3 | P8 | I/O |
| 3 | IO_L23P_3 | N8 | I/O |
| 3 | IO_L24N_3/VREF_3 | N4 | VREF |
| 3 | IO_L24P_3 | N5 | I/O |
| 3 | IO_L25N_3 | P2 | I/O |
| 3 | IO_L25P_3 | P1 | I/O |
| 3 | IO_L26N_3 | R7 | I/O |
| 3 | IO_L26P_3 | P7 | I/O |
| 3 | IO_L27N_3 | P6 | 1/O |
| 3 | IO_L27P_3 | P5 | 1/O |
| 3 | IO_L28N_3 | R2 | 1/O |
| 3 | IO_L28P_3 | R1 | 1/O |
| 3 | IO_L29N_3 | R3 | 1/O |
| 3 | IO_L29P_3 | R4 | 1/O |
| 3 | IO_L30N_3 | T6 | 1/O |
| 3 | IO_L30P_3 | R6 | I/O |
| 3 | IO_L31N_3 | U2 | 1/O |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 3 | IO_L31P_3 | U1 | I/O |
| 3 | IO_L32N_3 | T4 | I/O |
| 3 | IO_L32P_3 | T5 | 1/0 |
| 3 | IO_L33N_3 | W1 | I/O |
| 3 | IO_L33P_3 | V1 | I/O |
| 3 | IO_L34N_3 | U4 | I/O |
| 3 | IO_L34P_3 | U3 | I/O |
| 3 | IO_L35N_3 | V4 | I/O |
| 3 | IO_L35P_3 | V3 | 1/O |
| 3 | IO_L36N_3/VREF_3 | W3 | VREF |
| 3 | IO_L36P_3 | W2 | I/O |
| 3 | IO_L37N_3 | Y2 | I/O |
| 3 | IO_L37P_3 | Y1 | I/O |
| 3 | IO_L38N_3 | AA1 | I/O |
| 3 | IO_L38P_3 | AA2 | I/O |
| 3 | IP | F2 | INPUT |
| 3 | IP | F5 | INPUT |
| 3 | IP | G3 | INPUT |
| 3 | IP | H7 | INPUT |
| 3 | IP | J7 | INPUT |
| 3 | IP | K2 | INPUT |
| 3 | IP | K6 | INPUT |
| 3 | IP | M2 | INPUT |
| 3 | IP | M6 | INPUT |
| 3 | IP | N3 | INPUT |
| 3 | IP | P3 | INPUT |
| 3 | IP | R8 | INPUT |
| 3 | IP | T1 | INPUT |
| 3 | IP | T7 | INPUT |
| 3 | IP | U5 | INPUT |
| 3 | IP | W4 | INPUT |
| 3 | IP/VREF_3 | L3 | VREF |
| 3 | IP/VREF_3 | T3 | VREF |
| 3 | VCCO_3 | E2 | vCCO |
| 3 | vCCO_3 | H6 | vCCO |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| 3 | VCCO_3 | J2 | VCCO |
| 3 | VCCO_3 | M7 | VCCO |
| 3 | VCCO_3 | N2 | VCCO |
| 3 | VCCO_3 | R5 | VCCO |
| 3 | VCCO_3 | V2 | VCCO |
| GND | GND | A1 | GND |
| GND | GND | A11 | GND |
| GND | GND | A22 | GND |
| GND | GND | B7 | GND |
| GND | GND | B16 | GND |
| GND | GND | C3 | GND |
| GND | GND | C20 | GND |
| GND | GND | E10 | GND |
| GND | GND | E13 | GND |
| GND | GND | F6 | GND |
| GND | GND | F17 | GND |
| GND | GND | G2 | GND |
| GND | GND | G21 | GND |
| GND | GND | J4 | GND |
| GND | GND | J9 | GND |
| GND | GND | J12 | GND |
| GND | GND | J14 | GND |
| GND | GND | J19 | GND |
| GND | GND | K10 | GND |
| GND | GND | K12 | GND |
| GND | GND | L2 | GND |
| GND | GND | L6 | GND |
| GND | GND | L9 | GND |
| GND | GND | L13 | GND |
| GND | GND | M10 | GND |
| GND | GND | M14 | GND |
| GND | GND | M17 | GND |
| GND | GND | M21 | GND |
| GND | GND | N11 | GND |
| GND | GND | N13 | GND |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E <br> Pin Name | $\begin{gathered} \text { FG484 } \\ \text { Ball } \end{gathered}$ | Type |
| :---: | :---: | :---: | :---: |
| GND | GND | P4 | GND |
| GND | GND | P9 | GND |
| GND | GND | P11 | GND |
| GND | GND | P14 | GND |
| GND | GND | P19 | GND |
| GND | GND | T2 | GND |
| GND | GND | T21 | GND |
| GND | GND | U6 | GND |
| GND | GND | U17 | GND |
| GND | GND | V10 | GND |
| GND | GND | V13 | GND |
| GND | GND | Y3 | GND |
| GND | GND | Y20 | GND |
| GND | GND | AA7 | GND |
| GND | GND | AA16 | GND |
| GND | GND | AB1 | GND |
| GND | GND | AB12 | GND |
| GND | GND | AB22 | GND |
| VCCAUX | DONE | AA21 | CONFIG |
| vCCAUX | PROG_B | B1 | CONFIG |
| VCCAUX | TCK | E17 | JTAG |
| vCCAUX | TDI | B2 | JTAG |
| vCCAUX | TDO | B20 | JTAG |
| vCCAUX | TMS | D19 | JTAG |
| VCCAUX | VCCAUX | D12 | VCCAUX |
| vCCAUX | vccaux | E5 | vCCAUX |
| vCCAUX | vccaux | E18 | vccaux |
| vCCAUX | vCCAUX | K14 | vccaux |
| vCCAUX | vccaux | L4 | vccaux |
| vCCAUX | vccaux | M19 | vccaux |
| vCCAUX | vccaux | N9 | vccaux |
| vCCAUX | vccaux | V5 | vccaux |
| vCCAUX | vccaux | V18 | vccaux |
| vCCAUX | vccaux | W11 | vccaux |
| VCCINT | VCCINT | J10 | VCCINT |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E <br> Pin Name | FG484 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| VCCINT | VCCINT | K9 | VCCINT |
| VCCINT | VCCINT | K11 | VCCINT |
| VCCINT | VCCINT | K13 | VCCINT |
| VCCINT | VCCINT | L10 | VCCINT |
| VCCINT | VCCINT | L12 | VCCINT |
| VCCINT | VCCINT | L14 | VCCINT |
| VCCINT | VCCINT | VCCINT |  |
| VCCINT | VCCINT | M112 | VCCINT |
| VCCINT | VCCINT |  |  |
| VCCINT | VCCINT |  |  |

Table 31: FG484 Package Pinout

| Bank | XC3S1600E <br> Pin Name | FG484 <br> Ball | Type |
| :---: | :--- | :---: | :---: |
| VCCINT | VCCINT | M13 | VCCINT |
| VCCINT | VCCINT | N10 | VCCINT |
| VCCINT | VCCINT | N12 | VCCINT |
| VCCINT | VCCINT | N14 | VCCINT |
| VCCINT | VCCINT | P13 | VCCINT |

## User I/Os by Bank

Table 32 indicates how the 304 available user-I/O pins are distributed between the four I/O banks on the FG484 package.

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

| Package <br> Edge | I/O Bank | Maximum <br> $\mathbf{I / O}$ | All Possible I/O Pins by Type |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | INPUT | DUAL | VREF | GCLK |  |
| Top |  |  | 56 | 22 | 1 | 7 | 8 |
| Right | 1 |  | 50 | 16 | 21 | 7 | 0 |
| Bottom | 2 |  | 45 | 18 | 24 | 7 | 0 |
| Left | 3 |  | 63 | 16 | 0 | 7 | 8 |
| TOTAL |  | $\mathbf{3 7 6}$ | $\mathbf{2 1 4}$ | $\mathbf{7 2}$ | $\mathbf{4 6}$ | $\mathbf{2 8}$ | $\mathbf{1 6}$ |

## Footprint Migration Differences

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

## FG484 Footprint

## Left Half of Package (top view)

214
I/O: Unrestricted, general-purpose user I/O

NPUT: User I/O or
72 reference resistor input for bank

DUAL: Configuration pin, then possible user I/O

28
VREF: User I/O or input voltage reference for bank

GCLK: User I/O, input, or clock buffer input


CONFIG: Dedicated configuration pins


JTAG: Dedicated JTAG port pins

48
GND: Ground

VCCO: Output voltage supply for bank

VCCINT: Internal core
supply voltage (+1.2V)
VCCAUX: Auxiliary supply
voltage (+2.5V)
N.C.: Not connected


DS312_10_031105
Figure 10: FG484 Package Footprint (top view)


## 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 6. Corrected number of differential I/O <br> pairs on CP132. Added pinout and footprint information for the CP132, FG400, and FG484 <br> packages. Removed IRDY and TRDY pins from the VQ100, TQ144, and PQ208 packages. |

## The Spartan-3E Family Data Sheet

DS312-1, Spartan-3E FPGA Family: Introduction and Ordering Information (Module 1)
DS312-2, Spartan-3E FPGA Family: Functional Description (Module 2)
DS312-3, Spartan-3E FPGA Family: DC and Switching Characteristics (Module 3)
DS312-4, Spartan-3E FPGA Family: Pinout Descriptions (Module 4)


[^0]:    IMPORTANT NOTE: The SpartanTM-3E FPGA data sheet is created and published in separate modules. This complete version is provided for easy downloading and searching of the complete document. Page, figure, and table numbers begin at 1 for each module, and each module has its own Revision History at the end. Use the PDF "Bookmarks" for easy navigation in this volume.

