# Am29F200T/Am29F200B Advanced Micro Devices 2 Megabit (262,144 x 8-Bit/131,072 x 16-Bit) CMOS 5.0 Volt-only, Sector Erase Flash Memory # **DISTINCTIVE CHARACTERISTICS** - $5.0 \text{ V} \pm 10\%$ write and erase, read - Minimizes system level power requirements - Compatible with JEDEC-standard commands - Uses same software commands as E<sup>2</sup>PROMs - Compatible with JEDEC-standard word-wide pinouts - 44-pin SO - 48-pin TSOP - Minimum 100,000 write/erase cycles - High performance - 70 ns maximum access time - Sector erase architecture - Three 64 Kbytes, one 32 Kbyte, one 16 Kbyte and two 8 Kbytes - Any combination of sectors can be concurrently erased. Also supports full chip erase. - Embedded Erase Algorithms - Automatically pre-programs and erases the chip or any sector # ■ Embedded Program Algorithms - Automatically writes and verifies data at specified address - Data Polling and Toggle Bit feature for detection of program or erase cycle completion - Low power consumption - 20 mA typical active read current for Byte Mode - 28 mA typical active read current for Word Mode - 30 mA typical write/erase current - 25 μA typical standby current - Low Vcc write inhibit ≤ 3.2 V - Sector protection - Hardware method disables any combination of sectors from write or erase operations - Erase Suspend/Resume - Suspends the erase operation to allow a read in another sector within the same device - Boot Code Sector Architecture - T = Top sector - B = Bottom sector #### GENERAL DESCRIPTION The Am29F200 is a 2 Mbit, 5.0 V-only Flash memory organized as 256K bytes of 8 bits each or 128K words of 16 bits each. The Am29F200 is offered in 44-pin SO and 48-pin TSOP packages. This device is designed to be programmed in-system with the standard system 5.0 V Vcc supply. A 12.0 V Vpp is not required for write or erase operations. The device can also be reprogrammed in standard EPROM programmers. The Am29F200 is erased when shipped from the factory. The standard Am29F200 offers access times between 70 ns and 150 ns, allowing operation of high-speed microprocessors without wait states. To eliminate bus contention the device has separate chip enable ( $\overline{\text{CE}}$ ), write enable ( $\overline{\text{WE}}$ ) and output enable ( $\overline{\text{OE}}$ ) controls. The Am29F200 is pin and command set compatible with JEDEC standard 2 Mbit E<sup>2</sup>PROMs. Commands are written to the command register using standard microprocessor write timings. Register contents serve as input to an internal state-machine which controls the erase and programming circuitry. Write cycles also internally latch addresses and data needed for the programming and erase operations. Reading data out of the device is similar to reading from 12.0 V Flash or EPROM devices. # PRODUCT SELECTOR GUIDE | Family Part No: | | Am29F200 | | | | | | | | | |----------------------------------------------------|-----|----------|------|------|--|--|--|--|--|--| | Ordering Part No: $V_{CC} = 5.0 \text{ V} \pm 5\%$ | -75 | | | | | | | | | | | $V_{CC} = 5.0 \text{ V} \pm 10\%$ | | -90 | -120 | -150 | | | | | | | | Max Access Time (ns) | 70 | 90 | 120 | 150 | | | | | | | | CE (E) Access (ns) | 70 | 90 | 120 | 150 | | | | | | | | OE (G) Access (ns) | 30 | 35 | 50 | 55 | | | | | | | Publication# 18608 Rev. A Amendment /0 Issue Date: March 1994 This document contains information on a product under development at Advanced Micro Devices. Inc. The information is intended to help you evaluate this product. AMD reserves the right to change or discontinue work on this proposed product without notice. The Am29F200 is programmed by executing the program command sequence. This will invoke the Embedded Program Algorithm which is an internal algorithm that automatically times the program pulse widths and verifies proper cell margin. Typically, each sector can be programmed and verified in less than one second. Erase is accomplished by executing the erase command sequence. This will invoke the Embedded Erase Algorithm which is an internal algorithm that automatically preprograms the array if it is not already programmed before executing the erase operation. During erase, the device automatically times the erase pulse widths and verifies proper cell margin. The entire chip or any individual sector is typically erased and verified in 1.5 seconds (if already completely preprogrammed). This device also features a sector erase architecture. The sector mode allows each sector to be erased and reprogrammed without affecting other sectors. The device features single 5.0 V power supply operation for both read and write functions. Internally generated and regulated voltages are provided for the program and erase operations. A low V<sub>CC</sub> detector automatically inhibits write operations on the loss of power. The end of program or erase is detected by Data Polling of DQ7, by the Toggle Bit feature on DQ6, or the RY/BY pin. Once the end of a program or erase cycle has been completed, the device internally resets to the read mode. AMD's Flash technology combines years of EPROM and E²PROM experience to produce the highest levels of quality, reliability and cost effectiveness. The Am29F200 memory electrically erases the entire chip or all bits within a sector simultaneously via Fowler-Nordheim tunneling. The bytes/words are programmed one byte/word at a time using the EPROM programming mechanism of hot electron injection. # Flexible Sector-Erase Architecture - Three 64 Kbytes, one 32 Kbyte, one 16 Kbyte, and two 8 Kbytes - Individual-sector, multiple-sector, or bulk-erase capability - Individual or multiple-sector protection is userdefinable | <br>16 Kbyte | 3FFFFh | |--------------|-------------------| | <br>10 Kbyte | 3BFFFh | | 8 Kbyte | | | 8 Kbyte | 39FFFh | | <br>32 Kbyte | 37FFFh | | <br>64 Kbyte | 2FFFFh | | 64 Kbyte | 1FFFFh | | <br> | OFFFFh | | <br>64 Kbyte | <sub>00000h</sub> | Am29F200T Sector Architecture 18608A-1 | | | 3FFFFh | |---------|----------|--------| | | 64 Kbyte | ı | | | 64 Kbyte | 2FFFFh | | | 64 Kbyte | 1FFFFh | | | 32 Kbyte | OFFFFh | | | 8 Kbyte | 07FFFh | | <b></b> | 8 Kbyte | 05FFFh | | | 16 Kbyte | 03FFFh | | L | | 00000h | Am29F200B Sector Architecture # **BLOCK DIAGRAM** # **CONNECTION DIAGRAMS** so 1860BA-4 # **CONNECTION DIAGRAMS** #### Standard TSOP 18608A-5 Reverse TSOP # LOGIC SYMBOL Table 1. Am29F200 Pin Configuration | Pin | Function | |-------------|----------------------------------------------| | A-1, A0-A16 | Address Inputs | | DQ0-DQ15 | Data Input/Output | | CE | Chip Enable | | ŌĒ | Output Enable | | WE | Write Enable | | RY/BY | Ready-Busy Input | | RESET | Hardware Reset Pin/Sector Protect Unlock | | BYTE | Selects 8-bit or 16-bit mode | | NC | No Internal Connection | | Vss | Device Ground | | Vcc | Device Power Supply<br>(5.0 V ± 10% or ± 5%) | # ORDERING INFORMATION # Standard Products AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of: | Valid Cor | Valid Combinations | | | | | | | | | | | |-----------------|---------------------|--|--|--|--|--|--|--|--|--|--| | Am29F200T/B-75 | EC, FC, SC | | | | | | | | | | | | Am29F200T/B-90 | EC, EI, FC, FI, EE, | | | | | | | | | | | | Am29F200T/B-120 | EEB, FE, FEB, SC, | | | | | | | | | | | | Am29F200T/B-150 | SI, SE, SEB | | | | | | | | | | | #### **Valid Combinations** Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations. Table 2. Am29F200 User Bus Operations (BYTE = VIH) | Operation | CE | ŌĒ | WE | AO | <b>A</b> 1 | A6 | A9 | DQ0-DQ15 | RESET | |-----------------------------------|----|-----|----|----|------------|----|-----|----------|-------| | Auto-Select Manufacturer Code (1) | L | L | н | L | L | L | VID | Code | н | | Auto-Select Device Code (1) | L | L | н | Н | L | L | VID | Code | Н | | Read (3) | L | L | Н | A0 | A1 | A6 | A9 | Dout | Н | | Standby | Н | Х | Х | Х | Х | Х | х | HIGH Z | н | | Output Disable | L | н | Н | Х | Х | х | X | HIGH Z | Х | | Write | L | Н | L | A0 | <b>A</b> 1 | A6 | A9 | Din | Н | | Enable Sector Protect | L | ViD | L | Х | Х | Х | ViD | х | Н | | Verify Sector Protect (2) | L | L | Н | L | Н | L | ViD | Code | Н | | Temporary Sector Unprotect | Х | х | х | х | Х | Х | х | х | VID | | Reset (Hardware) | х | Х | х | х | Х | Х | Х | HIGH Z | L | Table 3. Am29F200 User Bus Operations (BYTE = VIL) | Operation | CE | ŌE | WE | ÀΟ | A1 | <b>A</b> 6 | A9 | DQ0-DQ7 | RESET | |-----------------------------------|----|-----|----|----|----|------------|-----|---------|-------| | Auto-Select Manufacturer Code (1) | L | L | Н | L | L | L | VID | Code | н | | Auto-Select Device Code (1) | L | L | Н | н | L | L | ViD | Code | Н | | Read (3) | Ł | L. | Н | A0 | A1 | A6 | A9 | Dout | Н | | Standby | Н | Х | Х | Х | Х | Х | х | HIGH Z | Н, | | Output Disable | L | Н | Н | Х | Х | х | Х | HIGH Z | х | | Write | L | Н | L | A0 | A1 | A6 | A9 | Din | Н | | Enable Sector Protect | L | ViD | L | Х | Х | Х | ViD | Х | Н | | Verify Sector Protect (2) | L | L | н | L | Н | L | ViD | Code | ·H | | Temporary Sector Unprotect | Х | х | Х | Х | Х | Х | X | Х | VıD | | Reset (Hardware) | Х | х | Х | х | Х | Х | Х | HIGH Z | L | #### Legend: L = VIL, H = VIH, X = Don't Care. See DC Characteristics for voltage levels. #### Notes: - 1. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 7. - 2. Refer to the section on Sector Protection. - 3. WE can be VIL if OE is VIL, OE at VIH initiates the write operations. # **Read Mode** The Am29F200 has two control functions which must be satisfied in order to obtain data at the outputs. $\overline{CE}$ is the power control and should be used for device selection. $\overline{OE}$ is the output control and should be used to gate data to the output pins if a device is selected. Address access time (tacc) is equal to the delay from stable addresses to valid output data. The chip enable access time (tce) is the delay from stable addresses and stable $\overline{\text{CE}}$ to valid data at the output pins. The output enable access time is the delay from the falling edge of $\overline{\text{OE}}$ to valid data at the output pins (assuming the addresses have been stable for at least tacc-toe time). 5.0 Volt-only, Sector Erase Flash Memories # Standby Mode The Am29F200 has two standby modes, a CMOS standby mode ( $\overline{CE}$ input held at $Vcc\pm0.5$ V), when the current consumed is less than 100 $\mu$ A; and a TTL standby mode ( $\overline{CE}$ is held at $V_{IH}$ ) when the current required is reduced to approximately 1 mA. In the standby mode the outputs are in a high impedance state, independent of the $\overline{OE}$ input. If the device is deselected during erasure or programming, the device will draw active current until the operation is completed. # **Output Disable** With the $\overline{OE}$ input at a logic high level (V<sub>H</sub>), output from the device is disabled. This will cause the output pins to be in a high impedance state. # **Autoselect** The autoselect mode allows the reading out of a binary code from the device and will identify its manufacturer and type. This mode is intended for use by programming equipment for the purpose of automatically matching the device to be programmed with its corresponding programming algorithm. This mode is functional over the entire temperature range of the device. To activate this mode, the programming equipment must force $V_{\rm ID}$ (11.5 V to 12.5 V) on address pin A9. Two identifier bytes may then be sequenced from the device outputs by toggling address A0 from $V_{\rm IL}$ to $V_{\rm IH}$ . All addresses are don't cares except A0, A1, and A6. The manufacturer and device codes may also be read via the command register, for instances when the Am29F200 is erased or programmed in a system without access to high voltage on the A9 pin. The command sequence is illustrated in Table 7 (refer to Autoselect Command section). Byte 0 (A0 = $V_{IL}$ ) represents the manufacturer's code (AMD=01H) and byte 1 (A0 = $V_{IH}$ ) the device identifier code (Am29F200T = 51H and Am29F200B = 52H for x8 mode; Am29F200T = 2251H and Am29F200B = 2252H for x16 mode). These two bytes/words are given in the table below. All identifiers for manufacturer and device will exhibit odd parity with the DQ7 defined as the parity bit. In order to read the proper device codes when executing the autoselect, A1 must be $V_{IL}$ (see Tables 4.1 and 4.2). Table 4.1 Am29F200 Sector Protection Verify Autoselect Codes | Туре | Туре | | A12-A16 | <b>A</b> 6 | A1 | Α0 | Code (HEX) | |---------------------|-----------|---------------------|---------|------------|-----|------|------------| | Manufacturer's Code | | Х | ViL | VIL | ViL | 01H | | | Δ | A 005000T | Byte | ., | VIL | ., | ., | 51H | | Am29F200 | Am29F200T | Word | X | | Vil | Vıн | 2251H | | Device<br>Code | Am29F200B | Byte | Х | ., | ., | V | 52H | | | Am29F200B | Word | ^ | ViL | VIL | ViH | 2252H | | Sector Protection | | Sector<br>Addresses | VIL | ViH | VIL | 01H* | | <sup>\*</sup>Outputs 01H at protected sector addresses **Table 4.2 Expanded Autoselect Code Table** | | Туре | Code | ∆o <sup>5</sup> | D<br>Q<br>14 | DQ13 | ۵α₽ | oo∓ | <b>□</b> @₽ | ΔØ® | D.Q;⊗ | D<br>Q<br>7 | DOΘ | ۵Øъ | DG4 | ΔØσ | DQ≈ | D<br>Q<br>1 | ۵Ø٥ | |--------------------|---------------------|--------------|-----------------|--------------|-----------|-----------|-----------|-------------|-----------|-----------|-------------|-----|-----|-----|-----|-----|-------------|-----| | Manufa | cturer's Code | 01H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Am29F200<br>Device | Am29F200T(B)<br>(W) | 51H<br>2251H | A-1<br>0 | HI–Z<br>O | HI–Z<br>1 | HI-Z<br>O | HI-Z<br>O | HI⊷Z<br>O | HI–Z<br>1 | HI–Z<br>0 | 0 | 1 | 0 | 1 | 00 | 0 0 | 0 | 1 | | Code | Am29F200B(B)<br>(W) | 52H<br>2252H | A-1<br>0 | HI-Z<br>0 | HI-Z<br>1 | HI-Z<br>0 | HI–Z | HI–Z<br>O | HI–Z<br>1 | HI–Z<br>0 | 00 | | 00 | 1 | 00 | 0 | 1 | 00 | | Sector Protection | | 01H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | <sup>(</sup>B) - Byte mode <sup>(</sup>W) - Word mode Table 5. Sector Address Tables (Am29F200T) | | A16 | A15 | A14 | A13 | A12 | Address Range | |-----|-----|-----|-----|-----|-----|---------------| | SA0 | 0 | 0 | х | х | х | 00000h-0FFFFh | | SA1 | 0 | 1 | х | х | Х | 10000h-1FFFFh | | SA2 | 1 | 0 | х | Х | Х | 20000h-2FFFFh | | SA3 | 1 | 1 | 0 | х | Х | 30000h-37FFFh | | SA4 | 1 | 1 | 1 | 0 | 0 | 38000h-39FFFh | | SA5 | 1 | 1 | 1 | 0 | 1 | 3A000h-3BFFFh | | SA6 | 1 | 1 | 1 | 1 | Х | 3C000h-3FFFFh | Table 6. Sector Address Tables (Am29F200B) | | A16 | A15 | <b>A</b> 14 | A13 | A12 | Address Range | |-----|-----|-----|-------------|-----|-----|---------------| | SA0 | 0 | 0 | 0 | 0 | Х | 00000h-03FFFh | | SA1 | 0 | 0 | 0 | 1 | 0 | 04000h-05FFFh | | SA2 | 0 | 0 | 0 | 1 | 1 | 06000h-07FFFh | | SA3 | 0 | 0 | 1 | х | X | 08000h-0FFFFh | | SA4 | 0 | 1 | Х | Х | Х | 10000h-1FFFFh | | SA5 | 1 | 0 | х | Х | Х | 20000h-2FFFFh | | SA6 | 1 | 1 | х | Х | Х | 30000h-3FFFFh | # Write Device erasure and programming are accomplished via the command register. The contents of the register serve as inputs to the internal state machine. The state machine outputs dictate the function of the device. The command register itself does not occupy any addressable memory location. The register is a latch used to store the commands, along with the address and data information needed to execute the command. The command register is written to by bringing $\overline{WE}$ to $V_{IL}$ , while $\overline{CE}$ is at $V_{IL}$ and $\overline{OE}$ is at $V_{IH}$ . Addresses are latched on the falling edge of $\overline{WE}$ or $\overline{CE}$ , whichever happens later; whichever happens first. Standard microprocessor write timings are used. Refer to AC Write Characteristics and the Erase/Programming Waveforms for specific timing parameters. #### Sector Protection The Am29F200 features hardware sector protection. This feature will disable both program and erase operations in any number of sectors (0 through 6). The sector protect feature is enabled using programming equipment at the user's site. The device is shipped with all sectors unprotected. Alternatively, AMD may program and protect sectors in the factory prior to shipping the device (AMD's ExpressFlash™ Service). To activate this mode, the programming equipment must force $V_{ID}$ on address pin A9 and control pin $\overline{OE}$ , (suggest $V_{ID} = 11.5$ V) and $\overline{CE} = V_{IL}$ . The sector addresses (A16, A15, A14, A13, and A12) should be set to the sector to be protected. Tables 5 and 6 define the sector address for each of the seven (7) individual sectors. Programming of the protection circuitry begins on the falling edge of the $\overline{WE}$ pulse and is terminated with the rising edge of the same. Sector addresses must be held constant during the $\overline{WE}$ pulse. Refer to figures 17 and 18 for sector protect algorithm and waveforms. To verify programming of the protection circuitry, the programming equipment must force $V_{ID}$ on address pin A9 with $\overline{CE}$ and $\overline{OE}$ at $V_{IL}$ and $\overline{WE}$ at $V_{IH}$ . Scanning the sector addresses (A16, A15, A14, A13, and A12) while (A6, A1, A0) = (0, 1, 0) will produce a logical "1" code at device output DQ0 for a protected sector. Otherwise the device will produce 00H for an unprotected sector. In this mode, the lower order addresses, except for A0, A1, and A6 are don't care. Address locations with A1 = $V_{IL}$ are reserved for Autoselect manufacturer and device codes. It is also possible to determine if a sector is protected in the system by writing an Autoselect command. Performing a read operation at the address location XX02H, where the higher order addresses (A16, A15, A14, A13, and A12) are the sector address will produce a logical "1" at DQ0 for a protected sector. See Tables 4.1 and 4.2 for Autoselect codes. # **Temporary Sector Unprotect** This feature allows temporary unprotection of previously protected sectors of the Am29F200 device in order to change data. The Sector Unprotect mode is activated by setting the RESET pin to high voltage (12V). During this mode, formerly protected sectors can be programmed or erased by selecting the sector addresses. Once the 12V is taken away from the RESET pin, all the previously protected sectors will be protected again. # **Sector Unprotect** The Am29F200 also features a sector unprotect mode, so that a protected sector may be unprotected to incorporate any changes in the code. All sectors should be protected prior to unprotecting any sector. To activate this mode, the programming equipment must force V<sub>ID</sub> on control pin $\overrightarrow{OE}$ and address pin A9. The $\overline{CE}$ and A0 pins must be set at $V_{IL}$ . Pins A6 and A1 must be set to $V_{IH}$ . Refer to Figure 19 for the sector unprotect algorithm. The unprotection mechanism begins on the falling edge of the $\overline{WE}$ pulse and is terminated with the rising edge of the same. It is also possible to determine if a sector is unprotected in the system by writing the autoselect command and A6 is set at $V_{\rm IL}$ . Performing a read operation at address location XXX2H, where the higher order addresses (A16, A15, A14, A13, and A12) define a particular sector address, will produce 00H at data outputs (DQ0–DQ7) for an unprotected sector. #### Command Definitions Device operations are selected by writing specific address and data sequences into the command register. Writing incorrect address and data values or writing them in the improper sequence will reset the device to the read mode. Table 7 defines the valid register command sequences. Note that the Erase Suspend (B0) and Erase Resume (30) commands are valid only while the Sector Erase operation is in progress. Either of the two reset commands will reset the device (when applicable). Please note that commands are always written at DQ0–DQ7 and DQ8–DQ15 bits are ignored. | Command<br>Sequence | | Bus<br>Write<br>Cycles | First Bus<br>Write Cycle | | Second<br>Write C | | Third Bus<br>Write Cycle | | Fourth Bus<br>Read/Write<br>Cycle | | Fifth Bus<br>Write Cycle | | Sixth Bus<br>Write Cycle | | |---------------------|--------|------------------------|--------------------------|---------|-------------------|----------|--------------------------|---------|-----------------------------------|-------------|--------------------------|----------|--------------------------|------| | Read/Reset | | Req'd | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | | Read/Reset | | 1 | XXXH | F0H | | | | | | _ | | | | | | Read/Reset | Word | 4 | 5555H | AAH | 2AAAH | 55H | 5555H | FOH | RA | RD | | | | | | | Byte | ] | AAAAH | | 5555H | ] | AAAAH | | | | | | | | | Autoselect | Word 4 | 5555H | AAH | 2AAAH | 55H | 5555H | 90H | | | | | | | | | | Byte | ] | AAAAH | | 5555H | <b>.</b> | AAAAH | | | | | <u> </u> | | | | Program | Word | 4 | 5555H | AAH | 2AAAH | 55H | 5555H | AOH | PA | Data | 1 | | | | | | Byte | 1 | AAAAH | | 5555H | | AAAAH | | | | | | | | | Chip Erase | Word | 6 | 5555H | AAH | 2AAAH | 55H | 5555H | 80H | 5555H | AAH | 2AAAH | 55H | 5555H | 10H | | | Byte | | AAAAH | } | 5555H | ] | AAAAH | ] | AAAAH | | 5555H | | AAAAH | | | Sector Erase | Word | 6 | 5555H | ААН | 2AAAH | 55H | 5555H | 80H | 5555H | AAH | 2AAAH | 55H | SA | 30H | | | Byte | | AAAAH | Ì | 5555H | 1 | AAAAH | | AAAAH | | 5555H | | | | | Sector Erase Suspen | nd | | Erase c | an be s | suspende | d durir | ng sector | erase v | vith Addr (do | on't care), | Data (B0 | H) | | | | Sector Erase Resum | ne | | Erase c | an be i | resumed | after si | uspend w | ith Add | r (don't care | ), Data (3 | (HO | | | | Table 7. Am29F200 Command Definitions #### Notes: - Address bit A15 = X = Don't Care for all address commands except for Program Address (PA) and Sector Address (SA) Write Sequences may be initiated with A15 in either state. - 2. Address bits A16 = X = Don't Care for all address commands except for Program Address (PA) and Sector Address (SA). - 3. Bus operations are defined in Table 2. - 4. RA = Address of the memory location to be read. - PA = Address of the memory location to be programmed. Addresses are latched on the falling edge of the $\overline{WE}$ pulse. - SA = Address of the sector to be erased. The combination of A16, A15, A14, A13, and A12 will uniquely select any sector. - 5. RD = Data read from location RA during read operation. - PD = Data to be programmed at location PA. Data is latched on the falling edge of WE. - 6. The system should generate the following address patterns: Word Mode: 5555H or 2AAAH to addresses A0 – A14 Byte Mode: AAAAH or 5555H to addresses A-1 – A14. # Read/Reset Command The read or reset operation is initiated by writing the read/reset command sequence into the command register. Microprocessor read cycles retrieve array data from the memory. The device remains enabled for reads until the command register contents are altered. The device will automatically power-up in the read/reset state. In this case, a command sequence is not required to read data. Standard microprocessor read cycles will retrieve array data. This default value ensures that no spurious alteration of the memory content occurs during the power transition. Refer to the AC Read Characteristics and Waveforms for the specific timing parameters. ### **Autoselect Command** Flash memories are intended for use in applications where the local CPU alters memory contents. As such, manufacture and device codes must be accessible while the device resides in the target system. PROM programmers typically access the signature codes by raising A9 to a high voltage. However, multiplexing high voltage onto the address lines is not generally desired system design practice. The device contains an autoselect command operation to supplement traditional PROM programming methodology. The operation is initiated by writing the autoselect command sequence into the command register. Following the command write, a read cycle from address XX00H retrieves the manufacture code of 01H. A read cycle from address XX01H returns the device code (Am29F200T = 51H and Am29F200B = 52H for x8 mode; Am29F200T = 2251H and Am29F200B = 2252H for x16 mode) (see Tables 4.1 and 4.2). All manufacturer and device codes will exhibit odd parity with DQ7 defined as the parity bit. Scanning the sector addresses (A16, A15, A14, A13, and A12) while (A6, A1, A0) = (0, 1, 0) will produce a logical "1" at device output DQ0 for a protected sector. To terminate the operation, it is necessary to write the read/reset command sequence into the register. #### Byte/Word Programming The device is programmed on a byte-by-byte (or word-by-word) basis. Programming is a four bus cycle operation. There are two "unlock" write cycles. These are followed by the program set-up command and data write cycles. Addresses are latched on the falling edge of $\overline{CE}$ or $\overline{WE}$ , whichever happens later and the data is latched on the rising edge of $\overline{CE}$ or $\overline{WE}$ , whichever happens first. The rising edge of $\overline{CE}$ or $\overline{WE}$ (whichever happens first) begins programming. Upon executing the Embedded Program Algorithm command sequence the system is *not* required to provide further controls or timings. The device will automatically provide adequate internally generated program pulses and verify the programmed cell margin. The automatic programming operation is completed when the data on DQ7 is equivalent to data written to this bit (see Write Operation Status section) at which time the device returns to the read mode and addresses are no longer latched. Therefore, the device requires that a valid address to the device be supplied by the system at this particular instance of time. Hence, Data Polling must be performed at the memory location which is being programmed. Any commands written to the chip during this period will be ignored. Programming is allowed in any sequence and across sector boundaries. Beware that a data "0" cannot be programmed back to a "1". Attempting to do so may either hang up the device or result in an apparent success according to the data polling algorithm but a read from reset/read mode will show that the data is still "0". Only erase operations can convert "0"s to "1"s. Figure 1 illustrates the Embedded Programming Algorithm using typical command strings and bus operations. # Chip Erase Chip erase is a six bus cycle operation. There are two "unlock" write cycles. These are followed by writing the "set-up" command. Two more "unlock" write cycles are then followed by the chip erase command. Chip erase does *not* require the user to program the device prior to erase. Upon executing the Embedded Erase<sup>™</sup> Algorithm command sequence the device automatically will program and verify the entire memory for an all zero data pattern prior to electrical erase. The system is not required to provide any controls or timings during these operations. The automatic erase begins on the rising edge of the last WE pulse in the command sequence and terminates when the data on DQ7 is "1" (see Write Operation Status section) at which time the device returns to read the mode. Figure 2 illustrates the Embedded Erase Algorithm using typical command strings and bus operations. #### Sector Erase Sector erase is a six bus cycle operation. There are two "unlock" write cycles. These are followed by writing the "set-up" command. Two more "unlock" write cycles are then followed by the sector erase command. The sector address (any address location within the desired sector) is latched on the falling edge of $\overline{WE}$ , while the command (30H) is latched on the rising edge of $\overline{WE}$ . A time-out of 80 $\mu$ s from the rising edge of the last sector erase command will initiate the sector erase command(s). Multiple sectors may be erased concurrently by writing the six bus cycle operations as described above. This sequence is followed with writes of the Sector Erase command to addresses in other sectors desired to be concurrently erased. The time between writes must be less than 80 $\mu s$ , otherwise that command will not be accepted and erasure will start. It is recommended that processor interrupts be disabled during this time to guarantee this condition. The interrupts can be re-enabled after the last Sector Erase command is written. A time-out of 80 $\mu s$ from the rising edge of the last WE will initiate the execution of the Sector Erase command(s). If another falling edge of the WE occurs within the 80 µs time-out window the timer is reset. (Monitor DQ3 to determine if the sector erase timer window is still open, see section DQ3, Sector Erase Timer.) Any command other than Sector Erase or Erase Suspend during this period will reset the device to the read mode, ignoring the previous command string. Resetting the device once execution has begun will corrupt the data in that sector, in that case, restart the erase on those sectors and allow them to complete. (Refer to the Write Operation Status section for Sector Erase Timer operation.) Loading the sector erase buffer may be done in any sequence and with any number of sectors (0 to 6). Sector erase does *not* require the user to program the device prior to erase. The device automatically programs all memory locations in the sector(s) to be erased prior to electrical erase. When erasing a sector or sectors the remaining unselected sectors are not affected. The system is *not* required to provide any controls or timings during these operations. The automatic sector erase begins after the $80~\mu s$ time out from the rising edge of the $\overline{WE}$ pulse for the last sector erase command pulse and terminates when the data on DQ7 is "1" (see Write Operation Status section) at which time the device returns to the read mode. Data Polling must be performed at an address within any of the sectors being erased. Figure 2 illustrates the Embedded Erase Algorithm using typical command strings and bus operations. #### Erase Suspend Erase Suspend command allows the user to interrupt the chip and then perform data reads (not program) from a non-busy sector during a Sector Erase operation (which may take up to several seconds). This command is applicable ONLY during the Sector Erase operation and will be ignored if written during the Chip Erase or Programming operation. The Erase Suspend command (B0H) which is allowed only during the Sector Erase Operation includes the sector erase time-out period after the Sector Erase commands (30H). Writing this command during the time-out will result in immediate termination of the time-out period. Any subsequent writes of the Sector Erase command will be ignored as such, but instead will be taken as the Erase Resume command. Note that any other commands during the time out will reset the device to read mode. The addresses are don't-cares when writing the erase Suspend or Erase Resume commands. When the Erase Suspend command is written during a Sector Erase operation, the chip will take between 0.1 µs to 15 µs to suspend the erase operation and go into erase suspended read mode (pseudo-read mode), during which the user can read from a sector that is NOT being erased. A read from a sector being erased may result in invalid data. The user must monitor the toggle bit (DQ6) to determine if the chip has entered the pseudoread mode, at which time the toggle bit stops toggling. An address of a sector NOT being erased must be used to read the toggle bit, otherwise the user may encounter intermittent problems. Note that the user must keep track of what state the chip is in since there is no external indication of whether the chip is in pseudo-read mode or actual read mode. After the user writes the Erase Suspend command, the user must wait until the toggle bit stops toggling before data reads from the device can be performed. Any further writes of the Erase Suspend command at this time will be ignored. Every time an Erase Suspend command followed by an Erase Resume command is written, the internal (pulse) counters are reset. These counters are used to count the number of high voltage pulses the memory cell requires to program or erase. If the count exceeds a certain limit, then the DQ5 bit will be set (Exceeded Time Limit flag). This resetting of the counters is necessary since the Erase Suspend command can potentially interrupt or disrupt the high voltage pulses. To resume the operation of Sector Erase, the Resume command (30H) should be written. Any further writes of the Resume command at this point will be ignored. Another Erase Suspend command can be written after the chip has resumed erasing. # **Write Operation Status** **Table 8. Hardware Sequence Flags** | | Status | DQ7 | DQ6 | DQ5 | DQ3 | DQ2-DQ0 | |-------------|-----------------------------|-----|--------|-----|-----|---------------------------| | In Progress | Auto-Programming | DQ7 | Toggle | 0 | 0 | ( <del>D</del> ) (Note 1) | | | Program/Erase in Auto Erase | 0 | Toggle | 0 | 1 | | | Exceeded | Auto-Programming | DQ7 | Toggle | 1 | 1 | (D) (Note 1) | | Time Limits | Program/Erase in Auto-Erase | 0 | Toggle | 1 | 1 | | #### Notes: - 1. DQ0, DQ1, and DQ2 are reserve pins for future use. - 2. DQ8-DQ15 = Don't Care for x16 mode. - 3. DQ4 for AMD internal use only. # DQ7 Data Polling The Am29F200 device features Data Polling as a method to indicate to the host that the Embedded Algorithms are in progress or completed. During the Embedded Program Algorithm an attempt to read the device will produce the complement of the data last written to DQ7. Upon completion of the Embedded Program Algorithm, an attempt to read the device will produce the true data last written to DQ7. During the Embedded Erase Algorithm, an attempt to read the device will produce a "0" at the DQ7 output. Upon completion of the Embedded Erase Algorithm an attempt to read the device will produce a "1" at the DQ7 output. The flowchart for Data Polling (DQ7) is shown in Figure 3. For chip erase, the Data Polling is valid after the rising edge of the sixth WE pulse in the six write pulse sequence. For sector erase, the Data Polling is valid after the last rising edge of the sector erase WE pulse. Data Polling must be performed at sector address within any of the sectors being erased and not a protected sector. Otherwise, the status may not be valid. Once the Embedded Algorithm operation is close to being completed, the Am29F200 data pins (DQ7) may change asynchronously while the output enable (OE) is asserted low. This means that the device is driving status information on DQ7 at one instant of time and then that byte's valid data at the next instant of time. Depending on when the system samples the DQ7 output, it may read the status or valid data. Even if the device has completed the Embedded Algorithm operation and DQ7 has a valid data, the data outputs on DQ0-DQ6 may be still invalid. The valid data on DQ0-DQ7 will be read on the successive read attempts. The Data Polling feature is only active during the Embedded Programming Algorithm, Embedded Erase Algorithm, or sector erase time-out (see Table 8). See Figure 11 for the Data Polling timing specifications and diagrams. # DQ6 Toggle Bit The Am29F200 also features the "Toggle Bit" as a method to indicate to the host system that the Embedded Algorithms are in progress or completed. During an Embedded Program or Erase Algorithm cycle, successive attempts to read ( $\overline{OE}$ toggling) data from the device will result in DQ6 toggling between one and zero. Once the Embedded Program or Erase Algorithm cycle is completed, DQ6 will stop toggling and valid data will be read on the next successive attempts. During programming, the Toggle Bit is valid after the rising edge of the fourth WE pulse in the four write pulse sequence. For chip erase, the Toggle Bit is valid after the rising edge of the sixth WE pulse in the six write pulse sequence. For Sector erase, the Toggle Bit is valid after the last rising edge of the sector erase WE pulse. The Toggle Bit is active during the sector time out. In programming, if the sector being written to is protected, the toggle bit will toggle for about 2 $\mu$ s and then stop toggling without the data having changed. In erase, the device will erase all the selected sectors except for the ones that are protected. If all selected sectors are protected, the chip will toggle the toggle bit for about 100 $\mu$ s and then drop back into read mode, having changed none of the data Either $\overline{\text{CE}}$ or $\overline{\text{OE}}$ toggling will cause the DQ6 to toggle. In addition, an Erase Suspend/Resume command will cause DQ6 to toggle. See Figure 12 for the Toggle Bit timing specifications and diagrams. #### DQ5 Exceeded Timing Limits DQ5 will indicate if the program or erase time has exceeded the specified limits (internal pulse count). Under these conditions DQ5 will produce a "1". This is a failure condition which indicates that the program or erase cycle was not successfully completed. Data Polling is the only operating function of the device under this condition. The $\overline{CE}$ circuit will partially power down the device under these conditions (to approximately 2 mA). The $\overline{OE}$ and $\overline{WE}$ pins will control the output disable functions as described in Table 2. If this failure condition occurs during sector erase operation, it specifies that a particular sector is bad and it may not be reused. However, other sectors are still functional and may be used for the program or erase operation. The device must be reset to use other sectors. Write the Reset command sequence to the device, and then execute program or erase command sequence. This allows the system to continue to use the other active sectors in the device. If this failure condition occurs during the chip erase operation, it specifies that the entire chip is bad or combination of sectors are bad. If this failure condition occurs during the byte programming operation, it specifies that the entire sector containing that byte is bad and this sector may not be reused, (other sectors are still functional and can be reused). The DQ5 failure condition may also appear if a user tries to program a non blank location without erasing. In this case the device locks out and never completes the Embedded Algorithm operation. Hence, the system never reads a valid data on DQ7 bit and DQ6 never stops toggling. Once the device has exceeded timing limits, the DQ5 bit will indicate a "1." Please note that this is not a device failure condition since the device was incorrectly used. #### DQ3 Sector Erase Timer After the completion of the initial sector erase command sequence the sector erase time-out will begin. DQ3 will remain low until the time-out is complete. Data Polling and Toggle Bit are valid after the initial sector erase command sequence. If Data Polling or the Toggle Bit indicates the device has been written with a valid erase command, DQ3 may be used to determine if the sector erase timer window is still open. If DQ3 is high ("1") the internally controlled erase cycle has begun; attempts to write subsequent commands to the device will be ignored until the erase operation is completed as indicated by Data Polling or Toggle Bit. If DQ3 is low ("0"), the device will accept additional sector erase commands. To insure the command has been accepted, the system software should check the status of DQ3 prior to and following each subsequent sector erase command. If DQ3 were high on the second status check, the command may not have been accepted. Refer to Table 8: Hardware Sequence Flags. # RY/BY #### Ready/Busy The Am29F200 provides a RY/BY output pin as a way to indicate to the host system that the Embedded Algorithms are either in progress or completed. If the output is low, the device is busy with either a program or erase operation. If the output is high, the device is ready to accept any read/write or erase operation. When the RY/BY pin is low, the device will not accept any additional program or erase commands. If the Am29F200 is placed in an Erase Suspend mode, the RY/BY output will be high. Also, since this is an open drain output, many RY/BY pins can be tied together in parallel with a pull up resistor to Vcc. During programming, the $RY/\overline{BY}$ pin is driven low after the rising edge of the fourth $\overline{WE}$ pulse. During an erase operation, the $RY/\overline{BY}$ pin is driven low after the rising edge of the sixth $\overline{WE}$ pulse. The $RY/\overline{BY}$ pin should be ignored while RESET is at $V_{IL}$ . Refer to Figure 13 for a detailed timing diagram. #### RESET #### **Hardware Reset** The Am29F200 device may be reset by driving the RESET pin to $V_{IL}$ . The RESET pin has a pulse requirement and has to be kept low $(V_{IL})$ for at least 500 ns in order to properly reset the internal state machine. Any operation in the process of being executed will be terminated and the internal state machine will be reset 20 $\mu$ s after the RESET pin is driven low. Furthermore, once the RESET pin goes high, the device requires an additional 50 ns before it will allow read access. When the RESET pin is low, the device will be in the standby mode for the duration of the pulse and all the data output pins will be tri-stated. If a hardware reset occurs during a program or erase operation, the data at that particular location will be corrupted. Please note that the RY/BY output signal should be ignored during the RESET pulse. Refer to Figure 14 for the timing diagram. # Byte/Word Configuration The BYTE pin selects the byte (8-bit) mode or word (16 bit) mode for the Am29F200 device. When this pin is driven high, the device operates in the word (16 bit) mode. The data is read and programmed at DQ0-DQ15. When this pin is driven low, the device operates in byte (8 bit) mode. Under this mode, the DQ15/A-1 pin becomes the lowest address bit and DQ8-DQ14 bits are tristated. However, the command bus cycle is always an 8-bit operation and hence commands are written at DQ0-DQ7 and the DQ8-DQ15 bits are ignored. Refer to Figures 15 and 16 for the timing diagram. # **Data Protection** The Am29F200 is designed to offer protection against accidental erasure or programming caused by spurious system level signals that may exist during power transitions. During power up the device automatically resets the internal state machine in the Read mode. Also, with its control register architecture, alteration of the memory contents only occurs after successful completion of specific multi-bus cycle command sequences. The device also incorporates several features to prevent inadvertent write cycles resulting form Vcc powerup and power-down transitions or system noise. ## Low Vcc Write Inhibit To avoid initiation of a write cycle during Vcc power-up and power-down, a write cycle is locked out for Vcc less than 3.2 V (typically 3.7 V). If Vcc < VLKO, the command register is disabled and all internal program/erase circuits are disabled. Under this condition the device will reset to the read mode. Subsequent writes will be ignored until the Vcc level is greater than VLKO. It is the users responsibility to ensure that the control pins are logically correct to prevent unintentional writes when Vcc is above 3.2 V. #### Write Pulse "Glitch" Protection Noise pulses of less than 5 ns (typical) on $\overline{OE}$ , $\overline{CE}$ or $\overline{WE}$ will not initiate a write cycle. # Logical Inhibit Writing is inhibited by holding any one of $\overline{OE} = V_{IL}$ , $\overline{CE} = V_{IH}$ or $\overline{WE} = V_{IH}$ . To initiate a write cycle $\overline{CE}$ and $\overline{WE}$ must be a logical zero while $\overline{OE}$ is a logical one. #### Power-Up Write Inhibit Power-up of the device with $\overline{WE} = \overline{CE} = V_{IL}$ and $\overline{OE} = V_{IH}$ will not accept commands on the rising edge of $\overline{WE}$ . The internal state machine is automatically reset to the read mode on power-up. # **EMBEDDED ALGORITHMS** # Program Command Sequence (Address/Command): Figure 1. Embedded Programming Algorithm Table 9. Embedded Programming Algorithm | Bus Operations | Command Sequence | Comments | |------------------|------------------|--------------------------------------| | Standby (Note 1) | | | | Write | Program | Valid Address/Data Sequence | | Read | | Data Polling to Verify Programming | | Standby (Note 1) | | Compare Data Output to Data Expected | #### Note: 1. Device is either powered-down, erase inhibit or program inhibit. # **EMBEDDED ALGORITHMS** # Chip Erase Command Sequence (Address/Command): # Individual Sector/Multiple Sector Erase Command Sequence (Address/Command): Figure 2. Embedded Erase Algorithm Table 10. Embedded Erase Algorithm | Bus Operations | Command Sequence | Comments | |------------------|------------------|--------------------------------| | Standby (Note 1) | | | | Write | Erase | | | Read | | Data Polling to Verify Erasure | | Standby (Note 1) | | Compare Output to FFH | #### Note: 1. Device is either powered-down, erase inhibit or program inhibit. # Note: 1. DQ7 is rechecked even if DQ5 = "1" because DQ7 may change simultaneously with DQ5. Figure 3. Data Polling Algorithm DQ6 is rechecked even if DQ5 = "1" because DQ6 may stop toggling at the same time as DQ5 changing to "1". Figure 4. Toggle Bit Algorithm Figure 5. Maximum Negative Overshoot Waveform Figure 6. Maximum Positive Overshoot Waveform # **ABSOLUTE MAXIMUM RATINGS** | Storage Temperature Ceramic Packages65°C to +150°C Plastic Packages65°C to +125°C | |-----------------------------------------------------------------------------------| | Ambient Temperature with Power Applied55°C to +125°C | | Voltage with Respect to Ground<br>All pins except A9 (Note 1)2.0 V to +7.0 V | | Vcc (Note 1)2.0 V to +7.0 V | | A9 (Note 2)2.0 V to +14.0 V | | Output Short Circuit Current (Note 3) 200 mA | ## Notes: - 1. Minimum DC voltage on input or I/O pins is -0.5 V. During voltage transitions, inputs may overshoot $V_{\rm SS}$ to -2.0 V for periods of up to 20 ns. Maximum DC voltage on output and I/O pins is $V_{\rm CC}$ + 0.5 V. During voltage transitions, outputs may overshoot to $V_{\rm CC}$ + 2.0 V for periods up to 20 ns. - Minimum DC input voltage on A9 pin is -0.5 V. During voltage transitions, A9 may overshoot Vss to -2.0 V for periods of up to 20 ns. Maximum DC input voltage on A9 is +13.5 V which may overshoot to 14.0 V for periods up to 20 ns. - No more than one output shorted at a time. Duration of the short circuit should not be greater than one second. Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only; functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure of the device to absolute maximum rating conditions for extended periods may affect device reliability. # **OPERATING RANGES** | Commercial (C) Devices Case Temperature (Tc) 0°C to +70°C | |---------------------------------------------------------------| | Industrial (I) Devices Case Temperature (Tc)40°C to +85°C | | Extended (E) Devices Case Temperature (Tc)55°C to +125°C | | Military (M) Devices Case Temperature (Tc)55°C to +125°C | | Vcc Supply Voltages Vcc for Am29F200T/B-75 +4.75 V to +5.25 V | | Vcc for Am29F200T/B-90, 120 +4.50 V to +5.50 V | Operating ranges define those limits between which the functionality of the device is guaranteed. # DC CHARACTERISTICS TTL/NMOS Compatible | Parameter<br>Symbol | Parameter Description | Test Conditions | | Min | Max | Unit | |---------------------|-------------------------------------------|------------------------------------------------------------|-------|------|--------------------------|------| | lu l | Input Load Current | Vin = Vss to Vcc, Vcc = Vcc | Max | | ±1.0 | μΑ | | lιπ | A9 Input Load Current | Vcc = Vcc Max, A9 = 12.5 V | | | 50 | μА | | llo | Output Leakage Current | Vout = Vss to Vcc, Vcc = Vc | с Мах | | ±1.0 | μA | | ICC1 | Vcc Active Current (Note 1) | CE = VIL, OE = VIH | Byte | | 40 | mA | | | | | Word | | 50 | | | lcc2 | Vcc Active Current (Notes 2, 3) | CE = VIL, OE = VIH | | | 60 | mA | | łcc3 | Vcc Standby Current | Vcc = Vcc Max, CE = V <sub>IH</sub> , OE = V <sub>IH</sub> | | | 1.0 | mA | | VIL | Input Low Level | | | -0.5 | 0.8 | ٧ | | Viн | Input High Level | | | 2.0 | V <sub>CC</sub><br>+ 0.5 | ٧ | | ViD | Voltage for Autoselect and Sector Protect | Vcc = 5.0 V | | 11.5 | 12.5 | ٧ | | VoL | Output Low Voltage | IOL = 5.8 mA, VCC = VCC Min | | | 0.45 | ٧ | | Vон . | Output High Level | Ioн = -2.5 mA Vcc = Vcc Min | | 2.4 | | ٧ | | VLKO | Low Vcc Lock-Out Voltage | | | 3.2 | 4.2 | ٧ | ### Notes: - The Icc current listed includes both the DC operating current and the frequency dependent component (at 6 MHz). The frequency component typically is less than 2 mA/MHz, with OE at V<sub>IH</sub>. - 2. Icc active while Embedded Algorithm (program or erase) is in progress. - 3. Not 100% tested. # DC CHARACTERISTICS (continued) CMOS Compatible | Parameter<br>Symbol | Parameter Description | Test Conditions | | Min | Max | Unit | |---------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|-------------|------| | lu | Input Load Current | VIN = Vss to Vcc, Vcc = | Vcc Max | | ±1.0 | μА | | ILIT | A9 Input Load Current | Vcc = Vcc Max, A9 = 1 | 2.5 V | | 50 | μА | | lLO | Output Leakage Current | Vout = Vss to Vcc, Vcc | c = Vcc Max | | ±1.0 | μА | | lcc1 | Vcc Active Current (Note 1) | CE = VIL, OE = VIH | Byte | | 40 | mA | | | | | Word | | 50 | | | ICC2 | Vcc Active Current (Notes 2, 3) | CE = V <sub>IL</sub> , OE = V <sub>I</sub> H | | | 60 | mA | | lcc3 | Vcc Standby Current | Vcc = Vcc Max, $\overline{CE}$ = Vcc ± 0.5 V,<br>$\overline{OE}$ = ViH | | | 100 | μА | | VIL | Input Low Level | | | -0.5 | 0.8 | ٧ | | Vін | Input High Level | · | | 0.7x<br>Vcc | Vcc<br>+0.3 | V | | VID | Voltage for Autoselect and Sector Protect | Vcc = 5.0 V | | 11.5 | 12.5 | v | | Vol | Output Low Voltage | loL = 5.8 mA, Vcc = Vc | c Min | | 0.45 | v | | VoH <sub>1</sub> | 0 | I <sub>OH</sub> = -2.5 mA, V <sub>CC</sub> = V <sub>CC</sub> Min I <sub>OH</sub> = -100 μA, V <sub>CC</sub> = V <sub>CC</sub> Min | | 0.85<br>Vcc | | ٧ | | Vон2 | Output High Voltage | | | Vcc<br>-0.4 | | V | | VLKO | Low Vcc Lock-out Voltage | | | 3.2 | 4.2 | V | #### Notes: - 2. Icc active while Embedded Algorithm (program or erase) is in progress. - 3. Not 100% tested. The Icc current listed includes both the DC operating current and the frequency dependent component (at 6 MHz). The frequency component typically is less than 2 mA/MHz, with OE at VIH. # **AC CHARACTERISTICS** # **Read Only Operations Characteristics** | Parameter<br>Symbols | | | | | | | 100 | | | |----------------------|----------------|-------------------------------------------------------------------------|----------------------|-----|-----------------|-----------------|------------------|------------------|------| | JEDEC | Standard | Description | Test Setup | | -75<br>(Note 1) | -90<br>(Note 2) | -120<br>(Note 2) | -150<br>(Note 2) | Unit | | tavav | trc | Read Cycle Time (Note 4) | | Min | 70 | 90 | 120 | 150 | ns | | tavov | tacc | Address to Output Delay | CE = VIL<br>OE = VIL | Max | 70 | 90 | 120 | 150 | ns | | tELQV | tcE | Chip Enable to Output Delay | OE = VIL | Мах | 70 | 90 | 120 | 150 | ns | | tarav | toe | Output Enable to<br>Output Delay | | Max | 30 | 35 | 50 | 55 | ns | | †EHQZ | tDF | Chip Enable to Output<br>High Z (Note 3, 4) | | Max | 20 | 20 | 30 | 35 | ns | | tghaz | tDF | Output Enable to Output<br>High Z (Note 3, 4) | | Мах | 20 | 20 | 30 | 35 | ns | | taxox | tон | Output Hold Time From<br>Addresses, CE or OE,<br>Whichever Occurs First | | Min | 0 | 0 | 0 | 0 | ns | | | tReady | RESET pin low to read mode | | Max | 20 | 20 | 20 | 20 | μs | | | telfl<br>telfh | CE to BYTE switching low or high | | Мах | 5 | 5 | 5 | 5 | ns | #### Notes: 1. Test Conditions: Output Load: 1 TTL gate and 30 pF Input rise and fall times: 5 ns Input pulse levels: 0.0 V to 3.0 V Timing measurement reference level Input: 1.5 V Output: 1.5 V 2. Test Conditions: Output Load: 1 TTL gate and 100 pF Input rise and fall times: 20 ns Input pulse levels: 0.45 V to 2.4 V Timing measurement reference level Input: 0.8 and 2.0 V Output: 0.8 and 2.0 V - 3. Output driver disable time. - 4. Not 100% tested. Figure 7. Test Conditions # **AC CHARACTERISTICS** # Write/Erase/Program Operations | Paramet | er Symbols | | | | | | | | | |---------|------------|----------------------|--------------------------------------|-----|-----|-----|------|------|------| | JEDEC | Standard | Description | | | -70 | -90 | -120 | -150 | Unit | | tavav | twc | Write Cycle Time (3) | | | 70 | 90 | 120 | 150 | ns | | tavwl | tas | Address Setup | Time | Min | 0 | 0 | 0 | 0 | ns | | twLax | taн | Address Hold T | ïme | Min | 45 | 45 | 50 | 50 | ns | | tovwh | tos | Data Setup Tim | ie | Min | 30 | 45 | 50 | 50 | ns | | twhox | tDH | Data Hold Time | | Min | 0 | 0 | 0 | 0 | ns | | | toes | Output Enable | Setup Time (3) | Min | 0 | 0 | 0 | 0 | ns | | | | Output Enable | Read (3) | Min | 0 | 0 | 0 | 0 | ns | | | toeh | Hold Time | Toggle and Data Polling (3) | Min | 10 | 10 | 10 | 10 | ns | | tgHWL | tghwL | Read Recover | Time Before Write | Min | 0 | 0 | 0 | 0 | ns | | tELWL | tcs | CE Setup Time | | Min | 0 | 0 | 0 | 0 | ns | | twhEH | tсн | CE Hold Time | | Min | 0 | 0 | 0 | 0 | ns | | twLwH | twp | Write Pulse Wid | dth | Min | 35 | 45 | 50 | 50 | ns | | twhwL | twph | Write Pulse Wid | dth High | Min | 20 | 20 | 20 | 20 | ns | | twhwH1 | twHwH1 | Byte Programm | ing Operation | Тур | 16 | 16 | 16 | 16 | μs | | twhwh2 | twhwh2 | Erase Operatio | n (1) | Тур | 1.5 | 1.5 | 1.5 | 1.5 | sec | | | | Mir. 1 | | Max | 30 | 30 | 30 | 30 | sec | | | tvcs | Vcc Set Up Tim | ne (3) | Min | 50 | 50 | 50 | 50 | μs | | | tvLHT | Voltage Transit | ion Time (2, 3, 5) | Min | 4 | 4 | 4 | 4 | μs | | | twpp | Write Pulse Wid | ith (2) | Min | 100 | 100 | 100 | 100 | μs | | | tWPP2 | Write Pulse Wid | ith (5) | Min | 10 | 10 | 10 | 10 | ms | | | toesp | OE Setup Time | OE Setup Time to WE Active (2, 3, 5) | | 4 | 4 | 4 | 4 | μs | | Ī | tcsp | CE Setup Time | to WE Active (3) | Min | 4 | 4 | 4 | 4 | μs | | | tre | RESET Pulse V | Vidth | Min | 500 | 500 | 500 | 500 | ns | | | †FLQZ | BYTE Switching | Low to Output High Z (3, 4) | Мах | 20 | 30 | 30 | 30 | ns | | | tBUSY | Program/Erase | Valid to RD/BY delay (3) | Min | 30 | 35 | 50 | 55 | ns | # Notes: - 1. This does not include the preprogramming time. - 2. These timings are for Sector Protect operation. - 3. Not 100% tested. - 4. Output Driver Disable Time # **KEY TO SWITCHING WAVEFORMS** KS000010 # **SWITCHING WAVEFORMS** Figure 8. AC Waveforms for Read Operations # **SWITCHING WAVEFORMS** 1. PA is address of the memory location to be programmed. 18608A-16 - 2. PD is data to be programmed at byte address. - 3. $\overline{DQ7}$ is the output of the complement of the data written to the device. - 4. Dout is the output of the data written to the device. - Figure indicates last two bus cycles of four bus cycle sequence. - 6. These waveforms are for the x16 mode. **Figure 9. Program Operation Timings** #### Notes: - 1. SA is the sector address for Sector Erase. Addresses = don't care for Chip Erase. - 2. These waveforms are for the x16 mode. Figure 10. AC Waveforms Chip/Sector Erase Operations 1-68 5.0 Volt-only, Sector Erase Flash Memories # **SWITCHING WAVEFORMS** \*DQ7=Valid Data (The device has completed the Embedded operation). 18608A-18 Figure 11. AC Waveforms for Data Polling During Embedded Algorithm Operations Note: \*DQ6 stops toggling (The device has completed the Embedded operation). Figure 12. AC Waveforms for Toggle Bit During Embedded Algorithm Operations Figure 13. RY/BY Timing Diagram During Program/Erase Operations Figure 14. RESET/RY/BY Timing Diagram Figure 15. BYTE Timing Diagram for Read Operation Figure 16. BYTE Timing Diagram for Write Operations Figure 17. Sector Protection Algorithm # **SWITCHING WAVEFORMS** SAx = Sector Address for initial sector SAy = Sector Address for next sector Figure 18. AC Waveforms for Sector Protection Figure 19. Sector Unprotect Algorithm # **SWITCHING WAVEFORMS** Figure 20. AC Waveforms for Sector Unprotect # **AC CHARACTERISTICS** # Write/Erase/Program Operations # Alternate CE Controlled Writes | Parameter Symbols | | | | | - | | | | | |-------------------|----------|---------------------|----------------------------|-----|-----|-----|------|------|------| | JEDEC | Standard | Description | | | -70 | -90 | -120 | -150 | Unit | | tavav | twc | Write Cycle Time | (4) | Min | 70 | 90 | 120 | 150 | ns | | tavel | tas | Address Setup Tir | ne ' | Min | 0 | 0 | 0 | 0 | ns | | telax | tan | Address Hold Tim | е | Min | 45 | 45 | 50 | 50 | ns | | toveh | tos | Data Setup Time | | Min | 30 | 45 | 50 | 50 | ns | | tehox | ton | Data Hold Time | | Min | 0 | 0 | 0 | 0 | ns | | | toes | Output Enable Se | tup Time | Min | 0 | 0 | 0 | 0 | ns | | | | Output Enable | Read (4) | Min | 0 | 0 | 0 | 0 | ns | | | toeh | Hold Time (4) | Toggle and Data Polling | Min | 10 | 10 | 10 | 10 | ns | | <b>t</b> GHEL | tGHEL. | Read Recover Tir | ne Before Write | Min | 0 | 0 | 0 | 0 | ns | | twlel | tws | WE Setup Time | | Min | 0 | 0 | 0 | 0 | ns | | tenwn | twн | WE Hold Time | | Min | 0 | 0 | 0 | 0 | ns | | teleh | tcp | CE Pulse Width | | Min | 35 | 45 | 50 | 50 | ns | | 1EHEL | tcph | CE Pulse Width H | ligh | Min | 20 | 20 | 20 | 20 | ns | | twHwH1 | twhwh1 | Byte Programming | g Operation | Тур | 16 | 16 | 16 | 16 | μs | | twhwh2 | twHwH2 | Erase Operation ( | 1) | Тур | 1.5 | 1.5 | 1.5 | 1.5 | sec | | | | | | Мах | 30 | 30 | 30 | 30 | sec | | | tvcs | Vcc Set Up Time (4) | | Тур | 50 | 50 | 50 | 50 | μs | | | tRP | RESET Pulse Width | | Min | 500 | 500 | 500 | 500 | ns | | | tFLQZ | BYTE Switching L | ow to Output High Z (3, 4) | Мах | 20 | 30 | 30 | 30 | ns | | | tBUSY | Program/Erase Va | alid to RD/BY Delay (4) | Min | 30 | 35 | 50 | 55 | ns | ### Notes: - 1. This does not include the preprogramming time. - 2. These timings are for Sector Protect/Unprotect operations. - 3. This timing is only for Sector Unprotect. - 4. Not 100% tested. #### Notes: - 1. PA is address of the memory location to be programmed. - 2. PD is data to be programmed at byte address. - 3. DQ7 is the output of the complement of the data written to the device. - 4. Dout is the output of the data written to the device. - 5. Figure indicates last two bus cycles of four bus cycle sequence. - 6. These waveforms are for the x16 mode. Figure 21. Alternate CE Controlled Program Operation Timings # **ERASE AND PROGRAMMING PERFORMANCE** | | Limits | | | | | | |----------------------------|---------|-----------------|------------------|--------|----------------------------------------------|--| | Parameter | Min | Тур | Max | Unit | Comments | | | Chip and Sector Erase Time | | 1.5<br>(Note 1) | 30 | sec | Excludes 00H programming<br>prior to erasure | | | Byte Programming Time | | 16 | 1000<br>(Note 2) | μs | Excludes system-level overhead | | | Chip Programming Time | | 8.5<br>(Note 1) | 50 | sec | Excludes system-level overhead | | | Erase/Program Cycles | 100,000 | 1,000,000 | | Cycles | | | #### Notes: - 1. 25°C, 5 V Vcc, 100,000 cycles - 2. The Embedded Algorithms allow for 48 ms byte program time. # LATCHUP CHARACTERISTICS | | Min | Max | |---------------------------------------------------|---------|-------------| | Input Voltage with respect to Vss on all I/O pins | -1.0 V | Vcc + 1.0 V | | Vcc Current | -100 mA | +100 mA | Includes all pins except Vcc. Test conditions: Vcc = 5.0 V, one pin at a time. # **TSOP PIN CAPACITANCE** | Parameter<br>Symbol | Parameter Description | Test Setup | Тур | Max | Unit | |---------------------|-------------------------|------------|-----|-----|------| | Cin | Input Capacitance | VIN = 0 | 6 | 7.5 | рF | | Соит | Output Capacitance | Vour = 0 | 8.5 | 12 | рF | | CIN2 | Control Pin Capacitance | VIN = 0 | 8 | 10 | pF | #### Notes: - 1. Sampled, not 100% tested. - 2. Test conditions TA = 25°C, f = 1.0 MHz # SO PIN CAPACITANCE | Parameter<br>Symbol | Parameter Description | Test Setup | Тур | Max | Unit | |---------------------|-------------------------|------------|-----|-----|------| | CIN | Input Capacitance | ViN = 0 | 6 | 7.5 | pF | | Соит | Output Capacitance | Vout = 0 | 8.5 | 12 | ρF | | CIN2 | Control Pin Capacitance | VPP = 0 | 8 | 10 | pF | #### Notes: - 1. Sampled, not 100% tested. - 2. Test conditions TA = 25°C, f = 1.0 MHz # **DATA RETENTION** | Parameter | Test Conditions | Min | Unit | | |-------------------------------------|-----------------|-----|-------|--| | Minimum Pattern Data Retention Time | 150°C | 10 | Years | | | | 125°C | 20 | Years | | 5.0 Volt-only, Sector Erase Flash Memories