## Am29F400AT/Am29F400AB 4 Megabit (524,288 x 8-Bit/262,144 x 16-Bit) CMOS 5.0 Volt-only, Sector Erase Flash Memory ## **DISTINCTIVE CHARACTERISTICS** ## ■ 5.0 V $\pm$ 10% for read and write operations - Minimizes system level power requirements ## **■** Compatible with JEDEC-standards - Pinout and software compatible with single-power-supply flash - Superior inadvertent write protection ## ■ Package options - 44-pin SO - 48-pin TSOP ## ■ Minimum 100,000 write/erase cycles guaranteed ## ■ High performance 60 ns maximum access time ## ■ Sector erase architecture - One 16 Kbyte, two 8 Kbytes, one 32 Kbyte, and seven 64 Kbytes - Any combination of sectors can be erased. Also supports full chip erase. ## ■ Sector protection Hardware method that disables any combination of sectors from write or erase operations. Implemented using standard PROM programming equipment. ## **■** Embedded Erase<sup>™</sup> Algorithms Automatically preprograms and erases the chip or any sector ## ■ Embedded Program<sup>™</sup> Algorithms - Automatically programs and verifies data at specified address - Data Polling and Toggle Bit feature for detection of program or 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 a sector not being erased ## **■** Low power consumption - 20 mA typical active read current for Byte Mode - 28 mA typical active read current for Word Mode - 30 mA typical program/erase current # Enhanced power management for standby mode 1 μA typical standby current ## **■** Boot Code Sector Architecture - T = Top sector - B = Bottom sector ## **■** Hardware RESET pin Resets internal state machine to the read mode ## **GENERAL DESCRIPTION** The Am29F400A is a 4 Mbit, 5.0 Volt-only Flash memory organized as 512 Kbytes of 8 bits each or 256 Kwords of 16 bits each. The 4 Mbits of data is divided into 11 sectors of one 16 Kbyte, two 8 Kbyte, one 32 Kbyte, and seven 64 Kbytes, for flexible erase capability. The 8 bits of data will appear on DQ0–DQ7 or 16 bits on DQ0–DQ15. The Am29F400A 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 Volt $\rm V_{CC}$ supply. 12.0 Volt $\rm V_{PP}$ is not required for program or erase operations. The device can also be reprogrammed in standard EPROM programmers. The standard Am29F400A offers access times of 60 ns, 70 ns, 90 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 Am29F400A 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 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 Volt Flash or EPROM devices. The Am29F400A 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. 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. 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.5 seconds. The Am29F400A is erased when shipped from the factory. The Am29F400A device also features hardware sector protection. This feature will disable both program and erase operations in any combination of eleven sectors of memory. AMD has implemented an Erase Suspend feature that enables the user to put erase on hold for any period of time to read data from a sector that was not being erased. Thus, true background erase can be achieved. The device features single 5.0 Volt 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 Am29F400A also has a hardware RESET pin. When this pin is driven low, execution of any Embedded Program Algorithm or Embedded Erase Algorithm will be terminated. The internal state machine will then be reset into the read mode. The RESET pin may be tied to the system reset circuitry. Therefore, if a system reset occurs during the Embedded Program Algorithm or Embedded Erase Algorithm, the device will be automatically reset to the read mode and will have erroneous data stored in the address locations being operated on. These locations will need rewriting after the Reset. 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 Am29F400A memory electrically erases all bits within a sector simultaneously via Fowler-Nordhiem 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 - One 16 Kbyte, two 8 Kbytes, one 32 Kbyte, and seven 64 Kbyte sectors - Individual-sector or multiple-sector erase capability - Sector protection is user definable | | | (8x) | (x16) | |------|----------|--------|--------| | | | 7FFFFh | 3FFFFh | | SA10 | 16 Kbyte | 7BFFFh | 3DFFFh | | SA9 | 8 Kbyte | | | | SA8 | 8 Kbyte | 79FFFh | 3CFFFh | | | 32 Kbyte | 77FFFh | 3BFFFh | | SA7 | <u> </u> | 6FFFFh | 37FFFh | | SA6 | 64 Kbyte | 5FFFFh | 2FFFFh | | SA5 | 64 Kbyte | | | | SA4 | 64 Kbyte | 4FFFFh | 27FFFh | | | <u> </u> | 3FFFFh | 1FFFFh | | SA3 | 64 Kbyte | 2FFFFh | 17FFFh | | SA2 | 64 Kbyte | 1FFFFh | ٥٥٥٥٥ | | SA1 | 64 Kbyte | | 0FFFFh | | SA0 | - | 0FFFFh | 07FFFh | | SAU | 64 Kbyte | 00000h | 00000h | | | | | | 20380B-1 ## Am29F400AT Sector Architecture | | | (8x) | (x16) | |--------------|----------|--------|--------| | | | 7FFFFh | 3FFFFh | | SA10 | 64 Kbyte | 6BFFFh | 37FFFh | | SA9 | 64 Kbyte | | _ | | SA8 | 64 Kbyte | | 2FFFFh | | | 64 Kbyte | 4FFFFh | 27FFFh | | SA7 | <u> </u> | 3FFFFh | 1FFFFh | | SA6 | 64 Kbyte | 2FFFFh | 17FFFh | | SA5 | 64 Kbyte | | | | SA4 | 64 Kbyte | 1FFFFh | 0FFFFh | | | 32 Kbyte | 0FFFFh | 07FFFh | | SA3 | 32 Rbyte | 07FFFh | 03FFFh | | SA2 | 8 Kbyte | 05FFFh | 02FFFh | | SA1 | 8 Kbyte | | _ | | SA0 | 16 Kbyte | 03FFFh | 01FFFh | | <i>5,</i> 10 | To Abyte | 00000h | 00000h | | | | | | 20380B-2 ## Am29F400AB Sector Architecture ## **PRODUCT SELECTOR GUIDE** | Family Part No: | | | Am29F400A | | | |-----------------------------------------------|-----|-----|-----------|------|------| | Ordering Part No:V <sub>CC</sub> = 5.0 V ± 5% | -65 | | | | | | V <sub>CC</sub> = 5.0 V ± 10% | | -70 | -90 | -120 | -150 | | Max Access Time (ns) | 60 | 70 | 90 | 120 | 150 | | CE (E) Access (ns) | 60 | 70 | 90 | 120 | 150 | | OE (G) Access (ns) | 30 | 30 | 35 | 50 | 55 | ## **BLOCK DIAGRAM** ## **CONNECTION DIAGRAMS** SO ## **CONNECTION DIAGRAMS** Standard TSOP 20380B-5 **Reverse TSOP** ## **PIN CONFIGURATION** A1, A0-A17 = 18 Addresses BYTE = Selects 8-bit or 16-bit mode CE = Chip Enable DQ0-DQ15 = 16 Data Inputs/Outputs NC = Pin Not Connected Internally OE = Output Enable RESET = Hardware Reset Pin, Active Low $RY/\overline{BY}$ = Ready/ $\overline{Busy}$ Output $V_{SS}$ = +5.0 Volt Single-Power Supply (±10% for -90, -120, -150) or (±5% for -75) $V_{SS}$ = Device Ground $\overline{WE}$ = Write Enable ## **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 following: ## Am29F400A 4 Megabit (512K x 8-Bit/256K x 16-Bit) CMOS Flash Memory 5.0 Volt-only Program and Erase | Valid Con | nbinations | |------------------|-------------------------------------| | AM29F400AT/B-65 | EC, EI, FC, FI, SC, SI | | AM29F400AT/B-70 | | | AM29F400AT/B-90 | EC, EI, EE, EEB, | | AM29F400AT/B-120 | FC, FI, FE, FEB,<br>SC, SI, SE, SEB | AM29F400AT/B-150 ## **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. Am29F400A User Bus Operations ( $\overline{BYTE} = V_{IH}$ ) | Operation | CE | OE | WE | Α0 | <b>A</b> 1 | A6 | A9 | DQ0-DQ15 | RESET | |--------------------------------------|----|----|----|----|------------|----|-----------------|------------------|-----------------| | Autoselect, AMD Manuf. Code (Note 1) | L | L | Н | L | L | L | $V_{\text{ID}}$ | Code | Н | | Autoselect Device Code (Note 1) | L | L | Н | Н | L | L | V <sub>ID</sub> | Code | Н | | Read | L | L | Н | A0 | A1 | A6 | A9 | D <sub>OUT</sub> | Н | | Standby | Н | Х | Х | Х | Х | Х | Х | HIGH Z | Н | | Output Disable | L | Н | Н | Х | Х | Х | Х | HIGH Z | Н | | Write | L | Н | L | A0 | A1 | A6 | A9 | D <sub>IN</sub> | Н | | Verify Sector Protect (Note 2) | L | L | Н | L | Н | L | V <sub>ID</sub> | Code | Н | | Temporary Sector Unprotect | Х | Х | Х | Х | Х | Х | Х | Х | V <sub>ID</sub> | | Hardware Reset | Х | Х | Х | Х | Х | Х | Х | HIGH Z | L | Table 2. Am29F400A User Bus Operations ( $\overline{BYTE} = V_{IL}$ ) | Operation | CE | ŌĒ | WE | A0 | <b>A</b> 1 | A6 | A9 | DQ0-DQ7 | DQ8-DQ15 | RESET | |--------------------------------------|----|----|----|----|------------|----|-----------------|------------------|----------|-----------------| | Autoselect, AMD Manuf. Code (Note 1) | L | L | Н | L | L | L | V <sub>ID</sub> | Code | HIGH Z | н | | Autoselect Device Code (Note 1) | L | L | Н | Н | L | L | V <sub>ID</sub> | Code | HIGH Z | Н | | Read | L | L | Н | A0 | A1 | A6 | A9 | D <sub>OUT</sub> | HIGH Z | Н | | Standby | Н | Х | Х | Х | Х | Х | Х | HIGH Z | HIGH Z | Н | | Output Disable | L | Н | Н | Х | Х | Х | Х | HIGH Z | HIGH Z | Н | | Write | L | Н | L | A0 | A1 | A6 | A9 | D <sub>IN</sub> | HIGH Z | Н | | Verify Sector Protect (Note 2) | L | L | Н | L | Н | L | V <sub>ID</sub> | Code | HIGH Z | Н | | Temporary Sector Unprotect | Х | Х | Х | Х | Х | Х | Х | Х | HIGH Z | V <sub>ID</sub> | | Hardware Reset | Х | Х | Х | Х | Х | Х | Х | HIGH Z | HIGH Z | L | ## Legend: L = logic 0, H = logic 1, X = Don't Care. See Characteristics for voltage levels. ## Notes - 1. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 4. - 2. Refer to the section on Sector Protection. ## **Read Mode** The Am29F400A 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 $(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 is the delay from the falling edge of $\overline{OE}$ to valid data at the output pins (as- suming the addresses have been stable for at least $t_{\mbox{\scriptsize ACC}}\text{-}t_{\mbox{\scriptsize OE}}$ time). ## **Standby Mode** There are two ways to implement the standby mode on the Am29F400A device, both using the $\overline{\text{CE}}$ pin. A CMOS standby mode is achieved with the $\overline{CE}$ input held at $V_{CC} \pm 0.5$ V. Under this condition the current is typically reduced to less than 5 $\mu A$ . A TTL standby mode is achieved with the $\overline{CE}$ pin held at $V_{IH}$ . Under this condition the current is typically reduced to 1 mA. In the standby mode the outputs are in the high impedance state, independent of the $\overline{\text{OE}}$ input. ## **Output Disable** With the $\overline{OE}$ input 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 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 (see Table 3). The manufacturer and device codes may also be read via the command register, for instances when the Am29F400A is erased or programmed in a system without access to high voltage on the A9 pin. The command sequence is illustrated in Table 4 (see Autoselect Command Sequence). Byte 0 (A0 = $V_{IL}$ ) represents the manufacturer's code (AMD=01H) and byte 1 (A0 = $V_{IH}$ ) the device identifier code (Am29F400AT = 23H and Am29F400AB = ABH for x8 mode; Am29F400AT = 2223H and Am29F400AB = 22ABH for x16 mode). These two bytes/words are given in the table below. 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 the Autoselect, A1 must be $V_{IL}$ (see Tables 3 and 4). The autoselect mode also facilitates the determination of sector protection in the system. By performing a read operation at the address location XX02H with the higher order address bits A12–A17 set to the desired sector address, the device will return 01H for a protected sector and 00H for a non-protected sector. Table 3. Am29F400A Sector Protection Verify Autoselect Codes | Туре | | | A12-A17 | A6 | <b>A</b> 1 | A0 | Code (HEX) | |-----------------------|-----------------------|-------------------|-----------------|-----------------|-----------------|-----------------|------------| | Manufacturer Code-AMD | Manufacturer Code-AMD | | | | V <sub>IL</sub> | $V_{IL}$ | 01H | | | Am29F400AT | Byte | Х | | \/ | V | 23H | | Am29F400A Device | AM29F400A1 | Word | 1 ^ | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | 2223H | | Amzar400A Device | Am20E400AB | Byte | Х | V | \/ | V | ABH | | Am29F400A | | Word | ^ | V <sub>IL</sub> | V <sub>IL</sub> | $V_{IH}$ | 22ABH | | Sector Protection | | Sector<br>Address | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | 01H* | | <sup>\*</sup>Outputs 01H at protected sector addresses Table 4. Expanded Autoselect Code Table | Туре | Code | DQ<br>15 | DQ<br>14 | DQ<br>13 | DQ<br>12 | DQ<br>11 | DQ<br>10 | DQ<br>9 | DQ<br>8 | 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 | 01H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | Am29F400A | Am29F400AT(B)<br>(W) | 23H<br>2223H | A-1<br>0 | HI-Z<br>0 | HI-Z<br>1 | HI-Z<br>0 | HI-Z<br>0 | HI-Z<br>0 | HI-Z<br>1 | HI-Z<br>0 | 0<br>0 | 0 | 1<br>1 | 0<br>0 | 0 | 0 | 1 | 1 | | Device Am29F400AB(B) (W) | | ABH<br>22ABH | A-1<br>0 | HI-Z<br>0 | HI-Z<br>1 | HI-Z<br>0 | HI-Z<br>0 | HI-Z<br>0 | HI-Z<br>1 | HI-Z<br>0 | 1 | 0 | 1 | 0<br>0 | 1 | 0 | 1 | 1 | | Sector Protection | | 01H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | B) - Byte mode (W) - Word mode Table 5. Sector Address Tables (Am29F400AT) | | A17 | A16 | A15 | A14 | A13 | A12 | (x8) Address<br>Range | (x16) Address<br>Range | |------|-----|-----|-----|-----|-----|-----|-----------------------|------------------------| | SA0 | 0 | 0 | 0 | Х | Х | Х | 00000h-0FFFFh | 00000h-07FFFh | | SA1 | 0 | 0 | 1 | Х | Х | Х | 10000h-1FFFFh | 08000h-0FFFFh | | SA2 | 0 | 1 | 0 | Х | Х | Х | 20000h-2FFFFh | 10000h-17FFFh | | SA3 | 0 | 1 | 1 | Х | Х | Х | 30000h-3FFFFh | 18000h-1FFFFh | | SA4 | 1 | 0 | 0 | Х | Х | Х | 40000h-4FFFFh | 20000h-27FFFh | | SA5 | 1 | 0 | 1 | Х | Х | Х | 50000h-5FFFFh | 28000h-2FFFFh | | SA6 | 1 | 1 | 0 | Х | Х | Х | 60000h-6FFFFh | 30000h-37FFFh | | SA7 | 1 | 1 | 1 | 0 | Х | Х | 70000h-77FFFh | 38000h-3BFFFh | | SA8 | 1 | 1 | 1 | 1 | 0 | 0 | 78000h-79FFFh | 3C000h-3CFFFh | | SA9 | 1 | 1 | 1 | 1 | 0 | 1 | 7A000h-7BFFFh | 3D000h-3DFFFh | | SA10 | 1 | 1 | 1 | 1 | 1 | Х | 7C000h-7FFFFh | 3E000h-3FFFFh | Table 6. Sector Address Tables (Am29F400AB) | | A17 | A16 | A15 | A14 | A13 | A12 | (x8) Address<br>Range | (x16) Address<br>Range | |------|-----|-----|-----|-----|-----|-----|-----------------------|------------------------| | SA0 | 0 | 0 | 0 | 0 | 0 | Х | 00000h-03FFFh | 00000h-01FFFh | | SA1 | 0 | 0 | 0 | 0 | 1 | 0 | 04000h-05FFFh | 02000h-02FFFh | | SA2 | 0 | 0 | 0 | 0 | 1 | 1 | 06000h-07FFFh | 03000h-03FFFh | | SA3 | 0 | 0 | 0 | 1 | Х | Х | 08000h-0FFFFh | 04000h-07FFFh | | SA4 | 0 | 0 | 1 | Х | Х | Х | 10000h-1FFFFh | 08000h-0FFFFh | | SA5 | 0 | 1 | 0 | Х | Х | Х | 20000h-2FFFFh | 10000h-17FFFh | | SA6 | 0 | 1 | 1 | Х | Х | Х | 30000h-3FFFFh | 18000h-1FFFFh | | SA7 | 1 | 0 | 0 | Х | Х | Х | 40000h-4FFFFh | 20000h-27FFFh | | SA8 | 1 | 0 | 1 | Х | Х | Х | 50000h-5FFFFh | 28000h-2FFFFh | | SA9 | 1 | 1 | 0 | Х | Х | Х | 60000h-6FFFFh | 30000h-37FFFh | | SA10 | 1 | 1 | 1 | Х | Х | Х | 70000h-7FFFFh | 38000h-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; while data is latched on the rising edge of $\overline{WE}$ or $\overline{CE}$ , 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 Am29F400A features hardware sector protection. This feature will disable both program and erase operations in any combination of ten sectors of memory. 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). 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 bits A12–A17 is the desired sector address, will produce a logical "1" at DQ0 for a protected sector. See Table 3 for Autoselect codes. ## **Temporary Sector Unprotect** This feature allows temporary unprotection of previously protected sectors of the Am29F400A device in order to change data in-system. 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 12 V is taken away from the RESET pin, all the previously protected sectors will be protected again. Refer to Figures 16 and 17. ## **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 (B0H) and Erase Resume (30H) commands are valid only while the Sector Erase operation is in progress. Moreover, both Reset/Read commands are functionally equivalent, resetting the device to the read mode. | Command | | Bus<br>Write | First <br>Write ( | | Second<br>Write ( | | Third<br>Write C | | | ırth Bus<br>Vrite Cycle | Fifth I<br>Write C | | Sixth <br>Write C | | |-----------------------|---------------|-----------------|--------------------|------|-------------------|------|------------------|------|-------|--------------------------------------------------|--------------------|------|--------------------|------| | Sequence<br>Read/Rese | et | Cycles<br>Req'd | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | | Reset/Read | | 1 | XXXXH | F0H | | | | | | | | | | | | Reset/ | Word | 3 | 5555H | AAH | 2AAAH | 55H | 5555H | FOLL | D.4 | DD | | | | | | Read | Byte | 3 | AAAAH | | 5555H | | AAAAH | F0H | RA | RD | | | | | | | Word | 3 | 5555H | AAH | 2AAAH | 55H | 5555H | 90H | 01H | 2223H<br>(T Device ID)<br>22ABH<br>(B Device ID) | | | | | | Autoselect | Byte | | ААААН | | 5555H | | AAAAH | | | 23H<br>(T Device ID)<br>ABH<br>(B Device ID) | | | | | | | Word<br>/Byte | | | | | | | | 00H | 01H (T/B<br>Manuf. ID) | | | | | | Dro area | Word | 4 | 5555H | AAH | 2AAAH | 55H | 5555H | A0H | PA | PD | | | | | | Program | Byte | | AAAAH | | 5555H | | AAAAH | | | | | | | | | Chip Erase | Word | 6 | 5555H | AAH | 2AAAH | 55H | 5555H | 80H | 5555H | AAH | 2AAAH | 55H | 5555H | 10H | | Criip Erase | Byte | | AAAAH | | 5555H | | AAAAH | | AAAAH | | 5555H | | AAAAH | | | Sector | Word | 6 | 5555H | AAH | 2AAAH | 55H | 5555H | 80H | 5555H | AAH | 2AAAH | 55H | SA | 30H | | Erase | Byte | | AAAAH | | 5555H | | AAAAH | | AAAAH | | 5555H | | | | | Erase Susp | end | 1 | XXXXH | вон | | | | | | | | | | | | Erase Resu | me | 1 | XXXXH | 30H | | | | | | | | | | | Table 7. Am29F400A Command Definitions (Notes 1–7) ## 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 of the sector to be erased. The combination of A17–A12 will uniquely select any sector. - 3. RD = Data read from location RA during read operation. - PD = Data to be programmed at location PA. Data is latched on the rising edge of WE - 4. Reading from non-erasing sectors is allowed in the Erase Suspend mode. - 5. Address bits A17-A15 are don't care for unlock and command cycles. - 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 can alter 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 a desirable 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 (Am29F400AT = 23H and Am29F400AB = ABH for x8 mode; Am29F400AT = 2223H and Am29F400AB = 22ABH for x16 mode) (see Tables 3 and 4). All manufacturer and device codes will exhibit odd parity with DQ7 defined as the parity bit. Furthermore, the write protect status of sectors can be read in this mode. Scanning the sector addresses (A17, 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 setup 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 using the Embedded Program Algorithm. Upon executing the algorithm, 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 (also used as Data Polling) is equivalent to the data written to this bit at which time the device returns to the read mode and addresses are no longer latched (see Table 8, Write Operation Status). Therefore, the device requires that a valid address to the device be supplied by the system at this particular instance of time for Data Polling operations. Data Polling must be performed at the memory location which is being programmed. Any commands written to the chip during the Embedded Program Algorithm will be ignored. If a hardware reset occurs during the programming operation, the data at that particular 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 may cause the device to exceed programming time limits (DQ5 = 1) 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 "013". 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 "setup" 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 Algorithm command sequence the device will automatically program and verify the entire memory for an all zero data pattern prior to electrical erase. The erase is performed sequentially on all sectors at the same time (see Table "Erase and Programming Performance"). 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 $\overline{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 1 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}.$ After a time-out of 100 $\mu s$ from the rising edge of the last sector erase command, the sector erase operation will begin. Multiple sectors may be erased sequentially 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 sequentially erased. The time between writes must be less than 100 $\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 100 $\mu s$ from the rising edge of the last $\overline{WE}$ will initiate the execution of the Sector Erase command(s). If another falling edge of the $\overline{WE}$ occurs within the 100 $\mu 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. In that case, restart the erase on those sectors and allow them to complete. (Refer to the Write Operation Status section for DQ3, Sector Erase Timer operation.) Loading the sector erase buffer may be done in any sequence and with any number of sectors (0 to10). 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 100 $\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, $\overline{Data}$ Polling, is "1" (see Write Operation Status section) at which time the device returns to the read mode. $\overline{Data}$ Polling must be performed at an address within any of the sectors being erased. Figure 1 illustrates the Embedded Erase Algorithm using typical command strings and bus operations. ## **Erase Suspend** The Erase Suspend command allows the user to interrupt a Sector Erase operation and then perform data reads from 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 Chip Erase operation or Embedded Program Algorithm. 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. Any other command written during the Erase Suspend mode will be ignored except the Erase Resume command. Writing the Erase Resume command resumes the 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 the Sector Erase operation, the device will take a maximum of 15 $\mu$ s to suspend the erase operation. When the device has entered the erase-suspended mode, DQ6 will stop toggling. The user must use the address of a sector being erased for reading DQ6 to determine if the erase operation has been suspended. Further writes of the Erase Suspend command are ignored. 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** Table 8. Write Operation Status | | Status | DQ7 | DQ6 | DQ5 | DQ3 | |-------------|-----------------------------|-----|--------|-----|-----| | In Drogram | Auto-Programming | DQ7 | Toggle | 0 | 0 | | In Progress | Program/Erase in Auto-Erase | 0 | Toggle | 0 | 1 | | Exceeded | Auto-Programming | DQ7 | Toggle | 1 | 0 | | Time Limits | Program/Erase in Auto-Erase | 0 | Toggle | 1 | 1 | - 1. D8-D15 = Don't Care for x16 mode. - 2. DQ4 for AMD internal use only. ## DQ7 ## **Data** Polling The Am29F400A 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 2. For chip erase, the $\overline{\text{Data}}$ Polling is valid after the rising edge of the sixth $\overline{\text{WE}}$ pulse in the six write pulse sequence. For sector erase, the $\overline{\text{Data}}$ Polling is valid after the last rising edge of the sector erase $\overline{\text{WE}}$ pulse. $\overline{\text{Data}}$ Polling must be performed at sector addresses within any of the sectors being erased and **not** 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 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 7). See Figure 10 for the $\overline{\text{Data}}$ Polling timing specifications and diagrams. ## DQ6 Toggle Bit The Am29F400A 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 at any address 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 attempt. During programming, the Toggle Bit is valid after the rising edge of the fourth $\overline{WE}$ pulse in the four write pulse sequence. For chip erase, the Toggle Bit is valid after the rising edge of the sixth $\overline{\text{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 $\overline{\text{WE}}$ pulse. The Toggle Bit is active during the sector time-out. Either $\overline{\text{CE}}$ or $\overline{\text{OE}}$ toggling will cause DQ6 to toggle. In addition, an Erase Suspend/Resume command will cause DQ6 to toggle. See Figure 11 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. $\overline{\text{Data}}$ Polling is the only operating function of the device under this condition. The $\overline{\text{CE}}$ circuit will partially power down the device under these conditions (to approximately 2 mA). The $\overline{\text{OE}}$ and $\overline{\text{WE}}$ pins will control the output disable functions as described in Table 1. The DQ5 failure condition will also appear if a user tries to program a 1 to a location that is previously programmed to 0. In this case the device locks out and never completes the Embedded Program Algorithm. 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. If this occurs, reset the device. ## 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 (other than Erase Suspend) 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: Write Operation Status. ## RY/BY ## Ready/Busy The Am29F400A provides a RY/BY open-drain output pin as a way to indicate to the host system that the Embedded 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/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 Am29F400A is placed in an Erase Suspend mode, the RY/BY output will be high. 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<sub>IL</sub>. Refer to Figure 12 for a detailed timing diagram. Since this is an open-drain output, several RY/ $\overline{\text{BY}}$ pins can be tied together in parallel with a pull-up resistor to $V_{CC}$ . ## RESET ## **Hardware Reset** The Am29F400A device may be reset by driving the RESET pin to $V_{IL}$ . The RESET pin must be kept low $(V_{IL})$ for at least 500 ns. Any operation in progress will be terminated and the internal state machine will be reset to the read mode 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 indeterminate. The RESET pin may be tied to the system reset input. Therefore, if a system reset occurs during the Embedded Program or Erase Algorithm, the device will be automatically reset to read mode and this will enable the system's microprocessor to read the boot-up firmware from the Flash memory. ## **Byte/Word Configuration** The BYTE pin selects the byte (8-bit) mode or word (16 bit) mode for the Am29F400A 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 tri-stated. 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 14 and 15 for the timing diagram. ## **Data Protection** The Am29F400A 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 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, the Am29F400A locks out write cycles for $V_{CC} < V_{LKO}$ (see DC Characteristics section for voltages). When $V_{CC} < V_{LKO}$ , the command register is disabled, all internal program/erase circuits are disabled, and the device resets to the read mode. The Am29F400A ignores all writes until $V_{CC} > V_{LKO}$ . The user must ensure that the control pins are in the correct logic state when $V_{CC} > V_{LKO}$ to prevent unintentional writes. ## 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} = \overline{VIL}$ 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 ## **EMBEDDED ALGORITHMS** # 5555H/AAH 2AAAH/55H 5555H/AAH 2AAAH/55H 2AAAH/55H 5555H/10H **Chip Erase Command Sequence** 20380B-9 ## Note: 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. Figure 2. Embedded Erase Algorithm Note: DQ7 is rechecked even if DQ5 = "1" because DQ7 may change simultaneously with DQ5. Figure 3. Data Polling Algorithm Note: 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 20380B-13 ## **ABSOLUTE MAXIMUM RATINGS** | Storage Temperature 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, OE and RESET<br>(Note 1)2.0 V to +7.0 V | | V <sub>CC</sub> (Note 1)2.0 V to +7.0 V | | A9, $\overline{\text{OE}},$ and $\overline{\text{RESET}}$ (Note 2)2.0 V to +13.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, input or I/O pins may undershoot $V_{\rm SS}$ to -2.0 V for periods of up to 20 ns. Maximum DC voltage on input or I/O pins is $V_{\rm CC}$ +0.5 V. During voltage transitions, input or I/O pins may overshoot to $V_{\rm CC}$ +2.0 V for periods up to 20 ns. See Figure 7 and Figure 8. - 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 7 and Figure 8. - 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 $^{\circ}$ C to +70 $^{\circ}$ C | | Industrial (I) Devices | | Ambient Temperature (T <sub>A</sub> )40 $^{\circ}$ C to +85 $^{\circ}$ C | | Extended (E) Devices | | Ambient Temperature (T <sub>A</sub> )55 $^{\circ}$ C to +125 $^{\circ}$ C | | V <sub>CC</sub> Supply Voltages | | $V_{CC}$ for Am29F400T/B-65, $\ldots$ +4.75 V to +5.25 V | | V <sub>CC</sub> for Am29F400T/B-70, -90, | | -120, -150 +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 | |---------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------|-----------------|------|-----------------------|------| | ILI | Input Load Current | $V_{IN} = V_{SS}$ to $V_{CC}$ , $V_{CC} = V_{CC}$ Max | | | ±1.0 | μΑ | | I <sub>LIT</sub> | A9, OE, RESET Input Load Current | $V_{CC} = V_{CC} Max, A9, \overline{OE}, \overline{RESET}$ | = 12.5 V | | 50 | μΑ | | I <sub>LO</sub> | Output Leakage Current | $V_{OUT} = V_{SS}$ to $V_{CC}$ , $V_{CC} = V_{CC}$ M | ах | | ±1.0 | μΑ | | | V Astina Danid Communit (Nata 4) | OF V OF V | Byte | | 40 | A | | I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current (Note 1) | $\overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | | | 50 | mA | | I <sub>CC2</sub> | V <sub>CC</sub> Active Program/Erase Current (Notes 2, 3) | $\overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | | | 60 | mA | | I <sub>CC3</sub> | V <sub>CC</sub> Standby Current | $V_{CC} = V_{CC} \text{ Max}, \overline{CE} = V_{IH}, \overline{OE} = V_{IH}$ | / <sub>IH</sub> | | 1.0 | mA | | V <sub>IL</sub> | Input Low Voltage | | | -0.5 | 0.8 | V | | V <sub>IH</sub> | Input High Voltage | | | 2.0 | V <sub>CC</sub> + 0.5 | V | | V <sub>ID</sub> | Voltage for Autoselect and<br>Temporary Sector Unprotect | V <sub>CC</sub> = 5.0 V | | | 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>OH</sub> | Output High Voltage | $I_{OH}$ = -2.5 mA, $V_{CC}$ = $V_{CC}$ Min | 2.4 | | V | | | V <sub>LKO</sub> | Low V <sub>CC</sub> Lock-Out Voltage | | | 3.2 | 4.2 | V | - 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 Program or Erase Algorithm is in progress. - 3. Not 100% tested. # DC CHARACTERISTICS (continued) CMOS Compatible | Parameter<br>Symbol | Parameter Description | Test Conditions | ; | Min | Тур | Max | Unit | |---------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------|---------------------|--------------------------|-----|-----------------------|------| | ILI | Input Load Current | $V_{IN} = V_{SS}$ to $V_{CC}$ , $V_{CC} = V_{CC}$ | <sub>C</sub> Max | | | ±1.0 | μΑ | | I <sub>LIT</sub> | A9, OE, RESET Input Load<br>Current | $V_{CC} = V_{CC} \text{ Max, A9, } \overline{OE},$<br>$\overline{RESET} = 12.5 \text{ V}$ | | | | 50 | μΑ | | I <sub>LO</sub> | Output Leakage Current | $V_{OUT} = V_{SS}$ to $V_{CC}$ , $V_{CC} = V_{CC}$ | √ <sub>CC</sub> Max | | | ±1.0 | μΑ | | | V Astina Danid Oromant (Nata 4) | OF V OF V | Byte | | 20 | 40 | 0 | | I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current (Note 1) | $CE = V_{IL}, OE = V_{IH}$ | Word | | 28 | 50 | mA | | I <sub>CC2</sub> | V <sub>CC</sub> Active Program/Erase<br>Current (Notes 2, 3) | $\overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | | | 30 | 50 | mA | | I <sub>CC3</sub> | V <sub>CC</sub> Standby Current (Note 4) | $V_{CC} = V_{CC} \text{ Max, } \overline{CE} = V_{IH},$<br>$\overline{OE} = V_{IH}$ | | | 1 | 5 | μΑ | | V <sub>IL</sub> | Input Low Voltage | | | -0.5 | | 0.8 | V | | V <sub>IH</sub> | Input High Voltage | | | 0.7 x<br>V <sub>CC</sub> | | V <sub>CC</sub> + 0.3 | V | | V <sub>ID</sub> | Voltage for Autoselect and<br>Temporary Sector Unprotect | V <sub>CC</sub> = 5.0 V | | 11.5 | | 12.5 | V | | V <sub>OL</sub> | Output Low Voltage | $I_{OL} = 5.8 \text{ mA}, V_{CC} = V_{CC} \text{ Min}$ | | | | 0.45 | V | | V <sub>OH1</sub> | Output Low Voltage | $I_{OH} = -2.5 \text{ mA}, V_{CC} = V_{CC} \text{ Min}$ | | 0.85<br>V <sub>CC</sub> | | | V | | V <sub>OH2</sub> | | $I_{OH} = -100 \mu A$ , $V_{CC} = V_{CC} Min$ | | V <sub>CC</sub> -0.4 | | | V | | V <sub>LKO</sub> | Low V <sub>CC</sub> Lock-Out Voltage | | | 3.2 | | 4.2 | V | - 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 Program or Erase Algorithm is in progress. - 3. Not 100% tested. - 4. $I_{CC3} = 20 \,\mu\text{A}$ max at extended temperatures (> +85°C). ## **AC CHARACTERISTICS** ## **Read-Only Operations Characteristics** | | ameter<br>mbols | | | | ; | Speed Op | tion (Note | es 1 and 2 | 2) | | |-------------------|--------------------|-------------------------------------------------------------------------|------------------------------------------------------|-----|-----|----------|------------|------------|------|------| | JEDEC | Standard | Description | Test Se | tup | -65 | -70 | -90 | -120 | -150 | Unit | | t <sub>AVAV</sub> | t <sub>RC</sub> | Read Cycle Time (Note 4) | | Min | 60 | 70 | 90 | 120 | 150 | ns | | t <sub>AVQV</sub> | t <sub>ACC</sub> | Address to Output Delay | $\overline{CE} = V_{IL}$<br>$\overline{OE} = V_{IL}$ | Max | 60 | 70 | 90 | 120 | 150 | ns | | t <sub>ELQV</sub> | t <sub>CE</sub> | Chip Enable to Output Delay | $\overline{OE} = V_{IL}$ | Max | 60 | 70 | 90 | 120 | 150 | ns | | t <sub>GLQV</sub> | t <sub>OE</sub> | Output Enable to Output Delay | | Max | 30 | 30 | 35 | 50 | 55 | ns | | t <sub>EHQZ</sub> | t <sub>DF</sub> | Chip Enable to Output High Z (Notes 3, 4) | | Max | 20 | 20 | 20 | 30 | 35 | ns | | t <sub>GHQZ</sub> | t <sub>DF</sub> | Output Enable to Output<br>High Z (Notes 3, 4) | | Max | 20 | 20 | 20 | 30 | 35 | ns | | t <sub>AXQX</sub> | t <sub>OH</sub> | Output Hold Time From<br>Addresses, CE or OE,<br>Whichever Occurs First | | Min | 0 | 0 | 0 | 0 | 0 | ns | | | t <sub>Ready</sub> | RESET Pin Low to Read<br>Mode (Note 4) | | Max | 20 | 20 | 20 | 20 | 20 | μs | | | t <sub>ELFL</sub> | CE to BYTE Switching Low or High | | Max | 5 | 5 | 5 | 5 | 5 | ns | ## Notes: - Test Conditions (for -65 only) 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: 1.5 V input and output - 2. Test Conditions (for -70, -90, -120, -150) 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: 0.8 V and 2.0 V input and output - 3. Output Driver Disable Time - 4. Not 100% tested. Figure 7. Test Conditions ## **AC CHARACTERISTICS** ## Write (Erase/Program) Operations | Parameter Symbols | | | | | | S | peed Opt | tion (Not | es 1 and | 2) | | |--------------------|--------------------|--------------------------------------------------|------------------------------------|--------------|-----|-----|----------|-----------|----------|------|------| | JEDEC | Standard | Description | 1 | | | -65 | -70 | -90 | -120 | -150 | Unit | | t <sub>AVAV</sub> | t <sub>WC</sub> | Write Cycle | Time | | Min | 60 | 70 | 90 | 120 | 150 | ns | | t <sub>AVWL</sub> | t <sub>AS</sub> | Address Set | tup Time | | Min | 0 | 0 | 0 | 0 | 0 | ns | | t <sub>WLAX</sub> | t <sub>AH</sub> | Address Ho | ld Time | | Min | 45 | 45 | 45 | 50 | 150 | ns | | t <sub>DVWH</sub> | t <sub>DS</sub> | Data Setup | Time | | Min | 30 | 30 | 45 | 50 | 50 | ns | | t <sub>WHDX</sub> | t <sub>DH</sub> | Data Hold T | ime | | Min | 0 | 0 | 0 | 0 | 0 | ns | | | | Output | Read (Note | 2) | Min | 0 | 0 | 0 | 0 | 0 | ns | | | t <sub>OEH</sub> | Enable<br>Hold Time | Toggle and I | Data Polling | Min | 10 | 10 | 10 | 10 | 10 | ns | | t <sub>GHWL</sub> | t <sub>GHWL</sub> | Read Recov | very Time Before WE Low) | ore Write | Min | 0 | 0 | 0 | 0 | 0 | ns | | t <sub>ELWL</sub> | t <sub>CS</sub> | CE Setup Ti | CE Setup Time | | Min | 0 | 0 | 0 | 0 | 0 | ns | | t <sub>WHEH</sub> | t <sub>CH</sub> | CE Hold Tin | ne | | Min | 0 | 0 | 0 | 0 | 0 | ns | | t <sub>WLWH</sub> | t <sub>WP</sub> | Write Pulse | Write Pulse Width | | Min | 35 | 35 | 45 | 50 | 50 | ns | | t <sub>WHDL</sub> | t <sub>WPH</sub> | Write Pulse | Width High | | Min | 20 | 20 | 20 | 20 | 20 | ns | | | 1. | | 0 | Byte | Тур | 7 | 7 | 7 | 7 | 7 | μs | | t <sub>WHWH1</sub> | t <sub>WHWH1</sub> | Programmin | g Operation | Word | Тур | 14 | 14 | 14 | 14 | 14 | μs | | | 1. | 0 | | M. ( . 4) | Тур | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | sec | | t <sub>WHWH2</sub> | t <sub>WHWH2</sub> | Sector Eras | e Operation (I | Note 1) | Max | 8 | 8 | 8 | 8 | 8 | sec | | | t <sub>VCS</sub> | V <sub>CC</sub> Setup 7 | Time (Note 2) | | Min | 50 | 50 | 50 | 50 | 50 | μs | | | t <sub>VIDR</sub> | Rise Time to | V <sub>ID</sub> (Notes 2 | 2, 3) | Min | 500 | 500 | 500 | 500 | 500 | ns | | | t <sub>OESP</sub> | OE Setup Time to WE Active (Notes 2, 3) | | Min | 4 | 4 | 4 | 4 | 4 | μs | | | | t <sub>RP</sub> | RESET Pulse Width | | Min | 500 | 500 | 500 | 500 | 500 | ns | | | | t <sub>FLQZ</sub> | BYTE Switching Low to Output High Z (Notes 3, 4) | | Max | 20 | 20 | 30 | 30 | 30 | ns | | | | t <sub>BUSY</sub> | Program/Era<br>(Note 2) | Program/Erase Valid to RY/BY Delay | | Min | 30 | 30 | 35 | 50 | 55 | ns | | | t <sub>RESSP</sub> | RESET Set | up Time to Wi | E Active | Min | 4 | 4 | 4 | 4 | 4 | μs | - 1. This does not include the preprogramming time. - 2. Not 100% tested. - 3. These timings are for Temporary Sector Unprotect operation. - 4. Output Driver Disable Time. ## **KEY TO SWITCHING WAVEFORMS** KS000010 ## **SWITCHING WAVEFORMS** Figure 8. AC Waveforms for Read Operations ## **SWITCHING WAVEFORMS** ## 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<sub>OUT</sub> 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 9. Program Operation Timings - 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 ## **SWITCHING WAVEFORMS** ## Note: \*DQ7=Valid Data (The device has completed the Embedded operation). 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 20380B-20 20380B-21 ## **SWITCHING WAVEFORMS** Figure 13. RY/BY Timing Diagram During Program/Erase Operations Figure 14. RESET Timing Diagram ## **SWITCHING WAVEFORMS** Figure 15. BYTE Timing Diagram for Read Operation 20380B-22 20380B-23 Figure 16. BYTE Timing Diagram for Write Operations 20380B-24 - 1. All protected sectors unprotected. - 2. All previously protected sectors are protected once again. Figure 17. Temporary Sector Unprotect Algorithm Figure 18. Temporary Sector Unprotect Timing Diagram ## **AC CHARACTERISTICS** # Write/Erase/Program Operations ## Alternate CE Controlled Writes | Parameter Symbols | | | | | Sp | eed Opt | ion (Not | es 1 and | d 2) | | |--------------------|--------------------|----------------------------------------------|----------------------------------|-----|-----|---------|----------|----------|------|-----| | JEDEC | Standard | Description | | -65 | -70 | -90 | -120 | -150 | Unit | | | t <sub>AVAV</sub> | t <sub>WC</sub> | Write Cycle Time (Note 2 | 2) | Min | 60 | 70 | 90 | 120 | 150 | ns | | t <sub>AVEL</sub> | t <sub>AS</sub> | Address Setup Time | | Min | 0 | 0 | 0 | 0 | 0 | ns | | t <sub>ELAX</sub> | t <sub>AH</sub> | Address Hold Time | | Min | 45 | 45 | 45 | 50 | 50 | ns | | t <sub>DVEH</sub> | t <sub>DS</sub> | Data Setup Time | | Min | 30 | 30 | 45 | 50 | 50 | ns | | t <sub>EHDX</sub> | t <sub>DH</sub> | Data Hold Time | | Min | 0 | 0 | 0 | 0 | 0 | ns | | | t <sub>OES</sub> | Output Enable Setup Tin | ne | Min | 0 | 0 | 0 | 0 | 0 | ns | | | | Outsid Frankla | Read (Note 2) | Min | 0 | 0 | 0 | 0 | 0 | ns | | | t <sub>OEH</sub> | Output Enable Hold Time | Toggle and Data Polling (Note 2) | Min | 10 | 10 | 10 | 10 | 10 | ns | | t <sub>GHEL</sub> | t <sub>GHEL</sub> | Read Recover Time Befo | ore Write | Min | 0 | 0 | 0 | 0 | 0 | ns | | t <sub>WLEL</sub> | t <sub>WS</sub> | WE Setup Time | | Min | 0 | 0 | 0 | 0 | 0 | ns | | t <sub>EHWH</sub> | t <sub>WH</sub> | WE Hold Time | | Min | 0 | 0 | 0 | 0 | 0 | ns | | t <sub>ELEH</sub> | t <sub>CP</sub> | CE Pulse Width | | Min | 35 | 35 | 45 | 50 | 50 | ns | | t <sub>EHEL</sub> | t <sub>CPH</sub> | CE Pulse Width High | | Min | 20 | 20 | 20 | 20 | 20 | ns | | | | B | Byte | Тур | 7 | 7 | 7 | 7 | 7 | μs | | t <sub>WHWH1</sub> | t <sub>WHWH1</sub> | Programming Operation | Word | Тур | 14 | 14 | 14 | 14 | 14 | μs | | | | Sector Erase Operation (Note 1) | | Тур | 1.0 | 1.0 | 1.0 | 1.0 | 1.0 | sec | | t <sub>WHWH2</sub> | t <sub>WHWH2</sub> | | | Max | 8 | 8 | 8 | 8 | 8 | sec | | | t <sub>FLQZ</sub> | BYTE Switching Low to Output High Z (Note 2) | | Max | 20 | 20 | 30 | 30 | 30 | ns | - 1. This does not include the preprogramming time. - 2. Not 100% tested. ## **SWITCHING WAVEFORMS** 20380B-26 ## 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. D<sub>OUT</sub> 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 19. Alternate CE Controlled Program Operation Timings ## **ERASE AND PROGRAMMING PERFORMANCE** | | Limits | | | | |-----------------------|------------------|-------------------|------|-------------------------------------------| | Parameter | Typ (Note 1) Max | | Unit | Comments | | Sector Erase Time | 1.0 | 8 | sec | Excludes 00H programming prior to erasure | | Chip Erase Time | 11 | 11 88 | | Excludes 00H programming prior to erasure | | Byte Programming Time | 7 | 300 (Note 3) | μs | Excludes system-level overhead (Note 4) | | Word Programming Time | 14 | 600 | μs | Excludes system-level overhead (Note 4) | | Chip Programming Time | 3.6 | 10.8 (Notes 3, 5) | sec | Excludes system-level overhead (Note 4) | - 1. 25°C, 5.0 V V<sub>CC</sub>, 100,000 cycles. - 2. Although Embedded Algorithms allow for longer chip program and erase time, the actual time will be considerably less since bytes program or erase significantly faster than the worst case byte. - 3. Under worst case condition of 90°C, 4.5 V V<sub>CC</sub>, 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 preprogramming step of the Embedded Erase algorithm, all bytes are programmed to 00H before erasure. - 5. The Embedded Algorithms allow for 2.5 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 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}$ = 5.0 V, one pin at a time. ## **TSOP PIN CAPACITANCE** | 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 | 8 | 10 | pF | ## Notes: - 1. Sampled, not 100% tested. - 2. Test conditions $T_A = 25^{\circ}C$ , f = 1.0 MHz. ## **SO PIN CAPACITANCE** | 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_{PP} = 0$ | 8 | 10 | pF | ## Notes: - 1. Sampled, not 100% tested. - 2. Test conditions $T_A = 25^{\circ}C$ , f = 1.0 MHz. ## **DATA RETENTION** | Parameter | Test Conditions | Min | Unit | |-------------------------------------------------|-----------------|-----|-------| | Minimum Pattern Data Retention Time | 150°C | 10 | Years | | IVIIIIIIIIIIII FAILEITI DAIA NELEIIIIOIT TIITIE | 125°C | 20 | Years | ## **REVISION SUMMARY** ## **Distinctive Characteristics:** High Performance: The fastest speed option available is now 60 ns. Enhanced power management for standby mode: Changed typical standby current to 1μA. ## **General Description:** First paragraph, first sentence should read, "...organized as 512 Kbytes of 8 bits each or 256 *Kwords* of 16 bits each." Added 60 ns speed option. ## **Product Selector Guide:** Added -65 column (60 ns, $\pm 5\%$ V<sub>CC</sub>). Added -70 (70 ns, $\pm 10\%$ V<sub>CC</sub>) and deleted -75 speed option. ## **Ordering Information, Standard Products:** The -65 speed option is now listed in the example. Valid Combinations: Added -65 and -70, and deleted -75 speed options. ## Tables 1 and 2, User Bus Operations: Corrected $\overline{WE}$ for read operations; was don't care (X), is now H. ## Standby Mode: Corrected standby mode current; was 100 $\mu A$ , is now 5 $\mu A$ . ## Table 5, Sector Address Tables (Am29F400AB): Corrected x16 starting address for SA5; was 1C000h, is now 28000h. ## **Erase Suspend:** Third paragraph, third sentence: Deleted the word "NOT." ## **Operating Ranges:** $V_{CC}$ Supply Voltages: Added -65 and deleted -75 speed options in the list. Changed A9 maximum to +13.0 V. ## DC Characteristics: *CMOS Compatible:* Revised $I_{CC}$ specifications. Added Note 4 (refers to $I_{CC3}$ ). ## **AC Characteristics:** Read Only Operations Characteristics: Added the -65 column and test conditions. Replaced -75 column with -70 column. ## **Test Conditions, Figure 7:** Changed speed option in first $C_L$ statement from -75 to -65. ## **AC Characteristics:** Write/Erase/Program Operations, Alternate CE Controlled Writes: Added the -65 column. Replaced -75 column with -70 column. Revised sector erase and programming specifications. ## **Erase and Programming Performance:** Revised specifications in table. Clarified table and notes. ## **Table 7, Command Definitions** Revised Note 5 to cover all upper address bits that are don't care. Deleted Note 6.