

DS030 (v1.10) November 18, 2002

# Spartan/XL Family One-Time Programmable Configuration PROMs (XC17S00/XL)

**Product Specification** 

#### Introduction

The Spartan<sup>™</sup> family of PROMs provides an easy-to-use, cost-effective method for storing Spartan device configuration bitstreams.

When the Spartan device is in Master Serial mode, it generates a configuration clock that drives the Spartan PROM. A short access time after the rising clock edge, data appears on the PROM DATA output pin that is connected to the Spartan device  $D_{\rm IN}$  pin. The Spartan device generates the appropriate number of clock pulses to complete the configuration. Once configured, it disables the PROM. When a Spartan device is in Slave Serial mode, the PROM and the Spartan device must both be clocked by an incoming signal.

For device programming, either the Xilinx Alliance or the Foundation series development systems compiles the Spartan device design file into a standard HEX format which is then transferred to most commercial PROM programmers.

#### **Spartan PROM Features**

- Configuration one-time programmable (OTP) read-only memory designed to store configuration bitstreams for Spartan, Spartan-XL, and Spartan-II FPGA devices
- Simple interface to the Spartan device requires only one user I/O pin
- Programmable reset polarity (active High or active Low)
- Low-power CMOS floating gate process
- Available in 5V and 3.3V versions
- Available in compact plastic 8-pin DIP, 8-pin VOIC, or 20-pin SOIC packages.
- Programming support by leading programmer manufacturers.
- Design support using the Xilinx Alliance and Foundation series software packages.
- Guaranteed 20 year life data retention

| Spartan FPGA           | Configuration Bits | Compatible Spartan PROM |
|------------------------|--------------------|-------------------------|
| XCS05                  | 53,984             | XC17S05                 |
| XCS05XL                | 54,544             | XC17S05XL               |
| XCS10                  | 95,008             | XC17S10                 |
| XCS10XL                | 95,752             | XC17S10XL               |
| XCS20                  | 178,144            | XC17S20                 |
| XCS20XL                | 179,160            | XC17S20XL               |
| XCS30                  | 247,968            | XC17S30                 |
| XCS30XL                | 249,168            | XC17S30XL               |
| XCS40                  | 329,312            | XC17S40                 |
| XCS40XL                | 330,696            | XC17S40XL               |
| XC2S50 <sup>(1)</sup>  | 559,200            | XC17S50XL               |
| XC2S100 <sup>(1)</sup> | 781,216            | XC17S100XL              |
| XC2S150 <sup>(1)</sup> | 1,040,096          | XC17S150XL              |

#### Notes:

For new Spartan-II designs, it is recommended to use the 17S00A family.

© 2002 Xilinx, Inc. All rights reserved. All Xilinx trademarks, registered trademarks, patents, and further disclaimers are as listed at <a href="http://www.xilinx.com/legal.htm">http://www.xilinx.com/legal.htm</a>. All other trademarks and registered trademarks are the property of their respective owners. All specifications are subject to change without notice.

NOTICE OF DISCLAIMER: Xilinx is providing this design, code, or information "as is." By providing the design, code, or information as one possible implementation of this feature, application, or standard, Xilinx makes no representation that this implementation is free from any claims of infringement. You are responsible for obtaining any rights you may require for your implementation. Xilinx expressly disclaims any warranty whatsoever with respect to the adequacy of the implementation, including but not limited to any warranties or representations that this implementation is free from claims of infringement and any implied warranties of merchantability or fitness for a particular purpose.



#### **Pin Description**

Pins not listed are "no connects."

Table 1: Spartan PROM Pinouts

| Pin Name               | 8-pin<br>PDIP (PD8) and<br>VOIC/TSOP<br>(VO8) | 20-pin<br>SOIC<br>(SO20) | Pin Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------|-----------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA                   | 1                                             | 1                        | Data output, High-Z state when either $\overline{\text{CE}}$ or $\overline{\text{OE}}$ are inactive. During programming, the DATA pin is I/O. Note that $\overline{\text{OE}}$ can be programmed to be either active High or active Low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| CLK                    | 2                                             | 3                        | Each rising edge on the CLK input increments the internal address counter, if both $\overline{\text{CE}}$ and $\overline{\text{OE}}$ are active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| RESET/OE<br>(OE/RESET) | 3                                             | 8                        | When High, this input holds the address counter reset and puts the DATA output in a high-impedance state. The polarity of this input pin is programmable as either RESET/OE or OE/RESET. To avoid confusion, this document describes the pin as RESET/OE, although the opposite polarity is possible on all devices. When RESET is active, the address counter is held at zero, and the DATA output is in a high-impedance state. The polarity of this input is programmable. The default is active High RESET, but the preferred option is active Low RESET, because it can be driven by the FPGAs \overline{INIT} pin.  The polarity of this pin is controlled in the programmer interface. This input pin is easily inverted using the Xilinx HW-130 programmer software. Third-party programmers have different methods to invert this |
| CE                     | 4                                             | 10                       | when High, this pin disables the internal address counter, puts the DATA output in a high-impedance state, and forces the device into low-I <sub>CC</sub> standby mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| GND                    | 5                                             | 11                       | GND is the ground connection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| V <sub>CC</sub>        | 7, 8                                          | 18, 20                   | The V <sub>CC</sub> pins are to be connected to the positive voltage supply.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# **Pinout Diagrams**







#### **Controlling PROMs**

Connecting the Spartan device with the PROM:

- The DATA output of the PROM drives the D<sub>IN</sub> input of the lead Spartan device.
- The Master Spartan device CCLK output drives the CLK input of the PROM.
- The RESET/OE input of the PROM is driven by the INIT output of the Spartan device. This connection assures that the PROM address counter is reset before the start of any (re)configuration, even when a reconfiguration is initiated by a V<sub>CC</sub> glitch. Other methods—such as driving RESET/OE from LDC or system reset—assume that the PROM internal power-on-reset is always in step with the FPGAs internal power-on-reset, which may not be a safe assumption.
- The CE input of the PROM is driven by the DONE output of the Spartan device, provided that DONE is not permanently grounded. Otherwise, LDC can be used to drive CE, but must then be unconditionally High during user operation. CE can also be permanently tied Low, but this keeps the DATA output active and causes an unnecessary supply current of 10 mA maximum.

#### **FPGA Master Serial Mode Summary**

The I/O and logic functions of the Configurable Logic Block (CLB) and their associated interconnections are established by a configuration program. The program is loaded either automatically upon power up, or on command, depending on the state of the Spartan device MODE pin. In Master Serial mode, the Spartan device automatically loads the configuration program from an external memory. The Spartan PROM has been designed for compatibility with the Master Serial mode.

Upon power-up or reconfiguration, the Spartan device enters the Master Serial mode when the MODE pin is Low. Data is read from the PROM sequentially on a single data line. Synchronization is provided by the rising edge of the

temporary signal CCLK, which is generated during configuration.

Master Serial mode provides a simple configuration interface (Figure 1). Only a serial data line and two control lines are required to configure the Spartan device. Data from the PROM is read sequentially, accessed via the internal address and bit counters which are incremented on every valid rising edge of CCLK.

If the user-programmable, dual-function  $D_{\rm IN}$  pin on the Spartan device is used only for configuration, it must still be held at a defined level during normal operation. The Spartan family takes care of this automatically with an on-chip default pull-up resistor.

# Programming the FPGA With Counters Unchanged Upon Completion

When multiple-configurations for a single Spartan device are stored in a PROM, the  $\overline{\text{OE}}$  pin should be tied Low. Upon power-up, the internal address counters are reset and configuration begins with the first program stored in memory. Since the  $\overline{\text{OE}}$  pin is held Low, the address counters are left unchanged after configuration is complete. Therefore, to reprogram the FPGA with another program, the DONE line is pulled Low and configuration begins at the last value of the address counters.

This method fails if a user applies RESET during the Spartan device configuration process. The Spartan device aborts the configuration and then restarts a new configuration, as intended, but the PROM does not reset its address counter, since it never saw a High level on its  $\overline{\text{OE}}$  input. The new configuration, therefore, reads the remaining data in the PROM and interprets it as preamble, length count etc. Since the Spartan device is the Master, it issues the necessary number of CCLK pulses, up to 16 million ( $2^{24}$ ) and DONE goes High. However, the Spartan device configuration will be completely wrong, with potential contentions inside the Spartan device and on its output pins. This method must, therefore, never be used when there is any chance of external reset during configuration.





(Low Resets the Address Pointer)



Figure 1: Master Serial Mode. The one-time-programmable Spartan PROM supports automatic loading of configuration programs.

An early DONE inhibits the PROM data output one CCLK cycle before the Spartan FPGA I/Os become active.



#### **Standby Mode**

The PROM enters a low-power standby mode whenever  $\overline{\text{CE}}$  is asserted High. The output remains in a high-impedance state regardless of the state of the  $\overline{\text{OE}}$  input.

# **Programming the Spartan Family PROMs**

The devices can be programmed on programmers supplied by Xilinx or qualified third-party vendors. The user must ensure that the appropriate programming algorithm and the latest version of the programmer software are used. The wrong choice can permanently damage the device.



Figure 2: Simplified Block Diagram (does not show programming circuit)

**Important:** Always tie the two V<sub>CC</sub> pins together in your application.

Table 2: Truth Table for XC17S00 Control Inputs

| Control Inputs       |      |                                                          |                  | Outputs           |  |  |
|----------------------|------|----------------------------------------------------------|------------------|-------------------|--|--|
| RESET <sup>(1)</sup> | CE   | Internal Address <sup>(2)</sup>                          | DATA             | I <sub>CC</sub>   |  |  |
| Inactive             | Low  | If address ≤ TC: increment If address > TC: don't change | Active<br>High-Z | Active<br>Reduced |  |  |
| Active               | Low  | Held reset                                               | High-Z           | Active            |  |  |
| Inactive             | High | Not changing                                             | High-Z           | Standby           |  |  |
| Active               | High | Held reset                                               | High-Z           | Standby           |  |  |

#### Notes:

- The XC17S00 RESET input has programmable polarity
- 2. TC = Terminal Count = highest address value. TC + 1 = address 0.



#### XC17S05, XC17S10, XC17S20, XC17S30, XC17S40

# **Absolute Maximum Ratings**(1)

| Symbol           | Description                                    | Value                        | Units |
|------------------|------------------------------------------------|------------------------------|-------|
| V <sub>CC</sub>  | Supply voltage relative to GND                 | -0.5 to +7.0                 | V     |
| V <sub>IN</sub>  | Input voltage relative to GND                  | -0.5 to V <sub>CC</sub> +0.5 | V     |
| V <sub>TS</sub>  | Voltage applied to High-Z output               | -0.5 to V <sub>CC</sub> +0.5 | V     |
| T <sub>STG</sub> | Storage temperature (ambient)                  | -65 to +150                  | °C    |
| T <sub>SOL</sub> | Maximum soldering temperature (10s @ 1/16 in.) | +260                         | °C    |

#### Notes:

## Operating Conditions<sup>(1)</sup>

| Symbol          | Description | Conditions                                                                              | Min  | Max  | Units |
|-----------------|-------------|-----------------------------------------------------------------------------------------|------|------|-------|
| V <sub>CC</sub> | Commercial  | Supply voltage relative to GND ( $T_A = 0$ °C to +70°C)                                 | 4.75 | 5.25 | V     |
|                 | Industrial  | Supply voltage relative to GND ( $T_A = -40^{\circ}\text{C}$ to $+85^{\circ}\text{C}$ ) | 4.50 | 5.50 | V     |

#### Notes:

#### **DC Characteristics Over Operating Condition**

| Symbol           | Description                                            | Description                                                    |      |                 | Units |
|------------------|--------------------------------------------------------|----------------------------------------------------------------|------|-----------------|-------|
| V <sub>IH</sub>  | High-level input voltage                               |                                                                | 2.0  | V <sub>CC</sub> | V     |
| V <sub>IL</sub>  | Low-level input voltage                                |                                                                | 0    | 0.8             | V     |
| V <sub>OH</sub>  | High-level output voltage (I <sub>OH</sub> = −4 mA)    | Commercial                                                     | 3.86 | -               | V     |
| V <sub>OL</sub>  | Low-level output voltage (I <sub>OL</sub> = +4 mA)     |                                                                | -    | 0.32            | V     |
| V <sub>OH</sub>  | High-level output voltage (I <sub>OH</sub> = −4 mA)    | High-level output voltage (I <sub>OH</sub> = -4 mA) Industrial |      | -               | V     |
| V <sub>OL</sub>  | Low-level output voltage (I <sub>OL</sub> = +4 mA)     |                                                                | -    | 0.37            | V     |
| I <sub>CCA</sub> | Supply current, active mode (at maximum                | frequency)                                                     | -    | 10              | mA    |
| Iccs             | Supply current, standby mode                           | XC17S05, XC17S10,<br>XC17S20, XC17S30                          | -    | 50              | μА    |
|                  |                                                        | XC17S40                                                        | -    | 100             | μА    |
| IL               | Input or output leakage current                        |                                                                | -10  | 10              | μА    |
| C <sub>IN</sub>  | Input Capacitance (V <sub>IN</sub> = GND, f = 1.0 MHz) |                                                                | -    | 10              | pF    |
| C <sub>OUT</sub> | Output Capacitance (V <sub>IN</sub> = GND, f = 1.0 M   | Hz)                                                            | -    | 10              | pF    |

Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. These are stress
ratings only, and functional operation of the device at these or any other conditions beyond those listed under Operating Conditions
is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time may affect device reliability.

<sup>1.</sup> During normal read operation both V<sub>CC</sub> pins must be connected together.



#### XC17S05XL, XC17S10XL, XC17S20XL, XC17S30XL, XC17S40XL, XC17S50XL, XC17S100XL, XC17S150XL

# Absolute Maximum Ratings(1)

| Symbol           | Description                                    | Value                        | Units |
|------------------|------------------------------------------------|------------------------------|-------|
| V <sub>CC</sub>  | Supply voltage relative to GND                 | -0.5 to +4.0                 | V     |
| V <sub>IN</sub>  | Input voltage with respect to GND              | -0.5 to V <sub>CC</sub> +0.5 | V     |
| $V_{TS}$         | Voltage applied to High-Z output               | -0.5 to V <sub>CC</sub> +0.5 | V     |
| T <sub>STG</sub> | Storage temperature (ambient)                  | -65 to +150                  | °C    |
| T <sub>SOL</sub> | Maximum soldering temperature (10s @ 1/16 in.) | +260                         | °C    |

#### Notes:

## Operating Conditions<sup>(1)</sup>

| Symbol   | Description |                                                                  | Min | Max | Units |
|----------|-------------|------------------------------------------------------------------|-----|-----|-------|
| $V_{CC}$ | Commercial  | Supply voltage relative to GND (T <sub>A</sub> = 0°C to +70°C)   | 3.0 | 3.6 | V     |
|          | Industrial  | Supply voltage relative to GND (T <sub>A</sub> = -40°C to +85°C) | 3.0 | 3.6 | V     |

#### Notes:

#### **DC Characteristics Over Operating Condition**

| Symbol           | Description                                             | Min | Max             | Units |
|------------------|---------------------------------------------------------|-----|-----------------|-------|
| V <sub>IH</sub>  | High-level input voltage                                | 2.0 | V <sub>CC</sub> | V     |
| V <sub>IL</sub>  | Low-level input voltage                                 | 0   | 0.8             | V     |
| V <sub>OH</sub>  | High-level output voltage (I <sub>OH</sub> = -3 mA)     | 2.4 | -               | V     |
| V <sub>OL</sub>  | Low-level output voltage (I <sub>OL</sub> = +3 mA)      | -   | 0.4             | V     |
| I <sub>CCA</sub> | Supply current, active mode (at maximum frequency)      | -   | 5               | mA    |
| I <sub>CCS</sub> | Supply current, standby mode                            | -   | 50              | μΑ    |
| ال               | Input or output leakage current                         | -10 | 10              | μΑ    |
| C <sub>IN</sub>  | Input Capacitance (V <sub>IN</sub> = GND, f = 1.0 MHz)  | -   | 10              | pF    |
| C <sub>OUT</sub> | Output Capacitance (V <sub>IN</sub> = GND, f = 1.0 MHz) | -   | 10              | pF    |

Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those listed under Operating Conditions is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time may affect device reliability.

During normal read operation both V<sub>CC</sub> pins must be connected together.



# **AC Characteristics Over Operating Condition**(1)



| Symbol           | Description                                         | Min | Max | Units |
|------------------|-----------------------------------------------------|-----|-----|-------|
| T <sub>OE</sub>  | RESET/OE to Data Delay                              | -   | 45  | ns    |
| T <sub>CE</sub>  | CE to Data Delay                                    | -   | 60  | ns    |
| T <sub>CAC</sub> | CLK to Data Delay                                   | -   | 80  | ns    |
| T <sub>OH</sub>  | Data Hold From CE, RESET/OE, or CLK <sup>(2)</sup>  | 0   | -   | ns    |
| T <sub>DF</sub>  | CE or RESET/OE to Data Float Delay <sup>(2,3)</sup> | -   | 50  | ns    |
| T <sub>CYC</sub> | Clock Periods                                       | 100 | -   | ns    |
| T <sub>LC</sub>  | CLK Low Time <sup>(2)</sup>                         | 50  | -   | ns    |
| T <sub>HC</sub>  | CLK High Time <sup>(2)</sup>                        | 50  | -   | ns    |
| T <sub>SCE</sub> | CE Setup Time to CLK (to guarantee proper counting) | 25  | -   | ns    |
| T <sub>HCE</sub> | CE Hold Time to CLK (to guarantee proper counting)  | 0   | -   | ns    |
| T <sub>HOE</sub> | RESET/OE Hold Time (guarantees counters are reset)  | 25  | -   | ns    |

#### Notes:

- 1. AC test load = 50 pF
- 2. Guaranteed by design, not tested.
- 3. Float delays are measured with 5 pF AC loads. Transition is measured at ±200 mV from steady state active levels.
- 4. All AC parameters are measured with  $V_{IL}$  = 0.0V and  $V_{IH}$  = 3.0V.



#### **Ordering Information**



#### **Spartan 5V Valid Ordering Combinations (XC17S00)**

| XC17S05PD8C | XC17S10PD8C | XC17S20PD8C | XC17S30PD8C | XC17S40PD8C  |
|-------------|-------------|-------------|-------------|--------------|
| XC17S05VO8C | XC17S10VO8C | XC17S20VO8C | XC17S30VO8C | XC17S40SO20C |
| XC17S05PD8I | XC17S10PD8I | XC17S20PD8I | XC17S30PD8I | XC17S40PD8I  |
| XC17S05VO8I | XC17S10VO8I | XC17S20VO8I | XC17S30VO8I | XC17S40SO20I |

# **Spartan 3.3V Valid Ordering Combinations (XC17S00XL)**

| XC17S05XLPD8C | XC17S100XLPD8C  | XC17S20XLPD8C | XC17S40XLPD8C  |
|---------------|-----------------|---------------|----------------|
| XC17S05XLVO8C | XC17S100XLSO20C | XC17S20XLVO8C | XC17S40XLSO20C |
| XC17S05XLPD8I | XC17S100XLPD8I  | XC17S20XLPD8I | XC17S40XLPD8I  |
| XC17S05XLVO8I | XC17S100XLSO20I | XC17S20XLVO8I | XC17S40XLSO20I |
| XC17S10XLPD8C | XC17S150XLPD8C  | XC17S30XLPD8C | XC17S50XLPD8C  |
| XC17S10XLVO8C | XC17S150XLSO20C | XC17S30XLVO8C | XC17S50XLSO20C |
| XC17S10XLPD8I | XC17S150XLPD8I  | XC17S30XLPD8I | XC17S50XLPD8I  |
| XC17S10XLVO8I | XC17S150XLSO20I | XC17S30XLVO8I | XC17S50XLSO20I |



#### **Marking Information**

Due to the small size of the PROM package, the complete ordering part number cannot be marked on the package. The XC prefix is deleted and the package code is simplified. Device marking is as follows.



Note: When marking the device number on the XL parts, an L is used in place of an XL.

### **Revision History**

The following table shows the revision history for this document.

| Date     | Revision | Revision                                                                                                                                                                                                                 |
|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 07/14/98 | 1.1      | Cosmetic edits for pages 1, 2, and 4.                                                                                                                                                                                    |
| 09/08/98 | 1.2      | Clarified the SPARTAN FPGA and PROM interface by removing references to $\overline{\text{CEO}}$ pin. Removed the ESD notation in Absolute Maximum table since it is now included in Xilinx's Reliability Monitor Report. |
| 01/20/00 | 1.3      | Added additional Spartan-XL parts, changed SPROM to PROM.                                                                                                                                                                |
| 02/18/00 | 1.4      | Changed device ordering numbers, added 4.7K resistor to OE/RESET in Figure 1.                                                                                                                                            |
| 04/04/00 | 1.5      | Added XC17S200XL PROM for Spartan XC2S200.                                                                                                                                                                               |
| 08/06/00 | 1.6      | Updated format.                                                                                                                                                                                                          |
| 04/07/01 | 1.7      | Added to features: "Guaranteed 20 year life data retention."                                                                                                                                                             |
| 10/10/01 | 1.8      | Added a note to Table 1. Changed V <sub>PP</sub> to V <sub>CC</sub> on Figure 1.                                                                                                                                         |
| 11/04/02 | 1.9      | Updated Table , page 1. Updated the template. Added Pinout Diagrams, page 2.                                                                                                                                             |
| 11/18/02 | 1.10     | Modified document title.                                                                                                                                                                                                 |