1700E/X Family

#### \*Description

The XC1700E/X Families 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 XC1700E or X Families.



#### 8-Pin DIP/SOIC/VOIC Pin Assignments



The XC1700E/X Family consists of one-time programmable (OTP) devices organized as follows:

| XC1736E  | 36,288  | X | 1 bit |
|----------|---------|---|-------|
| XC1765E  | 65,536  | х | 1 bit |
| XC1765X  | 65,536  | х | 1 bit |
| XC17128E | 131,072 | х | 1 bit |
| XC17128X | 131,072 | х | 1 bit |
| XC17256E | 262,144 | х | 1 bit |
| XC17256X | 262,144 | х | 1 bit |

\* **Note:** The low voltage devices, XC1765X, XC17128X, and XC17256X are also known as XC1765EL, XC17128EL, and XC17256EL

#### 20-Pin PLCC Pin Assignments

1700E/X Family

### **Programming Overview**

All the XC1765E and XC1765X SPROMs are internally organized in rows, each containing eight (8) 32-bit words. All of the XC17128E/XC17128X/XC17256E/ XC17256X SPROMs are internally organized in rows, each row containing eight (8) 64-bit words. Additional non-data rows are used read to the Manufacturer's/Device ID and set the Reset Polarity and cannot be used to 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_{PP}$  at  $V_{PP1}$  for two rising clock edges, then lowering  $V_{PP}$  to  $V_{PPNOM}$  for one more rising clock edge (See Figure 5). 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 and 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 "Manufacturing or Device ID Error."

To read the Manufacturer's/Device identification code, first enter the programming mode.

#### For XC1736E/ XC1765E/ XC1765X:

While holding  $\overline{CE}$  High and  $\overline{OE}$  Low, apply 2056 clock signals to the clock pin to access the ID row.

For XC17128E/ XC17128X/ XC17256E/ XC17256X:

While holding  $\overline{CE}$  High and  $\overline{OE}$  Low, apply 4600 clock signals to the clock pin to access the ID row.

#### For All Devices

Then bring  $\overline{\text{OE}}$  High and  $\overline{\text{CE}}$  Low\*. The first bit of the identification word is present when  $\overline{\text{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, while the last four bits of the second byte contain specific programming algorithm information (currently D for XC1700E and C for XC1700X). The data is read out MSB first.

XC1700E/X Family

#### The density codes are defined as follows:

| XC1736E    | E(1110) |
|------------|---------|
| XC1765E/X  | F(1111) |
| XC17128E/X | 8(1000) |
| XC17256E/X | A(1010) |

#### **Load 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 is temporarily held in internal latches and is programmed into the memory as an entire word upon strobing the device with  $V_{PP}$  at  $V_{PP1}$  for  $T_{PGM}$ .

#### **Increment the Address (Word) Counter**

After programming a data word, the address counter must be incremented. This is done on the rising edge of the clock while  $\overline{\text{CE}}$  is High and  $\overline{\text{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 3).

For XC1736E/ XC1765E/ or XC1765X:

Reset/ $\overline{OE}$  is located at row 257. Enter the programming mode, then lower Reset/ $\overline{OE}$ , hold the Data pin Low, strobe the clock 2048 times, load the data latches with all zeros (see Load a Data Word above), and strobe  $V_{PP}$  at  $V_{PP1}$  for 5 ms.

For XC17128E/ XC17128X/ XC17256E/ or XC17256X:

Reset/ $\overline{OE}$  is located at row 514. Enter the programming mode, then lower Reset/ $\overline{OE}$ , hold the Data pin Low, strobe the clock 4104 times, 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, set  $\overline{CE}$  low and sense the  $\overline{CEO}$  pin. If  $\overline{CEO}$  is high, reset is active low (successfully programmed). If  $\overline{CEO}$  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.

XC1700E/X Family

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

For XC1736E/ XC1765E/ XC1765X:

Strobe the clock 2048 times.

For XC17128E/ XC17128X/ XC17256E/ XC17256X:

Strobe the clock 4104 times.

For all devices:

Set  $\overline{\text{OE}}$  High, set  $\overline{\text{CE}}$  Low and sense the  $\overline{\text{CEO}}$  pin. If  $\overline{\text{CEO}}$  is High, Reset is active Low. If  $\overline{\text{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 VPP and VCC) 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{\text{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".

XC1700E/X Family

## **Programming Mode Pin Assignments**

| DIP/<br>SOIC/<br>VOIC<br>Pin | PLCC<br>Pin | Name            | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------|-------------|-----------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                            | 2           | 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                            | 4           | CLK             | I   | Clock input. Used to increment the internal address/word counter for reading and programming.                                                                                                                                                                                                                                                                                                                                                            |
| 3                            | 6           | RESET/OE        | -   | 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/ $\overline{OE}$ pin is <b>ignored</b> in the programming mode. |
| 4                            | 8           | Œ               | I   | 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                            | 10          | GND             |     | Ground pin                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6                            | 14          | CEO             | 0   | The polarity of the RESET/ $\overline{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                            | 17          | 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_{PP}$ to $V_{PPNOM}$ for one more rising clock edge. A word is programmed by strobing the device with $V_{PP}$ for the duration $T_{PGM}$ . $V_{PP}$ must be held at $V_{CC}$ for normal operation.                                                                |
| 8                            | 20          | $V_{CC}$        |     | V <sub>CC</sub> power supply input.                                                                                                                                                                                                                                                                                                                                                                                                                      |

XC1700E/X Family

## **DC** Programming Specifications

| Symbol                                   | Description                                     | Min  | Recommended     | Max             | Unit<br>s |
|------------------------------------------|-------------------------------------------------|------|-----------------|-----------------|-----------|
| V <sub>CCP*</sub>                        | Supply voltage during programming               |      | 5.0             |                 | V         |
| $V_{IL}$                                 | 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_{OL}$                                 | 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              | mΑ        |
| V <sub>CCNOM</sub> /V <sub>PPNOM</sub>   | Nominal Voltage                                 |      | 5.0             |                 | V         |
| V <sub>CCVFY</sub> (1736E/65E/128E/256E) | Supply voltage during stand alone margin verify |      | 5.0             |                 | V         |
| V <sub>CCVFY</sub> (1765X/128X/256X)     | Supply voltage during stand alone margin verify |      | 3.3             |                 | V         |
| V <sub>PPVFY</sub> (1736E/65E/128E/256E) | Margin voltage during stand alone margin verify |      | 5.4             |                 | V         |
| V <sub>PPVFY</sub> (1765X/128X/256X)     | Margin voltage during stand alone margin verify |      | 3.7             |                 | V         |

<sup>\*</sup> Noise and voltage deviation allowed: 5.0V ± 50 mV.

<sup>\*\*</sup> No overshoot is permitted on signal. V<sub>PP</sub> must not be allowed to exceed V<sub>PP1</sub> max.

<sup>\*\*\*</sup> Noise and voltage deviation allowed: 5.4V ± 250 mV.

XC1700E/X Family

### **AC Programming Specifications**

|    | ymbol            | Description                                            | Min  | Rec | Max  | Units |
|----|------------------|--------------------------------------------------------|------|-----|------|-------|
| 1  | $T_RPP$          | 10% to 90% rise time of V <sub>PP</sub>                | 5    | 5   | 70   | μs    |
| 2  | $T_{FPP}$        | 90% to 10% fall time V <sub>PP</sub>                   | 5    | 5   | 70   | μs    |
| 3  | $T_{PGM}$        | V <sub>PP</sub> programming pulse width                | 0.95 | 1.0 | 1.05 | ms    |
| 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_{SDP}$        | Data setup to CLK for programming                      | 50   |     |      | ns    |
| 7  | $T_{HDP}$        | 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                                      | 1    |     |      | 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 | T <sub>OH</sub>  | Data hold from CLK                                     | 0    |     |      | ns    |
| 16 | T <sub>CE</sub>  | CE low to data valid                                   |      |     | 250  | ns    |

XC1700E/X Family



Figure 1. Programming

XC1700E/X Family



\*\*\* Verify  $\overline{\text{CEO}}$  has gone LOW one clock after last bit

Figure 1. Programming Sequence (Continued)

XC1700E/X Family



\*Number Of Clocks For The Device Word

Figure 2. Programming Cycle Overview

XC1700E/X Family



\* Number of Clocks for the Device Reset Polarity Location

\*\* Number of Clocks for the Device Word

Figure 3. Programming Reset Polarity

XC1700E/X Family



Figure 4. Details Of The Programming Cycle

XC1700E/X Family



Figure 5. Enter Programming Mode

XC1700E/X Family



Figure 6. Exit Programming Mode

XC1700E/X Family



Figure 7. Details Of Verify Cycle

| • | X  | П | ı | П | Ν  | D  | X  | P | R  | (   | 7 |   | - | R | ) /        | ١Δ | ٨  | 11 | \/ | 16 | = | R | ) |   |    | l | 1   | Δ | ı | П | F | 10 | • | Δ           | П | 7 |   | )  | V | ( | 2 | P | F | (   | ΙF     | <i>-</i> [ [ | $\mathbf{C}$ | . Δ | T  | $\Box 1$ | $\bigcap$ | ۱۱ | V |
|---|----|---|---|---|----|----|----|---|----|-----|---|---|---|---|------------|----|----|----|----|----|---|---|---|---|----|---|-----|---|---|---|---|----|---|-------------|---|---|---|----|---|---|---|---|---|-----|--------|--------------|--------------|-----|----|----------|-----------|----|---|
| 4 | /\ | Ш | ᆫ |   | ı١ | 4/ | `\ |   | ı٦ | ` ' | J | • | J | 1 | <i>⊾</i> / | יר | ıv | ш  | v  | IL | _ | ľ | • | Ŀ | J' | L | ) [ | ┑ | _ | ш |   | ı١ |   | $m{\Gamma}$ | ١ |   | L | JΙ | N | • | _ |   | ᆫ | - \ | <br>11 |              | $\mathbf{C}$ | ,_  | ١ı | . 1      | $\smile$  | "  | N |

XC1700E/X Family