### Description

The Spartan Family of Serial Configuration PROMs provide easy-to-use, cost-effective configuration memory for Xilinx Field Programmable Gate Arrays.

These devices use a simple serial-access procedure to configure one or more LCA devices. The user can select the polarity of the reset function by programming a special bit. These devices are fully compatible and can be cascaded with other members of the XC17S00 family of devices.



#### 8 Pin Dip/VOIC Assignments

All devices are available in the 8 pin DIP and 8 pin VOIC package except the XC17S40, XC17S40XL, XC17S50XL, XC17S100XL, and XC17S150XL which comes in the 8 pin DIP and 20 pin SOIC package (See below).

| data 💻   | 1  | 20 | Vcc |
|----------|----|----|-----|
| nc 💻     | 2  | 19 | nc  |
| CLK 💻    | 3  | 18 | Vpp |
| nc 💻     | 4  | 17 | nc  |
| nc 💻     | 5  | 16 | nc  |
| nc 🚥     | 6  | 15 | nc  |
| nc 💻     | 7  | 14 | nc  |
| RESET/OE | 8  | 13 | CEO |
| nc 💻     | 9  | 12 | nc  |
| CE       | 10 | 11 | GND |

# 20-Pin SOIC Assignment (17S40/XL, 50XL, 100XL, 150XL Only)

The Spartan Family consists of 5 volt and 3.3 volt devices. For each 5 volt device (XC17S00), there is a 3.3 volt counterpart (XC17S00XL). All devices are one-time programmable (OTP) and are organized as follows:

| XC17S05    | 65,536     | х | 1 bit |
|------------|------------|---|-------|
| XC17S05XL  | 131,072    | х | 1 bit |
| XC17S10/XL | 131,072    | х | 1 bit |
| XC17S20/XL | 262,144    | х | 1 bit |
| XC17S30/XL | 262,144    | х | 1 bit |
| XC17S40/XL | 524,288    | х | 1 bit |
| XC17S50XL  | 1, 048,576 | х | 1 bit |
| XC17S100XL | 1, 048,576 | х | 1 bit |
| XC17S150XL | 1, 048,576 | х | 1 bit |

### **Programming Overview**

All the Spartan SPROMs are internally organized in rows, each row containing eight (8) words. The S05 device has 32 bit words and the S05XL, S10/XL, S20/XL, S30/XL and S40/XL has 64 bit words. Additional non-data used read rows are to the Manufacturer's/Device ID and set the Reset Polarity and cannot be used to store configuration data. The device programmer should prompt the user for the desired Reset Polarity.

Figure 1 shows the flow of how the SPROMs are programmed. See Figure 2 for the programming cycle overview and Figure 4 for the details of the programming cycle.

### **Enter Programming Mode**

The programming mode is entered by holding  $\overline{CE}$  and  $\overline{OE}$  High with V<sub>PP</sub> at V<sub>PP1</sub> for two rising clock edges, then lowering V<sub>PP</sub> to V<sub>PPNOM</sub> for one more rising clock edge (See Figure 3). Once in the programming mode, the following functions are available.

### Read Manufacturer's/Device ID

All of the SPROMs contain a Manufacturer's and Device identification code. Prior to attempting to program or verify the device, the device programmer should read this code and verify that it is the correct code for the device selected by the user. If not, display message **"Manufacturer or Device ID Error."** 

To read the Manufacturer's/Device identification code, first enter the programming mode. While holding  $\overline{CE}$  High and  $\overline{OE}$  Low, apply N<sub>IDCLK</sub> (See Table 1) clock signals to the clock pin to access the ID row.

|        | NIDCLK | N <sub>RSTCLK</sub> |
|--------|--------|---------------------|
| S05    | 2,056  | 2,048               |
| S05XL  | 4,600  | 4,104               |
| S10/XL | 4,600  | 4,104               |
| S20/XL | 4,600  | 4,104               |
| S30/XL | 4,600  | 4,104               |
| S40/XL | 19,791 | 16,384              |
| S50XL  | 19,791 | 16,384              |
| S100XL | 19,791 | 16,384              |
| S150XL | 19,791 | 16,384              |

#### Table I Clock To ID (decimal)

Then bring  $\overline{OE}$  High and  $\overline{CE}$  Low<sup>\*</sup>. The first bit of the identification word is present when  $\overline{CE}$ goes Low and does not require a clock. Apply 15 additional clock signals to the CLK pin to read the complete device ID.

### The Manufacturer's/Device ID

Consisting of 2 bytes of data. The first byte contains the JEDEC assigned Manufacturer's ID code for Xilinx (C9). The first four bits of the second byte define the density of the PROM (See Table II), while the last four bits of the second byte contain specific programming algorithm code (See Table III). The data is read out MSB first.

### Table II Density Codes

| <u>Device</u>       | Density Codes |
|---------------------|---------------|
| S05                 | F (1111)      |
| S10/S10XL/S05XL     | 8 (1000)      |
| S20/S20XL/S30/S30XL | A (1010)      |
| S40/S40XL           | 9 (1001)      |
| S50XL               | 9 (1101)      |
| S100XL              | 9 (1101)      |
| S150XL              | 9 (1101)      |

### Table III Programming Algo Codes

| -                 |                |
|-------------------|----------------|
| <u>Device</u>     | Algorithm Code |
| S10XL/S20XL/S40XL | 9 (1001)       |
| S05/S10/S20/S40   | 8 (1000)       |
| S30XL/S05XL       | 7 (0111)       |
| S30               | 6 (0110)       |
| S50XL             | 6 (0110)       |
| S100XL            | 7 (0111)       |
| S150XL            | 9 (1001)       |
|                   |                |

### Loading and Programming a Data Word

The data word is shifted into the SPROM, one bit at a time, on the rising edge of the clock, while  $\overline{CE}$ and  $\overline{OE}$  are High. The data word counter is temporarily held in internal latches until the address is advanced to the next address, and is programmed into the memory as an entire word upon strobing the device with V<sub>PP</sub> at V<sub>PP1</sub> for 100µs.

The contents of the data word must now be verified at V<sub>PP2</sub>. The data word is read while lowering  $\overline{CE}$  and capturing the data while clocking the device 31 or 63 times (See Programming Overview). The first bit of the word (LSB) is present when  $\overline{CE}$  goes low. After all bits were read, bring  $\overline{CE}$  high and compare the data to the original file data. If the data does not compare, stroke V<sub>PP</sub> at V<sub>PP1</sub> for 500µs. (Note, the original data is still contained in internal latches and does not have to be loaded into the device again.) Read the data word again (as described above) and compare it to the original data. If it still does not compare, pulse  $V_{PP}$  at  $V_{PP1}$  for another 500 $\mu$ s. Now read the data word again. If it still does not compare, power the device down and issue message: "Device Failed to Program". See Figure 4. If the word compares, increment the word counter as described below.

### Increment the Address (Word) Counter

After successfully programming a data word, the address counter must be incremented. This is done on the rising edge of the clock while  $\overline{CE}$  is High and  $\overline{OE}$  is Low.\*

### Set RESET Polarity

The polarity of the Reset/ $\overline{OE}$  pin may be made active Low by writing zeros into a dedicated row.(See Figure 5).

Reset/ $\overline{OE}$  is located outside of the user data array. Enter the programming mode, then lower Reset/ $\overline{OE}$ , hold the Data pin Low, strobe the clock N<sub>RSTCLK</sub> times (See Table I), raise the Reset/ $\overline{OE}$  pin, load the data latches with all zeros (see Load a Data Word above), and strobe V<sub>PP</sub> at V<sub>PP1</sub> for 5 ms.

The reset polarity has to be verified (sensed) at  $V_{PP2}$  while in programming mode. To sense the polarity bit, after strobing  $V_{PP}$  for 5ms, set  $\overline{CE}$  low and sense the  $\overline{CE0}$  pin. If  $\overline{CE0}$  is high, reset is active low (successfully programmed). If  $\overline{CE0}$  is low, reset is active high (failed to program).

Writing ones or not writing anything maintains RESET active High.

Note:

The Reset Polarity is actually only the MSB of the data word.

\* Be careful not to have  $\overline{CE}$  and  $\overline{OE}$  Low at the same time, as this causes the device to exit programming mode.

### Sensing RESET Polarity

To sense or read the polarity of the Reset/ $\overline{OE}$  pin, enter the programming mode, then lower Reset/ $\overline{OE}$ , hold the Data pin High, then strobe the clock N<sub>RSTCLK</sub> times (See Table I). Set Reset/ $\overline{OE}$  High, set  $\overline{CE}$  Low and sense the  $\overline{CEO}$  pin. If  $\overline{CEO}$  is High, Reset is active Low. If  $\overline{CEO}$  is Low, Reset is active High. The reset polarity bit is defaulted (unprogrammed) to active high. When the reset bit is programmed, the "reset" polarity is active low.

### **Exit Programming Mode**

To exit the programming mode, remove power from the device, per Figure 6.

# Stand Alone Verify Of Data Bits (Normal Mode)

The verify operation should be performed after programming. Power up the device and read the data bits out serially in normal readout

mode (see Figure 7). A margin voltage (difference between  $V_{PP}$  and  $V_{CC}$ ) is applied to the device to ensure charge retention on each programmed bit. Set  $V_{CC}$  to  $V_{CCVFY}$  and  $V_{PP}$  to  $V_{PPVFY}$ . When in normal mode, the Reset/ $\overline{OE}$  signal should be driven active high if the reset polarity bit was unprogrammed (logic "1"). It should be driven active low if the reset polarity bit was programmed (logic "0").

At the end of the verify operation the programmer must confirm that the  $\overline{CEO}$  pin has gone Low one clock after the last bit is read out.

If the data fails to verify, display message "Failed Margin Verify". If the data verifies, display message "Device Passed".

### XC17S00, & XC17S00XL Family

### **Programming Mode Pin Assignments**

| DIP8<br>Pin | VOIC8<br>Pin | SOIC20<br>Pin | Name            | I/O | Description                                                                               |
|-------------|--------------|---------------|-----------------|-----|-------------------------------------------------------------------------------------------|
| 1           | 1            | 1             | Data            | I/O | The rising edge of the clock shifts a data word in or out of                              |
|             |              |               |                 |     | the SPROM one bit at a time.                                                              |
| 2           | 2            | 3             | CLK             | I   | Clock input. Used to increment the internal address/word                                  |
|             |              |               |                 |     | counter for reading and programming.                                                      |
| 3           | 3            | 8             | RESET/          | Ι   | The rising edge of CLK shifts a data word into the PROM                                   |
|             |              |               | ŌĒ              |     | when $\overline{CE}$ and $\overline{OE}$ are High; it shifts a data word out of the       |
|             |              |               |                 |     | PROM when $\overline{CE}$ is Low and $\overline{OE}$ is High. The                         |
|             |              |               |                 |     | address/word counter is incremented on the rising edge                                    |
|             |              |               |                 |     | of CLK while $\overline{CE}$ is held High and $\overline{OE}$ is held Low. Note:          |
|             |              |               |                 |     | Any modified polarity of the RESET/OE pin is <b>ignored</b> in                            |
|             |              |               |                 |     | the programming mode.                                                                     |
| 4           | 4            | 10            | CE              | Ι   | The rising edge of CLK shifts a data word into the PROM                                   |
|             |              |               |                 |     | when $\overline{CE}$ and $\overline{OE}$ are High; it shifts a data word out of the       |
|             |              |               |                 |     | PROM when $\overline{CE}$ is Low and $\overline{OE}$ is High. The                         |
|             |              |               |                 |     | address/word counter is incremented on the rising edge                                    |
|             |              |               |                 |     | of CLK while $\overline{CE}$ is held High and $\overline{OE}$ is held Low.                |
| 5           | 5            | 11            | GND             |     | Ground pin                                                                                |
| 6           | 6            | 13            | CEO             | 0   | The polarity of the RESET/OE pin can be read by sensing                                   |
|             |              |               |                 |     | the $\overline{CEO}$ pin. Note: The polarity of the RESET/ $\overline{OE}$ pin is         |
|             |              |               |                 |     | ignored while in the programming mode. In final                                           |
|             |              |               |                 |     | verification, this pin must be monitored to go Low one                                    |
|             |              |               |                 |     | clock cycle after the last data bit has been read.                                        |
| 7           | 7            | 18            | V <sub>PP</sub> |     | Programming Voltage Supply. Programming mode is                                           |
|             |              |               |                 |     | entered by holding $\overline{CE}$ and $\overline{OE}$ High and $V_{PP}$ at $V_{PP1}$ for |
|             |              |               |                 |     | two rising clock edges and then lowering $V_{\text{PP}}$ to $V_{\text{PPNOM}}$            |
|             |              |               |                 |     | for one more rising clock edge. A word is programmed by                                   |
|             |              |               |                 |     | strobing the device with $V_{\text{PP}}$ for the duration $T_{\text{PGM}},V_{\text{PP}}$  |
|             |              |               |                 |     | must be held at $V_{CC}$ for normal operation.                                            |
| 8           | 8            | 20            | V <sub>CC</sub> |     | V <sub>CC</sub> power supply input.                                                       |

#### XC17S00, & XC17S00XL Family

### **DC** Programming Specifications

| Symbol                                 | Description                                                        | Min  | Recommended     | Max             | Units |
|----------------------------------------|--------------------------------------------------------------------|------|-----------------|-----------------|-------|
| V <sub>CCP*</sub>                      | Supply voltage during programming                                  |      | 5.0             |                 | V     |
| V <sub>IL</sub>                        | Low-level input voltage                                            | 0.0  | 0.0             | 0.5             | V     |
| V <sub>IH</sub>                        | High-level input voltage                                           | 2.4  | V <sub>CC</sub> | V <sub>CC</sub> | V     |
| V <sub>OL</sub>                        | Low-level output voltage                                           |      |                 | 0.4             | V     |
| V <sub>OH</sub>                        | High-level output voltage                                          | 2.5  |                 |                 | V     |
| V <sub>PP1**</sub>                     | Programming voltage                                                | 12.0 | 12.25           | 12.5            | V     |
| V <sub>PP2***</sub>                    | Margin verify voltage during programming                           |      | 5.4             |                 | V     |
| I <sub>PPP</sub>                       | Supply current on programming pin                                  |      |                 | 60              | mA    |
| V <sub>CCNOM</sub> /V <sub>PPNOM</sub> | Nominal Voltage                                                    |      | 5.0             |                 | V     |
| VCCVFY (S00 Only)                      | Supply voltage during stand alone margin verify (5 volt devices)   |      | 5.0             |                 | V     |
| VCCVFY (S00XL Only)                    | Supply voltage during stand alone margin verify (3.3 volt devices) |      | 3.3             |                 | V     |
| VPPVFY (S00 Only)                      | Margin voltage during stand alone margin verify (5 volt devices)   |      | 5.4             |                 | V     |
| $V_{PPVFY}$ (S00XL Only)               | Margin voltage during stand alone margin verify (3.3 volt devices) |      | 3.7             |                 | V     |

\* Noise and voltage deviation allowed:  $5.0V \pm 50 \text{ mV}$ .

\*\* No overshoot is permitted on signal.  $V_{PP}$  must not be allowed to exceed  $V_{PP1}$  max.

\*\*\* Noise and voltage deviation allowed:  $5.4V \pm 250$  mV.

XC17S00, & XC17S00XL Family

### **AC Programming Specifications**

| Symbol Description |                   | Min                                                    | Rec | Max             | Units |    |
|--------------------|-------------------|--------------------------------------------------------|-----|-----------------|-------|----|
| 1                  | T <sub>RPP*</sub> | 10% to 90% rise time of $V_{PP}$                       |     | 5               |       | μs |
| 2                  | T <sub>FPP*</sub> | 90% to 10% fall time $V_{PP}$                          |     | 5               |       | μs |
| 3                  | T <sub>PGM</sub>  | V <sub>PP</sub> programming pulse width                | 90  | 100 (500 Retry) |       | μs |
| 4                  | T <sub>SVC</sub>  | V <sub>PP</sub> setup to CLK for entering programming  | 100 |                 |       | ns |
| 5                  | T <sub>HVC</sub>  | V <sub>PP</sub> hold from CLK for entering programming | 300 |                 |       | ns |
| 6                  | T <sub>SDP</sub>  | Data setup to CLK for programming                      | 50  |                 |       | ns |
| 7                  | T <sub>HDP</sub>  | Data hold from CLK for programming                     | 0   |                 |       | ns |
| 8                  | T <sub>SCC</sub>  | CE setup from programming/verifying                    | 100 |                 |       | ns |
| 9                  | T <sub>ON</sub>   | Reset Pulse Width                                      |     | 5               |       | ms |
| 10                 | T <sub>SCV</sub>  | CE hold from CLK for programming/verifying             | 100 |                 |       | ns |
| 11                 | T <sub>HCV</sub>  | CE hold from V <sub>PP</sub> for programming           | 50  |                 |       | ns |
| 12                 | T <sub>SIC</sub>  | OEsetup to CLK for incrementing address                | 100 |                 |       | ns |
| 13                 | T <sub>HIC</sub>  | OE hold from CLK for incrementing address              | 0   |                 |       | ns |
| 14                 | T <sub>CAC</sub>  | CLK to data valid                                      |     |                 | 400   | ns |
| 15                 | Т <sub>ОН</sub>   | Data hold from CLK                                     | 0   |                 |       | ns |
| 16                 | T <sub>CE</sub>   | CE low to data valid                                   |     |                 | 250   | ns |

\* Use the fastest rise and fall time (permitting no overshoot or undershoot) your hardware can support.

### XC17S00, & XC17S00XL Family



Figure 1. Programming Flow

03/00 Rev. 2.1

#### XC17S00, & XC17S00XL Family



\*32 or 64 bits, See Programming Overview

### Figure 1. Programming Flow (Continued)

#### XC17S00, & XC17S00XL Family



### Figure 1. Programming Flow (Continued)



Figure 2. Programming Cycle Overview



Figure 3. Enter Programming Mode



Figure 4. Details Of The Programming Cycle



Figure 5. Programming Reset Polarity

XC17S00, & XC17S00XL



If your programming hardware does not allow  $V_{PP}$  and  $V_{CC}$  to power up and down simultaneously, make sure to first power up  $V_{PP}$  during power up and power down  $V_{PP}$  after  $V_{CC}$  during power down.

Figure 6. Exit Programming Mode



Figure 7. Details Of Verify Cycle