# SPANSION ${ }^{T M}$ Flash Memory 

Data Sheet


September 2003

This document specifies SPANSION ${ }^{\top M}$ memory products that are now offered by both Advanced Micro Devices and Fujitsu. Although the document is marked with the name of the company that originally developed the specification, these products will be offered to customers of both AMD and Fujitsu.

## Continuity of Specifications

There is no change to this datasheet as a result of offering the device as a SPANSION ${ }^{T M}$ product. Future routine revisions will occur when appropriate, and changes will be noted in a revision summary.

## Continuity of Ordering Part Numbers

AMD and Fujitsu continue to support existing part numbers beginning with "Am" and "MBM". To order these products, please use only the Ordering Part Numbers listed in this document.

## For More Information

Please contact your local AMD or Fujitsu sales office for additional information about SPANSION ${ }^{\text {TM }}$ memory solutions.

FUjilisu

## FLASH MEMORY

## CMOS

## $8 \mathrm{M}(1 \mathrm{M} \times 8 / 512 \mathrm{~K} \times 16) \mathrm{BIT}$

## MBM29DL800TA-7099/MBM29DL800BA-70/90

## ■ FEATURES

- Single 3.0 V read, program, and erase

Minimizes system level power requirements

- Simultaneous operations

Read-while-Erase or Read-while-Program

- Compatible with JEDEC-standard commands Uses same software commands as E²PROMs
- Compatible with JEDEC-standard worldwide pinouts (Pin compatible with MBM29LV800TA/BA) 48-pin TSOP(1) (Package suffix: PFTN - Normal Bend Type, PFTR - Reversed Bend Type) 48-ball FBGA (Package suffix: PBT)
- Minimum 100,000 program/erase cycles
- High performance 70 ns maximum access time
- Sector erase architecture

Two 16 K byte, four 8 K bytes, two 32 K byte, and fourteen 64 K bytes.
Any combination of sectors can be concurrently erased. Also supports full chip erase.

- Boot Code Sector Architecture

T = Top sector
B = Bottom sector

- Embedded Erase ${ }^{\text {TM }}$ Algorithms

Automatically pre-programs and erases the chip or any sector

- Embedded Program ${ }^{\text {TM }}$ Algorithms

Automatically writes and verifies data at specified address

- $\overline{\text { 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
- Automatic sleep mode

When addresses remain stable, automatically switch themselves to low power mode.

- Low Vcc write inhibit $\leq 2.5 \mathrm{~V}$
- Erase Suspend/Resume Suspends the erase operation to allow a read in another sector within the same device

[^0]
## MBM29DL800TA-7090/MBM29DL800BA-7090

(Continued)

- Sector protection

Hardware method disables any combination of sectors from program or erase operations

- Sector Protection Set function by Extended sector protection command
- Fast Programming Function by Extended Command
- Temporary sector unprotection

Temporary sector unprotection via the RESET pin.

## PACKAGES



## MBM29DL800TA-7090/MBM29DL800BA-7090

## GENERAL DESCRIPTION

The MBM29DL800TA/BA are a 8M-bit, 3.0 V-only Flash memory organized as 1 M bytes of 8 bits each or 512 K words of 16 bits each. The MBM29DL800TA/BA are offered in a 48-pin TSOP(1) and 48-ball FBGA packages. These devices are designed to be programmed in-system with the standard system 3.0 V Vcc supply. 12.0 V VPP and 5.0 V Vcc are not required for write or erase operations. The devices can also be reprogrammed in standard EPROM programmers.

MBM29DL800TA/BA provide simultaneous operation which can read a data during program/erase. The simultaneous operation architecture provides simultaneous operation by dividing the memory space into two banks. The device can allow a host system to program or erase in one bank, then immediately and simultaneously read from the other bank.

The standard MBM29DL800TA/BA offer access times 70 ns and 90 ns , allowing operation of high-speed microprocessors without wait states. To eliminate bus contention the devices have separate chip enable (CE), write enable ( $\overline{\mathrm{WE}}$ ), and output enable ( $\overline{\mathrm{OE}}$ ) controls.

The MBM29DL800TA/BA are pin and command set compatible with JEDEC standard E²PROMs. Commands are written to the command register using standard microprocessor write timings. Register contents serve as input to an internal state-machine which controls the erase and programming circuitry. Write cycles also internally latch addresses and data needed for the programming and erase operations. Reading data out of the devices is similar to reading from 5.0 V and 12.0 V Flash or EPROM devices.

The MBM29DL800TA/BA are programmed by executing the program command sequence. This will invoke the Embedded Program Algorithm which is an internal algorithm that automatically times the program pulse widths and verifies proper cell margin. Typically, each sector can be programmed and verified in about 0.5 seconds. 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 devices automatically time the erase pulse widths and verify proper cell margin.

A sector is typically erased and verified in 1.0 second. (If already completely preprogrammed.)
The devices also feature a sector erase architecture. The sector mode allows each sector to be erased and reprogrammed without affecting other sectors. The MBM29DL800TA/BA are erased when shipped from the factory.

The devices feature single 3.0 V power supply operation for both read and write functions. Internally generated and regulated voltages are provided for the program and erase operations. A low $\mathrm{V} c \mathrm{~d}$ detector automatically inhibits write operations on the loss of power. The end of program or erase is detected by Data Polling of DQ7, by the Toggle Bit feature on $\mathrm{DQ}_{6}$, or the $\mathrm{RY} / \overline{\mathrm{BY}}$ output pin. Once the end of a program or erase cycle has been completed, the devices internally reset to the read mode.

Fujitsu's Flash technology combines years of EPROM and E2PROM experience to produce the highest levels of quality, reliability, and cost effectiveness. The MBM29DL800TA/BA memories electrically erase the entire chip or 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.

## MBM29DL800TA-7090/MBM29DL800BA-7090

## $\square$ PRODUCT LINE UP

| Part No. |  | MBM29DL800TA/MBM29DL800BA |  |
| :--- | :--- | :---: | :---: |
| Ordering Part No. | $\mathrm{V}_{\mathrm{cc}}=3.3 \mathrm{~V}_{-0.3 \mathrm{~V}}^{+0.3 \mathrm{~V}}$ | -70 | - |
|  | $\mathrm{V}_{\mathrm{cc}}=3.0 \mathrm{~V}_{-0.3 \mathrm{~V}}^{+0.6}$ | - | -90 |
| Max Address Access Time (ns) | 70 | 90 |  |
| Max $\overline{\mathrm{CE}}$ Access Time (ns) | 70 | 90 |  |
| Max $\overline{\mathrm{OE}}$ Access Time (ns) | 30 | 35 |  |

## BLOCK DIAGRAM



## MBM29DL800TA-70/90/MBM29DL800BA-70/90

## PIN ASSIGNMENTS



| $\mathrm{A}_{1}$ | 24 | (Marking Side) | 25 | A0 |
| :---: | :---: | :---: | :---: | :---: |
| $A_{2}$ | 23 |  | 26 | CE |
| А 3 | 22 |  | 27 | V ss |
| $\mathrm{A}_{4}$ | 21 |  | 28 | $\square \mathrm{OE}$ |
| $\mathrm{A}_{5}$ | 20 |  | 29 | $\square \mathrm{DQ}_{0}$ |
| $A_{6}$ | 19 |  | 30 | $\square \mathrm{DQ}_{8}$ |
| A7 | 18 |  | 31 | $\square \mathrm{DQ}_{1}$ |
| $\mathrm{A}_{17}$ | 17 |  | 32 | $\square \mathrm{DQ}_{9}$ |
| $A_{18}$ | 16 |  | 33 | $\square \mathrm{DQ}_{2}$ |
| RY/BY $\square$ | 15 |  | 34 | $\mathrm{DQ}_{10}$ |
| N.C. | 14 |  | 35 | $\mathrm{DQ}_{3}$ |
| N.C. | 13 | MBM29DL800TA/MBM29DL800BA | 36 | DQ11 |
| RESET $\square$ | 12 | Reverse Bend | 37 | $\square \mathrm{Vcc}$ |
| WE $\square$ | 11 |  | 38 | $\mathrm{DQ}_{4}$ |
| N.C. | 10 |  | 39 | $\square \mathrm{DQ}_{12}$ |
| N.C. $\square$ | 9 |  | 40 | $\checkmark \mathrm{DQ}_{5}$ |
| A8 | 8 |  | 41 | $\mathrm{DQ}_{13}$ |
| A9 $\square$ | 7 |  | 42 | $\square \mathrm{DQ}^{7}$ |
| $A_{10} \square$ | 6 |  | 43 | $\square \mathrm{DQ}_{14}$ |
| $A_{11}$ | 5 |  | 44 | $\square \mathrm{DQ}_{7}$ |
| $A_{12}$ | 4 |  | 45 | $\square \mathrm{DQ}_{15} / \mathrm{A}$ |
| $A_{13}$ | 3 |  | 46 | $\square \mathrm{V}$ ss |
| $A_{14}$ | 2 |  | 47 | $\square$ BYTE |
| $A_{15}$ | $1 \bigcirc$ |  | 48 | ${ }^{\text {A }} 16$ |

(Continued)

## MBM29DL800TA-7090/MBM29DL800BA-7090

(Continued)


- PIN DESCRIPTION

| Pin Name | Function |
| :---: | :--- |
| $\mathrm{A}_{-1}, \mathrm{~A}_{0}$ to $\mathrm{A}_{18}$ | Address Inputs |
| $\mathrm{DQ}_{0}$ to $\mathrm{DQ}_{15}$ | Data Inputs/Outputs |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\overline{\mathrm{WE}}$ | Write Enable |
| $\mathrm{RY} \overline{\mathrm{BY}}$ | Ready/Busy Output |
| $\overline{\mathrm{RESET}}$ | Hardware Reset Pin/Temporary Sector <br> Unprotection |
| $\overline{\mathrm{BYTE}}$ | Selects 8-bit or 16-bit mode |
| N.C. | No Internal Connection |
| Vss | Device Ground |
| Vcc | Device Power Supply |

## LOGIC SYMBOL



## MBM29DL800TA-7090/MBM29DL800BA-70/90

## ■ DEVICE BUS OPERATION

MBM29DL800TA/BA User Bus Operations Table ( $\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{H}}$ )

| Operation | $\overline{C E}$ | $\overline{\mathrm{OE}}$ | WE | A | $\mathrm{A}_{1}$ | $A_{6}$ | A9 | DQ ${ }_{0}$ to $\mathrm{DQ}_{15}$ | RESET |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Auto-Select Manufacturer Code** | L | L | H | L | L | L | VID | Code | H |
| Auto-Select Device Code*1 | L | L | H | H | L | L | VID | Code | H |
| Read*3 | L | L | H | A 0 | $\mathrm{A}_{1}$ | $\mathrm{A}_{6}$ | A9 | Dout | H |
| Standby | H | X | X | X | X | X | X | High-Z | H |
| Output Disable | L | H | H | X | X | X | X | High-Z | H |
| Write (Program/Erase) | L | H | L | Ao | $\mathrm{A}_{1}$ | $\mathrm{A}_{6}$ | A9 | Din | H |
| Enable Sector Protection*2, *4 | L | VID | Ч | L | H | L | VID | X | H |
| Verify Sector Protection *2, *4 | L | L | H | L | H | L | VID | Code | H |
| Temporary Sector Unprotection*5 | X | X | X | X | X | X | X | X | VID |
| Reset (Hardware)/Standby | X | X | X | X | X | X | X | High-Z | L |

MBM29DL800TA/BA User Bus Operations Table ( $\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{L}}$ )

| Operation | $\overline{C E}$ | $\overline{O E}$ | WE | $\underset{\mathbf{A}_{15}}{\mathbf{A Q}_{15}}$ | A0 | $\mathrm{A}_{1}$ | A6 | A9 | $\mathrm{DQ}_{0}$ to $\mathrm{DQ}_{7}$ | RESET |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Auto-Select Manufacturer Code*1 | L | L | H | L | L | L | L | VID | Code | H |
| Auto-Select Device Code*1 | L | L | H | L | H | L | L | VID | Code | H |
| Read*3 | L | L | H | A-1 | $A_{0}$ | $\mathrm{A}_{1}$ | $\mathrm{A}_{6}$ | A9 | Dout | H |
| Standby | H | X | X | X | X | X | X | X | High-Z | H |
| Output Disable | L | H | H | X | X | X | X | X | High-Z | H |
| Write (Program/Erase) | L | H | L | A-1 | Ao | $\mathrm{A}_{1}$ | $A_{6}$ | A9 | Din | H |
| Enable Sector Protection*2, *4 | L | VID | $\checkmark$ | L | L | H | L | $V_{\text {II }}$ | X | H |
| Verify Sector Protection *2, *4 | L | L | H | L | L | H | L | $V_{10}$ | Code | H |
| Temporary Sector Unprotection *5 | X | X | X | X | X | X | X | X | X | VID |
| Reset (Hardware)/Standby | X | X | X | X | X | X | X | X | High-Z | L |

Legend: $\mathrm{L}=\mathrm{V}_{\mathrm{IL}}, \mathrm{H}=\mathrm{V}_{\mathrm{IH}}, \mathrm{X}=\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{H}}, ~ 乙=$ Pulse input. See " ${ }^{\text {DC }}$ CHARACTERISTICS" for voltage levels.
*1 : Manufacturer and device codes may also be accessed via a command register write sequence. See "MBM29DL800TA/BA Command Definitions Table".
*2 : Refer to the section on Sector Protection.
*3 : $\overline{\mathrm{WE}}$ can be $\mathrm{V}_{\text {IL }}$ if $\overline{\mathrm{OE}}$ is $\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{OE}}$ at $\mathrm{V}_{\mathrm{IH}}$ initiates the write operations.
*4: Vcc = $3.0 \mathrm{~V} \pm 10 \%$
*5 : It is also used for the extended sector protection.

## MBM29DL800TA-7090/MBM29DL800BA-7090

MBM29DL800TA/BA Command Definitions Table

| Command Sequence |  | BusWriteCyclesReq'd | First Bus Write Cycle |  | Second Bus Write Cycle |  | Third Bus Write Cycle |  | Fourth Bus Read/Write Cycle |  | Fifth Bus Write Cycle |  | Sixth Bus Write Cycle |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Addr. | Data | Addr. | Data | Addr. | Data | Addr. | Data | Addr. | Data | Addr. | Data |
| Read/Reset | Word <br> Byte |  | 1 | XXXh | F0h | - | - | - | - | - | - | - | - | - | - |
| Read/Reset | $\begin{array}{\|c\|} \hline \text { Word } \\ \hline \text { Byte } \\ \hline \end{array}$ | 3 | 555h | AAh | $\begin{aligned} & \text { 2AAh } \\ & \hline 555 h \end{aligned}$ | 55h | $\begin{aligned} & \hline 555 h \\ & \hline \text { AAAh } \end{aligned}$ | F0h | RA | RD | - | - | - | - |
| Autoselect | Word | 3 | 555h | AAh | 2AAh | 55h | $\begin{gathered} \hline \text { (BA) } \\ 555 \mathrm{~h} \\ \hline \text { (BA) } \\ \text { AAAh } \end{gathered}$ | 90h | - | - | - | - | - | - |
| Program | $\begin{array}{\|c\|} \hline \text { Word } \\ \hline \text { Byte } \\ \hline \end{array}$ | 4 | $\begin{aligned} & \text { 555h } \\ & \hline \text { AAAh } \end{aligned}$ | AAh | $\frac{2 A A h}{555 h}$ | 55h | $\begin{gathered} 555 h \\ \hline \text { AAAh } \end{gathered}$ | A0h | PA | PD | - | - | - | - |
| Chip Erase | $\begin{array}{\|c\|} \hline \text { Word } \\ \hline \text { Byte } \\ \hline \end{array}$ | 6 | 555h <br> AAAh | AAh | $\frac{2 A A h}{555 h}$ | 55h | 555h <br> AAAh | 80h | 555h <br> AAAh | AAh | $\frac{2 A A h}{555 h}$ | 55h | $\begin{aligned} & \text { 555h } \\ & \hline \text { AAAh } \end{aligned}$ | 10h |
| Sector Erase | $\begin{array}{\|c\|} \hline \text { Word } \\ \hline \text { Byte } \\ \hline \end{array}$ | 6 | $\begin{aligned} & \text { 555h } \\ & \hline \text { AAAh } \end{aligned}$ | AAh | $\frac{2 A A h}{555 h}$ | 55h | $\begin{gathered} \hline 555 h \\ \hline \text { AAAh } \end{gathered}$ | 80h | $\begin{aligned} & \text { 555h } \\ & \hline \text { AAAh } \end{aligned}$ | AAh | $\frac{2 A A h}{555 h}$ | 55h | SA | 30h |
| Erase Sus | end | 1 | BA | B0h | - | - | - | - | - | - | - | - | - | - |
| Erase Res | me | 1 | BA | 30h | - | - | - | - | - | - | - | - | - | - |
| Set to Fast Mode | $\begin{array}{\|c\|} \hline \text { Word } \\ \hline \text { Byte } \\ \hline \end{array}$ | 3 | 555h <br> AAAh | AAh | $\frac{2 A A h}{555 h}$ | 55h | 555h <br> AAAh | 20h | - | - | - | - | - | - |
| Fast Program *1 | Word | 2 | $\begin{aligned} & \mathrm{XXXh} \\ & \hline \mathrm{XXXh} \end{aligned}$ | A0h | PA | PD | - | - | - | - | - | - | - | - |
| Reset from Fast Mode * | Word | 2 | $\begin{aligned} & \mathrm{BA} \\ & \hline \mathrm{BA} \end{aligned}$ | 90h | $\begin{aligned} & \text { XXXh } \\ & \hline \text { XXXh } \end{aligned}$ | $\underset{* 3}{\text { FOh }}$ | - | - | - | - | - | - | - | - |
| Extended Sector Protect*2 | Word <br> Byte | 4 | XXXh | 60h | SPA | 60h | SPA | 40h | SPA | SD | - | - | - | - |

*1 : This command is valid during Fast Mode.
*2 : This command is valid while $\overline{\operatorname{RESET}}=\mathrm{V}_{\mathrm{I} D}$.
*3 : This data "00h" is also acceptable.
Notes : •Address bits $\mathrm{A}_{12}$ to $\mathrm{A}_{18}=\mathrm{X}=$ "H" or "L" for all address commands except or Program Address (PA), Sector Address (SA), and Bank Address (BA).

- Bus operations are defined in "MBM29DL800TA/BA User Bus Operations Tables ( $\overline{\mathrm{BYTE}}=\mathrm{V}_{\text {H }}$ and $\overline{\mathrm{BYTE}}$ $=V_{\text {IL }}$ )".
- 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 write pulse.
$S A=$ Address of the sector to be erased. The combination of $A_{18}, A_{17}, A_{16}, A_{15}, A_{14}, A_{13}$, and $A_{12}$ will uniquely select any sector.
BA =Bank Address (A16 to A 18 )
-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 write pulse.

- SPA $=$ Sector address to be protected. Set sector address (SA) and ( $\left.\mathrm{A}_{6}, \mathrm{~A}_{1}, \mathrm{~A}_{0}\right)=(0,1,0)$.

SD $=$ Sector protection verify data. Output 01 h at protected sector addresses and output 00h at unprotected sector addresses.
-The system should generate the following address patterns:
Word Mode: 555 h or 2AAh to addresses $A_{0}$ to $A_{11}$
Byte Mode: AAAh or 555h to addresses $\mathrm{A}_{-1}$ and $\mathrm{A}_{0}$ to $\mathrm{A}_{11}$

- Both Read/Reset commands are functionally equivalent, resetting the device to the read mode.
-The command combinations not described in "MBM29DL800TA/BA Command Definitions Table" are illegal.


## MBM29DL800TA-7090/MBM29DL800BA-70/90

MBM29DL800TA/BA Sector Protection Verify Autoselect Codes Table

| Type |  |  | $\mathrm{A}_{12}$ to $\mathrm{A}_{18}$ | $\mathrm{A}_{6}$ | $\mathrm{A}_{1}$ | A0 | A-1 ${ }^{+1}$ | Code (HEX) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacture's Code |  |  | X | VIL | VIL | VIL | VIL | 04h |
| Device Code | MBM29DL800TA | Byte | X | VIL | VIL | VIH | VIL | 4Ah |
|  |  | Word |  |  |  |  | X | 224Ah |
|  | MBM29DL800BA | Byte | X | VIL | VIL | V ${ }_{\text {H }}$ | VIL | CBh |
|  |  | Word |  |  |  |  | X | 22CBh |
| Sector Protection |  |  | Sector Addresses | VIL | VIH | VIL | VIL | $01{ }^{* 2}$ |

*1 : A-1 is for Byte mode. At Byte mode, DQ8 to DQ14 are High-Z and DQ ${ }_{15}$ is $\mathrm{A}_{-1}$, the lowest address.
*2 : Outputs 01h at protected sector addresses and outputs 00 h at unprotected sector addresses.
Extended Autoselect Code Table

| Type |  |  | Code | DQ ${ }_{15}$ | DQ ${ }_{14}$ | DQ ${ }_{13}$ | DQ ${ }_{12}$ | DQ ${ }_{11}$ | DQ ${ }_{10}$ | DQ9 | DQ | DQ7 | DQ 6 | DQ ${ }_{5}$ | DQ 4 | $\mathrm{DQ}_{3}$ | DQ ${ }_{2}$ | DQ 1 | DQ 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer's Code |  |  | 04h | A.1/0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| Device Code | MBM29DL800TA | (B)* | 4Ah | A-1 | HI-Z | HI-Z | HI-Z | HI-Z | HI-Z | HI-Z | HI-Z | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 |
|  |  | (W) | 224Ah | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 |
|  | MBM29DL800BA | (B)* | CBh | A-1 | HI-Z | HI-Z | HI-Z | HI-Z | HI-Z | HI-Z | HI-Z | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 |
|  |  | (W) | 22CBh | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 |
| Sector Protection |  |  | 01h | A.1/0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |

(B): Byte mode
(W): Word mode

HI-Z: High-Z

* : At Byte mode, DQ8 to $\mathrm{DQ}_{14}$ are High-Z and DQ15 is $\mathrm{A}^{-1}$, the lowest address.


## MBM29DL800TA-7090/MBM29DL800BA-7090

## ■ FLEXIBLE SECTOR-ERASE ARCHITECTURE

- Two 16 K bytes, four 8 K bytes, two 32 K bytes, and fourteen 64 K bytes
- Individual-sector, multiple-sector, or bulk-erase capability
- Individual or multiple-sector protection is user definable.

|  |  | ( $\times 8$ ) ( $\times 16$ ) |  |  | ( $\times 8$ ) | ( $\times 16$ ) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bank 1 | 16 K byte | FFFFFh 7FFFFh |  | 64 K byte | FFFFFh 7FFFFh |  |
|  | 32 K byte | FBFFFh 7DFFFh |  | 64 K byte | EFFFFh 77FFFh |  |
|  | 8 K byte | F3FFFh 79FFFh |  | 64 K byte | DFFFFh 6FFFFh |  |
|  | 8 K byte | F1FFFh 78FFFh |  | 64 K byte | CFFFFh 67FFFh |  |
|  | 8 K byte | EFFFFh 77FFFh |  | 64 K byte | BFFFFh 5FFFFh |  |
|  |  | EDFFFh 76FFFh |  |  | AFFFFh 57FFFh |  |
|  | 8 K byte |  |  | 64 K byte | 9FFFFh 4FFFFh |  |
|  | 32 K byte | EBFFFh 75FFFh |  | 64 K byte |  |  |
|  | 16 K byte | DFFFFh 6FFFFh CFFFFh 67FFFh |  | 64 K byte | 7FFFFh 3FFFFh |  |
| Bank 2 2 | 64 K byte |  |  | 64 K byte |  |  |
|  |  |  |  |  | 6FFFFh | 37FFFh |
|  | 64 K byte | BFFFFh 5FFF |  | 64 K byte | 5FFFFh 2FFFFh |  |
|  | 64 K byte | AFFFFh 57FFF |  | 64 K byte |  |  |
|  | 64 K byte | 9FFFFh 4FFFFh |  | 64 K byte | 4FFFFh 27FFFh |  |
|  | 64 K byte | 8FFFFh 47FFFh |  | 64 K byte | 3 3FFFFh 1FFFFh |  |
|  | 64 K byte |  |  | 64 K byte | 2FFFFh 17FFFh |  |
|  |  | 7FFFFh 3FFFFh |  |  | 1FFFFFh OFFFFh |  |
|  | 64 K byte |  |  | 16 K byte |  |  |
|  | 64 K byte | 6FFFFh 37FFFh |  | 32 K byte | 1BFFFh ODFFFh |  |
|  | 64 K byte | 5FFFFh 2FFFFh |  | 8 K byte | 13FFFh 09FFFh |  |
|  | 64 K byte | 4FFFFh 27FFFh |  | 8 K byte | 11FFFh 08FFFh |  |
|  | 64 K byte | 3FFFFh 1FFFFh Bank 12 |  | 8 K byte | OFFFFh 07FFFh |  |
|  | 64 K byte | 2FFFFh 17FFFh1FFFFh OFFFFh |  | 8 K byte | ODFFFh 06FFFh |  |
|  |  |  |  |  | OBFFFh | 05FFFh |
|  | 64 K byte |  |  | 32 K byte |  |  |
|  | 64 K byte |  |  | 16 K byte |  |  |
|  |  | 00000h 00000h |  |  | 00000h | 00000h |
|  | MBM29DL800TA Sector Architecture |  |  | MBM29DL800BA Sector Architecture |  |  |

## MBM29DL800TA-70/90/MBM29DL800BA-70/90

Sector Address Table (MBM29DL800BA)

| Bank | Sector | Sector Address |  |  |  |  |  |  | Sector Size (Kbytes/ Kwords) | $\underset{(\times 8)}{(\times 8)}$ Address Range | $(\times 16)$ <br> Address Range |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Bank Address |  |  | A15 | $\mathrm{A}_{14}$ | $\mathrm{A}_{13}$ | $\mathrm{A}_{12}$ |  |  |  |
|  |  | $\mathrm{A}_{18}$ | $\mathrm{A}_{17}$ | $\mathrm{A}_{16}$ |  |  |  |  |  |  |  |
| Bank 2 | SA21 | 1 | 1 | 1 | 1 | X | X | X | 64/32 | F0000h to FFFFFh | 78000h to 7FFFFh |
|  | SA20 | 1 | 1 | 1 | 0 | X | X | X | 64/32 | E0000h to EFFFFh | 70000h to 77FFFh |
|  | SA19 | 1 | 1 | 0 | 1 | X | X | X | 64/32 | D0000h to DFFFFh | 68000h to 6FFFFh |
|  | SA18 | 1 | 1 | 0 | 0 | X | X | X | 64/32 | C0000h to CFFFFh | 60000h to 67FFFh |
|  | SA17 | 1 | 0 | 1 | 1 | X | X | X | 64/32 | B0000h to BFFFFh | 58000h to 5FFFFh |
|  | SA16 | 1 | 0 | 1 | 0 | X | X | X | 64/32 | A0000h to AFFFFh | 50000h to 57FFFh |
|  | SA15 | 1 | 0 | 0 | 1 | X | X | X | 64/32 | 90000h to 9FFFFh | 48000h to 4FFFFh |
|  | SA14 | 1 | 0 | 0 | 0 | X | X | X | 64/32 | 80000h to 8FFFFh | 40000h to 47FFFh |
|  | SA13 | 0 | 1 | 1 | 1 | X | X | X | 64/32 | 70000h to 7FFFFh | 38000h to 3FFFFh |
|  | SA12 | 0 | 1 | 1 | 0 | X | X | X | 64/32 | 60000h to 6FFFFh | 30000h to 37FFFh |
|  | SA11 | 0 | 1 | 0 | 1 | X | X | X | 64/32 | 50000h to 5FFFFh | 28000h to 2FFFFh |
|  | SA10 | 0 | 1 | 0 | 0 | X | X | X | 64/32 | 40000h to 4FFFFh | 20000h to 27FFFh |
|  | SA9 | 0 | 0 | 1 | 1 | X | X | X | 64/32 | 30000h to 3FFFFh | 18000h to 1FFFFh |
|  | SA8 | 0 | 0 | 1 | 0 | X | X | X | 64/32 | 20000h to 2FFFFh | 10000h to 17FFFh |
| Bank 1 | SA7 | 0 | 0 | 0 | 1 | 1 | 1 | X | 16/8 | 1C000h to 1FFFFh | 0E000h to 0FFFFh |
|  | SA6 | 0 | 0 | 0 | 1 | 1 0 | 0 1 | X | 32/16 | 18000h to 1BFFFh, 14000h to 17FFFh | OC000h to ODFFFh, OA000h to OBFFFh |
|  | SA5 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 8/4 | 12000h to 13FFFh | 09000h to 09FFFh |
|  | SA4 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 8/4 | 10000h to 11FFFh | 08000h to 08FFFh |
|  | SA3 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 8/4 | OE000h to 0FFFFh | 07000h to 07FFFh |
|  | SA2 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 8/4 | 0C000h to 0DFFFh | 06000h to 06FFFh |
|  | SA1 | 0 | 0 | 0 | 0 | 1 0 | 0 | X | 32/16 | 08000h to OBFFFh, 04000h to 07FFFh | 04000h to 05FFFh, 02000h to 03FFFh |
|  | SAO | 0 | 0 | 0 | 0 | 0 | 0 | X | 16/8 | 00000h to 03FFFh | 00000h to 01FFFh |

Note : The address range is $\mathrm{A}_{18}$ : $\mathrm{A}_{-1}$ if in byte mode ( $\left.\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{IL}}\right)$.
The address range is $A_{18}: A_{0}$ if in word mode ( $\left.\overline{\text { BYTE }}=V^{\prime}\right)$ ).

## MBM29DL800TA-7099/MBM29DL800BA-7090

Sector Address Table (MBM29DL800TA)

| Bank | Sector | Sector Address |  |  |  |  |  |  | $\begin{gathered} \text { Sector Size } \\ \text { (Kbytes/ } \\ \text { Kwords) } \end{gathered}$ | $\begin{gathered} (\times 8) \\ \text { Address Range } \end{gathered}$ | $\stackrel{(\times 16)}{ } \text { Address Range }$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | BankAddress |  |  | $\mathrm{A}_{15}$ | $\mathrm{A}_{14}$ | $\mathrm{A}_{13}$ | $\mathrm{A}_{12}$ |  |  |  |
|  |  | $\mathrm{A}_{18}$ | $\mathrm{A}_{17}$ | $\mathrm{A}_{16}$ |  |  |  |  |  |  |  |
| Bank 2 | SAO | 0 | 0 | 0 | 0 | X | X | X | 64/32 | 00000h to 0FFFFh | 00000h to 07FFFh |
|  | SA1 | 0 | 0 | 0 | 1 | X | X | X | 64/32 | 10000h to 1FFFFh | 08000h to 0FFFFh |
|  | SA2 | 0 | 0 | 1 | 0 | X | X | X | 64/32 | 20000h to 2FFFFh | 10000h to 17FFFh |
|  | SA3 | 0 | 0 | 1 | 1 | X | X | X | 64/32 | 30000h to 3FFFFh | 18000h to 1FFFFFh |
|  | SA4 | 0 | 1 | 0 | 0 | X | X | X | 64/32 | 40000h to 4FFFFh | 20000h to 27FFFh |
|  | SA5 | 0 | 1 | 0 | 1 | X | X | X | 64/32 | 50000h to 5FFFFh | 28000h to 2FFFFh |
|  | SA6 | 0 | 1 | 1 | 0 | X | X | X | 64/32 | 60000h to 6FFFFh | 30000h to 37FFFh |
|  | SA7 | 0 | 1 | 1 | 1 | X | X | X | 64/32 | 70000h to 7FFFFh | 38000h to 3FFFFh |
|  | SA8 | 1 | 0 | 0 | 0 | X | X | X | 64/32 | 80000h to 8FFFFh | 40000h to 47FFFh |
|  | SA9 | 1 | 0 | 0 | 1 | X | X | X | 64/32 | 90000h to 9FFFFh | 48000h to 4FFFFh |
|  | SA10 | 1 | 0 | 1 | 0 | X | X | X | 64/32 | A0000h to AFFFFh | 50000h to 57FFFh |
|  | SA11 | 1 | 0 | 1 | 1 | X | X | X | 64/32 | B0000h to BFFFFh | 58000h to 5FFFFh |
|  | SA12 | 1 | 1 | 0 | 0 | X | X | X | 64/32 | C0000h to CFFFFh | 60000h to 67FFFh |
|  | SA13 | 1 | 1 | 0 | 1 | X | X | X | 64/32 | D0000h to DFFFFh | 68000h to 6FFFFh |
| Bank 1 | SA14 | 1 | 1 | 1 | 0 | 0 | 0 | X | 16/8 | E0000h to E3FFFh | 70000h to 71FFFh |
|  | SA15 | 1 | 1 | 1 | 0 | 0 1 | 1 | X | 32/16 | E4000h to E7FFFh, E8000h to EBFFFh | 72000h to 73FFFh, <br> 74000h to 75FFFh |
|  | SA16 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 8/4 | EC000h to EDFFFh | 76000h to 76FFFh |
|  | SA17 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 8/4 | EE000h to EFFFFh | 77000h to 77FFFh |
|  | SA18 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 8/4 | F0000h to F1FFFh | 78000h to 78FFFh |
|  | SA19 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 8/4 | F2000h to F3FFFh | 79000h to 79FFFh |
|  | SA20 | 1 | 1 | 1 | 1 | 0 1 | 1 | X | 32/16 | F4000h to F7FFFh, F8000h to FBFFFh | 7A000h to 7BFFFh, 7C000h to 7DFFFh |
|  | SA21 | 1 | 1 | 1 | 1 | 1 | 1 | X | 16/8 | FC000h to FFFFFh | 7E000h to 7FFFFh |

Note : The address range is $\mathrm{A}_{18}$ : $\mathrm{A}_{-1}$ if in byte mode $\left(\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{L}}\right)$.
The address range is $\mathrm{A}_{18}$ : $\mathrm{A}_{0}$ if in word mode ( $\overline{\mathrm{BYTE}}=\mathrm{V}_{\boldsymbol{\prime}}$ ).

## MBM29DL800TA-7090/MBM29DL800BA-7090

## FUNCTIONAL DESCRIPTION

## Simultaneous Operation

MBM29DL800TA/BA have feature, which is capability of reading data from one bank of memory while a program or erase operation is in progress in the other bank of memory (simultaneous operation), in addition to the conventional features (read, program, erase, erase-suspend read, and erase-suspend program). The bank selection can be selected by bank address ( $\mathrm{A}_{16}$ to $\mathrm{A}_{18}$ ) with zero latency.

The MBM29DL800TA/BA have two banks which contain Bank 1 ( $16 \mathrm{~KB}, 32 \mathrm{~KB}, 8 \mathrm{~KB}, 8 \mathrm{~KB}, 8 \mathrm{~KB}, 8 \mathrm{~KB}, 32 \mathrm{~KB}$, and 16 KB ) and Bank 2 ( $64 \mathrm{~KB} \times$ fourteen sectors).
The simultaneous operation can not execute multi-function mode in the same bank. "Simultaneous Operation Table" shows combination to be possible for simultaneous operation.

Simultaneous Operation Table

| Case | Bank 1 Status | Bank 2 Status |
| :---: | :---: | :---: |
| 1 | Read mode | Read mode |
| 2 | Read mode | Autoselect mode |
| 3 | Read mode | Program mode |
| 4 | Read mode | Erase mode ${ }^{*}$ |
| 5 | Autoselect mode | Read mode |
| 6 | Program mode | Read mode |
| 7 | Erase mode * | Read mode |

*: An erase operation may also be supended to read from or program to a sector not being erased.

## Read Mode

The MBM29DL800TA/BA have two control functions which must be satisfied in order to obtain data at the outputs. $\overline{\mathrm{CE}}$ is the power control and should be used for a device selection. $\overline{\mathrm{OE}}$ is the output control and should be used to gate data to the output pins if a device is selected.
Address access time (tacc) is equal to the delay from stable addresses to valid output data. The chip enable access time (tcE) is the delay from stable addresses and stable $\overline{\mathrm{CE}}$ to valid data at the output pins. The output enable access time is the delay from the falling edge of $\overline{O E}$ to valid data at the output pins. (Assuming the addresses have been stable for at least tacc-toe time.) When reading out a data without changing addresses after power-up, it is necessary to input hardware reset or to change CE pin from " H " or " L "

## Standby Mode

There are two ways to implement the standby mode on the MBM29DL800TA/BA devices, one using both the $\overline{\mathrm{CE}}$ and RESET pins; the other via the RESET pin only.

When using both pins, a CMOS standby mode is achieved with CE and RESET inputs both held at $\mathrm{V}_{\mathrm{cc}} \pm 0.3 \mathrm{~V}$. Under this condition the current consumed is less than $5 \mu \mathrm{~A}$ Max During Embedded Algorithm operation, Vcc active current (Iccz) is required even $\overline{\mathrm{CE}}=$ " H ". The device can be read with standard access time ( tcE ) from either of these standby modes.
When using the $\overline{\text { RESET }}$ pin only, a CMOS standby mode is achieved with $\overline{\text { RESET }}$ input held at $\mathrm{V}_{\mathrm{ss}} \pm 0.3 \mathrm{~V}$ ( $\overline{\mathrm{CE}}$ $=$ " H " or " L "). Under this condition the current is consumed is less than $5 \mu \mathrm{~A}$ Max Once the RESET pin is taken high, the device requires trн of wake up time before outputs are valid for read access.
In the standby mode the outputs are in the high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## MBM29DL800TA-7090/MBM29DL800BA-7090

## Automatic Sleep Mode

There is a function called automatic sleep mode to restrain power consumption during read-out of MBM29DL800TA/BA data. This mode can be used effectively with an application requested low power consumption such as handy terminals.

To activate this mode, MBM29DL800TA/BA automatically switch themselves to low power mode when MBM29DL800TA/BA addresses remain stably during access fine of 150 ns . It is not necessary to control $\overline{\mathrm{CE}}$, $\overline{\mathrm{WE}}$, and $\overline{\mathrm{OE}}$ on the mode. Under the mode, the current consumed is typically $1 \mu \mathrm{~A}$ (CMOS Level).
During simultaneous operation, $\mathrm{V}_{\mathrm{cc}}$ active current (Iccz) is required.
Since the data are latched during this mode, the data are read-out continuously. If the addresses are changed, the mode is canceled automatically and MBM29DL800TA/BA read-out the data for changed addresses.

## Output Disable

With the $\overline{\mathrm{OE}}$ input at a logic high level $\left(\mathrm{V}_{\boldsymbol{H}}\right)$, output from the devices are 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 devices and will identify its manufacturer and type. This mode is intended for use by programming equipment for the purpose of automatically matching the devices to be programmed with its corresponding programming algorithm. This mode is functional over the entire temperature range of the devices.
To activate this mode, the programming equipment must force $\mathrm{V}_{\mathrm{ID}}(11.5 \mathrm{~V}$ to 12.5 V ) on address pin A . Two identifier bytes may then be sequenced from the devices outputs by toggling address $\mathrm{A}_{0}$ from $\mathrm{V}_{\text {IL }}$ to $\mathrm{V}_{\text {Ir. }}$. All addresses are DON'T CARES except $\mathrm{A}_{0}, \mathrm{~A}_{1}$, and $\mathrm{A}_{6}\left(\mathrm{~A}_{-1}\right)$. (See "MBM29DL800TA/BA User Bus Operations Tables ( $\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{H}}$ and $\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{IL}}$ )" in ■DEVICE BUS OPERATION.)
The manufacturer and device codes may also be read via the command register, for instances when the MBM29DL800TA/BA are erased or programmed in a system without access to high voltage on the As pin. The command sequence is illustrated in "MBM29DL800TA/BA Command Definitions Table" (in ■DEVICE BUS OPERATION). (Refer to Autoselect Command section.)
Word $0\left(\mathrm{~A}_{0}=\mathrm{V}_{L}\right)$ represents the manufacturer's code (Fujitsu $=04 \mathrm{~h}$ ) and word $1\left(\mathrm{~A}_{0}=\mathrm{V}_{H}\right)$ represents the device identifier code (MBM29DL800TA $=4 \mathrm{Ah}$ and MBM29DL800BA $=\mathrm{CBh}$ for $\times 8$ mode; MBM29DL800TA $=224 \mathrm{Ah}$ and MBM29DL800BA $=22 C B h$ for $\times 16$ mode). These two bytes/words are given in "MBM29DL800TA/BA Sector Protection Verify Autoselect Codes Table" and "Extended Autoselect Code Table" (in ■DEVICE BUS OPERATION). All identifiers for manufactures 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, A must be VIL. (See "MBM29DL800TA/BA Sector Protection Verify Autoselect Codes Table" and "Extended Autoselect Code Table" in ■DEVICE BUS OPERATION.)
In case of applying $\mathrm{V}_{\mathrm{ID}}$ on $\mathrm{A}_{9}$, since both Bank 1 and Bank 2 enters Autoselect mode, the simultenous operation can not be executed.

## 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 by bringing $\overline{\mathrm{WE}}$ to $\mathrm{V}_{\mathrm{LL}}$, while $\overline{\mathrm{CE}}$ is at $\mathrm{V}_{\mathrm{IL}}$ and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. Addresses are latched on the falling edge of $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$, whichever happens later; while data is latched on the rising edge of $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$, whichever happens first. Standard microprocessor write timings are used.
Refer to AC Write Characteristics and the Erase/Programming Waveforms for specific timing parameters.

## MBM29DL800TA-7090/MBM29DL800BA-70/90

## Sector Protection

The MBM29DL800TA/BA feature hardware sector protection. This feature will disable both program and erase operations in any number of sectors ( 0 through 21). The sector protection feature is enabled using programming equipment at the user's site. The devices are shipped with all sectors unprotected. Alternatively, Fujitsu may program and protect sectors in the factory prior to shiping the device.
To activate this mode, the programming equipment must force $\mathrm{V}_{\mathrm{II}}$ on address pin $\mathrm{A}_{9}$ and control pin $\overline{\mathrm{OE}}$, (suggest $\mathrm{V}_{\mathrm{ID}}=11.5 \mathrm{~V}$ ), $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$, and $\mathrm{A}_{0}=\mathrm{A}_{6}=\mathrm{V}_{\mathrm{LL}}, \mathrm{A}_{1}=\mathrm{V}_{\mathrm{IH}}$. The sector addresses ( $\mathrm{A}_{18}, \mathrm{~A}_{17}, \mathrm{~A}_{16}, \mathrm{~A}_{15}, \mathrm{~A}_{14}, \mathrm{~A}_{13}$, and $\mathrm{A}_{12}$ ) should be set to the sector to be protected. "Sector Address Tables (MBM29DL800TA/BA)" in ■FLEXIBLE SECTOR-ERASE ARCHITECTURE define the sector address for each of the twenty two (22) individual sectors. Programming of the protection circuitry begins on the falling edge of the WE pulse and is terminated with the rising edge of the same. Sector addresses must be held constant during the WE pulse. See "(13) AC Waveforms for Sector Protection" in ■TIMING DIAGRAM and "(5) Sector Protection Algorithm" in ■FLOW CHART for sector protection waveforms and algorithm.

To verify programming of the protection circuitry, the programming equipment must force $\mathrm{V}_{\mathbf{I D}}$ on address pin $\mathrm{A}_{9}$ with $\overline{C E}$ and $\overline{O E}$ at $\mathrm{V}_{12}$ and $\overline{W E}$ at $\mathrm{V}_{14}$. Scanning the sector addresses ( $\mathrm{A}_{18}, \mathrm{~A}_{17}, \mathrm{~A}_{16}, \mathrm{~A}_{15}, \mathrm{~A}_{14}, \mathrm{~A}_{13}$, and $\mathrm{A}_{12}$ ) while $\left(A_{6}, A_{1}, A_{0}\right)=(0,1,0)$ will produce a logical "1" code at device output DQ for a protected sector. Otherwise the devices will read 00 h for unprotected sector. In this mode, the lower order addresses, except for $\mathrm{A}_{0}, \mathrm{~A}_{1}$, and $\mathrm{A}_{6}$ are DON'T CARES. Address locations with $\mathrm{A}_{1}=\mathrm{V}_{\mathrm{IL}}$ are reserved for Autoselect manufacturer and device codes. A-1 requires to apply to VIL on byte mode.
It is also possible to determine if a sector is protected in the system by writing an Autoselect command. Performing a read operation at the address location XX02h, where the higher order addresses ( $\mathrm{A}_{18}, \mathrm{~A}_{17}, \mathrm{~A}_{16}, \mathrm{~A}_{15}, \mathrm{~A}_{14}, \mathrm{~A}_{13}$, and $\mathrm{A}_{12}$ ) are the desired sector address will produce a logical " 1 " at $\mathrm{DQ}_{0}$ for a protected sector. See "MBM29DL800TA/BA Sector Protection Verify Autoselect Codes Table" and "Extended Autoselect Code Table" in ■DEVICE BUS OPERATION for Autoselect codes.

## Temporary Sector Unprotection

This feature allows temporary unprotection of previously protected sectors of the MBM29DL800TA/BA devices in order to change data. The Sector Unprotection mode is activated by setting the RESET pin to high voltage ( 12 V ). 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. See "(14) Temporary Sector Unprotection Timing Diagram" in ■TIMING DIAGRAM and "(6) Temporary Sector Unprotection Algorithm" in ©FLOW CHART.

## RESET

## Hardware Reset

The MBM29DL800TA/BA devices may be reset by driving the $\overline{\text { RESET }}$ pin to Vı. The $\overline{\text { RESET }}$ pin has a pulse requirement and has to be kept low ( $\mathrm{V}_{\mathrm{L}}$ ) for at least 500 ns in order to properly reset the internal state machine. Any operation in the process of being executed will be terminated and the internal state machine will be reset to the read mode $20 \mu \mathrm{~s}$ after the RESET pin is driven low. Furthermore, once the RESET pin goes high, the devices require an additional tre before it will allow read access. When the RESET pin is low, the devices will be in the standby mode for the duration of the pulse and all the data output pins will be tri-stated. If a hardware reset occurs during a program or erase operation, the data at that particular location will be corrupted. Please note that the RY/BY output signal should be ignored during the RESET pulse. See "(9) RESET/RY/BY Timing Diagram" in ■TIMING DIAGRAM for the timing diagram. Refer to Temporary Sector Unprotection for additional functionality.

## MBM29DL800TA-7099/MBM29DL800BA-70900

## - 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 devices to the read mode. Some commands are required Bank Address (BA) input. When command sequences are inputed to bank being read, the commands have priority than reading. "MBM29DL800TA/BA Command Definitions Table" in ■DEVICE BUS OPERATION 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 Read/Reset commands are functionally equivalent, resetting the device to the read mode. Please note that commands are always written at $\mathrm{DQ}_{0}$ to $\mathrm{DQ}_{7}$ and $\mathrm{DQ}_{8}$ to $\mathrm{DQ}_{15}$ bits are ignored.

## Read/Reset Command

In order to return from Autoselect mode or Exceeded Timing Limits ( $\mathrm{DQ}_{5}=1$ ) to Read/Reset mode, the Read/ 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 devices remain enabled for reads until the command register contents are altered.

The devices will automatically power-up in the Read/Reset state. In this case, a command sequence is not required to read data. Standard microprocessor read cycles will retrieve array data. This default value ensures that no spurious alteration of the memory content occurs during the power transition. Refer to the AC Read Characteristics and Waveforms for the specific timing parameters.

## Autoselect Command

Flash memories are intended for use in applications where the local CPU alters memory contents. As such, manufacture and device codes must be accessible while the devices reside in the target system. PROM programmers typically access the signature codes by raising $A 9$ to a high voltage. However, multiplexing high voltage onto the address lines is not generally desired system design practice.

The device contains an Autoselect command operation to supplement traditional PROM programming methodology. The operation is initiated by writing the Autoselect command sequence into the command register.

The Autoselect command sequence is initiated by first writing two unlock cycles. This is followed by a third write cycle that contains the bank address (BA) and the Autoselect command. Then the manufacture and device codes can be read from the bank, and an actual data of memory cell can be read from the another bank.

Following the command write, a read cycle from address (BA)00h retrieves the manufacture code of 04h. A read cycle from address (BA)01h for $\times 16((\mathrm{BA}) 02 \mathrm{~h}$ for $\times 8)$ returns the device code (MBM29DL800TA $=4 \mathrm{Ah}$ and MBM29DL800BA $=$ CBh for $\times 8$ mode; MBM29DL800TA $=224 \mathrm{Ah}$ and MBM29DL800BA $=22 \mathrm{CBh}$ for $\times 16$ mode). (See "MBM29DL800TA/BA Sector Protection Verify Autoselect Codes Table" and "Extended Autoselect Code Table" in ■DEVICE BUS OPERATION.)

All manufacturer and device codes will exhibit odd parity with DQ7 defined as the parity bit. Sector state (protection or unprotection) will be informed by address (BA)02h for $\times 16$ ((BA)04h for $\times 8$ ). Scanning the sector addresses $\left(A_{18}, A_{17}, A_{16}, A_{15}, A_{14}, A_{13}\right.$, and $\left.A_{12}\right)$ while $\left(A_{6}, A_{1}, A_{0}\right)=(0,1,0)$ will produce a logical " 1 " at device output $D_{0}$ for a protected sector. The programming verification should be performed by verify sector protection on the protected sector. (See "MBM29DL800TA/BA User Bus Operations Tables ( $\overline{\mathrm{BYTE}}=\mathrm{V}_{\boldsymbol{\prime}}$ and $\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{IL}}$ )" in ■DEVICE BUS OPERATION.)

The manufacture and device codes can be allowed reading from selected bank. To read the manufacture and device codes and sector protection status from non-selected bank, it is necessary to write Read/Reset command sequence into the register and then Autoselect command should be written into the bank to be read.

If the software (program code) for Autoselect command is stored into the Frash memory, the device and manufacture codes should be read from the other bank where is not contain the software.

## MBM29DL800TA-70/90/MBM29DL800BA-70/90

To terminate the operation, it is necessary to write the Read/Reset command sequence into the register, and also to write the Autoselect command during the operation, execute it after writing Read/Reset command sequence.

## Byte/Word Programming

The devices are programmed on a byte-by-byte (or word-by-word) basis. Programming is a four bus cycle operation. There are two "unlock" write cycles. These are followed by the program set-up command and data write cycles. Addresses are latched on the falling edge of $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$, whichever happens later and the data is latched on the rising edge of $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$, whichever happens first. The rising edge of $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$ (whichever happens first) begins programming. Upon executing the Embedded Program Algorithm command sequence, the system is not required to provide further controls or timings. The device will automatically provide adequate internally generated program pulses and verify the programmed cell margin.

The system can determine the status of the program operation by using DQ7 ( $\overline{\text { Data }}$ Polling), DQ6 (Toggle Bit), or RY/BY. The $\overline{\text { Data }}$ Polling and Toggle Bit must be performed at the memory location which is being programmed.

The automatic programming operation is completed when the data on $\mathrm{DQ}_{7}$ is equivalent to data written to this bit at which time the devices return to the read mode and addresses are no longer latched. (See "Hardware Sequence Flags Table".) Therefore, the devices require that a valid address to the devices be supplied by the system at this particular instance of time. Hence, Data Polling must be performed at the memory location which is being programmed.
Any commands written to the chip during this period will be ignored. If hardware reset occurs during the programming operation, it is impossible to guarantee the data are being written.

Programming is allowed in any sequence and across sector boundaries. Beware that a data " 0 " cannot be programmed back to a "1". Attempting to do so may either hang up the device or result in an apparent success according to the data polling algorithm but a read from Read/Reset mode will show that the data is still " 0 ". Only erase operations can convert " 0 "s to " 1 "s.
"(1) Embedded Program ${ }^{\text {TM }}$ Algorithm" in ■FLOW CHART illustrates the Embedded Program ${ }^{\text {TM }}$ Algorithm using typical command strings and bus operations.

## Chip Erase

Chip erase is a six bus cycle operation. There are two "unlock" write cycles. These are followed by writing the "set-up" command. Two more "unlock" write cycles are then followed by the chip erase command.

Chip erase does not require the user to program the device prior to erase. Upon executing the Embedded Erase Algorithm command sequence the devices will automatically program and verify the entire memory for an all zero data pattern prior to electrical erase (Preprogram function). The system is not required to provide any controls or timings during these operations.
The system can determine the status of the erase operation by using DQ ( $\overline{\text { Data }}$ Polling), DQ (Toggle Bit), or $\mathrm{RY} / \overline{\mathrm{BY}}$. The chip erase begins on the rising edge of the last $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$, whichever happens first in the command sequence and terminates when the data on $\mathrm{DQ}_{7}$ is " 1 " (See Write Operation Status section.) at which time the device returns to read the mode.
Chip Erase Time; Sector Erase Time $\times$ All sectors + Chip Program Time (Preprogramming)
"(2) Embedded Erase ${ }^{T M}$ Algorithm" in ■FLOW CHART illustrates the Embedded Erase ${ }^{T M}$ Algorithm using typical command strings and bus operations.

## MBM29DL800TA-70990/MBM29DL800BA-7090

## 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 CE or WE whichever happens later, while the command ( $\mathrm{Data}=30 \mathrm{~h}$ ) is latched on the rising edge of $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$ which happens first. After time-out of $50 \mu \mathrm{~s}$ from the rising edge of the last sector erase command, the sector erase operation will begin.

Multiple sectors may be erased concurrently by writing the six bus cycle operations on "MBM29DL800TA/BA Command Definitions Table" in ■DEVICE BUS OPERATION. This sequence is followed with writes of the Sector Erase command to addresses in other sectors desired to be concurrently erased. The time between writes must be less than $50 \mu \mathrm{~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 $50 \mu$ s from the rising edge of last CE or WE whichever happens first will initiate the execution of the Sector Erase command(s). If another falling edge of $\overline{\mathrm{CE}}$ or $\overline{W E}$, whichever happens first occurs within the $50 \mu \mathrm{~s}$ time-out window the timer is reset. (Monitor DQ ${ }_{3}$ to determine if the sector erase timer window is still open, see section $\mathrm{DQ}_{3}$, Sector Erase Timer.) Any command other than Sector Erase or Erase Suspend during this time-out period will reset the devices to the read mode, ignoring the previous command string. Resetting the devices once execution has begun will corrupt the data in the sector. In that case, restart the erase on those sectors and allow them to complete. (Refer to the Write Operation Status section for Sector Erase Timer operation.) Loading the sector erase buffer may be done in any sequence and with any number of sectors ( 0 to 21 ).

Sector erase does not require the user to program the devices prior to erase. The devices automatically program all memory locations in the sector(s) to be erased prior to electrical erase (Preprogram function). 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 system can determine the status of the erase operation by using DQ7 (Data Polling), DQ6 (Toggle Bit), or $\mathrm{RY} / \overline{\mathrm{BY}}$.

The sector erase begins after the $50 \mu \mathrm{~s}$ time out from the rising edge of $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$ whichever happens first for the last sector erase command pulse and terminates when the data on DQ7 is " 1 " (See Write Operation Status section.) at which time the devices return to the read mode. Data polling and Toggle Bit must be performed at an address within any of the sectors being erased.

Multiple Sector Erase Time; [Sector Erase Time + Sector Program Time (Preprogramming)] $\times$ Number of Sector Erase

In case of multiple sector erase across bank boundaries, a read from bank (read-while-erase) can not performe.
"(2) Embedded Erase ${ }^{\text {TM }}$ Algorithm" in ■FLOW CHART illustrates the Embedded Erase ${ }^{\text {TM }}$ Algorithm using typical command strings and bus operations.

## Erase Suspend/Resume

The Erase Suspend command allows the user to interrupt a Sector Erase operation and then perform data reads from or programs to 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. Writting the Erase Suspend command (BOh) during the Sector Erase time-out results in immediate termination of the time-out period and suspension of the erase operation.

Writing the Erase Resume command (30h) resumes the erase operation. The bank addresses of sector being erasing or suspending should be set when writting the Erase Suspend or Erase Resume command.

## MBM29DL800TA-70/90/MBM29DL800BA-70/90


#### Abstract

When the Erase Suspend command is written during the Sector Erase operation, the device will take a maximum of $20 \mu \mathrm{~s}$ to suspend the erase operation. When the devices have entered the erase-suspended mode, the RY/ $\overline{\mathrm{BY}}$ output pin will be at $\mathrm{Hi}-\mathrm{Z}$ and the $\mathrm{DQ}_{7}$ bit will be at logic " 1 ", and $\mathrm{DQ}_{6}$ will stop toggling. The user must use the address of the erasing sector for reading $\mathrm{DQ}_{6}$ and $\mathrm{DQ}_{7}$ 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 devices default 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. Successively reading from the erase-suspended sector while the device is in the erase-suspend-read mode will cause $\mathrm{DQ}_{2}$ to toggle. (See the section on DQ2.)


After entering the erase-suspend-read mode, the user can program the device by writing the appropriate command sequence for 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 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 devices are in the erase-suspend-program mode will cause $\mathrm{DQ}_{2}$ to toggle. The end of the erasesuspended Program operation is detected by the RY/ $\overline{B Y}$ output pin, Data polling of DQ7 or by the Toggle Bit I ( $\mathrm{DQ}_{6}$ ) which is the same as the regular Program operation. Note that $\mathrm{DQ}_{7}$ must be read from the Program address while $\mathrm{DQ}_{6}$ can be read from any address within bank being erase-suspended.
To resume the operation of Sector Erase, the Resume command (30h) should be written to the bank being erase suspended. 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.

## Extended Command

(1) Fast Mode

MBM29DL800TA/BA has Fast Mode function. This mode dispenses with the initial two unclock cycles required in the standard program command sequence by writing Fast Mode command into the command register. In this mode, the required bus cycle for programming is two cycles instead of four bus cycles in standard program command. (Do not write erase command in this mode.) The read operation is also executed after exiting this mode. To exit this mode, it is necessary to write Fast Mode Reset command into the command register. The first cycle must contain the bank address. (Refer to "(8) Embedded Program ${ }^{\text {TM }}$ Algorithm for Fast Mode" in ■FLOW CHART Extended algorithm.) The Vcc active current is required even $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{H}}$ during Fast Mode.
(2) Fast Programming

During Fast Mode, the programming can be executed with two bus cycles operation. The Embedded Program Algorithm is executed by writing program set-up command (AOh) and data write cycles (PA/PD). (Refer to "(8) Embedded Program ${ }^{\text {TM }}$ Algorithm for Fast Mode" in ■FLOW CHART Extended algorithm.)
(3) Extended Sector Protection

In addition to normal sector protection, the MBM29DL800TA/BA has Extended Sector Protection as extended function. This function enable to protect sector by forcing VID on RESET pin and write a commnad sequence. Unlike conventional procedure, it is not necessary to force $\mathrm{V}_{\mathrm{ID}}$ and control timing for control pins. The only $\overline{R E S E T}$ pin requires $\mathrm{V}_{\text {ID }}$ for sector protection in this mode. The extended sector protect requires $\mathrm{V}_{\text {ID }}$ on $\overline{\text { RESET }}$ pin. With this condition, the operation is initiated by writing the set-up command ( 60 h ) into the command register. Then, the sector addresses pins ( $A_{18}, A_{17}, A_{16}, A_{15}, A_{14}, A_{13}$ and $A_{12}$ ) and ( $\left.A_{6}, A_{1}, A_{0}\right)=(0,1,0)$ should be set to the sector to be protected (recommend to set VIL for the other addresses pins), and write extended sector protect command (60h). A sector is typically protected in $250 \mu \mathrm{~s}$. To verify programming of the protection circuitry, the sector addresses pins ( $A_{18}, A_{17}, A_{16}, A_{15}, A_{14}, A_{13}$ and $A_{12}$ ) and ( $\left.A_{6}, A_{1}, A_{0}\right)=(0,1,0)$ should be set and write a command (40h). Following the command write, a logical "1" at device output DQ0 will produce for protected sector in the read operation. If the output data is logical " 0 ", please repeat to write extended sector protect command (60h) again. To terminate the operation, it is necessary to set RESET pin to $\mathrm{V}_{\text {н }}$.

## MBM29DL800TA-7090/MBM29DL800BA-70/90

## Write Operation Status

Detailed in "Hardware Sequence Flags Table" are all the status flags that can determine the status of the bank for the current mode operation. The read operation from the bank where is not operate Embedded Algorithm returns a data of memory cell. These bits offer a method for determining whether a Embedded Algorithm is completed properly. The information on $\mathrm{DQ}_{2}$ is address sensitive. This means that if an address from an erasing sector is consectively read, then the $\mathrm{DQ}_{2}$ bit will toggle. However, $\mathrm{DQ}_{2}$ will not toggle if an address from a nonerasing sector is consectively read. This allows the user to determine which sectors are erasing and which are not.

The status flag is not output from bank (non-busy bank) not executing Embedded Algorithm. For example, there is bank (busy bank) which is now executing Embedded Algorithm. When the read sequence is [1] <busy bank>, [2] <non-busy bank>, [3] <busy bank>, the DQ 6 is toggling in the case of [1] and [3]. In case of [2], the data of memory cell is outputted. In the erase-suspend read mode with the same read sequence, DQ6 will not be toggled in the [1] and [3].
In the erase suspend read mode, $\mathrm{DQ}_{2}$ is toggled in the [1] and [3]. In case of [2], the data of memory cell is outputted.

## Hardware Sequence Flags Table

| Status |  |  | $\mathrm{DQ}_{7}$ | DQ6 | DQ5 | DQ ${ }^{\text {a }}$ | DQ 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| In Progress | Embedded Program Algorithm |  | $\overline{\mathrm{DQ}}_{7}$ | Toggle | 0 | 0 | 1 |
|  | Embedded Erase Algorithm |  | 0 | Toggle | 0 | 1 | Toggle*1 |
|  | Erase <br> Suspended <br> Mode | Erase Suspend Read (Erase Suspended Sector) | 1 | 1 | 0 | 0 | Toggle |
|  |  | Erase Suspend Read (Non-Erase Suspended Sector) | Data | Data | Data | Data | Data |
|  |  | Erase Suspend Program <br> (Non-Erase Suspended Sector) | $\overline{\mathrm{DQ}}{ }_{7}$ | Toggle | 0 | 0 | 1*2 |
| Exceeded Time Limits | Embedded Program Algorithm |  | $\overline{\mathrm{DQ}}_{7}$ | Toggle | 1 | 0 | 1 |
|  | Embedded Erase Algorithm |  | 0 | Toggle | 1 | 1 | N/A |
|  | Erase <br> Suspended <br> Mode | Erase Suspend Program <br> (Non-Erase Suspended Sector) | $\overline{\mathrm{DQ}}{ }_{7}$ | Toggle | 1 | 0 | N/A |

*1 : Successive reads from the erasing or erase-suspend sector cause $\mathrm{DQ}_{2}$ to toggle.
*2 : Reading from non-erase suspend sector address indicates logic "1" at the DQ2 bit.

## MBM29DL800TA-70/90/MBM29DL800BA-70/90

## DQ7

Data Polling
The MBM29DL800TA/BA devices feature 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 devices 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 "(3) $\overline{\text { Data }}$ Polling Algorithm" in $■ F L O W$ CHART.
For programming, the $\overline{\text { Data }}$ Polling is valid after the rising edge of fourth write pulse in the four write pulse sequence.
For chip erase and sector erase, the Data Polling is valid after the rising edge of the sixth write pulse in the six write pulse sequence. Data Polling must be performed at sector address within any of the sectors being erased and not a protected sector. Otherwise, the status may not be valid.
If a program address falls within a protected sector, $\overline{\mathrm{Data}}$ Polling on $\mathrm{DQ}_{7}$ is active for approximately $1 \mu \mathrm{~s}$, then that bank returns to the read mode. After an erase command sequence is written, if all sectors selected for erasing are protected, $\overline{\text { Data }}$ Polling on DQ7 is active for approximately $100 \mu \mathrm{~s}$, then the bank returns to read mode.

Once the Embedded Algorithm operation is close to being completed, the MBM29DL800TA/BA data pins (DQ7) may change asynchronously while the output enable ( $\overline{\mathrm{OE}}$ ) is asserted low. This means that the devices are driving status information on DQ7 at one instant of time and then that byte's valid data at the next instant of time. Depending on when the system samples the DQ7 output, it may read the status or valid data. Even if the device has completed the Embedded Algorithm operation and DQ7 has a valid data, the data outputs on DQ $\mathrm{D}_{0}$ to $\mathrm{DQ}_{6}$ may be still invalid. The valid data on DQo to 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 "Hardware Sequence Flags Table".)
See "(6) AC Waveforms for Data Polling during Embedded Algorithm Operations" in ■TIMING DIAGRAM for the Data Polling timing specifications and diagrams.

## DQ6

Toggle Bit I
The MBM29DL800TA/BA also feature the "Toggle Bit l" 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{\mathrm{OE}}$ toggling) data from the devices will result in DQ 6 toggling between one and zero. Once the Embedded Program or Erase Algorithm cycle is completed, DQ6 will stop toggling and valid data will be read on the next successive attempts. During programming, the Toggle Bit I is valid after the rising edge of the fourth write pulse in the four write pulse sequence. For chip erase and sector erase, the Toggle Bit I is valid after the rising edge of the sixth write pulse in the six write pulse sequence. The Toggle Bit I is active during the sector time out.
In programming, if the sector being written to is protected, the toggle bit will toggle for about $2 \mu \mathrm{~s}$ and then stop toggling without the data having changed. In erase, the devices will erase all the selected sectors except for the ones that are protected. If all selected sectors are protected, the chip will toggle the toggle bit for about $100 \mu \mathrm{~s}$ and then drop back into read mode, having changed none of the data.
Either $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ toggling will cause the $\mathrm{DQ}_{6}$ to toggle. In addition, an Erase Suspend/Resume command will cause the DQ6 to toggle.

The system can use $\mathrm{DQ}_{6}$ to determine whether a sector is actively erasing or is erase-suspended. When a bank is actively erasing (that is, the Embedded Erase Algorithm is in progress), DQ6 toggles. When a bank enters the Erase Suspend mode, DQ6 stops toggling. Successive read cycles during the erase-suspend-program cause DQ6 to toggle.

## MBM29DL800TA-7090/MBM29DL800BA-7090

To operate toggle bit function properly, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ must be high when bank address is changed.
See "(7) AC Waveforms for Toggle Bit I during Embedded Algorithm Operations" in ■TIMING DIAGRAM for the Toggle Bit I 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 devices under this condition. The $\overline{C E}$ circuit will partially power down the device under these conditions (to approximately 2 mA ). The $\overline{\mathrm{OE}}$ and $\overline{\mathrm{WE}}$ pins will control the output disable functions as described in "MBM29DL800TA/BA User Bus Operations Tables ( $\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{H}}$ and $\overline{\mathrm{BYTE}}=\mathrm{V}_{\mathrm{IL}}$ )" (in CDEVICE BUS OPERATION).
The DQs failure condition may also appear if a user tries to program a non blank location without erasing. In this case the devices lock out and never complete the Embedded Algorithm operation. Hence, the system never reads a valid data on DQ7 bit and DQ6 never stops toggling. Once the devices have exceeded timing limits, the DQ5 bit will indicate a "1." Please note that this is not a device failure condition since the devices were incorrectly used. If this occurs, reset the device with command sequence.

## DQ3

## Sector Erase Timer

After the completion of the initial sector erase command sequence the sector erase time-out will begin. $\mathrm{DQ}_{3}$ 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 I indicates the device has been written with a valid erase command, $\mathrm{DQ}_{3}$ may be used to determine if the sector erase timer window is still open. If $\mathrm{DQ}_{3}$ is high ("1") the internally controlled erase cycle has begun; attempts to write subsequent commands to the device will be ignored until the erase operation is completed as indicated by Data Polling or Toggle Bit I. 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 $\mathrm{DQ}_{3}$ prior to and following each subsequent Sector Erase command. If $\mathrm{DQ}_{3}$ were high on the second status check, the command may not have been accepted.
See "Hardware Sequence Flags Table".

## DQ2

Toggle Bit II
This toggle bit II, along with $\mathrm{DQ}_{6}$, can be used to determine whether the devices are in the Embedded Erase Algorithm or in Erase Suspend.
Successive reads from the erasing sector will cause $\mathrm{DQ}_{2}$ to toggle during the Embedded Erase Algorithm. If the devices are in the erase-suspended-read mode, successive reads from the erase-suspended sector will cause $\mathrm{DQ}_{2}$ to toggle. When the devices are in the erase-suspended-program mode, successive reads from the byte address of the non-erase suspended sector will indicate a logic "1" at the DQ2 bit.
$\mathrm{DQ}_{6}$ is different from $\mathrm{DQ}_{2}$ in that $\mathrm{DQ}_{6}$ toggles only when the standard program or Erase, or Erase Suspend Program operation is in progress. The behavior of these two status bits, along with that of DQ7, is summarized as follows:
For example, $\mathrm{DQ}_{2}$ and $\mathrm{DQ}_{6}$ can be used together to determine if the erase-suspend-read mode is in progress. (DQ ${ }_{2}$ toggles while DQ $_{6}$ does not.) See also "Hardware Sequence Flags Table" and "(16) DQ ${ }_{2}$ vs. DQ6" in ■TIMING DIAGRAM.
Furthermore, $\mathrm{DQ}_{2}$ can also be used to determine which sector is being erased. When the device is in the erase mode, $\mathrm{DQ}_{2}$ toggles if this bit is read from an erasing sector.
To operate toggle bit function properly, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ must be high when bank address is changed.

## MBM29DL800TA-7090/MBM29DL800BA-7090

## Reading Toggle Bits DQ/DQ2

Whenever the system initially begins reading toggle bit status, it must read $\mathrm{DQ}_{7}$ to $\mathrm{DQ}_{0}$ at least twice in a row to determine whether a toggle bit is toggling. Typically, a system would note and store the value of the toggle bit after the first read. After the second read, the system would compare the new value of the toggle bit with the first. If the toggle bit is not toggling, this indicates that the device has completed the program or erase operation. The system can read array data on $\mathrm{DQ}_{7}$ to $\mathrm{DQ}_{0}$ on the following read cycle.

However, if after the initial two read cycles, the system determines that the toggle bit is still toggling, the system also should note whether the value of $\mathrm{DQ}_{5}$ is high (see "the section on DQ5") . If it is the system should then determine again whether the toggle bit is toggling, since the toggle bit may have stopped toggling just as DQ5 went high. If the toggle bit is no longer toggling, the device has successfully completed the program or erase operation. If it is still toggling, the device did not complete the operation successfully, and the system must write the reset command to return to reading array data.

The remaining scenario is that the system initially determines that the toggle bit is toggling and DQ5 has not gone high. The system may continue to monitor the toggle bit and DQ5 through successive read cycles, determining the status as described in the previous paragraph. Alternatively, it may choose to perform other system tasks. In this case, the system must start at the beginning of the algorithm when it returns to determine the status of the operation (See "(4) Toggle bit algorithm" in ■FLOW CHART).

## Toggle Bit Status Table

| Mode | $\mathbf{D Q}_{7}$ | $\mathbf{D Q}_{6}$ | $\mathbf{D Q}_{\mathbf{2}}$ |
| :--- | :---: | :---: | :---: |
| Program | $\overline{\mathrm{DQ}}_{7}$ | Toggle | 1 |
| Erase | 0 | Toggle | Toggle $^{* 1}$ |
| Erase-Suspend Read <br> (Erase-Suspended Sector) | 1 | 1 | Toggle |
| Erase-Suspend Program | $\overline{\mathrm{DQ}}_{7}$ | Toggle | $1^{{ }^{\star 2}}$ |

*1 : Successive reads from the erasing or erase-suspend sector cause $\mathrm{DQ}_{2}$ to toggle.
*2 : Reading from non-erase suspend sector address indicates logic "1" at the DQ2 bit.

## RY/BY

## Ready/Busy

The MBM29DL800TA/BA provide 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 has been completed. If the output is low, the devices are busy with either a program or erase operation. If the output is high, the devices are ready to accept any read/ write or erase operation. When the RY/ $\overline{\mathrm{BY}}$ pin is low, the devices will not accept any additional program or erase commands. If the MBM29DL800TA/BA are placed in an Erase Suspend mode, the RY/ $\overline{\mathrm{BY}}$ output will be high.

During programming, the RY/ $\overline{\mathrm{BY}}$ pin is driven low after the rising edge of the fourth write pulse. During an erase operation, the RY/BY pin is driven low after the rising edge of the sixth write pulse. The RY/ $\overline{\mathrm{BY}}$ pin will indicate a busy condition during the RESET pulse. Refer to "(8) RY/ $\overline{\mathrm{BY}}$ Timing Diagram during Program/Erase Operations" and "(9) $\overline{\text { RESET/RY/BY Timing Diagram" in ■TIMING DIAGRAM for a detailed timing diagram. The }}$ $\mathrm{RY} / \overline{\mathrm{BY}}$ pin is pulled high in standby mode.

Since this is an open-drain output, the pull-up resistor needs to be connected to $\mathrm{V}_{\mathrm{cc}}$; multiples of devices may be connected to the host system via more than one $\mathrm{RY} / \overline{\mathrm{BY}}$ pin in parallel.

## Byte/Word Configuration

The BYTE pin selects the byte (8-bit) mode or word (16-bit) mode for the MBM29DL800TA/BA devices. When this pin is driven high, the devices operate in the word (16-bit) mode. The data is read and programmed at DQo

## MBM29DL800TA-7090/MBM29DL800BA-70/90

to DQ15. When this pin is driven low, the devices operate in byte (8-bit) mode. Under this mode, the $\mathrm{DQ}_{15} / \mathrm{A}_{-1}$ pin becomes the lowest address bit and $\mathrm{DQ}_{8}$ to $\mathrm{DQ}_{14}$ bits are tri-stated. However, the command bus cycle is always an 8-bit operation and hence commands are written at $\mathrm{DQ}_{0}$ to $\mathrm{DQ}_{7}$ and the $\mathrm{DQ}_{8}$ to $\mathrm{DQ}_{15}$ bits are ignored. Refer to "(10) Timing Diagram for Word Mode Configuration" and "(11) Timing Diagram for Byte Mode Configuration" and "(12) BYTE Timing Diagram for Write Operations" in ■TIMING DIAGRAM for the timing diagram.

## Data Protection

The MBM29DL800TA/BA are 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 devices automatically reset 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 devices also incorporate several features to prevent inadvertent write cycles resulting form Vcc power-up and power-down transitions or system noise.

## Low Vcc Write Inhibit

To avoid initiation of a write cycle during V cc power-up and power-down, a write cycle is locked out for Vcc less than 2.3 V (typically 2.4 V ). If V сс < V เко, the command register is disabled and all internal program/erase circuits are disabled. Under this condition the device will reset to the read mode. Subsequent writes will be ignored until the $V$ cc level is greater than $V_{\text {Lko. It }}$ is the users responsibility to ensure that the control pins are logically correct to prevent unintentional writes when $\mathrm{V}_{\mathrm{cc}}$ is above 2.3 V .
If Embedded Erase Algorithm is interrupted, there is possibility that the erasing sector(s) cannot be used.

## Write Pulse "Glitch" Protection

Noise pulses of less than 3 ns (typical) on $\overline{\mathrm{OE}}, \overline{\mathrm{CE}}$, or $\overline{\mathrm{WE}}$ will not initiate a write cycle.

## Logical Inhibit

Writing is inhibited by holding any one of $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{L}}, \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{I}}$, or $\overline{\mathrm{WE}}=\mathrm{V}_{\boldsymbol{H}}$. To initiate a write cycle $\overline{\mathrm{CE}}$ and $\overline{\mathrm{WE}}$ must be a logical zero while $\overline{O E}$ is a logical one.

## Power-Up Write Inhibit

Power-up of the devices with $\overline{W E}=\overline{C E}=V_{I L}$ and $\overline{O E}=V_{\mathbb{H}}$ will not accept commands on the rising edge of $\overline{W E}$. The internal state machine is automatically reset to the read mode on power-up.

## Sector Protection

Device user is able to protect each sector individually to store and protect data. Protection circuit voids both program and erase commands that are addressed to protected sectors.

Any commands to program or erase addressed to protected sector are ignored (see "Sector Protection" in ■ FUNCTIONAL DESCRIPTION)

## MBM29DL800TA-7090/MBM29DL800BA-7090

ABSOLUTE MAXIMUM RATINGS

| Parameter | Symbol | Rating |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| Storage Temperature | Tstg | -55 | +125 | ${ }^{\circ} \mathrm{C}$ |
| Ambient Temperature with Power Applied | $\mathrm{T}_{\mathrm{A}}$ | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |
| Voltage with respect to Ground All pins except As, $\overline{\mathrm{OE}}, \overline{\mathrm{RESET}}{ }^{* 2}$ | Vin, Vout | -0.5 | Vcc+0.5 | V |
| A $9, \overline{\mathrm{OE}}$, and $\overline{\mathrm{RESET}}{ }^{* 1}$, *3 | Vin | -0.5 | +13.0 | V |
| Power Supply Voltage*1 | Vcc | -0.5 | +5.5 | V |

*1 : Voltage is defined on the basis of $\mathrm{Vss}=\mathrm{GND}=0 \mathrm{~V}$.
*2 : Minimum DC voltage on input or I/O pins are -0.5 V . During voltage transitions, input or I/O pins may undershoot V ss to -2.0 V for periods of up to 20 ns . Maximum DC voltage on input or I/O pins is $\mathrm{Vcc}+0.5 \mathrm{~V}$. During voltage transitions, input or I/O pins may overshoot to $\mathrm{V}_{\mathrm{cc}}+2.0 \mathrm{~V}$ for periods of up to 20 ns .
*3 : Minimum DC input voltage on $\mathrm{A} 9, \overline{\mathrm{OE}}$ and $\overline{\mathrm{RESET}}$ pins is -0.5 V . During voltage transitions, $\mathrm{A}_{9}, \overline{\mathrm{OE}}$ and $\overline{\mathrm{RESET}}$ pins may undershoot $\mathrm{Vss}^{\text {s }}$ to -2.0 V for periods of up to 20 ns . Voltage difference between input and supply voltage $\left(\mathrm{V}_{\mathbb{N}}-\mathrm{V}_{\mathrm{Cc}}\right)$ does not exceed +9.0 V . Maximum DC input voltage on $\mathrm{A}_{9}$, $\overline{\mathrm{OE}}$ and $\overline{\text { RESET }}$ pins is +13.0 V which may overshoot to +14.0 V for periods of up to 20 ns .

WARNING: Semiconductor devices can be permanently damaged by application of stress (voltage, current, temperature, etc.) in excess of absolute maximum ratings. Do not exceed these ratings.

■ RECOMMENDED OPERATING CONDITIONS

| Parameter | Symbol | Part No. | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |
| Ambient Temperature | TA | - | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |
| Power Supply Voltages* | Vcc | -70 | +3.0 | +3.6 | V |
|  |  | -90 | +2.7 | +3.6 | V |

* : Voltage is defined on the basis of $\mathrm{Vss}=\mathrm{GND}=0 \mathrm{~V}$.

Note: Operating ranges define those limits between which the functionality of the devices are guaranteed.
WARNING: The recommended operating conditions are required in order to ensure the normal operation of the semiconductor device. All of the device's electrical characteristics are warranted when the device is operated within these ranges.
Always use semiconductor devices within their recommended operating condition ranges. Operation outside these ranges may adversely affect reliability and could result in device failure.
No warranty is made with respect to uses, operating conditions, or combinations not represented on the data sheet. Users considering application outside the listed conditions are advised to contact their FUJITSU representatives beforehand.

## MBM29DL800TA-70990/MBM29DL800BA-7090

## MAXIMUM OVERSHOOT/MAXIMUM UNDERSHOOT



Figure 1 Maximum Undershoot Waveform


Figure 2 Maximum Overshoot Waveform 1


Note : This waveform is applied for $\mathrm{A}_{9}, \overline{\mathrm{OE}}$, and $\overline{\mathrm{RESET}}$.

Figure 3 Maximum Overshoot Waveform 2

## MBM29DL800TA-7099/MBM29DL800BA-7090

DC CHARACTERISTICS

| Parameter | Symbol | Conditions |  | Value |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Typ | Max |  |
| Input Leakage Current | l ı | $\mathrm{V}_{1}=\mathrm{V}_{\text {ss }}$ to V cc, V cc $=\mathrm{V}_{\text {cc }}$ Max |  | -1.0 | - | +1.0 | $\mu \mathrm{A}$ |
| Output Leakage Current | ILo | $\mathrm{V}_{\text {out }}=\mathrm{V}_{\text {ss }}$ to $\mathrm{V}_{\mathrm{cc}}$, $\mathrm{V}_{\mathrm{cc}}=\mathrm{V}_{\mathrm{cc}} \mathrm{Max}$ |  | -1.0 | - | +1.0 | $\mu \mathrm{A}$ |
| $\mathrm{A}_{9}, \overline{\mathrm{OE}}, \overline{\mathrm{RESET}}$ Inputs Leakage Current | ІІт | $\begin{aligned} & V_{c c}=\mathrm{V} \mathrm{Vcc} \mathrm{Max} \\ & \mathrm{~A}_{9}, \overline{\mathrm{OE}}, \overline{\mathrm{RESET}}=12.5 \mathrm{~V} \end{aligned}$ |  | - | - | 35 | $\mu \mathrm{A}$ |
| Vcc Active Current *1 | Iccı | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{L}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{H}}, \\ & \mathrm{f}=10 \mathrm{MHz} \end{aligned}$ | Byte |  | - | 18 |  |
|  |  |  | Word |  | - | 20 |  |
|  |  | $\begin{aligned} & \overline{C E}=V_{\mathrm{VL}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{H}}, \\ & \mathrm{f}=5 \mathrm{MHz} \end{aligned}$ | Byte | - | - | 8 | mA |
|  |  |  | Word |  | - | 10 |  |
| Vcc Active Current *2 | Icca | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{H}}$ |  | - | - | 35 | mA |
| Vcc Current (Standby) | Icc3 | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=\mathrm{V}_{\mathrm{cc}} \operatorname{Max}, \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{cc}} \pm 0.3 \mathrm{~V}, \\ & \mathrm{RESET}=\mathrm{V}_{\mathrm{cc}} \pm 0.3 \mathrm{~V} \end{aligned}$ |  | - | 1 | 5 | $\mu \mathrm{A}$ |
| Vcc Current (Standby, Reset) | Icc4 | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=\mathrm{V}_{\mathrm{cc}} \operatorname{Max}, \\ & \mathrm{RESET}=\mathrm{V}_{\mathrm{ss}} \pm 0.3 \mathrm{~V} \end{aligned}$ |  | - | 1 | 5 | $\mu \mathrm{A}$ |
| Vcc Current <br> (Automatic Sleep Mode) *5 | Iccs | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=\mathrm{V} \mathrm{cc} \operatorname{Max}, \overline{\mathrm{CE}}=\mathrm{V} \mathrm{Vs} \pm 0.3 \mathrm{~V}, \\ & \mathrm{RESET}=\mathrm{V}_{\mathrm{cc}} \pm 0.3 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{cc}} \pm 0.3 \mathrm{~V} \text { or } \mathrm{Vss} \pm 0.3 \mathrm{~V} \end{aligned}$ |  | - | 1 | 5 | $\mu \mathrm{A}$ |
| Vcc Active Current *6 | Icc6 | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{L}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{H}}$ | Byte | - | - | 45 | mA |
| (Read-While-Program) |  |  | Word | - | - | 45 |  |
| Vcc Active Current *6 | 1 lc 7 | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{L}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{H}}$ | Byte | - | - | 45 | mA |
| (Read-While-Erase) |  |  | Word | - | - | 45 |  |
| Vcc Active Current <br> (Erase-Suspend-Program) | Icc8 | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{I}}$ |  | - | - | 35 | mA |
| Input Low Voltage | VIL | - |  | -0.5 | - | 0.6 | V |
| Input High Voltage | $\mathrm{V}_{\mathrm{H}}$ | - |  | 2.0 | - | Vcc+0.3 | V |
| Voltage for Autoselect and Sector Protection (A9, $\overline{\mathrm{OE}}, \overline{\mathrm{RESET}}$ ) *3,*4 | VID | - |  | 11.5 | 12 | 12.5 | V |
| Output Low Voltage | Vol | $\mathrm{lol}=4.0 \mathrm{~mA}, \mathrm{Vcc}=\mathrm{Vcc}$ Min |  | - | - | 0.45 | V |
| Output High Voltage | Vor1 | $\mathrm{loH}=-2.0 \mathrm{~mA}, \mathrm{Vcc}=\mathrm{Vcc}_{\text {cc }} \mathrm{Min}$ |  | 2.4 | - | - | V |
|  | Vон2 | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ |  | Vcc-0.4 | - | - | V |
| Low Vcc Lock-Out Voltage | Vıкo | - |  | 2.3 | 2.4 | 2.5 | V |

*1 : The Icc current listed includes both the DC operating current and the frequency dependent component.
*2 : Icc active while Embedded Algorithm (program or erase) is in progress.
*3 : This timing is only for Sector Protection operation and Autoselect mode.
*4 : Applicable for only $\mathrm{V}_{\mathrm{cc}}$ applying.
*5 : Automatic sleep mode enables the low power mode when address remain stable for 150 ns .
*6 : Embedded Algorithm (program or erase) is in progress. (@5 MHz)

## MBM29DL800TA-7090/MBM29DL800BA-7090

## - AC CHARACTERISTICS

- Read Only Operations Characteristics

| Parameter | Symbols |  | Test Setup | Value (Note) |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | -70 | -90 |  |  |
|  | JEDEC | Standard |  | Min | Max | Min | Max |  |
| Read Cycle Time | tavav | trc |  | - | 70 | - | 90 | - | ns |
| Address to Output Delay | tavav | tacc | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}} \end{aligned}$ | - | 70 | - | 90 | ns |
| Chip Enable to Output Delay | telav | tce | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | - | 90 | - | 90 | ns |
| Output Enable to Output Delay | talov | toe | - | - | 30 | - | 35 | ns |
| Chip Enable to Output High-Z | tehaz | tof | - | - | 25 | - | 30 | ns |
| Output Enable to Output High-Z | tghaz | tof | - | - | 25 | - | 30 | ns |
| Output Hold Time From Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurs First | taxax | toн | - | 0 | - | 0 | - | ns |
| RESET Pin Low to Read Mode | - | tready | - | - | 20 | - | 20 | $\mu \mathrm{s}$ |
| $\overline{\mathrm{CE}}$ to BYTE Switching Low or High | - | $\begin{aligned} & \hline \text { tELFL } \\ & \text { teLFH } \end{aligned}$ | - | - | 5 | - | 5 | ns |

Note: Test Conditions:
Output Load: 1TTL gate and 30 pF (MBM29DL800TA/BA-70)
1TTL gate and 100 pF (MBM29DL800TA/BA-90
Input rise and fall times: 5 ns
Input pulse levels: 0.0 V or 3.0 V
Timing measurement reference level
Input: 1.5 V
Output:1.5 V


Notes: $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ including jig capacitance (MBM29DL800TA/BA-70)
$\mathrm{CL}=100 \mathrm{pF}$ including jig capacitance (MBM29DL800TA/BA-90)
Figure 4 Test Conditions

## MBM29DL800TA-7090/MBM29DL800BA-7090

- Write/Erase/Program Operations

| Parameter |  |  | Symbol |  | Value |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | -70 | -90 |  |  |  |
|  |  |  | JEDEC | Standard | Min | Typ | Max | Min | Typ | Max |  |
| Write Cycle Time |  |  |  |  | tavav | twc | 70 | - | - | 90 | - | - | ns |
| Address Setup Time |  |  | tavwL | tAs | 0 | - | - | 0 | - | - | ns |
| Address Setup Time to $\overline{\mathrm{OE}}$ Low During Toggle Bit Polling |  |  | - | taso | 15 | - | - | 15 | - | - | ns |
| Address Hold Time |  |  | twlax | taH | 45 | - | - | 45 | - | - | ns |
| Address Hold Time from $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ High During Toggle Bit Polling |  |  | - | taht | 0 | - | - | 0 | - | - | ns |
| Data Setup Time |  |  | tovwh | tos | 35 | - | - | 45 | - | - | ns |
| Data Hold Time |  |  | twhdx | tor | 0 | - | - | 0 | - | - | ns |
| Output Enable Hold Time | Read |  | - | tоен | 0 | - | - | 0 | - | - | ns |
|  | Toggle a | ta Polling |  |  | 10 | - | - | 10 | - | - | ns |
| $\overline{\overline{C E}}$ High During Toggle Bit Polling |  |  | - | tceph | 20 | - | - | 20 | - | - | ns |
| $\overline{\text { OE High During Toggle Bit Polling }}$ |  |  | - | toEph | 20 | - | - | 20 | - | - | ns |
| Read Recover Time Before Write |  |  | tghwL | tghwL | 0 | - | - | 0 | - | - | ns |
| Read Recover Time Before Write |  |  | tghel | tghel | 0 | - | - | 0 | - | - | ns |
| $\overline{\text { CE Setup Time }}$ |  |  | telw | tcs | 0 | - | - | 0 | - | - | ns |
| $\overline{\text { WE Setup Time }}$ |  |  | twleL | tws | 0 | - | - | 0 | - | - | ns |
| CE Hold Time |  |  | twHEH | tch | 0 | - | - | 0 | - | - | ns |
| WE Hold Time |  |  | terwh | twh | 0 | - | - | 0 | - | - | ns |
| Write Pulse Width |  |  | twww | twp | 35 | - | - | 45 | - | - | ns |
| $\overline{\text { CE Pulse Width }}$ |  |  | tELEEH | tcp | 35 | - | - | 45 | - | - | ns |
| Write Pulse Width High |  |  | twhwL | twpH | 25 | - | - | 25 | - | - | ns |
| $\overline{\text { CE Pulse Width High }}$ |  |  | tehel | tcp | 25 | - | - | 25 | - | - | ns |
| Programming Operation |  | Byte | twhwh | twHWH1 | - | 8 | - | - | 8 | - | $\mu \mathrm{s}$ |
|  |  | Word |  |  | - | 16 | - | - | 16 | - | $\mu \mathrm{s}$ |
| Sector Erase Operation *1 |  |  | twнwн\% | twHwH2 | - | 1 | - | - | 1 | - | s |
| Vcc Setup Time |  |  | - | tvos | 50 | - | - | 50 | - | - | $\mu \mathrm{s}$ |
| Rise Time to $\mathrm{V}_{10}{ }^{\text {*2 }}$ |  |  | - | tvide | 500 | - | - | 500 | - | - | ns |
| Voltage Transition Time *2 |  |  | - | tvLHT | 4 | - | - | 4 | - | - | $\mu \mathrm{s}$ |
| Write Pulse Width *2 |  |  | - | twpp | 100 | - | - | 100 | - | - | $\mu \mathrm{s}$ |
| $\overline{\text { OE Setup Time to } \overline{\text { WE }} \text { Active *2 }}$ |  |  | - | toesp | 4 | - | - | 4 | - | - | $\mu \mathrm{s}$ |

## MBM29DL800TA-7090/MBM29DL800BA-7090

(Continued)

| Parameter | Symbol |  | Value |  |  |  |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | -70 |  |  | -90 |  |  |  |
|  | JEDEC | Standard | Min | Typ | Max | Min | Typ | Max |  |
| $\overline{\mathrm{CE}}$ Setup Time to $\overline{\mathrm{WE}}$ Active *2 | - | tcsp | 4 | - | - | 4 | - | - | $\mu \mathrm{s}$ |
| Recover Time From RY/ $\overline{\mathrm{BY}}$ | - | trB | 0 | - | - | 0 | - | - | ns |
| RESET Pulse Width | - | trp | 500 | - | - | 500 | - | - | ns |
| RESET Hold Time Before Read | - | tre | 200 | - | - | 200 | - | - | ns |
| BYTE Switching Low to Output High-Z | - | tfloz | - | - | 25 | - | - | 30 | ns |
| $\overline{\text { BYTE Switching High to Output Active }}$ | - | tFhov | - | - | 70 | - | - | 90 | ns |
| Program/Erase Valid to RY/BY Delay | - | tBus ${ }^{\text {r }}$ | - | - | 90 | - | - | 90 | ns |
| Delay Time from Embedded Output Enable | - | teoe | - | - | 70 | - | - | 90 | ns |

*1: This does not include the preprogramming time.
*2 : This timing is for Sector Protection operation.

## MBM29DL800TA-7090/MBM29DL800BA-70/90

## ■ ERASE AND PROGRAMMING PERFORMANCE

| Parameter | Limits |  |  | Unit | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min | Typ | Max |  |  |
| Sector Erase Time | - | 1 | 10 | s | Excludes programming time prior to erasure |
| Word Programming Time | - | 16 | 360 | $\mu \mathrm{s}$ | Excludes system-level |
| Byte Programming Time | - | 8 | 300 | $\mu \mathrm{S}$ | overhead |
| Chip Programming Time | - | 8.4 | 25 | s | Excludes system-level overhead |
| Program/Erase Cycle | 100,000 | - | - | cycle | - |

## TSOP(1) PIN CAPACITANCE

| Parameter | Symbol | Test Setup | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Typ | Max |  |
| Input Capacitance | $\mathrm{CIN}_{\text {In }}$ | $\mathrm{V}_{1 \times}=0$ | 6 | 7.5 | pF |
| Output Capacitance | Cout | Vout $=0$ | 8.5 | 12 | pF |
| Control Pin Capacitance | $\mathrm{Cin}^{2}$ | $\mathrm{V}_{\mathrm{IN}}=0$ | 8 | 10 | pF |

Notes: - Test conditions $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$

- DQ15/A-1 pin capacitance is stipulated by output capacitance.

FBGA PIN CAPACITANCE

| Parameter | Symbol | Test Setup | Value |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Typ | Max |  |
| Input Capacitance | $\mathrm{Cin}^{\text {N }}$ | $\mathrm{V}_{1 \times}=0$ | 6 | 7.5 | pF |
| Output Capacitance | Cout | Vout $=0$ | 8.5 | 12 | pF |
| Control Pin Capacitance | Cin2 | $\mathrm{V}_{\mathrm{IN}}=0$ | 8 | 10 | pF |

Notes: $\bullet$ Test conditions $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$

- DQ15/A-1 pin capacitance is stipulated by output capacitance.


## MBM29DL800TA-70/90/MBM29DL800BA-70/90

## TIMING DIAGRAM

- Key to Switching Waveforms

| WAVEFORM | INPUTS | OUTPUTS |
| :---: | :---: | :---: |
|  | Must Be Steady | Will Be Steady |
| $415$ | May Change from H to L | Will Be Changing from H to L |
|  | May Change from L to H | Will Be Changing from $L$ to $H$ |
|  | "H" or "L" <br> Any Change <br> Permitted | Changing State Unknown |
|  | Does Not <br> Apply | Center Line is HighImpedance "Off" State |

(1) AC Waveforms for Read Operations


## MBM29DL800TA-7090/MBM29DL800BA-7090

(2) AC Waveforms for Hardware Reset/Read Operations

(3) Alternate $\overline{\text { WE Controlled Program Operations }}$


## MBM29DL800TA-7090/MBM29DL800BA-7090

## (4) Alternate CE Controlled Program Operations



Notes: - PA is address of the memory location to be programmed.

- PD is data to be programmed at byte address.
- $\overline{\mathrm{DQ}}_{7}$ is the output of the complement of the data written to the device.
- Dout is the output of the data written to the device.
- Figure indicates last two bus cycles out of four bus cycle sequence.
- These waveforms are for the $\times 16$ mode. (The addresses differ from $\times 8$ mode.)


## MBM29DL800TA-7099/MBM29DL800BA-7090

(5) AC Waveforms Chip/Sector Erase Operations


## MBM29DL800TA-7090/MBM29DL800BA-7090

## (6) AC Waveforms for $\overline{\text { Data }}$ Polling during Embedded Algorithm Operations



## MBM29DL800TA-7090/MBM29DL800BA-7090

(7) AC Waveforms for Toggle Bit I during Embedded Algorithm Operations


## MBM29DL800TA-70/90/MBM29DL800BA-70/90

(8) RY/BY Timing Diagram during Program/Erase Operations

(9) $\overline{\text { RESET }} /$ RY $/ \overline{B Y}$ Timing Diagram


## MBM29DL800TA-7090/MBM29DL800BA-7090

(10) Timing Diagram for Word Mode Configuration

(11) Timing Diagram for Byte Mode Configuration

(12) BYTE Timing Diagram for Write Operations


## MBM29DL800TA-70990/MBM29DL800BA-7090

(13) AC Waveforms for Sector Protection


## MBM29DL800TA-7090/MBM29DL800BA-7090

(14) Temporary Sector Unprotection Timing Diagram

(15) Bank-to-bank Read/Write Timing Diagram


Note : This is example of Read for Bank 1 and Embedded Algorithm (program) for Bank 2.
BA1: Address corresponding of Bank 1.
BA2: Address corresponding of Bank 2.

## MBM29DL800TA-70/90/MBM29DL800BA-70/90

(16) $\mathrm{DQ}_{2}$ vs. $\mathrm{DQ}_{6}$


## MBM29DL800TA-7090/MBM29DL800BA-7090

## (17) Extended Sector Protection Timing Diagram



## MBM29DL800TA-70/90/MBM29DL800BA-70/90

## FLOW CHART

## (1) Embedded Program ${ }^{\text {TM }}$ Algorithm

## EMBEDDED ALGORITHM



Program Command Sequence (Address/Command):


Notes: • The sequence is applied for $\times 16$ mode.

- The addresses differ from $\times 8$ mode.


## MBM29DL800TA-7099/MBM29DL800BA-7090

## (2) Embedded Erase ${ }^{\text {TM }}$ Algorithm

## EMBEDDED ALGORITHM



Chip Erase Command Sequence (Address/Command):

Individual Sector/Multiple Sector Erase Command Sequence (Address/Command):


Notes : • The sequence is applied for $\times 16$ mode.

- The addresses differ from $\times 8$ mode.


## MBM29DL800TA-70/90/MBM29DL800BA-70/90

## (3) Data Polling Algorithm



VA = Byte address for programming
= Any of the sector addresses within the sector being erased during sector erase or multiple sector erases operation
= Any of the sector addresses within the sector not being protected during chip erase operation
*: $\mathrm{DQ}_{7}$ is rechecked even if $\mathrm{DQ}_{5}=$ " 1 " because $\mathrm{DQ}_{7}$ may change simultaneously with $\mathrm{DQ}_{5}$.

## MBM29DL800TA-7990/MBM29DL800BA-7090

## (4) Toggle Bit Algorithm


*1 : Read toggle bit twice to determine whether it is toggling.
*2 : Recheck toggle bit because it may stop toggling as DQ5 changes to " 1 ".

## MBM29DL800TA-70/90/MBM29DL800BA-70/90

## (5) Sector Protection Algorithm



## MBM29DL800TA-7090/MBM29DL800BA-7090

## (6) Temporary Sector Unprotection Algorithm


*1 : All protected sectors are unprotected.
*2 : All previously protected sectors are protected once again.

## MBM29DL800TA-70/90/MBM29DL800BA-70/90

## (7) Extended Sector Protection Algorithm



## MBM29DL800TA-7099/MBM29DL800BA-7090

(8) Embedded Program ${ }^{\text {TM }}$ Algorithm for Fast Mode

## FAST MODE ALGORITHM



Notes: - The sequence is applied for $\times 16$ mode.

- The addresses differ from $\times 8$ mode.


## MBM29DL800TA-7099/MBM29DL800BA-7090

## ORDERING INFORMATION

| Part No. | Package | Access Time | Sector Architecture |
| :---: | :---: | :---: | :---: |
| MBM29DL800TA-70PFTN MBM29DL800TA-90PFTN | 48-pin plastic TSOP (1) (FPT-48P-M19) (Normal Bend) | $\begin{aligned} & 70 \\ & 90 \end{aligned}$ | Top Sector |
| MBM29DL800TA-70PFTR MBM29DL800TA-90PFTR | 48-pin plastic TSOP (1) (FPT-48P-M20) (Reverse Bend) | $\begin{aligned} & 70 \\ & 90 \end{aligned}$ |  |
| MBM29DL800TA-70PBT MBM29DL800TA-90PBT | 48-pin plastic FBGA <br> (BGA-48P-M12) | $\begin{aligned} & 70 \\ & 90 \end{aligned}$ |  |
| MBM29DL800BA-70PFTN MBM29DL800BA-90PFTN | 48-pin plastic TSOP (1) (FPT-48P-M19) (Normal Bend) | $\begin{aligned} & 70 \\ & 90 \end{aligned}$ | Bottom Sector |
| MBM29DL800BA-70PFTR MBM29DL800BA-90PFTR | $\begin{gathered} \hline \text { 48-pin plastic TSOP (1) } \\ \text { (FPT-48P-M20) } \\ \text { (Reverse Bend) } \\ \hline \end{gathered}$ | $\begin{aligned} & 70 \\ & 90 \end{aligned}$ |  |
| MBM29DL800BA-70PBT MBM29DL800BA-90PBT | 48-pin plastic FBGA <br> (BGA-48P-M12) | $\begin{aligned} & \hline 70 \\ & 90 \end{aligned}$ |  |

MBM29DL800

## MBM29DL800TA-7090/MBM29DL800BA-70900

## PACKAGE DIMENSIONS

48-pin plastic TSOP (1) (FPT-48P-M19)

Note1 : * : Values do not include resin protrusion.
Resin protrusion and gate protrusion are +0.15 (.006) Max (each side) . Note2 : Pins width and pins thickness include plating thickness.

© 2002 FUJTSU LIMITED F48029S-C.5.6
Dimensions in mm (inches)
48-pin plastic TSOP (1)
(FPT-48P-M20)
Note1 : *: Values do not include resin protrusion.
Resin protrusion and gate protrusion are +0.15 (.006) Max (each side) .
Note2 : Pins width and pins thickness include plating thickness.

© 2002 FUJITSU LIMITED F48030S-C.5.6
(Continued)

## MBM29DL800TA-70/90/MBM29DL800BA-70/90

(Continued)

© 2001 FUJTSU LIMTED B48012S-C.3.3
Dimensions in mm (inches)

## FUJITSU LIMITED

All Rights Reserved.
The contents of this document are subject to change without notice. Customers are advised to consult with FUJITSU sales representatives before ordering.

The information and circuit diagrams in this document are presented as examples of semiconductor device applications, and are not intended to be incorporated in devices for actual use. Also, FUJITSU is unable to assume responsibility for infringement of any patent rights or other rights of third parties arising from the use of this information or circuit diagrams.

The products described in this document are designed, developed and manufactured as contemplated for general use, including without limitation, ordinary industrial use, general office use, personal use, and household use, but are not designed, developed and manufactured as contemplated (1) for use accompanying fatal risks or dangers that, unless extremely high safety is secured, could have a serious effect to the public, and could lead directly to death, personal injury, severe physical damage or other loss (i.e., nuclear reaction control in nuclear facility, aircraft flight control, air traffic control, mass transport control, medical life support system, missile launch control in weapon system), or (2) for use requiring extremely high reliability (i.e., submersible repeater and artificial satellite).
Please note that Fujitsu will not be liable against you and/or any third party for any claims or damages arising in connection with above-mentioned uses of the products.

Any semiconductor devices have an inherent chance of failure. You must protect against injury, damage or loss from such failures by incorporating safety design measures into your facility and equipment such as redundancy, fire protection, and prevention of over-current levels and other abnormal operating conditions.

If any products described in this document represent goods or technologies subject to certain restrictions on export under the Foreign Exchange and Foreign Trade Law of Japan, the prior authorization by Japanese government will be required for export of those products from Japan.


[^0]:    Embedded Erase ${ }^{\mathrm{TM}}$ and Embedded Program ${ }^{\mathrm{TM}}$ are trademarks of Advanced Micro Devices, Inc.

