# 32K X 8 CMOS Electrically Erasable PROM 5ms Nonvolatile Write Cycle ### **FEATURES** - **■** Fast Read Access Times - 150ns, 200ns and 250ns - Low CMOS Power Consumption - 60mA (Active) - 150µA (Stand By) - 5 Volt-only Operation - Including write - Fast Nonvolatile Write Cycle - Internally latched data and address - 120ns byte-load cycle - 5ms (max.) nonvolatile write cycle - Self-Timed Writes - Effective 75us/byte write - 64 byte page input buffer - Auto-erase before write - DATA Polling - Toggle bit - Software Mode Control - Automatic Page Write Mode - 64 byte page size - 10ms page write time - **On-chip Inadvertent Write Protection** - 10,000 Rewrites per Byte - 10 Year Secure Data Retention - **ESD Protected to 2000V** #### OVERVIEW The XL28C256 is a full-featured, 32K x 8 bit CMOS E<sup>2</sup>PROM (Electrically Erasable Programmable Read Only Memory). Operationally, it is compatible with industry standard 256K devices, but offers improved speed and power efficiency. Read access times can be as low as 150ns; standby current, less than 100µA. It features a page-wide input buffer and improved protection against inadvertent writes. Operating modes function from a single 5V power supply, and the XL28C256 is manufactured with EXEL's proven double-metal, 1.4µ CMOS process. In order to speed up erase and write operations, a 64-byte page reprogramming function is provided. #### PIN CONFIGURATIONS 32 Pin PLCC Type "D" Package #### **PIN NAMES** ### **BLOCK DIAGRAM** The sophisticated architecture of this device provides complete and automatic control of the nonvolatile write cycle eliminating the need for external timers, latches, high voltage generators and supplemental inadvertent write protection circuitry. It fits into standard SRAM sockets and responds to typical SRAM write commands. The fully-automatic 64-byte page-write allows the entire memory to be programmed in less than 0.65 sec. Internal latches, for address and data, free the system bus during the 5ms self-timed, nonvolatile write period. Moreover, the byte-load cycle time matches the read access time, adding to system performance. Inadvertent writes are inhibited by a wide range of protections built into the XL28C256. A low V<sub>CC</sub> lockout feature disables nonvolatile write cycles when V<sub>CC</sub> drops below 3.5V (Vwi) (typical). Additionally, the XL28C256 features power-on reset and noise protected WE. The XL28C256 is compatible with existing 256K E<sup>2</sup>PROMs—both pinout and operating modes conform to industry standards. This compatibility extends to higher and lower density E<sup>2</sup>PROMs as well. #### **APPLICATIONS** The nonvolatile storage in the XL28C256 replaces dip switches as a means of storing configuration data. It delivers firmware for booting up systems, and for operating industrial and process controllers, traffic controllers, robotics and telemetry, measuring instruments and appliance controls. It retains phone numbers and messages in telephones and facsimile machines. The XL28C256 is ideal in applications that are self-adapting, such as video games and systems that require automatic re-calibration, as well as those that are subject to power failures. #### **ENDURANCE and DATA RETENTION** The XL28C256 is designed for applications requiring up to 10,000 data changes per E<sup>2</sup>PROM byte ensuring a guaranteed endurance of over 325 million data changes per device. It provides 10 years of secure data retention, with or without power applied after the data is written. #### **DEVICE OPERATION** Three control pins ( $\overline{\text{CE}}$ , $\overline{\text{OE}}$ and $\overline{\text{WE}}$ ) select all standard user-operating modes for the XL28C256. Chip erase (typically executed during test procedures) requires a higher supply voltage on the $\overline{\text{OE}}$ input pin. This conforms with existing E²PROM standards. #### Read Mode Data is read from the XL28C256 by bringing both $\overline{CE}$ and $\overline{OE}$ LOW while keeping $\overline{WE}$ HIGH. With the read mode selected, address lines can be changed at any time, in any order to read data at various locations in the E<sup>2</sup>PROM array. Read access time is measured from the latter of either the time when the controlling line goes LOW ( $\overline{CE}$ or $\overline{OE}$ ), or the time when the address is established. The device can be read an unlimited number of times, because the stored charge that defines the bit state is not affected by a read cycle. ### Write Mode The XL28C256 uses a two-step process to store new data. Byte-load cycles fill latches in a volatile page buffer. A subsequent nonvolatile write cycle transfers this data in the page-buffer to the E<sup>2</sup>PROM array without user intervention. The XL28C256 contains (512) 64-byte pages. Address lines $A_6$ - $A_{14}$ identify the page; lines $A_0$ - $A_5$ identify the byte within the page. All bytes written within one nonvolatile write cycle must be on the same page ( $A_6$ - $A_{14}$ must remain unchanged). Any number of the 64 bytes in the page can be written or re-written, in any order; the last data written to any given byte when the nonvolatile write cycle begins is retained. Either WE or CE can be used to initiate the byte-load cycle. The address is latched into internal address latches upon the last falling edge of WE or CE. An internal byte-load timer is started on the falling edge of the controlling line. The timer provides a 100µs window for initiating the next byte-load cycle. Byte-loading can continue indefinitely if each new load cycle is started within the timeout period. When the byte-load timer times out, additional external byte-load cycles are ignored and data is automatically transferred from the page buffer to the E<sup>2</sup>PROM array through an internally managed nonvolatile write cycle. Byte flags, set during the byte-load cycles, ensure that high voltage is applied only to newly written bytes. By avoiding the unnecessary cycling of bytes, the endurance of the array is extended. The high voltage cycle is immune to any overlapping control pin activity. An internal write-flag is set on the first byte-load of each write cycle. Data pins remain in a high impedance state except during a byte-load (when they contain the forced input data) or during a $\overline{DATA}$ polling read (see below). When the high voltage cycle is completed, the write-flag is reset and the operating mode is again determined by the control pins ( $\overline{CE}$ , $\overline{OE}$ and $\overline{WE}$ ). ## Standby Mode Whenever $\overline{CE}$ is brought HIGH, the device operates in standby mode, with the I/O pins in a high impedance state. Standby power dissipation is less than 200µA with CMOS level inputs. #### Chip Erase — High Voltage Mode The chip erase mode allows the user to erase the entire E<sup>2</sup>PROM array with a single command. The method requires the application of high voltage (V<sub>H</sub>) on the $\overline{OE}$ pin, with $\overline{CE}$ at a logical "0." Chip erase is initiated by a standard byte write command, but in this case, the data on the I/O pins is ignored. A byte containing all "1's" is automatically written to all locations in the E<sup>2</sup>PROM array. (Refer to Mode Selection chart.) #### MODE SELECTION | CE | ŌĒ | WE | Mode | I/O | Power | |-----|-----------------|-----|----------------------------|-------------|---------| | VIL | VIL | ViH | Read | Douт | Active | | VIL | ViH | ~ | Byte Write (WE Controlled) | DiN | Active | | 7_5 | ViH | ViL | Byte Write (CE Controlled) | Din | Active | | ViH | X | Х | Standby | HIGH Z | Standby | | VIL | Vн | VIL | Chip Erase | Data In = X | Active | | VIL | VIL | ViH | DATA Polling | <b>D</b> 7 | Active | | X | V <sub>IL</sub> | Х | Write Inhibit | X | Active | ## DEVICE OPERATION—SOFTWARE CONTROL Under software control, the XL28C256 offers 5V-only data protection and chip erase. Software control is accomplished by byte-load sequences involving specific address and data patterns. Short command sequences require three byte-loads; long sequences require six byte-loads. Whenever one of these sequences is recognized in a write operation, it is executed as a software command sequence, and any preceding byte-loads are lost. These address and data patterns could conceivably occur in a normal application. However, the protocol utilizes differing page addresses within one write cycle—a practice that is illegal in standard write operations. #### Chip Erase Mode This software command sequence activates the standard chip erase, but without the high voltage input on the OE pin. When the byte-loads for the command are complete, all byte flag latches are set. When the byte-load timer expires, a special mass-mode high voltage cycle is performed, erasing the entire E<sup>2</sup>PROM array. The device then returns to standard read mode. ## **Chip Erase Software Command Sequence:** | Byte-load | A <sub>14</sub> -A <sub>0</sub> | 1/O <sub>7</sub> -1/O <sub>0</sub> | |-----------|---------------------------------|------------------------------------| | 1 | 5555 (hex) | AA (hex) | | 2 | 2AAA (hex) | 55 (hex) | | 3 | 5555 (hex) | 80 (hex) | | 4 | 5555 (hex) | AA (hex) | | 5 | 2AAA (hex) | 55 (hex) | | 6 | 5555 (hex) | 10 (hex) | ## Set Data Protection Mode (See Figure 1) This software command sequence disables the high voltage cycle for standard writes (those controlled by the enable lines). Each "set data protect" command can be followed by data for one page of the E²PROM array. Thereafter, standard writes are disabled, and can be enabled only by a "disable data protect" command. However, additional pages can be written by the "set data protect" command. ## **Set Data Protect Software Command Sequence:** | Byte-load | A,4-A0 | 1/O <sub>7</sub> -1/O <sub>0</sub> | | | |-----------|------------|------------------------------------|--|--| | 1 | 5555 (hex) | AA (hex) | | | | 2 | 2AAA (hex) | 55 (hex) | | | | 3 | 5555 (hex) | A0 (hex) | | | When this command is recognized, the part remains in write mode. Any number of normal byte-load cycles can be performed in the same write cycle. When the byte-load timer expires, a normal high voltage cycle occurs, writing the page buffer data to the E²PROM array and setting a nonvolatile data protect bit. If the data protect bit was already set—by a previous "set data protect" command—it remains set. If a power failure interrupts the operation, neither the data nor the protect bit is written. Setting the data protect bit inhibits only the high voltage cycles of standard writes (those controlled by the enable lines); byte-load cycles are still accepted. When the byte-load timer expires, the part skips the high voltage cycle and becomes accessible to the standard read mode. Because the data protect bit is a nonvolatile E<sup>2</sup> element, protect mode status is maintained during power off. ## Disable Data Protection Mode (See Figure 2) This software command sequence re-enables the high voltage cycle of the standard write. Each "disable data protect" command can be accompanied by data for one page of the E<sup>2</sup>PROM. Standard writes are then enabled, until disabled by a subsequent "set data protect" command. ### Disable Data Protect Software Command Sequence: | Byte-load | A <sub>14</sub> -A <sub>0</sub> | 1/O <sub>7</sub> -1/O <sub>0</sub> | |-----------|---------------------------------|------------------------------------| | 1 | 5555 (hex) | AA (hex) | | 2 | 2AAA (hex) | 55 (hex) | | 3 | 5555 (hex) | 80 (hex) | | 4 | 5555 (hex) | AA (hex) | | 5 | 2AAA (hex) | 55 (hex) | | 6 | 5555 (hex) | 20 (hex) | The six byte-loads specifying this command leave the part in write mode; any number of normal byte-load cycles can be performed in the same write cycle. When the byte-load timer expires, a normal high voltage cycle occurs, writing the page buffer data to the E²PROM array and setting the nonvolatile data protection. If the data protection was already set (by a previous set data protect command), it remains set. If a power failure interrupts the operation, neither the data nor the data protection is written. For normal, hardware-controlled writes, the data protection inhibits only the high voltage cycles; byte-load cycles are still accepted. When the byte-load timer expires, the part skips the high voltage cycle and reverts to read mode. Because the data protection is a nonvolatile E<sup>2</sup> element, protect mode status is maintained during power off. ## MONITORING DEVICE STATUS Because the byte-load timer and its high voltage cycle are completely under the control of the XL28C256, a status register allows the host system to monitor device status. ## **Status Register** Any read performed during the nonvolatile write cycle is interpreted as a status register read. (Reading the status register has no effect on the byte-load timer, byte-load flags, high voltage cycle or the contents of the page buffer.) The status of a write operation is monitored in one of two ways; Toggle Polling or $\overline{DATA}$ Polling. While the non-volatile write cycle is in progress, $O_6$ will toggle between 0 and 1 on successive reads; $O_7$ will hold the complement of bit 7 of the last byte loaded. When the write-latch is reset, the write operation is complete. $O_6$ and $O_7$ become bits 6 and 7 of the actual byte location. Bit 6 will no longer toggle; bit 7 will no longer be a complement. While the write cycle is in progress, there is additional information available from the status register, as follows: Bits 0 and 1: Reserved for use by factory Bit 2: Always 0 Bit 3: 1 means data protect feature is enabled 0 means data protect feature is disabled Bit 4: Always 1 Bit 5: Reserved for use by factory Bit 6: Used in Toggle polling Bit 7: Used in DATA Polling **DATA** Polling The XL28C256 provides a feature named DATA polling which enables the host system to determine the status of the device through the use of the system busses. No additional hardware is required. Any attempt to read the part while the XL28C256 is busy executing its nonvolatile write cycle will be interpreted as a DATA polling read. This is performed by exercising the control pins in the same sequence as for a normal read. DATA polling cycles have no effect on the byte-load timer, contents of the data buffer or the nonvolatile cycle timing. ## Preliminary DATA polling is a simple software technique used to determine the status of the XL28C256. It is executed as a normal read cycle where the target byte location is the same as that of the byte last written to the XL28C256. During the 5ms (max.) period that the device requires to complete its nonvolatile write cycle, the I/O buffers output the contents of the status register, during a read cycle. I/O<sub>7</sub> is set to output the complement of the value of the MSB of the last byte written to the XL28C256 when a read command is asserted. This procedure is quite simple. The system simply reads the location last written to in the XL28C256 and executes a compare operation between the data thus retrieved and the original data byte written. If the compare fails, the XL28C256 is still busy with its nonvolatile write cycle. If the compare passes, the nonvolatile write cycle is complete and the device is available for read or write accesses. This procedure is commonly used to determine the actual nonvolatile write cycle completion timing, eliminating the need to await the 5ms (max.) period specified, and enabling accelerated device loading operations. #### WRITE PROTECT MECHANISMS The XL28C256 features several integrated mechanisms to protect it from inadvertent writes that might occur during system power supply transitions or periods of system noise. #### **OE** Write Inhibit If OE is brought LOW before the CE and WE write command sequence, the internal nonvolatile write cycle will not occur. See the Mode Selection Table on page 3. In addition to the user-controlled protection mechanisms, the following specialized circuits are built in. #### Vcc Lockout The XL28C256 has a specialized power supply monitor circuit integrated to protect the device from inadvertent write commands asserted by the system during low Vcc conditions. This circuitry constantly evaluates the power ## Preliminary supply voltage level applied to the XL28C256 and actively inhibits the initiation of nonvolatile write cycles if the applied supply voltage falls below Vwi. This circuitry does not abort nor affect nonvolatile write cycles already in progress, yet inhibits new cycles from being initiated. ## Power-Up Write Enable Delay At power on, operation is inhibited until $V_{CC}$ is stable and sufficiently high. Write operations are inhibited until 1ms after $V_{CC}$ reaches $V_{WI}$ to allow the system to stabilize while blocking potential inadvertent write commands. ## **Noise Protection** Write pulses of less than 10ns duration on the $\overline{WE}$ pin will not initiate nonvolatile write cycles. ## **Data Protection Mode (Software Controlled)** The XL28C256 can be placed in a write-disabled mode through software control. ### **ABSOLUTE MAXIMUM RATINGS** | Temperature Under Bias | 55°C to +125°C | |---------------------------------------------------|----------------| | Storage Temperature | 65°C to +150°C | | Lead Soldering Temperature (less than 10 seconds) | 300°C | | Supply Voltage | 0 to 6 5V | | Voltage on Any Pin* | -1.0 to ±7.0V | | Voltage on OE pin* | 1.0 to +15.0V | | ESD Rating | 2000V | | DC Output Current | 5mA | | *With respect to ground | | NOTE: These are STRESS ratings only. Appropriate conditions for operating these devices are given elsewhere in this specification. Stresses beyond those listed here may permanently damage the part. Prolonged exposure to maximum ratings may affect device reliability. Although this product includes specific circuitry to protect it from electrostatic discharge, conventional precautions should be taken to avoid any voltages higher than the rated maxima. ## DC ELECTRICAL CHARACTERISTICS TA = 0°C to +70°C for the XLS28C256 or -40°C to +85°C for the XLE28C256, VCC = $5V \pm 10\%$ | Symbol | Parameter | Test Conditions | Min. | Max. | Units | |--------|------------------------------|------------------------------------------------------------------|------|-----------|-------| | lcc | Vcc Current — Active (TTL) | CE = OE = VIL WE = VIH I/O's = open Ao-A14 toggling at 5MHz | | 60 | mA | | ISB | Vcc Current — Standby (TTL) | CE = WE = VIH OE = VIL I/O's = open A0-A14 = Vcc | | 2 | mA | | Isec | Vcc Current — Standby (CMOS) | CE = WE V cc2V<br>OE = V ss+0.2V<br>I/O's = open<br>A0-A14 = Vcc | | 150 | Αų | | lu | Input Leakage Current | Vin = GND to Vcc | | 10 | μA | | ILO | Output Leakage — Standby | Vout = GND to Vcc<br>CE = ViH | | 10 | μА | | VIL | Input Low Voltage | | -0.5 | 0.8 | V | | ViH | Input High Voltage | | 2.0 | Vcc + 0.5 | V | | Vol | Output Low Voltage | IOL = 2.1 mA | | 0.4 | ٧ | | Vон | Output High Voltage | 1он = -400µА | 2.4 | | v | | Vн | High Voltage for Chip Erase | | 11.4 | 12.6 | V | ## **CAPACITANCE** $T_A = 25$ °C, f = 1.0MHz | Symbol | Test | Test Conditions | Max. | Units | |--------|--------------------------|-----------------|------|-------| | Ci/o | Input/Output Capacitance | Vvo = 0V | 10 | pF | | Cin | Input Capacitance | VIN = 0V | 6 | pF | # **AC OPERATING CHARACTERISTICS** READ CYCLE (See Figures 3 and 4) TA=0°C to +70°C for the XLS28C256 or -40°C to +85°C for the XLE28C256, VCC=5V±10% | | Test | XL28C256-150 | | XL28C256-200 | | XL28C256-250 | | | |--------|------------------------------------|--------------|------|--------------|------|--------------|------|-------| | Symbol | | Min. | Max. | Min. | Max. | Min. | Max. | Units | | trc | Read Cycle Time | 150 | | 200 | | 250 | | ns | | taa | Address Access Time | | 150 | | 200 | | 250 | ns | | tCE | Chip Enable Access Time | | 150 | | 200 | | 250 | ns | | toE | Output Enable Access Time | | 70 | | 80 | | 90 | ns | | tLZ | Chip Enable to Output in Low Z | 0 | | 0 | | 0_ | L | ns | | tHZ | Chip Disable to Output in High Z | 0 | 35 | 0 | 40 | 0 | 45 | ns | | toLZ | Output Enable to Output in Low Z | 0 | | 0 | | 0 | | ns | | tonz | Output Disable to Output in High Z | 0 | 35 | 0 | 40 | 0 | 45 | ns | | tон | Output Hold from Address Change | 0 | | 0 | | 0 | | ns | WRITE CYCLE (See Figures 5, 6 and 7) TA=0°C to +70°C for the XLS28C256 or -40°C to +85°C for the XLE28C256, VCC=5V $\pm$ 10% | Symbol | Test | Min. | Max. | Units | |-------------|--------------------------------|------|------|-------| | twc | Write Cycle Time | | 5 | ms | | tBLC | Byte Load Cycle | .120 | 100 | μs | | tas | Address Setup Time | 0 | | ns | | tan | Address Hold Time | 35 | | ns | | tcs | Write Setup Time | 0 | | ns | | tсн | Write Hold Time | 0 | | ns | | tcw | Chip Enable Pulse Width | 50 | | ns | | toes | Output Enable Setup Time | 5 | | ns | | toen | Output Enable Hold Time | 5 | | ns | | twp | Write Enable Pulse Width | 70 | | ns | | twph | Write Pulse Width High | 50 | | ns | | tos | Data Setup Time | 30 | | ns | | <b>t</b> DH | Data Hold Time | 5 | | ns | | tov | Data Valid Time., | | 1 | μs | | tinit | Power-up Initialization Period | | 20 | ms |