## Am29LV400T/Am29LV400B # 4 Megabit (524,288 x 8-Bit/262,144 x 16-Bit) CMOS 3.0 Volt-only Sector Architecture Flash Memory #### DISTINCTIVE CHARACTERISTICS ## ■ 2.7 to 3.6 volt, extended voltage range for read and write operations Minimizes system-level power requirements #### ■ Compatibility with JEDEC standards - Pinout and software compatible with singlepower-supply Flash - Superior inadvertent write protection #### ■ Package options - 48-pin TSOP - 44-pin SO #### ■ Minimum 100,000 write/erase cycles guaranteed #### ■ High performance Access times as fast as 100 ns #### **■** Flexible, sector architecture - One 16 Kbyte, two 8 Kbyte, one 32 Kbyte, and seven 64 Kbyte sectors - Any combination of sectors can be erased; supports full chip erase. #### **■** Embedded Erase algorithm Automatically pre-programs and erases the chip or specified sector #### ■ Embedded Program algorithm Automatically writes and verifies data at specified address #### ■ Data Polling and toggle bit Detects program and erase cycle completion #### ■ Ready/Busy output (RY/BY) Hardware method for detection of program or erase cycle completion #### ■ Erase Suspend/Resume Supports reading data from or programming data to a sector not being erased #### Low current consumption (typical values at 5 MHz) - 10 mA active read current - 20 mA program/erase current #### ■ Advanced power management - 1 µA typical in standby mode - 1 µA typical in automatic sleep mode #### ■ Sector protection Hardware method that disables any combination of sectors from write or erase operations. Implemented using standard PROM programming equipment. #### ■ Hardware reset pin (RESET) - Resets the internal state machine to the read mode - Top or bottom boot block configurations available #### **GENERAL DESCRIPTION** The Am29LV400 is an 4 Mbit, 3.0 Volt-only Flash memory organized as 512 Kbytes of 8 bits each. For flexible erase and program capability, the 512 Kbits of data is divided into 11 sectors of one 16 Kbyte, two 8 Kbyte, one 32 Kbyte, and seven 64 Kbytes. The x8 data appears on DQ0–DQ7; the x16 data appears on DQ0-DQ15. The Am29LV400 is offered in a 48-pin TSOP and a 44-pin SO package. This device is designed to be programmed in-system with the standard system 3.0 volt $V_{CC}$ supply. The device can also be reprogrammed in standard EPROM programmers. The standard Am29LV400 offers access times of 100 ns, 120 ns, and 150 ns, allowing high speed microprocessors to operate 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 Am29LV400 is entirely command set-compatible with the JEDEC single-power-supply Flash standard. Commands are written to the command register using standard microprocessor write timings. Register contents serve as input to an internal state-machine that 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 other Flash or EPROM devices. The Am29LV400 is programmed by executing the program command sequence. This invokes the Embedded Program Algorithm, which is an internal algorithm that automatically times the program pulse widths and verifies proper cell margin. The device is erased by executing the erase command sequence. This invokes 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. This device also features a sector erase architecture. This allows for sectors of memory to be erased and reprogrammed without affecting the data contents of other sectors. A sector is typically erased and verified within 1.0 second. The Am29LV400 is fully erased when shipped from the factory. The Am29LV400 device also features hardware sector protection, implemented via external programming equipment, which disables both program and erase operations in any combination of the memory sectors. The Erase Suspend feature enables the user to pause the erase operation, for any period of time, to read data from or program data to a sector that was not being erased. Thus, true background erase can be achieved. The device features 3.0 volt, single-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_{CC}$ detector automatically inhibits write operations during power transitions. The end of program or erase is detected by the RY/ $\overline{BY}$ pin. $\overline{Data}$ Polling of DQ7, or by the Toggle Bit (DQ6). Once the end of a program or erase cycle has been completed, the device automatically resets to the read mode. The Am29LV400 also has a hardware RESET pin. When this pin is driven low, execution of any Embedded Program or Erase Algorithm will be terminated. The internal state machine is then be reset into the read mode. Resetting the device will enable the system's microprocessor to read the boot-up firmware from the Flash memory. AMD's Flash technology combines years of Flash memory manufacturing experience to produce the highest levels of quality, reliability and cost effectiveness. The Am29LV400 memory electrically erases all bits within a sector simultaneously via Fowler-Nordheim tunneling. The bytes are programmed one byte at a time using the EPROM programming mechanism of hot electron injection. ## **PRODUCT SELECTOR GUIDE** | Family Part Number | | Am29LV400T/Am29LV400B | | |------------------------------------------------------|------|-----------------------|------| | Ordering Part Number V <sub>CC</sub> = 2.7 V - 3.6 V | -100 | -120 | -150 | | Max access time (ns) | 100 | 120 | 150 | | CE access time (ns) | 100 | 120 | 150 | | OE access time (ns) | 40 | 50 | 55 | ### **BLOCK DIAGRAM** #### **CONNECTION DIAGRAMS** Standard 48-Pin TSOP **Reverse 48-Pin TSOP** ### **CONNECTION DIAGRAMS (continued)** 20514B-3 #### **PIN CONFIGURATION** A0-A17 = 18 addresses DQ0-DQ14 = 15 data inputs/outputs DQ15/A-1 = DQ15 data input/output, A-1 address mux BYTE = Selects 8-bit or 16-bit mode CE= Chip enableOE= Output enableWE= Write enable RESET = Hardware reset pin, active low RY/BY = Ready/Busy output $V_{CC}$ = +3.0 volt single power supply (+20%/-10% for -100, -120, -150) $V_{SS}$ = Device ground NC = Pin not connected internally #### LOGIC SYMBOL #### **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 the elements below. | Valid Combinations | | | | | | | | | |--------------------|-------------------------------------|--|--|--|--|--|--|--| | AM29LV400T/B-100 | EC, FC, SC | | | | | | | | | AM29LV400T/B-120 | EC, EI, EE, EEB, | | | | | | | | | AM29LV400T/B-150 | FC, FI, FE, FEB,<br>SC, 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 1. Am29LV400 User Bus Operations ( $\overline{BYTE} = V_{IH}$ ) | Operation | CE | ŌĒ | WE | Α0 | <b>A</b> 1 | A6 | A9 | DQ0-DQ15 | RESET | |-------------------------------------------|----|-----------------|---------|----|------------|----|-----------------|-------------|-----------------| | Autoselect, Manufacturer Code<br>(Note 1) | L | L | Н | L | L | L | V <sub>ID</sub> | Code | Н | | Autoselect Device Code (Note 1) | L | L | Н | Н | L | L | $V_{ID}$ | Code | Н | | Read | L | L | Н | A0 | A1 | A6 | A9 | RD | Н | | Standby | Н | Х | Х | Х | Х | Х | Х | HIGH Z | Н | | Output Disable | L | Н | Н | Х | Х | Х | Х | HIGH Z | Н | | Write | L | Н | L | A0 | A1 | A6 | A9 | PD (Note 2) | Н | | Enable Sector Protect (Note 3) | L | V <sub>ID</sub> | Pulse/H | L | Н | L | $V_{ID}$ | Code | Н | | Verify Sector Protect (Note 4) | L | L | Н | L | Н | L | $V_{ID}$ | Code | Н | | Temporary Sector Unprotect | Х | Х | Х | Х | Х | Х | Х | Х | V <sub>ID</sub> | | Reset | Х | Х | Х | Х | Х | Х | Х | HIGH Z | L | Table 2. Am29LV400 User Bus Operations ( $\overline{BYTE} = V_{|L}$ ) | Operation | CE | ŌĒ | WE | Α0 | <b>A</b> 1 | A6 | A9 | DQ0-DQ7 | DQ8-DQ15 | RESET | |----------------------------------------------|----|-----------------|---------|----|------------|----|-----------------|-------------|----------|-----------------| | Autoselect,<br>Manufacturer Code<br>(Note 1) | L | L | н | L | L | L | V <sub>ID</sub> | Code | HIGH Z | Н | | Autoselect, Device<br>Code (Note 1) | L | L | Н | Н | L | L | V <sub>ID</sub> | Code | HIGH Z | Н | | Read | L | L | Н | A0 | A1 | A6 | A9 | RD | HIGH Z | Н | | Standby | Н | Х | Х | Х | Х | Х | Х | HIGH Z | HIGH Z | Н | | Output Disable | L | Н | Н | Х | Х | Х | Х | HIGH Z | HIGH Z | Н | | Write | L | Н | L | A0 | A1 | A6 | A9 | PD (Note 2) | HIGH Z | Н | | Enable Sector Protect (Note 3) | L | V <sub>ID</sub> | Pulse/H | L | Н | L | V <sub>ID</sub> | Code | HIGH Z | Н | | Verify Sector Protect<br>(Note 4) | L | L | Н | L | Н | L | V <sub>ID</sub> | Code | HIGH Z | Н | | Temporary Sector<br>Unprotect | Х | Х | Х | Х | Х | Х | Х | Х | HIGH Z | V <sub>ID</sub> | | Reset | Х | Х | Х | Х | Х | Х | Х | HIGH Z | HIGH Z | L | #### Legend: $L = V_{IL}$ , $H = V_{IH}$ , $V_{ID} = 12.0 \pm 0.5$ Volts, X = Don't care. See "DC Characteristics" on page 28 for voltage levels. PD = program data, RD = read data. Refer to Table 4 on page 10 for more information. #### Notes: - 1. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 6 on page 13. - 2. Refer to Table 4 for valid PD during a write operation. - 3. Set $V_{CC} = 3.0 \text{ Volts} \pm 10\%$ . - 4. Refer to "Sector Protection" on page 12. #### **USER BUS OPERATIONS** #### **Read Mode** The Am29LV400 has three control functions which must be satisfied in order to obtain data at the outputs: - CE is the power control and should be used for device selection (CE = V<sub>II</sub>) - OE is the output control and should be used to gate data to the output pins if the device is selected (OE = V<sub>II</sub>) - WE remains at V<sub>IH</sub> Address access time ( $T_{ACC}$ ) is equal to the delay from stable addresses to valid output data. The chip enable access time ( $T_{CE}$ ) is the delay from stable addresses and stable $\overline{CE}$ to valid data at the output pins. The output enable access time ( $T_{OE}$ ) is the delay from the falling edge of $\overline{OE}$ to valid data at the output pins (assuming the addresses have been stable at least $T_{ACC}-T_{OE}$ time). #### Standby Mode The Am29LV400 accomodates low standby power consumption by applying the following voltages to the $\overline{\text{CE}}$ and $\overline{\text{RESET}}$ pins. $I_{CC3}$ for CMOS compatible I/Os (current consumption <5 $\mu\text{A}$ max.) is enabled when a CMOS logic level '1' (V $_{CC}$ $\pm$ 0.3 V) is applied to the $\overline{\text{CE}}$ control pin with $\overline{\text{RESET}}$ = V $_{CC}$ $\pm$ 0.3 V. While in the $I_{CC3}$ standby mode, the data I/O pins remain in the high impedance state independent of the voltage level applied to the $\overline{\text{OE}}$ input. See the DC Characteristics section for more details on Standby Modes. Deselecting $\overline{CE}$ ( $\overline{CE}$ , $\overline{RESET}$ = $V_{CC}$ ± 0.3 V) puts the device into the $I_{CC3}$ standby mode. If the device is deselected during an Embedded Algorithm<sup>TM</sup> operation, it will continue to draw active power ( $I_{CC2}$ ), prior to entering the standby mode, until the operation is complete. When the device is again selected ( $\overline{CE} = V_{IL}$ ), active operations occur in accordance with the AC timing specifications. #### **Automatic Sleep Mode** Advanced power management features such as the automatic sleep mode minimize Flash device energy consumption. This is extremely important in battery-powered applications. The Am29LV400 automatically enables the low-power, automatic sleep mode when addresses remain stable for 300 ns. Automatic sleep mode is independent of the $\overline{\text{CE}}$ , $\overline{\text{WE}}$ , and $\overline{\text{OE}}$ control signals. Typical sleep mode current draw is 1 $\mu\text{A}$ (for CMOS-compatible operation). Standard address access timings provide new data when addresses are changed. While in sleep mode, output data is latched and always available to the system. #### **Output Disable** If the $\overline{\text{OE}}$ input is at a logic high level (V<sub>IH</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. The intent is to allow programming equipment to automatically match the device to be programmed with its corresponding programming algorithm. The Autoselect command may also be used to check the status of write-protected sectors (see Table 3). This mode is functional over the entire temperature range of the device. To activate this mode, the programming equipment must force VID (11.5–12.5 Volts) on address pin A9. Two identifier bytes may then be sequenced from the device outputs by toggling address A0 from $V_{IL}$ to $V_{IH}$ . All addresses are don't cares except A0, A1, and A6 see Table 3. The manufacturer and device codes may also be read via the command register, for instances when the Am29LV400 is erased or programmed in a system without access to high voltage on the A9 pin. The command sequence is illustrated in Table 6 on page 13. Byte 0 (A0 = $V_{IL}$ ) represents the manufacture's code and byte 1 (A0 = $V_{IH}$ ) the device identifier code. For the Am29LV400 these two bytes are given in Table 3. All identifiers for manufacturer and device will exhibit odd parity with DQ7 defined as the parity bit. In order to read the proper device codes when executing Autoselect, A1 must be $V_{IL}$ (see Table 3). For device identification in word mode (BYTE = $V_{IH}$ ), DQ9 and DQ13 are equal to '1' and DQ8, DQ10-12, DQ14, and DQ15 are equal to '0'. If $\overline{\text{BYTE}} = \text{V}_{\text{IH}}$ (for word mode), the device code will be 22B9H (for top boot block) or 22BAH (for bottom boot block). If BYTE = $\text{V}_{\text{IL}}$ (for byte mode), the device code will be B9H (for top boot block) or BAH (for bottom boot block). In order to determine which sectors are write protected, A1 must be at $V_{IH}$ while running through the sector addresses; if the selected sector is protected, a logical '1' will be output on DQ0 (DQ0 = 1). Table 3. Autoselect/Sector Protection Codes | Туре | Mode | A12-A17 | A6 | <b>A</b> 1 | Α0 | Code<br>(HEX) | DQ8-DQ15 | DQ<br>7 | DQ<br>6 | DQ<br>5 | DQ<br>4 | DQ<br>3 | DQ<br>2 | DQ<br>1 | DQ<br>0 | |---------------------------------------|------|-------------------------|----|------------|----|---------------|-------------------------------------|---------|---------|---------|---------|---------|---------|---------|---------| | Manufacturer Code:<br>AMD | | Х | L | L | L | 01H | High-Z | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | 29LV400 Device<br>(Top Boot Block) | Word | Х | L | L | Н | 22B9H | DQ9 = 1,<br>DQ13 = 1,<br>Others = 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | | | Byte | Х | | | | В9Н | High-Z | | | | | | | | | | 29LV400 Device<br>(Bottom Boot Block) | Word | Х | L | L | Н | 22BAH | DQ9 = 1,<br>DQ13 = 1,<br>Others = 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | | | Byte | Х | | | | BAH | High-Z | | | | | | | | | | Sector Protection | | Set Sector<br>Addresses | L | Н | L | 01H* | Х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | X = Don't care. <sup>\*</sup> Outputs 01H at protected sector addresses. Table 4. Sector Address Tables (Am29LV400T) | | A17 | A16 | A15 | A14 | A13 | A12 | Sector Size | (x8)<br>Address Range | (x16)<br>Address Range | |------|-----|-----|-----|-----|-----|-----|------------------------|-----------------------|------------------------| | SA0 | 0 | 0 | 0 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 00000h-0FFFFh | 00000h-07FFFh | | SA1 | 0 | 0 | 1 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 10000h-1FFFFh | 08000h-0FFFFh | | SA2 | 0 | 1 | 0 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 20000h-2FFFFh | 10000h-17FFFh | | SA3 | 0 | 1 | 1 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 30000h-3FFFFh | 18000h-1FFFFh | | SA4 | 1 | 0 | 0 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 40000h-4FFFFh | 20000h-27FFFh | | SA5 | 1 | 0 | 1 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 50000h-5FFFFh | 28000h-2FFFFh | | SA6 | 1 | 1 | 0 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 60000h-6FFFFh | 30000h-37FFFh | | SA7 | 1 | 1 | 1 | 0 | Х | Х | 32 Kbytes<br>16 Kwords | 70000h-77FFFh | 38000h-3BFFFh | | SA8 | 1 | 1 | 1 | 1 | 0 | 0 | 8 Kbytes<br>4 Kwords | 78000h-79FFFh | 3C000h-3CFFFh | | SA9 | 1 | 1 | 1 | 1 | 0 | 1 | 8 Kbytes<br>4 Kwords | 7A000h-7BFFFh | 3D000h-3DFFFh | | SA10 | 1 | 1 | 1 | 1 | 1 | Х | 16 Kbytes<br>8 Kwords | 7C000h-7FFFFh | 3E000h-3FFFFh | #### Note. The address range is A18:A-1 if in byte mode ( $\overline{BYTE} = V_{IL}$ ). The address range is A18:A0 if in word mode ( $\overline{BYTE} = V_{IH}$ ). Table 5. Sector Address Tables (Am29LV400B) | | A17 | A16 | A15 | A14 | A13 | A12 | Sector Size | (x8)<br>Address Range | (x16)<br>Address Range | |------|-----|-----|-----|-----|-----|-----|------------------------|-----------------------|------------------------| | SA0 | 0 | 0 | 0 | 0 | 0 | Х | 16 Kbytes<br>8 Kwords | 00000h-03FFFh | 00000h-01FFFh | | SA1 | 0 | 0 | 0 | 0 | 1 | 0 | 8 Kbytes<br>4 Kwords | 04000h-05FFFh | 02000h-02FFFh | | SA2 | 0 | 0 | 0 | 0 | 1 | 1 | 8 Kbytes<br>4 Kwords | 06000h-07FFFh | 03000h-03FFFh | | SA3 | 0 | 0 | 0 | 1 | X | Х | 32 Kbytes<br>16 Kwords | 08000h-0FFFFh | 04000h-07FFFh | | SA4 | 0 | 0 | 1 | X | Х | Х | 64 Kbytes<br>32 Kwords | 10000h-1FFFFh | 08000h-0FFFFh | | SA5 | 0 | 1 | 0 | X | X | Х | 64 Kbytes<br>32 Kwords | 20000h-2FFFFh | 10000h-17FFFh | | SA6 | 0 | 1 | 1 | X | X | Х | 64 Kbytes<br>32 Kwords | 30000h-3FFFFh | 18000h-1FFFFh | | SA7 | 1 | 0 | 0 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 40000h-4FFFFh | 20000h-27FFFh | | SA8 | 1 | 0 | 1 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 50000h-5FFFFh | 28000h-2FFFFh | | SA9 | 1 | 1 | 0 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 60000h-6FFFFh | 30000h-37FFFh | | SA10 | 1 | 1 | 1 | Х | Х | Х | 64 Kbytes<br>32 Kwords | 70000h-7FFFFh | 38000h-3FFFFh | #### Note: The address range is A18:A-1 if in byte mode ( $\overline{BYTE} = V_{IL}$ ). The address range is A18:A0 if in word mode ( $\overline{BYTE} = V_{IH}$ ). #### Write Device erasure and programming are accomplished via the command register. The command register is written 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{CE}$ or $\overline{WE}$ , whichever occurs later, while data is latched on the rising edge of the $\overline{CE}$ or $\overline{WE}$ pulse, whichever occurs first. Standard microprocessor write timings are used. Refer to AC Write Characteristics and the Erase/Programming Waveforms for specific timing parameters. #### **Sector Protection** Sectors of the Am29LV400 may be hardware protected at the user's factory with external programming equipment. The protection circuitry will disable both program and erase functions for the protected sectors, making the protected sectors read-only. Requests to program or erase a protected sector will be ignored by the device. If the user attempts to write to a protected sector, $\overline{DATA}$ Polling will be activated for about 1 $\mu s$ ; the device will then return to read mode, with data from the protected sector unchanged. If the user attempts to erase a protected sector, Toggle Bit will be activated for about 50 $\mu s$ ; the device will then return to read mode, without having erased the protected sector. It is 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 address A17–A12 represents the sector address, will produce a logical '1' at DQ0 for a protected sector. #### **Temporary Sector Unprotect** The sectors of the Am29LV400 may be temporarily unprotected by raising the $\overline{RESET}$ pin to 12.0 Volts (V<sub>ID</sub>). During this mode, formerly protected sectors can be programmed or erased with standard command sequences by selecting the appropriate byte or sector addresses. Once the $\overline{RESET}$ pin goes to V<sub>IH</sub>, all the previously protected sectors will be protected again. #### **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 6 on page 13 defines the valid register command sequences. Note that the Erase Suspend (B0H) and Erase Resume (30H) commands are valid only while the Sector Erase operation is in progress. #### Read/Reset Command 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 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 Characteristics section for the specific timing parameters. 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. #### **Autoselect Command** Flash memories are intended for use in applications where the local CPU alters memory contents. As such, manufacturer and device codes must be accessible while the device resides in the target system. The Am29LV400 contains an autoselect command operation that provides device information and sector protection status to the system. 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 manufacturer code of 01H. A read cycle from address XX01H returns the device code B9H/BAH for x8 configuration or 22B9H/22BAH for x16 configuration (see Table 3 on page 9). All manufacturer and device codes will exhibit odd parity with the MSB of the lower byte (DQ7) defined as the parity bit. Scanning the sector addresses (A12, A13, A14, A15, A16 and A17) while (A6, A1, A0) = (0, 1, 0) will produce a logical '1' code at device output DQ0 for a write protected sector (See Table 3). To terminate the Autoselect operation, it is necessary to write the read/reset command sequence into the register. Table 6. Am29LV400 Command Definitions (Notes 1-7) | _ | | | First I<br>Write C | | | Second Bus<br>Write Cycle | | Bus<br>Sycle | Fourth<br>Write C | | Fifth I<br>Write C | | Sixth Write C | | |-----------------------------------------|---------------|-----------------|--------------------|--------|-------|---------------------------|-------|--------------|-------------------|------|--------------------|------|---------------|------| | Comman<br>Sequence (N | | Cycles<br>Req'd | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | | Reset/Read<br>(Notes 2, 3, 7) | | 1 | XXXXH | F0H | RA | RD | | | | | | | | | | Autoselect | Word | 4 | 5555H | ААН | 2AAAH | 55H | 5555H | 90H | | | | | | | | Autoselect | Byte | 4 | AAAAH | AAN | 5555H | ээп | AAAAH | 9011 | | | | | | | | Program | Word | 4 | 5555H | | 2AAAH | | 5555H | 4011 | PA | PD | | | | | | (Notes 2, 3) | Byte | 4 | AAAAH | AH AAH | 5555H | 55H | AAAAH | A0H<br>AH | PA | PD | | | | | | Ohin France | Word | | 5555H | | 2AAAH | | 5555H | 0011 | 5555H | | 2AAAH | 5511 | 5555H | 4011 | | Chip Erase | Byte | 6 | AAAAH | AAH | 5555H | 55H | AAAAH | 80H | AAAAH | AAH | 5555H | 55H | AAAAH | 10H | | Sector Erase | Word | | 5555H | | 2AAAH | 55H | 5555H | 0011 | 5555H | | 2AAAH | 5511 | SA | 2011 | | (Notes 2, 4) | Byte | 6 | AAAAH | AAH | 5555H | DDH | AAAAH | 80H | AAAAH | AAH | 5555H | 55H | SA | 30H | | Sector Erase<br>Suspend<br>(Notes 4, 5) | Word<br>/Byte | 1 | XXXXH | вон | | | | | | | | | | | | Sector Erase<br>Resume<br>(Note 6) | Word<br>/Byte | 1 | XXXXH | 30H | | | | | | | | | | | #### Notes: - 1. Bus operations are defined in Tables 1 and 2. - 2. 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 to the sector to be erased. The combination of the higher order address (A17-A12) will uniquely select any sector. - 3. RD = Data read from location RA during a read operation. - PD = Data to be programmed at location PA. Data is latched on the rising edge of $\overline{WE}$ . - 4. Read and Byte program functions non-erasing sectors are allowed in the Erase Suspend mode. - 5. Erase can be suspended during sector erase with Addr (don't care), Data (30H). - 6. Erase can be resumed after suspend with Addr (don't care), Data (30H). - 7. Read/Reset command can be used at any point during the command sequence to return the device to the read mode and reset the internal state machine. - 8. Address bits A17 through A13 = X; X= don't care. #### **Word/Byte Programming** The device can be programmed on a word or byte basis. Programming is a four-bus-cycle operation. There are two "unlock" write cycles. These are followed by the program command and address/data write cycles. Addresses are latched on the falling edge of $\overline{\text{CE}}$ or $\overline{\text{WE}}$ , whichever occurs later, while the data is latched on the rising edge of $\overline{\text{CE}}$ or $\overline{\text{WE}}$ , whichever occurs first. The rising edge of $\overline{\text{CE}}$ or $\overline{\text{WE}}$ , whichever occurs first, initiates programming using the Embedded Program Algorithm. Upon executing the write command, the system is **not** required to provide further controls or timing. The device will automatically provide adequate internally generated program pulses and verify the programmed cell margin. The status of the Embedded Program Algorithm operation can be determined three ways: - DATA Polling of DQ7 - Checking the status of the toggle bit DQ6 - Checking the status of the RY/BY pin Any commands written to the chip during the Embedded Program Algorithm will be ignored. If a hardware reset occurs during a programming operation, the data at that location will be corrupted. 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 will cause the device to exceed programming time limits (DQ5 = 1) or result in an apparent success according to the data polling algorithm. However, reading the device after executing the Read/Reset operation will show that the data is still '0'. Only erase operations can convert '0's to '1's. Figure 6 illustrates the Embedded Program Algorithm, using typical command strings and bus operations. #### **Chip Erase** Chip erase is a six bus cycle operation. There are two "unlock" write cycles, followed by writing the erase "set up" command. Two more "unlock" write cycles are followed by the chip erase command. Chip erase does **not** require the user to preprogram the device to all '0's prior to erase. Upon executing the Embedded Erase Algorithm command sequence, the device automatically programs and verifies the entire memory to an all zero data pattern prior to electrical erase. The system is not required to provide any controls or timings during these operations. The Embedded Erase Algorithm erase begins on the rising edge of the last $\overline{\text{WE}}$ or $\overline{\text{CE}}$ (whichever occurs first) pulse in the command sequence. The status of the Embedded Erase Algorithm operation can be determined three ways: - DATA Polling of DQ7 - Checking the status of the toggle bit DQ6 - Checking the status of the RY/BY pin Figure 7 illustrates the Embedded Erase Algorithm, using a typical command sequence and bus operations. #### **Sector Erase** Sector erase is a six bus cycle operation. There are two "unlock" writes. These are followed by writing the erase "set up" command. Two more "unlock" writes are followed by the Sector Erase command (30H). The sector address (any address location within the desired sector) is latched on the falling edge of $\overline{\text{WE}}$ or $\overline{\text{CE}}$ (whichever occurs last) while the command (30H) is latched on the rising edge of $\overline{\text{WE}}$ or $\overline{\text{CE}}$ (whichever occurs first). Multiple sectors can be specified for erase by writing the six bus cycle operation as described above and then following it by additional writes of the Sector Erase command to addresses of other sectors to be erased. The time between Sector Erase command writes must be less than $80~\mu s$ , otherwise that command will not be accepted. 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 µs from the rising edge of the last WE (or CE) will initiate the execution of the Sector Erase command(s). If another falling edge of the $\overline{WE}$ (or $\overline{CE}$ ) occurs within the 80 $\mu s$ time-out window, the timer is reset. During the 80 µs window, any command other than Sector Erase or Erase Suspend written to the device will reset the device back to Read mode. Once the 80 µs window has timed out, only the Erase suspend command is recognized. Note that although the Reset command is not recognized in the Erase Suspend mode, the device is available for read or program operations in sectors that are not erase suspended. The Erase Suspended and Erase Resume commands may be written as often as required during a sector erase operation. Hence, once erase has begun, it must ultimately complete unless Hardware Reset is initiated. Loading the sector erase registers may be done in any sequence and with any number of sectors (0 to 10). Sector erase does **not** require the user to program the device prior to erase. The device automatically preprograms all memory locations, within sectors to be erased, prior to electrical erase. When erasing a sector or sectors, the remaining unselected sectors or the write protected sectors are unaffected. The system is not required to provide any controls or timings during sector erase operations. The Erase Suspend and Erase Resume commands may be written as often as required during a sector erase operation. Automatic sector erase operations begin on the rising edge of the $\overline{WE}$ (or $\overline{CE})$ pulse of the last sector erase command issued, and once the 80 $\mu s$ time-out window has expired. The status of the sector erase operation can be determined three ways: - DATA Polling of DQ7 - Checking the status of the toggle bit DQ6 - Checking the status of the RY/BY pin Further status of device activity during the sector erase operation can be determined using toggle bits DQ2and DQ3. Figure 7 illustrates the Embedded Erase Algorithm, using a typical command sequence and bus operations. #### **Erase Suspend** The Erase Suspend command allows the user to interrupt a Sector Erase operation and then perform data read or programs in a sector not being erased. This command is applicable **only** during the Sector Erase operation, which includes the time-out period for Sector Erase. The Erase Suspend command will be ignored if written during the execution of the Chip Erase operation or Embedded Program Algorithm (but will reset the chip if written improperly during the command sequences.) Writing the Erase Suspend command during the Sector Erase time-out results in immediate termination of the time-out period and suspension of the erase operation. Once in Erase Suspend, the device is available for read (note that in the Erase Suspend mode, the Reset/Read command is not required for read operations and is ignored) or program operations in sectors not being erased. Any other command written during the Erase Suspend mode will be ignored, except for the Erase Resume command. Writing the Erase Resume command resumes the sector erase operation. The addresses are "don't cares" when writing the Erase Suspend or Erase Resume command. When the Erase Suspend command is written during a Sector Erase operation, the chip will take between 0.1 $\mu s$ and 20 $\mu s$ to actually suspend the operation and go into erase suspended read mode (pseudo-read mode), at which time the user can read or program from a sector that is not erase suspended. Reading data in this mode is the same as reading from the standard read mode, except that the data must be read from sectors that have not been erase suspended. Successively reading from the erase-suspended sector while the device is in the erase-suspend-read mode will cause DQ2 to toggle. Polling DQ2 on successive reads from a given sector provides the system the ability to determine if a sector is in Erase Suspend. After entering the erase-suspend-read mode, the user can program the device by writing the appropriate command sequence for Byte Program. This program mode is known as the erase suspend-program mode. Again, programming in this mode is the same as programming in the regular Byte Program mode, except that the data must be programmed to sectors that are not erase suspended. Successively reading from the erase suspended sector while the device is in the erase suspend-program mode will cause DQ2 to toggle. Completion of the erase suspend operation can be determined two ways: - Checking the status of the toggle bit DQ2 - Checking the status of the RY/BY pin 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. However, another Erase Suspend command can be written after the device has resumed sector erase operations. When the erase operation has been suspended, the device defaults to the erase-suspend-read mode. Reading data in this mode is the same as reading from the standard read mode except that the data must be read from sectors that have not been erase-suspended. 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** #### **Address Sensitivity of Write Status Flags** Detailed in Table 7 are all the status flags that can be used to check the status of the device for current mode operation. During Sector Erase, the part provides the status flags automatically to the I/O ports. The information on DQ2 is address sensitive. This means that if an address from an erasing sector is consecutively read, then the DQ2 bit will toggle. However, DQ2 will not toggle if an address from a non-erasing sector is consecutively read. This allows the user to determine which sectors are erasing and which are not. Once Erase Suspend is entered, address sensitivity still applies. If the address of a non-erasing sector (that is, one available for read) is provided, then stored data can be read from the device. If the address of an erasing sector (that is, one unavailable for read) is applied, the device will output its status bits. Confirmation of status bits can be done by doing consecutive reads to toggle DQ2, which is active throughout the Embedded Erase mode, including Erase Suspend. In order to effectively use DATA Polling to determine if the device has entered into erase-suspended mode, it is necessary to apply a sector address from a sector being erased. | | | Status | DQ7 | DQ6 | DQ5 | DQ3 | DQ2 | RY/BY | |-------------------------|-----------------------------|-----------------------------|------|-----------|------|------|--------------------|-------| | | Byte and | Word Programming | DQ7 | Toggle | 0 | 0 | No Toggle | 0 | | | Program/E | Program/Erase in Auto-Erase | | Toggle | 0 | 1 | (Note 1) | 0 | | In Progress | Erase | Erase Sector Address | 1 | No Toggle | 0 | 0 | Toggle<br>(Note 1) | 1 | | 10g.000 | Suspend<br>Mode | Non-Erase Sector Address | Data | Data | Data | Data | Data<br>(Note 2) | 1 | | | Program i | Program in Erase Suspend | | Toggle | 0 | 0 | 1<br>(Note 2) | 0 | | | Byte and \ | Word Programming | DQ7 | Toggle | 1 | 0 | No Toggle | 0 | | Exceeded<br>Time Limits | Program/Erase in Auto-Erase | | 0 | Toggle | 1 | 1 | (Note 3) | 0 | | | Program i | Program in Erase Suspend | | Toggle | 1 | 0 | No Toggle | 0 | Table 7. Hardware Sequence Flags #### Notes: - 1. DQ2 can be toggled when the sector address applied is that of an erasing or erase suspended sector. Conversely, DQ2 cannot be toggled when the sector address applied is that of a non-erasing or non-erase suspended sector. DQ2 is therefore used to determine which sectors are erasing or erase suspended and which are not. - 2. These status flags apply when outputs are read from the address of a non-erase-suspended sector. - 3. If DQ5 is high (exceeded timing limits), successive reads from a problem sector will cause DQ2 to toggle. #### DQ7: Data Polling The Am29LV400 features DATA Polling as a method to indicate to the host system that the embedded algorithms are in progress or completed. During the Embedded Program Algorithm, an attempt to read the device will produce the compliment 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. Note that just at the instant when DQ7 switches to true data, the other bits, DQ6-DQ0, may not yet be true data. However, they will all be true data on the next read from the device. Please note that Data Polling (DQ7) may give an inaccurate result when an attempt is made to write to a protected sector. During an 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 DQ7. For chip erase, the $\overline{DATA}$ Polling is valid (DQ7 = 1) after the rising edge of the sixth $\overline{WE}$ pulse in the six write pulse sequence. For sector erase, the $\overline{DATA}$ Polling is valid after the last rising edge of the sector erase $\overline{WE}$ pulse. $\overline{DATA}$ Polling must be performed at sector addresses within any of the sectors being erased and not a sector that is within a protected sector. Otherwise, the status may not be valid. Just prior to the completion of Embedded Algorithm operations, DQ7 may change asynchronously while the output enable $(\overline{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 operations and DQ7 has valid data, DQ0–DQ6 may still provide write operation status. The valid data on DQ0–DQ7 can be read on the next successive read attempt. The DATA Polling feature is only active during the Embedded Programming Algorithm, Embedded Erase Algorithm, Erase Suspend, erase suspend-program mode, or sector erase time-out (see Table 7). If the user attempts to write to a protected sector, $\overline{DATA}$ Polling will be activated for about 1 $\mu s$ ; the device will then return to read mode, with data from the protected sector unchanged. If the user attempts to erase a protected sector, Toggle Bit will be activated for about 50 $\mu s$ ; the device will then return to read mode, without having erased the protected sector. See Figure 8 for the $\overline{\text{DATA}}$ Polling timing specifications and diagrams. #### **DQ6: Toggle Bit** The Am29LV400 also features a "Toggle Bit" as a method to indicate to the host system whether the embedded algorithms are in progress or completed. During an Embedded Program or Erase Algorithm, successive attempts to read data from the device will result in DQ6 toggling between one and zero. Once the Embedded Program or Erase Algorithm is completed, DQ6 will stop toggling and valid data can 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. During Chip erase, the Toggle Bit is valid after the rising edge of the sixth WE pulse in the six-write-pulse sequence. During 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 Erase time-out. Either $\overline{\text{CE}}$ or $\overline{\text{OE}}$ toggling will cause DQ6 to toggle. If the user attempts to write to a protected sector, $\overline{\text{DATA}}$ Polling will be activated for about 1 $\mu s$ ; the device will then return to read mode, with data from the protected sector unchanged. If the user attempts to erase a protected sector, Toggle Bit will be activated for about 50 $\mu s$ ; the device will then return to read mode, without having erased the protected sector. #### **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' indicating that the program or erase cycle was not successfully completed. Write operation status and reset command are the only operating functions under this condition. The device will draw active power under this condition. The DQ5 failure condition will also appear if the user attempts to write a data '1' to a bit that has already been programmed to a data '0'. In this case, the DQ5 failure condition is not guaranteed to happen, since the device was incorrectly used. Please note that programming a data '0' to a data '1' should never be attempted, and only erasure should be used for this purpose. If programming to a data '1' is attempted, the device should be reset. If the DQ5 failure condition is observed while in Sector Erase mode (that is, exceeded timing limits), then DQ2 can be used to determine which sector had the problem. This is especially useful when multiple sectors have been loaded for erase. #### **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 (DQ7) and Toggle Bit (DQ6) are also valid after the first sector erase command sequence. If DATA Polling or the Toggle Bit indicates the device has been written with a valid Sector 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 the DATA Polling or Toggle Bit. If DQ3 is low ('0'), the device will accept additional sector erase commands. To be certain the command has been accepted, the software should check the status of DQ3 following each Sector Erase command. If DQ3 was high on the second status check, the command may not have been accepted. It is recommended that the user guarantee the time between sector erase command writes be less than 80 $\mu s$ by disabling the processor interrupts just for the duration of the Sector Erase (30H) commands. This approach will ensure that sequential sector erase command writes will be written to the device while the sector erase timer window is still open. #### DQ2: Toggle Bit 2 This toggle bit, along with DQ6, can be used to determine whether the device is in the Embedded Erase Algorithm or in Erase Suspend. Successive reads from the erasing sector will cause DQ2 to toggle during the Embedded Erase Algorithm. If the device is in the erase suspend-read mode, successive reads from the erase-suspended sector will cause DQ2 to toggle. When the device is in the erase suspend-program mode, successive reads from the byte address of the non-erase suspended sector will indicate a logic '1' at the DQ2 bit. Note that a sector which is selected for erase is not available for read in Erase Suspend mode. Other sectors which are not selected for Erase can be read in Erase Suspend. DQ6 is different from DQ2 in that DQ6 toggles only when the standard program or erase, or erase suspend-program operation is in progress. If the DQ5 failure condition is observed while in Sector Erase mode (that is, exceeded timing limits), the DQ2 toggle bit can give extra information. In this case, the normal function of DQ2 is modified. If DQ5 is at logic '1', then DQ2 will toggle with consecutive reads only at the sector address that caused the failure condition. DQ2 will toggle at the sector address where the failure occurred and will not toggle at other sector addresses. #### RY/BY: Ready/Busy Pin The Am29LV400 provides a RY/BY open-drain output pin as a way to indicate to the host system that the Em- bedded Algorithms are either in progress or have been 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/ $\overline{BY}$ pin is low, the device will not accept any additional program or erase commands with the exception of the Erase Suspend command. If the Am29LV400 is placed in an Erase Suspend mode, the RY/ $\overline{BY}$ output will be high. For programming, the RY/ $\overline{BY}$ is valid (RY/ $\overline{BY}$ =0) after the rising edge of the fourth $\overline{WE}$ pulse in the four write pulse sequence. For chip erase, the RY/ $\overline{BY}$ is valid after the rising edge of the sixth $\overline{WE}$ pulse in the six write pulse sequence. For sector erase, the RY/ $\overline{BY}$ is also valid after the rising edge of the sixth $\overline{WE}$ pulse. Since the RY/ $\overline{BY}$ pin is an open-drain output, several RY/ $\overline{BY}$ pins can be tied together in parallel with a pull-up resistor to V<sub>CC</sub>. | Table 8. Tog | igle Bit | : Status | |--------------|----------|----------| |--------------|----------|----------| | Mode | DQ7 | DQ6 | DQ2 | |------------------------------------------------------|--------------|---------|------------| | Program | DQ7 | Toggles | 1 | | Erase | 0 | Toggles | Toggles | | Erase-Suspend Read (Note 1) (Erase-Suspended Sector) | 1 | 1 | Toggles | | Erase Suspend Program | DQ7 (Note 2) | Toggles | 1 (Note 2) | #### Notes: - 1. These status flags apply when outputs are read from a sector that has been erase suspended. - 2. These status flags apply when outputs are read from the byte/word addresses of the non-erase suspended sector. Figure 1. RY/BY Timing Diagram #### **RESET:** Hardware Reset Pin The RESET pin is an active low signal. A logic '0' on this pin will force the device out of any mode that is currently executing back to the reset state. This allows a system reset to take effect immediately without having to wait for the device to finish a long execution cycle. To avoid a potential bus contention during a system reset, the device is isolated from the data I/O bus by tri-stating the data output pins for the duration of the RESET pulse. If RESET is asserted during a program or erase operation, the RY/BY pin will remain low until the reset operation is internally complete. This will require between 1 $\mu$ s and 20 $\mu$ s. Hence the RY/BY pin can be used to signal that the reset operation is complete. Otherwise, allow for the maximum reset time of 20 $\mu$ s. If RESET is asserted when a program or erase operation is not executing (RY/BY pin is high), the reset operation will be complete within 500 ns. Asserting RESET during a program or erase operation leaves erroneous data stored in the address locations being operated on at the time of device reset. These locations need updating after the reset operation is complete. See Figure 2 for timing specifications. The device enters $I_{CC4}$ standby mode (<1 $\mu$ A) when $V_{SS}\pm 0.3$ V is applied to the $\overline{RESET}$ pin. The device can enter this mode at any time, regardless of the logical condition of the $\overline{CE}$ pin. Furthermore, entering $I_{CC4}$ during a program or erase operation leaves erroneous data in the address locations being operated on at the time of the $\overline{RESET}$ pulse. These locations need updating after the device resumes standard operations. After the $\overline{RESET}$ pin goes high, a minimum latency period of 50 ns must occur before a valid read can take place. 20514B-6 Figure 2. Device Reset During a Program or Erase Operation Figure 3. Device Reset During Read Mode ### **Word/Byte Configuration** The BYTE pin of the Am29LV800 is used to set device data I/O pins in the byte or word configuration. If the BYTE pin is set at logic '1', the device is in word configuration, DQ0–15 are active and controlled by $\overline{\text{CE}}$ and $\overline{\text{OE}}$ (see Figure 4). If the BYTE pin is set at logic '0', the device is in byte configuration, and only data I/O pins DQ0–7 are active and controlled by CE and OE. The data I/O pins DQ8–14 are tri-stated. In byte mode, the DQ15 pin is used as an input for the LSB (A-1) address function (see Figure 5). 20514B-8 Figure 4. Timing Diagram for Word Mode Configuration Figure 5. Timing Diagram for Byte Mode Configuration #### **Data Protection** The Am29LV400 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 to the read mode. Also, with its control register architecture, alteration of the memory contents only occurs after successful completion of the command sequences. The Am29LV400 incorporates several features to prevent inadvertent write cycles resulting from $V_{\rm CC}$ power-up and power-down transitions or system noise. ### Low V<sub>CC</sub> Write Inhibit To avoid initiation of a write cycle during $V_{CC}$ power-up and power-down, a write cycle is locked out for $V_{CC}$ less than $V_{LKO}$ (lock-out voltage). If $V_{CC} < V_{LKO}$ , the command register is disabled and all internal program/erase circuits are disabled. Under this condition, the device will reset to read mode. Subsequent writes will be ignored until the $V_{CC}$ level is greater than $V_{LKO}$ . It is the user's responsibility to ensure that the control levels are logically correct when $V_{CC}$ is above $V_{LKO}$ (unless the RESET pin is asserted). #### Write Pulse "Glitch" Protection Noise pulses of less than 5 ns (typical) on $\overline{OE}$ , $\overline{CE}$ , or $\overline{WE}$ will not change the command registers. #### **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, $\overline{CE}$ and $\overline{WE}$ must be 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 read mode on power up. # **EMBEDDED ALGORITHMS Embedded Program Algorithm** Figure 6. Embedded Program Algorithm | Bus Operation | Command Sequence | Comments | |---------------|------------------|--------------------------------------| | Standby* | | | | Write | Program | Valid Address/Data | | Read | | DATA Polling to Verify Programming | | Standby* | | Compare Data Output to Data Expected | <sup>\*</sup> Device is either powered-down, erase inhibit, or program inhibit. ## **Embedded Erase Algorithm** Figure 7. Embedded Erase Algorithm | Bus Operation | Command Sequence | Comments | |---------------|------------------|--------------------------------| | Standby | | | | Write | Erase | | | Read | | DATA Polling to Verify Erasure | | Standby | | Compare Output to FFH | ## **Data Polling Algorithm** Figure 8. Data Polling Algorithm ## **Toggle Bit Algorithm** Figure 9. Toggle Bit Algorithm ## **Temporary Sector Unprotect Algorithm** #### Notes: - 1. All protected sectors unprotected. - 2. All previously protected sectors are protected once again. Figure 10. Temporary Sector Unprotect Algorithm #### **ABSOLUTE MAXIMUM RATINGS** | Storage Temperature Plastic Packages65°C to +150°C | |-------------------------------------------------------------------------------------| | Ambient Temperature with Power Applied65°C to +125°C | | Voltage with Respect to Ground All pins except A9, OE and RESET | | (Note 1)0.5 V to V <sub>CC</sub> +0.5 V | | V <sub>CC</sub> (Note 1)0.5 V to +3.6 V | | A9, $\overline{\text{OE}}$ , and $\overline{\text{RESET}}$ (Note 2)0.5 V to +13.0 V | | Output Short Circuit Current (Note 3) 200 mA | | Notes: | #### Minimum DC voltage on input or I/O pins is -0.5 V. During voltage transitions, input or I/O pins may undershoot V<sub>SS</sub> to -2.0 V for periods of up to 20 ns. Maximum DC voltage on input or I/O pins is V = 10.5 V. During voltage on input or I/O pins is $V_{CC}$ +0.5 V. During voltage transitions, input or I/O pins may overshoot to $V_{CC}$ +2.0 V for periods up to 20 ns. See Figure 12 and Figure 13. - Minimum DC input voltage on pins A9, OE, and RESET is -0.5 V. During voltage transitions, A9, OE, and RESET may undershoot V<sub>SS</sub> to -2.0 V for periods of up to 20 ns. Maximum DC input voltage on pin A9 is +12.5 V which may overshoot to 14.0 V for periods up to 20 ns. See Figure 12 and Figure 13. - No more than one output may be shorted to ground at a time. Duration of the short circuit should not be greater than one second. - 4. 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 data sheet is not implied. Exposure of the device to absolute maximum rating conditions for extended periods may affect device reliability. #### **OPERATING RANGES** | Commercial (C) Devices | |----------------------------------------------------------------------| | Ambient Temperature (T <sub>A</sub> )0°C to +70°C | | Industrial (I) Devices | | Ambient Temperature (T <sub>A</sub> )40°C to +85°C | | Extended (E) Devices | | Ambient Temperature (T <sub>A</sub> )55°C to +125°C | | V <sub>CC</sub> Supply Voltages | | V <sub>CC</sub> for Am29LV400T/B<br>-100, -120, -150 +2.7 V to 3.6 V | Operating ranges define those limits between which the functionality of the device is guaranteed. #### **DC CHARACTERISTICS** ## **CMOS Compatible** | Parameter<br>Symbol | Parameter Description | Test Conditions | | Min | Max | Unit | | |---------------------|----------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------|-----------------------|------|--| | I <sub>LI</sub> | Input Load Current | $V_{IN} = V_{SS}$ to $V_{CC}$ ,<br>$V_{CC} = V_{CC \text{ max}}$ | | | ±1.0 | μΑ | | | I <sub>LIT</sub> | A9 Input Load Current | $V_{CC} = V_{CC \text{ max}}$ ; A9 = | 13.0 V | | 35 | μΑ | | | I <sub>LO</sub> | Output Leakage Current | $V_{OUT} = V_{SS}$ to $V_{CC}$ ,<br>$V_{CC} = V_{CC \text{ max}}$ | | | ±1.0 | μΑ | | | | // Active Current (Note 1) | CE _ V OF V | Byte | | 30 | | | | I <sub>CC1</sub> | V <sub>CC</sub> Active Current (Note 1) | $\overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | Word | | 35 | mA | | | I <sub>CC2</sub> | V <sub>CC</sub> Active Current (Notes 2 and 4) | $\overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | | | 35 | mA | | | I <sub>CC3</sub> | V <sub>CC</sub> Standby Current | $V_{CC} = V_{CC \text{ max}};$ $\overline{CE}, \overline{RESET} = V_{CC} \pm 0$ | ).3 V | | 5 | μΑ | | | I <sub>CC4</sub> | V <sub>CC</sub> Reset Current | $V_{CC} = V_{CC \text{ max}}; RESET = V_{SS} \pm 0.3 \text{ V}$ | | | 5 | μΑ | | | I <sub>CC5</sub> | Automatic Sleep Mode (Note 3) | $V_{IH} = V_{CC} \pm 0.3 \text{ V}; V_{0.3} \text{ V}$ | $V_{IH} = V_{CC} \pm 0.3 \text{ V}; V_{IL} = V_{SS} \pm 0.3 \text{ V}$ | | 5 | μΑ | | | V <sub>IL</sub> | Input Low Voltage | | | -0.5 | 0.8 | V | | | V <sub>IH</sub> | Input High Voltage | | | 0.7 x V <sub>CC</sub> | V <sub>CC</sub> + 0.3 | V | | | V <sub>ID</sub> | Voltage for Autoselect and Temporary<br>Sector Unprotect | V <sub>CC</sub> = 5 V | | 11.5 | 12.5 | V | | | V <sub>OL</sub> | Output Low Voltage | $I_{OL}$ = 5.8 mA, $V_{CC}$ = $V_{CC min}$ | | | 0.45 | V | | | V <sub>OH1</sub> | Output High Voltage | I <sub>OH</sub> = -2.0 mA, V <sub>CC</sub> = | V <sub>CC min</sub> | 0.85 V <sub>CC</sub> | | V | | | V <sub>OH2</sub> | Output High Voltage | $I_{OH} = -100 \mu A, V_{CC} =$ | V <sub>CC min</sub> | V <sub>CC</sub> -0.4 | | | | | $V_{LKO}$ | Low V <sub>CC</sub> Lock-Out Voltage (Note 4) | | | 2.3 | 2.5 | V | | $V_{CC} = 2.7 \text{ to } 3.6 \text{ V}.$ #### Notes: - 1. The $I_{CC}$ 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 $\overline{OE}$ at $V_{IH}$ . - 2. $I_{CC}$ active while Embedded Erase or Embedded Program is in progress. - 3. Automatic sleep mode enables the low power mode when addresses remain stable for 300 ns. Typical sleep mode current is $1 \mu A$ . - 4. Not 100% tested. ### **AC CHARACTERISTICS** ## **Read-Only Operations Characteristics** | Parameter Symbols | | | | | -1000 | -120 | -150 | | |-------------------|--------------------|----------------------------------------------------------------------------|----------------------------------------------|-----|----------|----------|----------|------| | JEDEC | Standard | Description | Test Setup | | (Note 1) | (Note 1) | (Note 1) | Unit | | t <sub>AVAV</sub> | t <sub>RC</sub> | Read Cycle Time (Note 3) | | Min | 100 | 120 | 150 | ns | | t <sub>AVQV</sub> | t <sub>ACC</sub> | Address to Output Delay | CE = V <sub>IL</sub><br>OE = V <sub>IL</sub> | Max | 100 | 120 | 150 | ns | | t <sub>ELQV</sub> | t <sub>CE</sub> | Chip Enable to Output Delay | OE = V <sub>IL</sub> | Max | 100 | 120 | 150 | ns | | t <sub>GLQV</sub> | t <sub>OE</sub> | Output Enable to Output Delay | | Max | 40 | 50 | 55 | ns | | t <sub>EHQZ</sub> | t <sub>DF</sub> | Chip Enable to Output High Z (Notes 2, 3) | | Max | 30 | 30 | 40 | ns | | t <sub>GHQZ</sub> | t <sub>DF</sub> | Output Enable to Output High Z (Notes 2, 3) | | Max | 30 | 30 | 40 | ns | | t <sub>AXQX</sub> | t <sub>OH</sub> | Output Hold Time From Addresses, CE or OE, Whichever Occurs First (Note 3) | | Min | 0 | 0 | 0 | ns | | | t <sub>Ready</sub> | RESET Pin Low to Read Mode (Note 3) | | Max | 20 | 20 | 20 | μs | #### Notes: 1. Test Conditions 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. Output Driver Disable Time - 3. Not 100% tested. Figure 11. Test Conditions ## **AC CHARACTERISTICS** ## Write (Erase/Program) Operations | Paramet | er Symbols | | | | | | | | | | |--------------------|--------------------------------------|------------------------------|------------------------|------------------|-----|------|------|------|------|--| | JEDEC | Standard | Description | | | | -100 | -120 | -150 | Unit | | | t <sub>AVAV</sub> | t <sub>WC</sub> | Write Cycle Time | (Note 2) | | Min | 100 | 120 | 150 | ns | | | t <sub>AVWL</sub> | t <sub>AS</sub> | Address Setup T | ime | | Min | 0 | 0 | 0 | ns | | | t <sub>WLAX</sub> | t <sub>AH</sub> | Address Hold Tin | Address Hold Time | | | 50 | 50 | 65 | ns | | | t <sub>DVWH</sub> | t <sub>DS</sub> | Data Setup Time | | | Min | 50 | 50 | 65 | ns | | | t <sub>WHDX</sub> | t <sub>DH</sub> | Data Hold Time | | | Min | 0 | 0 | 0 | ns | | | | t <sub>OES</sub> | Output Enable So | etup Time (Note 2) | | Min | 0 | 0 | 0 | ns | | | | 4 | Output Enable | Read (Note 2) | | Min | 0 | 0 | 0 | ns | | | | toeh | Hold Time | Toggle and Data | Polling (Note 2) | Min | 10 | 10 | 10 | ns | | | t <sub>GHWL</sub> | t <sub>GHWL</sub> | Read Recovery (OE High to WE | Time Before Write Low) | | Min | 0 | 0 | 0 | ns | | | t <sub>ELWL</sub> | t <sub>CS</sub> | CE Setup TIme | | | Min | 0 | 0 | 0 | ns | | | t <sub>WHEH</sub> | t <sub>CH</sub> | CE Hold Time | CE Hold Time | | | | 0 | 0 | ns | | | t <sub>WLWH</sub> | t <sub>WP</sub> | Write Pulse Widtl | Write Pulse Width | | | | 50 | 65 | ns | | | t <sub>WHDL</sub> | t <sub>WPH</sub> | Write Pulse Widtl | n High | | Min | 30 | 30 | 35 | ns | | | | | NHWH1 Programming Op | Byte | Byte | Тур | 9 | 9 | 9 | | | | t <sub>WHWH1</sub> | <sup>t</sup> WHWH1 | Programming Op | eration | Word | Тур | 11 | 11 | 11 | μs | | | t <sub>WHWH2</sub> | t <sub>WHWH2</sub> | Sector Erase Op | eration (Note 1) | | Тур | 1 | 1 | 1 | sec | | | | t <sub>VCS</sub> | V <sub>CC</sub> Setup TIme | | | Min | 50 | 50 | 50 | μs | | | | t <sub>RB</sub> | Write Recovery T | ime from RY/BY | | Min | 0 | 0 | 0 | ns | | | | t <sub>RH</sub> | RESET High Tim | e Before Read | | Min | 50 | 50 | 50 | ns | | | | t <sub>RPD</sub> | RESET To Powe | r Down Time | | Min | 20 | 20 | 20 | μs | | | | t <sub>BUSY</sub> | Program/Erase V | alid to RY/BY Dela | ay | Min | 90 | 90 | 90 | ns | | | | t <sub>ELFL</sub> /t <sub>ELFH</sub> | CE to BYTE Swit | ching Low or High | | Max | 5 | 5 | 5 | ns | | | | t <sub>FLQZ</sub> | BYTE Switching | Low to Output HIGH Z | | Min | 30 | 40 | 40 | ns | | | | t <sub>FHQV</sub> | BYTE Switching | High to Output Active | | Min | 30 | 40 | 40 | ns | | | | t <sub>VIDR</sub> | Rise TIme to V <sub>ID</sub> | V <sub>ID</sub> | | Min | 500 | 500 | 500 | ns | | | | t <sub>RP</sub> | RESET Pulse Wi | dth | | Min | 500 | 500 | 500 | ns | | | | t <sub>RRB</sub> | RESET Low to R | Y/BY High | | Max | 20 | 20 | 20 | μs | | | | t <sub>RSP</sub> | RESET Setup Tir | me for Temporary | Sector Unprotect | Min | 4 | 4 | 4 | μs | | #### Notes - 1. The duration of the program or erase operation is variable and is calculated in the internal algorithms. - 2. Note 100% tested. #### **KEY TO SWITCHING WAVEFORMS** KS000010-PAL Figure 12. Maximum Negative Overshoot Waveform 20514B-16 Figure 13. Maximum Positive Overshoot Waveform 20514B-18 Figure 14. AC Waveforms for Read Operations #### Notes: - 1. DQ7 is the output of the complement of the data written to the device. - 2. $D_{OUT}$ is the output of the data written to the device. - 3. PA is the address of the memory location to b programmed. - 4. PD is the data to be programmed at the byte address. - 5. Illustration shows the last two cycles of a two-bus-cycle sequence. Figure 15. AC Waveforms for Program Operations #### Notes: 1. SA is the sector address for Sector Erase. Addresses = don't care for Chip Erase. 20514B-20 Figure 16. AC Waveforms for Chip/Sector Erase Operations #### Note: \* DQ7 = Valid Data (The device has completed the embedded operation.) Figure 17. AC Waveforms for Data Polling During Embedded Algorithm Operations #### Note: DQ6 stops toggling (The device has completed the embedded operation.) 20514B-22 Figure 18. AC Waveforms for Toggle Bit During Embedded Algorithm Operations #### Note: DQ7 = Valid Data (The device has completed the embedded operation.) 20514B-23 Figure 19. RY/BY Timing Diagram During Program/Erase Operations Figure 20. RESET Timing Diagram 20514B-25 Figure 21. BYTE Timing Diagram for Read Operation Figure 22. BYTE Timing Diagram for Write Operations Figure 23. Temporary Sector Unprotect Timing Diagram ## **AC CHARACTERISTICS** ## Write (Erase/Program) Operations ### Alternate **CE** Controlled Writes | Paramet | er Symbols | | | | | | | | | |------------------------------------------------|--------------------|-----------------------------------------------------|----------------------------------|---------------|-----|------|------|------|------| | JEDEC | Standard | Description | | | | -100 | -120 | -150 | Unit | | t <sub>AVAV</sub> | t <sub>WC</sub> | Write Cycle Time | (Note 2) | | Min | 100 | 120 | 150 | ns | | t <sub>AVWL</sub> | t <sub>AS</sub> | Address Setup T | ime | | Min | 0 | 0 | 0 | ns | | t <sub>ELAX</sub> | t <sub>AH</sub> | Address Hold Tin | ne | | Min | 45 | 50 | 50 | ns | | t <sub>DVEH</sub> | t <sub>DS</sub> | Data Setup Time | | | Min | 50 | 50 | 50 | ns | | t <sub>EHDX</sub> | t <sub>DH</sub> | Data Hold Time | | | Min | 0 | 0 | 0 | ns | | | t <sub>OES</sub> | Output Enable So | etup Time | | Min | 0 | 0 | 0 | ns | | | | Output Enable Read (Note 2) | | | Min | 0 | 0 | 0 | ns | | | | | Toggle and Data Polling (Note 2) | | | 10 | 10 | 10 | ns | | t <sub>GHEL</sub> | t <sub>GHEL</sub> | Read Recovery Time Before Write (OE High to WE Low) | | | Min | 0 | 0 | 0 | ns | | t <sub>WLEL</sub> | t <sub>WS</sub> | WE Setup Time | WE Setup Time | | | 0 | 0 | 0 | ns | | t <sub>EHWH</sub> | t <sub>WH</sub> | WE Hold Time | | | Min | 0 | 0 | 0 | ns | | t <sub>ELEH</sub> | t <sub>CP</sub> | CE Pulse Width | | | Min | 50 | 50 | 50 | ns | | t <sub>EHEL</sub> | t <sub>CPH</sub> | CE Pulse Width I | High | | Min | 30 | 30 | 35 | ns | | t <sub>WHWH1</sub> t <sub>WHWH1</sub> Programi | | | | Byte | Тур | 9 | 9 | 9 | | | | | Programming Operation | | Word | Тур | 11 | 11 | 11 | μs | | t <sub>WHWH2</sub> | t <sub>WHWH2</sub> | Sector Erase Op | Sector Erase Operation (Note 1) | | Тур | 1 | 1 | 1 | sec | | | t <sub>FLQZ</sub> | BYTE Switching | Low to Output HIG | GH Z (Note 2) | Min | 30 | 30 | 30 | ns | #### Notes: The duration of the program or erase operation is variable and is calculated in the internal algorithms. - 1. Does not include the preprogramming time. - 2. 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. $\overline{DQ7}$ is the output of the complement of the data written to the device. - 4. $D_{OUT}$ is the output of the data written to the device. - 5. Figure indicates last two bus cycles of four bus cycle sequence. Figure 24. Alternate CE Controlled Write Operation Timings #### **ERASE AND PROGRAMMING PERFORMANCE** | | | Limits | | | | |-----------------------|--------------|--------------|---------------------|--------|-------------------------------------------| | Parameter | | Тур | Max | Unit | Comments | | Sector Erase Time | | 1 (Note 1) | 15<br>(Notes 2,3) | S | Excludes 00H programming prior to erasure | | Byte Programming Time | | 9 (Note 1) | 300<br>(Notes 4,5) | μs | Excludes 00H programming prior to erasure | | Word Programming Time | | 11 (Note 1) | 360<br>(Notes 2,3) | μs | Excludes system level overhead (Note 4) | | Byte<br>Mode | | 4.5 (Note 1) | 13.5<br>(Notes 2,3) | S | Excludes system level overhead (Note 4) | | Chip Programming Time | Word<br>Mode | 2.9 (Note 1) | 8.7<br>(Notes 2,3) | s | Excludes system level overhead (Note 4) | | Erase/Program Cycles | | 100,000 | 1,000,000 | cycles | | #### Notes: - 1. 25°C, 3 V V<sub>CC</sub>, 100,000 cycles. Programming typicals assume checkerboard pattern. - 2. Although Embedded Algorithms allow for a longer chip program and erase time, the actual time will be considerably less since most bytes program or erase significantly faster than the worst case byte. - 3. Under worst case condition of 90°C, $V_{CC} = 2.7 \text{ V}$ , 100,000 cycles. - 4. System-level overhead is defined as the time required to execute the four bus cycle command necessary to program each byte. In the pre-programming step of the Embedded Erase Algorithm, all bytes are programmed to 00H before erasure. - 5. The Embedded Algorithms allow for approximately 1.0 ms byte program time. DQ5 = "1" only after a byte takes the theoretical maximum time to program. A minimal number of bytes may require significantly more programming pulses than the typical byte. The majority of the bytes will program within one or two pulses. This is demonstrated by the Typical and Maximum programming times listed above. #### LATCHUP CHARACTERISTICS | | Min | Max | |---------------------------------------------------------------------------------------------------------|---------|-------------------------| | Input voltage with respect to V <sub>SS</sub> on all pins except I/O pins (including A9, OE, and RESET) | -1.0 V | 13.0 V | | Input voltage with respect to V <sub>SS</sub> on all I/O pins | -1.0 V | V <sub>CC</sub> + 1.0 V | | V <sub>CC</sub> Current | -100 mA | +100 mA | Includes all pins except $V_{CC}$ . Test conditions: $V_{CC} = 3.0 \text{ V}$ , one pin at a time. ## PIN CAPACITANCE, TSOP AND SO PACKAGES (Notes 1-2) | Parameter<br>Symbol | Parameter Description | Test Setup | Тур | Max | Unit | |---------------------|-------------------------|----------------------|-----|-----|------| | C <sub>IN</sub> | Input Capacitance | V <sub>IN</sub> = 0 | 6 | 7.5 | pF | | C <sub>OUT</sub> | Output Capacitance | V <sub>OUT</sub> = 0 | 8.5 | 12 | pF | | C <sub>IN2</sub> | Control Pin Capacitance | V <sub>IN</sub> = 0 | 7.5 | 9 | pF | #### Notes: - 1. Sampled, not 100% tested. - 2. Test conditions $T_A = 25$ °C, f = 1.0 MHz. ### **PHYSICAL DIMENSIONS\*** #### **TS 048** ## 48-Pin (measured in millimeters) <sup>\*</sup> For reference only. BSC is an ANSI standard for Basic Space Centering. ## **PHYSICAL DIMENSIONS (continued)** ## **TSR048** ## 48-Pin (measured in millimeters) ## **PHYSICAL DIMENSIONS (continued)** ### **SO 044** ### 44-Pin (measured in millimeters) #### Trademarks Copyright © 1996 Advanced Micro Devices, Inc. All rights reserved. AMD and the AMD logo are registered trademarks of Advanced Micro Devices, Inc. Embedded Erase and Embedded Program are trademarks of Advanced Micro Devices, Inc. Product names used in this publication are for identification purposes only and may be trademarks of their respective companies.