

## M59DR016C M59DR016D

16 Mbit (1Mb x16, Dual Bank, Page)
1.8V Supply Flash Memory

PRODUCT PREVIEW

#### ■ SUPPLY VOLTAGE

- V<sub>DD</sub> = V<sub>DDQ</sub> = 1.65V to 2.2V for Program, Erase and Read
- V<sub>PP</sub> = 12V for fast Program (optional)

#### ■ ASYNCHRONOUS PAGE MODE READ

Page Width: 4 wordsPage Access: 35nsRandom Access: 100ns

#### ■ PROGRAMMING TIME

- 10µs by Word typical
- Double Word Programming Option
- MEMORY BLOCKS
  - Dual Bank Memory Array: 4 Mbit 12 Mbit
  - Parameter Blocks (Top or Bottom location)

#### ■ DUAL BANK OPERATIONS

- Read within one Bank while Program or Erase within the other
- No delay between Read and Write operations

#### ■ BLOCK PROTECTION/UNPROTECTION

- All Blocks protected at Power Up
- Any combination of Blocks can be protected
- COMMON FLASH INTERFACE (CFI)
- 64 bit SECURITY CODE
- ERASE SUSPEND and RESUME MODES
- 100,000 PROGRAM/ERASE CYCLES per BLOCK

#### ■ ELECTRONIC SIGNATURE

- Manufacturer Code: 20h

- Top Device Code, M59DR016C: 2293h

- Bottom Device Code, M59DR016D: 2294h



Figure 1. Logic Diagram



March 2001 1/37





**Table 1. Signal Names** 

| A0-A19           | Address Inputs                                      |
|------------------|-----------------------------------------------------|
| DQ0-DQ15         | Data Input/Outputs, Command Inputs                  |
| Ē                | Chip Enable                                         |
| G                | Output Enable                                       |
| W                | Write Enable                                        |
| RP               | Reset/Power Down                                    |
| WP               | Write Protect                                       |
| V <sub>DD</sub>  | Supply Voltage                                      |
| V <sub>DDQ</sub> | Supply Voltage for Input/Output<br>Buffers          |
| V <sub>PP</sub>  | Optional Supply Voltage for<br>Fast Program & Erase |
| V <sub>SS</sub>  | Ground                                              |
| NC               | Not Connected Internally                            |

#### **DESCRIPTION**

The M59DR016 is a 16 Mbit non-volatile Flash memory that may be erased electrically at block level and programmed in-system on a Word-by-Word basis using a 1.65V to 2.2V  $V_{DD}$  supply for the circuitry. For Program and Erase operations the necessary high voltages are generated internally. The device supports asynchronous page mode from all the blocks of the memory array.

The array matrix organization allows each block to be erased and reprogrammed without affecting other blocks. All blocks are protected against programming and erase at Power Up. Blocks can be unprotected to make changes in the application and then reprotected.

Instructions for Read/Reset, Auto Select, Write Configuration Register, Programming, Block Erase, Bank Erase, Erase Suspend, Erase Resume, Block Protect, Block Unprotect, Block Locking, CFI Query, are written to the memory through a Command Interface using standard microprocessor write timings.

The device is offered in TFBGA48 (0.75 mm pitch) packages and it is supplied with all the bits erased (set to '1').

Table 2. Absolute Maximum Ratings (1)

| Symbol                             | Parameter                         | Value                         | Unit |
|------------------------------------|-----------------------------------|-------------------------------|------|
| T <sub>A</sub>                     | Ambient Operating Temperature (2) | -40 to 85                     | °C   |
| T <sub>BIAS</sub>                  | Temperature Under Bias            | -40 to 125                    | °C   |
| T <sub>STG</sub>                   | Storage Temperature               | -55 to 155                    | °C   |
| V <sub>IO</sub> (3)                | Input or Output Voltage           | -0.5 to V <sub>DDQ</sub> +0.5 | V    |
| V <sub>DD</sub> , V <sub>DDQ</sub> | Supply Voltage                    | -0.5 to 2.7                   | V    |
| V <sub>PP</sub>                    | Program Voltage                   | -0.5 to 13                    | V    |

Note: 1. Except for the rating "Operating Temperature Range", stresses above those listed in the Table "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only and operation of the device at these or any other conditions above those indicated in the Operating sections of this specification is not implied. Exposure to Absolute Maximum Rating conditions for extended periods may affect device reliability. Refer also to the STMicroelectronics SURE Program and other relevant quality documents.

- 2. Depends on range.
- 3. Minimum Voltage may undershoot to -2V during transition and for less than 20ns.

#### Organization

The M59DR016 is organized as 1Mb x16 bits. A0-A19 are the address lines, DQ0-DQ15 are the Data Input/Output. Memory control is provided by Chip Enable  $\overline{E}$ , Output Enable  $\overline{G}$  and Write Enable  $\overline{W}$  inputs.

Reset  $\overline{RP}$  is used to reset all the memory circuitry and to set the chip in power down mode if this function is enabled by a proper setting of the Configuration Register. Erase and Program operations are controlled by an internal Program/Erase Controller (P/E.C.). Status Register data output on DQ7 provides a Data Polling signal, DQ6 and DQ2 provide Toggle signals and DQ5 provides error bit to indicate the state of the P/E.C operations.

#### **Memory Blocks**

The device features asymmetrically blocked architecture. M59DR016 has an array of 39 blocks and is divided into two banks A and B, providing Dual Bank operations. While programming or erasing in

Bank A, read operations are possible into Bank B or vice versa. The memory also features an erase suspend allowing to read or program in another block within the same bank. Once suspended the erase can be resumed. The Bank Size and Sectorization are summarized in Table 7. Parameter Blocks are located at the top of the memory address space for the M59DR016C, and at the bottom for the M59DR016D. The memory maps are shown in Tables 3, 4, 5 and 6.

The Program and Erase operations are managed automatically by the P/E.C. Block protection against Program or Erase provides additional data security. All blocks are protected at Power Up. Instructions are provided to protect or unprotect any block in the application. A second register locks the protection status while WP is low (see Block Locking description). The Reset command does not affect the configuration of unprotected blocks and the Configuration Register status.

Table 3. Bank A, Top Boot Block Addresses M59DR016C

| NOOD I CO I CO |                 |                 |  |  |  |  |  |
|----------------|-----------------|-----------------|--|--|--|--|--|
| #              | Size<br>(KWord) | Address Range   |  |  |  |  |  |
| 14             | 4               | 0FF000h-0FFFFh  |  |  |  |  |  |
| 13             | 4               | 0FE000h-0FEFFFh |  |  |  |  |  |
| 12             | 4               | 0FD000h-0FDFFFh |  |  |  |  |  |
| 11             | 4               | 0FC000h-0FCFFFh |  |  |  |  |  |
| 10             | 4               | 0FB000h-0FBFFFh |  |  |  |  |  |
| 9              | 4               | 0FA000h-0FAFFFh |  |  |  |  |  |
| 8              | 4               | 0F9000h-0F9FFFh |  |  |  |  |  |
| 7              | 4               | 0F8000h-0F8FFFh |  |  |  |  |  |
| 6              | 32              | 0F0000h-0F7FFFh |  |  |  |  |  |
| 5              | 32              | 0E8000h-0EFFFFh |  |  |  |  |  |
| 4              | 32              | 0E0000h-0E7FFh  |  |  |  |  |  |
| 3              | 32              | 0D8000h-0DFFFFh |  |  |  |  |  |
| 2              | 32              | 0D0000h-0D7FFFh |  |  |  |  |  |
| 1              | 32              | 0C8000h-0CFFFFh |  |  |  |  |  |
| 0              | 32              | 0C0000h-0C7FFFh |  |  |  |  |  |
|                |                 |                 |  |  |  |  |  |

Table 4. Bank B, Top Boot Block Addresses M59DR016C

| #  | Size<br>(KWord) | Address Range   |
|----|-----------------|-----------------|
| 23 | 32              | 0B8000h-0BFFFFh |
| 22 | 32              | 0B0000h-0B7FFFh |
| 21 | 32              | 0A8000h-0AFFFFh |
| 20 | 32              | 0A0000h-0A7FFFh |
| 19 | 32              | 098000h-09FFFFh |
| 18 | 32              | 090000h-097FFh  |
| 17 | 32              | 088000h-08FFFFh |
| 16 | 32              | 080000h-087FFFh |
| 15 | 32              | 078000h-07FFFh  |
| 14 | 32              | 070000h-077FFFh |
| 13 | 32              | 068000h-06FFFFh |
| 12 | 32              | 060000h-067FFFh |
| 11 | 32              | 058000h-05FFFFh |
| 10 | 32              | 050000h-057FFFh |
| 9  | 32              | 048000h-04FFFFh |
| 8  | 32              | 040000h-047FFFh |
| 7  | 32              | 038000h-03FFFFh |
| 6  | 32              | 030000h-037FFFh |
| 5  | 32              | 028000h-02FFFFh |
| 4  | 32              | 020000h-027FFFh |
| 3  | 32              | 018000h-01FFFFh |
| 2  | 32              | 010000h-017FFFh |
| 1  | 32              | 008000h-00FFFh  |
| 0  | 32              | 000000h-007FFFh |

Table 5. Bank B, Bottom Boot Block Addresses M59DR016D

| #  | Size<br>(KWord) | Address Range   |
|----|-----------------|-----------------|
| 23 | 32              | 0F8000h-0FFFFh  |
| 22 | 32              | 0F0000h-0F7FFh  |
| 21 | 32              | 0E8000h-0EFFFFh |
| 20 | 32              | 0E0000h-0E7FFh  |
| 19 | 32              | 0D8000h-0DFFFFh |
| 18 | 32              | 0D0000h-0D7FFFh |
| 17 | 32              | 0C8000h-0CFFFFh |
| 16 | 32              | 0C0000h-0C7FFFh |
| 15 | 32              | 0B8000h-0BFFFFh |
| 14 | 32              | 0B0000h-0B7FFFh |
| 13 | 32              | 0A8000h-0AFFFFh |
| 12 | 32              | 0A0000h-0A7FFFh |
| 11 | 32              | 098000h-09FFFFh |
| 10 | 32              | 090000h-097FFh  |
| 9  | 32              | 088000h-08FFFFh |
| 8  | 32              | 080000h-087FFFh |
| 7  | 32              | 078000h-07FFFh  |
| 6  | 32              | 070000h-077FFFh |
| 5  | 32              | 068000h-06FFFFh |
| 4  | 32              | 060000h-067FFh  |
| 3  | 32              | 058000h-05FFFFh |
| 2  | 32              | 050000h-057FFh  |
| 1  | 32              | 048000h-04FFFh  |
| 0  | 32              | 040000h-047FFh  |

Table 6. Bank A, Bottom Boot Block Addresses M59DR016D

| #  | Size<br>(KWord) | Address Range   |
|----|-----------------|-----------------|
| 14 | 32              | 038000h-03FFFFh |
| 13 | 32              | 030000h-037FFFh |
| 12 | 32              | 028000h-02FFFFh |
| 11 | 32              | 020000h-027FFFh |
| 10 | 32              | 018000h-01FFFFh |
| 9  | 32              | 010000h-017FFFh |
| 8  | 32              | 008000h-00FFFh  |
| 7  | 4               | 007000h-007FFFh |
| 6  | 4               | 006000h-006FFFh |
| 5  | 4               | 005000h-005FFFh |
| 4  | 4               | 004000h-004FFFh |
| 3  | 4               | 003000h-003FFFh |
| 2  | 4               | 002000h-002FFFh |
| 1  | 4               | 001000h-001FFFh |
| 0  | 4               | 000000h-000FFFh |

Table 7. Bank Size and Sectorization

|        | Bank Size | Parameter Blocks    | Main Blocks           |  |
|--------|-----------|---------------------|-----------------------|--|
| Bank A | 4 Mbit    | 8 blocks of 4 KWord | 7 blocks of 32 KWord  |  |
| Bank B | 12 Mbit   | -                   | 24 blocks of 32 KWord |  |

#### SIGNAL DESCRIPTIONS

See Figure 1 and Table 1.

**Address Inputs (A0-A19).** The address inputs for the memory array are latched during a write operation on the falling edge of Chip Enable  $\overline{E}$  or Write Enable  $\overline{W}$ , whichever occurs last.

Data Input/Output (DQ0-DQ15). The Input is data to be programmed in the memory array or a command to be written to the Command Interface (C.I.) Both input data and commands are latched on the rising edge of Write Enable  $\overline{W}$ . The Ouput is data from the Memory Array, the Common Flash Interface, the Electronic Signature Manufacturer or Device codes, the Block Protection status, the Configuration Register status or the Status Register Data Polling bit DQ7, the Toggle Bits DQ6 and DQ2, the Error bit DQ5. The data bus is high impedance when the chip is deselected, Output Enable  $\overline{G}$  is at  $V_{IH}$ , or  $\overline{RP}$  is at  $V_{IL}$ .

Chip Enable ( $\overline{\mathbf{E}}$ ). The Chip Enable input activates the memory control logic, input buffers, decoders and sense amplifiers.  $\overline{\mathbf{E}}$  at  $V_{IH}$  deselects the memory and reduces the power consumption to the standby level.  $\overline{\mathbf{E}}$  can also be used to control writing to the command register and to the memory array, while  $\overline{\mathbf{W}}$  remains at  $V_{IL}$ .

Output Enable  $(\overline{G})$ . The Output Enable gates the outputs through the data buffers during a read operation. When  $\overline{G}$  is at  $V_{IH}$  the outputs are High impedance.

Write Enable ( $\overline{W}$ ). This input controls writing to the Command Register and Data latches. Data are latched on the rising edge of  $\overline{W}$ .

Write Protect ( $\overline{WP}$ ). This input gives an additional hardware protection level against program or erase when pulled at  $V_{IL}$ , as described in the Block Lock instruction description.

**Reset/Power Down Input (\overline{RP}).** The  $\overline{RP}$  input provides hardware reset of the memory (without affecting the Configuration Register status), and/ or Power Down functions, depending on the Configuration Register status. Reset/Power Down of the memory is achieved by pulling  $\overline{RP}$  to  $V_{IL}$  for at least  $t_{PLPH}$ . When the reset pulse is given, if the memory is in Read, Erase Suspend Read or Standby, it will output new valid data in  $t_{PHQ7V1}$  after the rising edge of  $\overline{RP}$ . If the memory is in Erase or Program modes, the operation will be aborted

and the reset recovery will take a maximum of  $t_{PLQ7V}$ . The memory will recover from Power Down (when enabled) in  $t_{PHQ7V2}$  after the rising edge of  $\overline{RP}$ . See Tables 25, 26 and Figure 9.

 $V_{DD}$  and  $V_{DDQ}$  Supply Voltage (1.65V to 2.2V). The main power supply for all operations (Read, Program and Erase).  $V_{DD}$  and  $V_{DDQ}$  must be at the same voltage.

**VPP Programming Voltage (11.4V to 12.6V).** Used to provide high voltage for fast factory programming. High voltage on VPP pin is required to use the Double Word Program instruction. It is also possible to perform word program or erase instructions with VPP pin grounded.

**Vss Ground.** Vss is the reference for all the voltage measurements.

#### **DEVICE OPERATIONS**

The following operations can be performed using the appropriate bus cycles: Read Array (Random, and Page Modes), Write command, Output Disable, Standby, Reset/Power Down and Block Locking. See Table 8.

Read. Read operations are used to output the contents of the Memory Array, the Electronic Signature, the Status Register, the CFI, the Block Protection Status or the Configuration Register status. Read operation of the memory array is performed in asynchronous page mode, that provides fast access time. Data is internally read and stored in a page buffer. The page has a size of 4 words and is addressed by A0-A1 address inputs. Read operations of the Electronic Signature, the Status Register, the CFI, the Block Protection Status, the Configuration Register status and the Security Code are performed as single asyncronous read cycles (Random Read). Both Chip Enable  $\overline{E}$  and Output Enable  $\overline{G}$  must be at  $V_{IL}$  in order to read the output of the memory.

**Write.** Write operations are used to give Instruction Commands to the memory or to latch Input Data to be programmed. A write operation is initiated when Chip Enable  $\overline{E}$  and Write Enable  $\overline{W}$  are at  $V_{IL}$  with Output Enable  $\overline{G}$  at  $V_{IH}$ . Addresses are latched on the falling edge of  $\overline{W}$  or  $\overline{E}$  whichever occurs last. Commands and Input Data are latched on the rising edge of  $\overline{W}$  or  $\overline{E}$  whichever occurs first. Noise pulses of less than 5ns typical on  $\overline{E}$ ,  $\overline{W}$  and  $\overline{G}$  signals do not start a write cycle.

Table 8. User Bus Operations (1)

| Operation          | Ē               | G               | W               | RP              | WP              | DQ15-DQ0   |
|--------------------|-----------------|-----------------|-----------------|-----------------|-----------------|------------|
| Write              | V <sub>IL</sub> | V <sub>IH</sub> | VIL             | V <sub>IH</sub> | V <sub>IH</sub> | Data Input |
| Output Disable     | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Hi-Z       |
| Standby            | V <sub>IH</sub> | Х               | Х               | V <sub>IH</sub> | V <sub>IH</sub> | Hi-Z       |
| Reset / Power Down | Х               | Х               | Х               | V <sub>IL</sub> | V <sub>IH</sub> | Hi-Z       |
| Block Locking      | VIL             | Х               | Х               | V <sub>IH</sub> | VIL             | Х          |

Note: 1. X = Don't care.

Table 9. Read Electronic Signature (AS and Read CFI instructions)

| Code              | Device    | Ē        | G               | W               | Α0              | A1              | A7-A2 | Other<br>Addresses | DQ15-DQ8 | DQ7-DQ0 |
|-------------------|-----------|----------|-----------------|-----------------|-----------------|-----------------|-------|--------------------|----------|---------|
| Manufacturer Code |           | $V_{IL}$ | $V_{IL}$        | $V_{IH}$        | $V_{IL}$        | $V_{IL}$        | 0     | Don't Care         | 00h      | 20h     |
| Device Code       | M59DR016C | $V_{IL}$ | $V_{IL}$        | $V_{IH}$        | V <sub>IH</sub> | $V_{IL}$        | 0     | Don't Care         | 22h      | 93h     |
| Device Code       | M59DR016D | $V_{IL}$ | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IL</sub> | 0     | Don't Care         | 22h      | 94h     |

Table 10. Read Block Protection (AS and Read CFI instructions)

| Block Status      | Ē               | G               | W               | Α0              | <b>A</b> 1      | A19-A12       | A7-A2 | Other<br>Addresses | DQ0 | DQ1 | DQ15-DQ2 |
|-------------------|-----------------|-----------------|-----------------|-----------------|-----------------|---------------|-------|--------------------|-----|-----|----------|
| Protected Block   | $V_{IL}$        | $V_{IL}$        | $V_{IH}$        | $V_{IL}$        | V <sub>IH</sub> | Block Address | 0     | Don't Care         | 1   | 0   | 0000h    |
| Unprotected Block | V <sub>IL</sub> | $V_{IL}$        | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Block Address | 0     | Don't Care         | 0   | 0   | 0000h    |
| Locked Block      | VIL             | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Block Address | 0     | Don't Care         | Х   | 1   | 0000h    |

Table 11. Read Configuration Register (AS and Read CFI instructions)

| RP Function      | Ē               | G        | W               | A0              | <b>A</b> 1      | A7-A2 | Other Addresses | DQ10 | DQ9-DQ0<br>DQ15-DQ11 |
|------------------|-----------------|----------|-----------------|-----------------|-----------------|-------|-----------------|------|----------------------|
| Reset            | V <sub>IL</sub> | $V_{IL}$ | V <sub>IH</sub> | $V_{IH}$        | V <sub>IH</sub> | 0     | Don't Care      | 0    | Don't Care           |
| Reset/Power Down | VIL             | $V_{IL}$ | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | 0     | Don't Care      | 1    | Don't Care           |

**Dual Bank Operations.** The Dual Bank allows to read data from one bank of memory while a program or erase operation is in progress in the other bank of the memory. Read and Write cycles can be initiated for simultaneous operations in different banks without any delay. Status Register during Program or Erase must be monitored using an address within the bank being modified.

**Output Disable.** The data outputs are high impedance when the Output Enable  $\overline{G}$  is at  $V_{IH}$  with Write Enable  $\overline{W}$  at  $V_{IH}$ .

**Standby.** The memory is in standby when Chip Enable  $\bar{E}$  is at  $V_{IH}$  and the P/E.C. is idle. The power consumption is reduced to the standby level and the outputs are high impedance, independent of the Output Enable  $\bar{G}$  or Write Enable  $\bar{W}$  inputs.

**Automatic Standby.** When in Read mode, after 150ns of bus inactivity and when CMOS levels are driving the addresses, the chip automatically enters a pseudo-standby mode where consumption is reduced to the CMOS standby value, while outputs still drive the bus.

**Power Down.** The memory is in Power Down when the <u>Configuration</u> Register is set for Power Down and  $\overline{RP}$  is at  $V_{IL}$ . The power consumption is reduced to the Power Down level, and Outputs are in high impedance, independent of the <u>Chip Enable E</u>, Output Enable  $\overline{G}$  or Write Enable  $\overline{W}$  inputs.

**Block Locking.** Any combination of blocks can be temporarily protected against Program or Erase by setting the lock register and pulling  $\overline{WP}$  to  $V_{IL}$  (see Block Lock instruction).

#### **INSTRUCTIONS AND COMMANDS**

Seventeen instructions are defined (see Table 14), and the internal P/E.C. automatically handles all timing and verification of the Program and Erase operations. The Status Register Data Polling, Toggle, Error bits can be read at any time, during programming or erase, to monitor the progress of the operation.

Instructions, made up of one or more commands written in cycles, can be given to the Program/ Erase Controller through a Command Interface (C.I.). The C.I. latches commands written to the memory. Commands are made of address and data sequences. Two Coded Cycles unlock the Command Interface. They are followed by an input command or a confirmation command. The Coded Sequence consists of writing the data AAh at the address 555h during the first cycle and the data 55h at the address 2AAh during the second cycle. Instructions are composed of up to six cycles. The first two cycles input a Coded Sequence to the Command Interface which is common to all instructions (see Table 14). The third cycle inputs the instruction set-up command. Subsequent cycles output the addressed data, Electronic Signature, Block Protection, Configuration Register Status or CFI Query for Read operations. In order to give additional data protection, the instructions for Block Erase and Bank Erase require further command inputs. For a Program instruction, the fourth command cycle inputs the address and data to be programmed. For a Double Word Programming instruction, the fourth and fifth command cycles input the address and data to be programmed. For a Block Erase and Bank Erase instructions, the fourth and fifth cycles input a further Coded Sequence before the Erase confirm command on the sixth cycle. Any combination of blocks of the same memory bank can be erased. Erasure of a memory block may be suspended, in order to read data from another block or to program data in another block, and then resumed. When power is first applied the command interface

Command sequencing must be followed exactly. Any invalid combination of commands will reset the device to Read Array. The increased number of cycles has been chosen to ensure maximum data security.

is reset to Read Array.

Read/Reset (RD) Instruction. The Read/Reset instruction consists of one write cycle giving the command F0h. It can be optionally preceded by the two Coded Cycles. Subsequent read operations will read the memory array addressed and output the data read.

CFI Query (RCFI) Instruction. Common Flash Interface Query mode is entered writing 98h at address 55h. The CFI data structure gives information on the device, such as the sectorization, the command set and some electrical specifications. Tables 15, 19, 20 and 21 show the addresses used to retrieve each data. The CFI data structure contains also a security area; in this section, a 64 bit unique security number is written, starting at address 80h. This area can be accessed only in read mode by the final user and there are no ways of changing the code after it has been written by ST. Write a read instruction (RD) to return to Read mode.

Table 12. Commands

| Hex Code | Command                                                                                       |
|----------|-----------------------------------------------------------------------------------------------|
| 00h      | Bypass Reset                                                                                  |
| 10h      | Bank Erase Confirm                                                                            |
| 20h      | Unlock Bypass                                                                                 |
| 30h      | Block Erase Resume/Confirm                                                                    |
| 40h      | Double Word Program                                                                           |
| 60h      | Block Protect, or<br>Block Unprotect, or<br>Block Lock, or<br>Write Configuration Register    |
| 80h      | Set-up Erase                                                                                  |
| 90h      | Read Electronic Signature, or<br>Block Protection Status, or<br>Configuration Register Status |
| 98h      | CFI Query                                                                                     |
| A0h      | Program                                                                                       |
| B0h      | Erase Suspend                                                                                 |
| F0h      | Read Array/Reset                                                                              |

Auto Select (AS) Instruction. This instruction uses two Coded Cycles followed by one write cycle giving the command 90h to address 555h for command set-up. A subsequent read will output the Manufacturer or the Device Code (Electronic Signature), the Block Protection status or the Configuration Register status depending on the levels of A0 and A1 (see Tables 9, 10 and 11). A7-A2 must be at V<sub>IL</sub>, while other address input are ignored. The bank address is don't care for this instruction. The Electronic Signature can be read from the memory allowing programming equipment or applications to automatically match their interface to the characteristics of M59DR016. The Manufacturer Code is output when the address lines A0 and A1 are at  $V_{\text{IL}}$ , the Device Code is output when A0 is at V<sub>IH</sub> with A1 at V<sub>IL</sub>

The codes are output on DQ0-DQ7 with DQ8-DQ15 at 00h. The AS instruction also allows the access to the Block Protection Status. After giving the AS instruction, A0 is set to  $V_{IL}$  with A1 at  $V_{IH}$ , while A12-A19 define the address of the block to be verified. A read in these conditions will output a 01h if the block is protected and a 00h if the block is not protected.

The AS Instruction finally allows the access to the Configuration Register status if both A0 and A1 are set to  $V_{IL}$ . If DQ10 is '0' only the Reset function is active as RP is set to  $V_{IL}$  (default at power-up). If DQ10 is '1' both the Reset and the Power Down functions will be achieved by pulling  $\overline{RP}$  to  $V_{IL}$ . The other bits of the Configuration Register are reserved and must be ignored. A reset command puts the device in read array mode.

Write Configuration Register (CR) Instruction. This instruction uses two Coded Cycles followed by one write cycle giving the command 60h to address 555h. A further write cycle giving the command 03h writes the contents of address bits A0-A15 to the 16 bits configuration register. Bits written by inputs A0-A9 and A11-A15 are reserved for future use. Address input A10 defines the status of the Reset/Power Down functions. It must be set to  $V_{IL}$  to enable only the Reset function and to  $V_{IH}$  to enable also the Power Down function. At Power Up all the Configuration Register bits are reset to '0'.

Enter Bypass Mode (EBY) Instruction. This instruction uses the two Coded cycles followed by one write cycle giving the command 20h to address 555h for mode set-up. Once in Bypass mode, the device will accept the Exit Bypass

(XBY) and Program or Double Word Program in Bypass mode (PGBY, DPGBY) commands. The Bypass mode allows to reduce the overall programming time when large memory arrays need to be programmed.

**Exit Bypass Mode (XBY) Instruction.** This instruction uses two write cycles. The first inputs to the memory the command 90h and the second inputs the Exit Bypass mode confirm (00h). After the XBY instruction, the device resets to Read Memory Array mode.

Program in Bypass Mode (PGBY) Instruction. This instruction uses two write cycles. The Program command A0h is written to any Address on the first cycle and the second write cycle latches the Address on the falling edge of W or E and the Data to be written on the rising edge and starts the P/E.C. Read operations within the same bank output the Status Register bits after the programming has started. Memory programming is made only by writing '0' in place of '1'. Status bits DQ6 and DQ7 determine if programming is on-going and DQ5 allows verification of any possible error.

Program (PG) Instruction. This instruction uses four write cycles. The Program command A0h is written to address 555h on the third cycle after two Coded Cycles. A fourth write operation latches the Address and the Data to be written and starts the P/E.C. Read operations within the same bank output the Status Register bits after the programming has started. Memory programming is made only by writing '0' in place of '1'. Status bits DQ6 and DQ7 determine if programming is on-going and DQ5 allows verification of any possible error. Programming at an address not in blocks being erased is also possible during erase suspend.

Double Word Program (DPG) Instruction. This feature is offered to improve the programming throughput, writing a page of two adjacent words in parallel. High voltage (11.4V to 12.6V) on VPP pin is required. This instruction uses five write cycles. The double word program command 40h is written to address 555h on the third cycle after two Coded Cycles. A fourth write cycle latches the address and data to be written to the first location. A fifth write cycle latches the new data to be written to the second location and starts the P/E.C.. Note that the two locations must have the same address except for the address bit A0. The Double Word Program can be executed in Bypass mode (DPG-BY) to skip the two coded cycles at the beginning of each command.

Table 13. Protection States (1)

| Current State (2) | Program/Erase |         | Next State After Event <sup>(3)</sup> |      |                           |  |  |
|-------------------|---------------|---------|---------------------------------------|------|---------------------------|--|--|
| (WP, DQ1, DQ0)    | Allowed       | Protect | Unprotect                             | Lock | WP transition             |  |  |
| 100               | yes           | 101     | 100                                   | 111  | 000                       |  |  |
| 101               | no            | 101     | 100                                   | 111  | 001                       |  |  |
| 110               | yes           | 111     | 110                                   | 111  | 011                       |  |  |
| 111               | no            | 111     | 110                                   | 111  | 011                       |  |  |
| 000               | yes           | 001     | 000                                   | 011  | 100                       |  |  |
| 001               | no            | 001     | 000                                   | 011  | 101                       |  |  |
| 011               | no            | 011     | 011                                   | 011  | 111 or 110 <sup>(4)</sup> |  |  |

Note: 1. All blocks are protected at power-up, so the default configuration is 001 or 101 according to WP status.

- Current state and Next state gives the protection status of a block. The protection status is defined by the write protect pin and by DQ1 (= 1 for a locked block) and DQ0 (= 1 for a protected block) as read in the Autoselect instruction with A1 = V<sub>IH</sub> and A0 = V<sub>IL</sub>.
- 3. Next state is the protection status of a block after a Protect or Unprotect or Lock command has been issued or after WP has changed its logic value.
- 4. A WP transition to VIH on a locked block will restore the previous DQ0 value, giving a 111 or 110.

Block Protect (BP), Block Unprotect (BU), Block Lock (BL) Instructions. All blocks are protected at power-up. Each block of the array has two levels of protection against program or erase operation. The first level is set by the Block Protect instruction; a protected block cannot be programmed or erased until a Block Unprotect instruction is given for that block. A second level of protection is set by the Block Lock instruction, and requires the use of the WP pin, according to the following scheme:

- when WP is at V<sub>IH</sub>, the Lock status is overridden and all blocks can be protected or unprotected;
- when WP is at V<sub>IL</sub>, Lock status is enabled; the locked blocks are protected, regardless of their previous protect state, and protection status cannot be changed. Blocks that are not locked can still change their protection status, and program or erase accordingly;
- the lock status is cleared for all blocks at power up; once a block has been locked state can be cleared only with a reset command. The protection and lock status can be monitored for each block using the Autoselect (AS) instruction. Protected blocks will output a '1' on DQ0 and locked blocks will output a '1' on DQ1.

Refer to Table 13 for a list of the protection states. Block Erase (BE) Instruction. This instruction uses a minimum of six write cycles. The Erase Set-up command 80h is written to address 555h on third cycle after the two Coded cycles. The Block Erase Confirm command 30h is similarly written on the sixth cycle after another two Coded cycles and an address within the block to be erased is given and latched into the memory.

Additional block Erase Confirm commands and block addresses can be written subsequently to erase other blocks in parallel, without further Coded cycles. All blocks must belong to the same bank of memory; if a new block belonging to the other bank is given, the operation is aborted. The erase will start after an erase timeout period of 100µs. Thus, additional Erase Confirm commands for other blocks must be given within this delay. The input of a new Erase Confirm command will restart the timeout period. The status of the internal timer can be monitored through the level of DQ3, if DQ3 is '0' the Block Erase Command has been given and the timeout is running, if DQ3 is '1', the timeout has expired and the P/E.C. is erasing the Block(s). If the second command given is not an erase confirm or if the Coded cycles are wrong, the instruction aborts, and the device is reset to Read Array. It is not necessary to program the block with 00h as the P/E.C. will do this automatically before erasing to FFh. Read operations within the same bank, after the sixth rising edge of  $\overline{W}$ or  $\overline{E}$ , output the status register bits.

During the execution of the erase by the P/E.C., the memory accepts only the Erase Suspend ES instruction; the Read/Reset RD instruction is accepted during the 100µs time-out period. Data Polling bit DQ7 returns '0' while the erasure is in progress and '1' when it has completed. The Toggle bit DQ6 toggles during the erase operation, and stops when erase is completed.

After completion the Status Register bit DQ5 returns '1' if there has been an erase failure. In such a situation, the Toggle bit DQ2 can be used to determine which block is not correctly erased. In the case of erase failure, a Read/Reset RD instruction is necessary in order to reset the P/E.C.

Bank Erase (BKE) Instruction. This instruction uses six write cycles and is used to erase all the blocks belonging to the selected bank. The Erase Set-up command 80h is written to address 555h on the third cycle after the two Coded cycles. The Bank Erase Confirm command 10h is similarly written on the sixth cycle after another two Coded cycles at an address within the selected bank. If the second command given is not an erase confirm or if the Coded cycles are wrong, the instruction aborts and the device is reset to Read Array. It is not necessary to program the array with 00h first as the P/E.C. will automatically do this before erasing it to FFh. Read operations within the same bank after the sixth rising edge of  $\overline{W}$  or  $\overline{E}$  output the Status Register bits. During the execution of the erase by the P/E.C., Data Polling bit DQ7 returns '0', then '1' on completion. The Toggle bit DQ6 toggles during erase operation and stops when erase is completed. After completion the Status Register bit DQ5 returns '1' if there has been an Erase Failure.

**Erase Suspend (ES) Instruction.** In a dual bank memory the Erase Suspend instruction is used to read data within the bank where erase is in

progress. It is also possible to program data in blocks not being erased.

The Erase Suspend instruction consists of writing the command B0h without any specific address. No Coded Cycles are required. Erase suspend is accepted only during the Block Erase instruction execution. The Toggle bit DQ6 stops toggling when the P/E.C. is suspended within 15µs after the Erase Suspend (ES) command has been written. The device will then automatically be set to Read Memory Array mode. When erase is suspended, a Read from blocks being erased will output DQ2 toggling and DQ6 at '1'. A Read from a block not being erased returns valid data. During suspension the memory will respond only to the Erase Resume ER and the Program PG instructions. A Program operation can be initiated during erase suspend in one of the blocks not being erased. It will result in DQ6 toggling when the data is being programmed.

**Erase Resume (ER) Instruction.** If an Erase Suspend instruction was previously executed, the erase operation may be resumed by giving the command 30h, at an address within the bank being erased and without any Coded Cycle.

Table 14. Instructions (1,2)

| Mne.              | Instr.                          | Cyc. |                      | 1st Cyc. | 2nd Cyc.                                               | 3rd Cyc.             | 4th Cyc.                             | 5th Cyc.                      | 6th Cyc.    |  |
|-------------------|---------------------------------|------|----------------------|----------|--------------------------------------------------------|----------------------|--------------------------------------|-------------------------------|-------------|--|
|                   |                                 | 4.   | Addr. <sup>(3)</sup> | Х        | Dood Mars                                              | 0 m / A mmo / / / m  |                                      | ita avala ia i                | aitioto d   |  |
| RD <sup>(4)</sup> | Read/Reset                      | 1+   | Data                 | F0h      | Read Memory Array until a new write cycle is initiated |                      |                                      |                               |             |  |
| RD (1)            | Memory Array                    | 0.   | Addr.                | 555h     | 2AAh                                                   | 555h                 | Read Mem                             | Read Memory Array until a ne  |             |  |
|                   |                                 | 3+   | Data                 | AAh      | 55h                                                    | F0h                  | write cycle is initiated.            |                               |             |  |
| RCFI              | CFI Query                       | 1+   | Addr.                | 55h      | Pood CELo                                              | lata until a r       | ow write ov                          | ala is initiata               | .d          |  |
| KCFI              | CFI Query                       | 17   | Data                 | 98h      | Read CFI C                                             | iala urilir a r      | ntil a new write cycle is initiated. |                               |             |  |
|                   |                                 |      | Addr.                | 555h     | 2AAh                                                   | 555h                 |                                      | ronic Signat                  |             |  |
| AS <sup>(4)</sup> | Auto Select                     | 3+   | Data                 | AAh      | 55h                                                    | 90h                  |                                      | ection or Cor<br>atus until a |             |  |
| CR                | Configuration<br>Register Write | 4    | Addr.                | 555h     | 2AAh                                                   | 555h                 | Configura-<br>tion Data              |                               |             |  |
|                   | Register Write                  |      | Data                 | AAh      | 55h                                                    | 60h                  | 03h                                  |                               |             |  |
| PG                | Program                         | 4    | Addr.                | 555h     | 2AAh                                                   | 555h                 | Program<br>Address                   | Read Data                     |             |  |
| rG                | PG Program                      |      | Data                 | AAh      | 55h                                                    | A0h                  | Program Program complete             |                               |             |  |
| DPG               | Double Word                     | 5    | Addr.                | 555h     | 2AAh                                                   | 555h                 | Program<br>Address 1                 | Program<br>Address 2          | Note 6, 7   |  |
| DFG               | Program                         |      | Data                 | AAh      | 55h                                                    | 40h                  | Program<br>Data 1                    | Program<br>Data 2             | Note o, 7   |  |
| EBY               | Enter Bypass                    | 3    | Addr.                | 555h     | 2AAh                                                   | 555h                 |                                      |                               |             |  |
| CDI               | Mode                            | 3    | Data                 | AAh      | 55h                                                    | 20h                  |                                      |                               |             |  |
| XBY               | Exit Bypass                     | 2    | Addr.                | Х        | Х                                                      |                      |                                      |                               |             |  |
| XDT               | Mode                            |      | Data                 | 90h      | 00h                                                    |                      |                                      |                               |             |  |
| PGBY              | Program in                      | 2    | Addr.                | Х        | Program<br>Address                                     |                      | Polling or To                        | oggle Bit un                  | til Program |  |
| 1 051             | Bypass Mode                     |      | Data                 | A0h      | Program<br>Data                                        | completes.           |                                      |                               |             |  |
| DPGBY             | Double Word<br>Program in       | 3    | Addr.                | Х        | Program<br>Address 1                                   | Program<br>Address 2 | ess 2<br>Tram Note 6, 7              |                               |             |  |
| יים פיי           | Bypass Mode                     | 3    | Data                 | 40h      | Program<br>Data 1                                      | Program<br>Data 2    |                                      |                               |             |  |
| BP                | Block Protect                   | 4    | Addr.                | 555h     | 2AAh                                                   | 555h                 | Block<br>Address                     |                               |             |  |
|                   |                                 |      | Data                 | AAh      | 55h                                                    | 60h                  | 01h                                  |                               |             |  |
| BU                | Block Unprotect                 | 1    | Addr.                | 555h     | 2AAh                                                   | 555h                 | Block<br>Address                     |                               |             |  |
|                   |                                 |      | Data                 | AAh      | 55h                                                    | 60h                  | D0h                                  |                               |             |  |
|                   | •                               |      |                      | •        | •                                                      | •                    |                                      |                               |             |  |

## M59DR016C, M59DR016D

| Mne.            | Instr.         | Cyc. |                      | 1st Cyc.        | 2nd Cyc.                                                  | 3rd Cyc.                        | 4th Cyc.         | 5th Cyc.     | 6th Cyc.         |  |
|-----------------|----------------|------|----------------------|-----------------|-----------------------------------------------------------|---------------------------------|------------------|--------------|------------------|--|
| BL              | BL Block Lock  |      | Addr.                | 555h            | 2AAh                                                      | 555h                            | Block<br>Address |              |                  |  |
|                 |                |      | Data                 | AAh             | 55h                                                       | 60h                             | 2Fh              |              |                  |  |
| BE              | Block Erase 6  |      | Addr.                | 555h            | 2AAh                                                      | 555h                            | 555h             | 2AAh         | Block<br>Address |  |
|                 |                |      | Data                 | AAh             | 55h                                                       | 80h                             | AAh              | 55h          | 30h              |  |
| BKE             | BKE Bank Erase | 6    | Addr.                | 555h            | 2AAh                                                      | 555h                            | 555h             | 2AAh         | Bank<br>Address  |  |
|                 |                |      | Data                 | AAh             | 55h                                                       | 80h                             | AAh              | 55h          | 10h              |  |
| ES              | Erase Suspend  | 1    | Addr. <sup>(3)</sup> | Х               | Read until <sup>-</sup>                                   | Toggle stops                    | s, then read     | all the data | needed           |  |
| LO              | Liase Suspend  | '    | Data                 | B0h             | from any Blocks not being erased then Resume Erase.       |                                 |                  |              |                  |  |
| ER Erase Resume |                | 1    | Addr.                | Bank<br>Address | Read Data Polling or Toggle Bits until Erase completes of |                                 |                  | mpletes or   |                  |  |
|                 |                |      | Data                 | 30h             | L1036 15 50                                               | Erase is suspended another time |                  |              |                  |  |

Note: 1. Commands not interpreted in this table will default to read array mode.
2. For Coded cycles address inputs A11-A19 are don't care.

- 3. X = Don't Care.
- 4. The first cycles of the RD or AS instructions are followed by read operations. Any number of read cycles can occur after the command cycles.

- During Erase Suspend, Read and Data Program functions are allowed in blocks not being erased.
   Program Address 1 and Program Address 2 must be consecutive addresses differing only for address bit A0.
   High voltage on V<sub>PP</sub> (11.4V to 12.6V) is required for the proper execution of the Double Word Program instruction.

Table 15. Status Register Bits (1)

| DQ | Name            | Logic Level       | Definition                                                                                                          | Note                                                                                                           |  |
|----|-----------------|-------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--|
|    |                 | '1'               | Erase Complete or erase block in Erase Suspend.                                                                     |                                                                                                                |  |
| /  | Doto            | '0'               | Erase On-going                                                                                                      | Indicates the P/E.C. status, check                                                                             |  |
|    | Data<br>Polling | DQ                | Program Complete or data of non erase block during Erase Suspend.                                                   | during Program or Erase, and on completion before checking bits DQ5 for Program or Erase Success.              |  |
|    |                 | DQ                | Program On-going (2)                                                                                                |                                                                                                                |  |
|    |                 | '-1-0-1-0-1-0-1-' | Erase or Program On-going                                                                                           | Successive reads output                                                                                        |  |
|    |                 | DQ                | Program Complete                                                                                                    | complementary data on DQ6 while Programming or Erase operations are                                            |  |
| 6  | Toggle Bit      | '-1-1-1-1-1-1-'   | Erase Complete or Erase<br>Suspend on currently addressed<br>block                                                  | on-going. DQ6 remains at constant level when P/E.C. operations are completed or Erase Suspend is acknowledged. |  |
| _  | Error Bit       | '1'               | Program or Erase Error                                                                                              | This bit is set to '1' in the case of                                                                          |  |
| 5  | EIIOI BIL       | '0'               | Program or Erase On-going                                                                                           | Programming or Erase failure.                                                                                  |  |
| 4  | Reserved        |                   |                                                                                                                     |                                                                                                                |  |
| 3  | 3 Erase Time    | '1'               | Erase Timeout Period Expired                                                                                        | P/E.C. Erase operation has started.<br>Only possible command entry is Erase<br>Suspend (ES)                    |  |
|    | Bit             | '0'               | Erase Timeout Period On-going                                                                                       | An additional block to be erased in parallel can be entered to the P/E.C:                                      |  |
| 2  | Toggle Bit      | '-1-0-1-0-1-0-1-' | Erase Suspend read in the Erase Suspended Block. Erase Error due to the currently addressed block (when DQ5 = '1'). | Indicates the erase status and allows                                                                          |  |
|    |                 | 1                 | Program on-going or Erase Complete.                                                                                 | to identify the erased block.                                                                                  |  |
|    |                 | DQ                | Erase Suspend read on non Erase Suspend block.                                                                      |                                                                                                                |  |
| 1  | Reserved        |                   |                                                                                                                     |                                                                                                                |  |
| 0  | Reserved        |                   |                                                                                                                     |                                                                                                                |  |

Note: 1. Logic level '1' is High, '0' is Low. -0-1-0-0-0-1-1-1-0- represent bit value in successive Read operations.

2. In case of double word program DQ7 refers to the last word input.

Table 16. Polling and Toggle Bits

| Mode                                                   | DQ7 | DQ6    | DQ2    |
|--------------------------------------------------------|-----|--------|--------|
| Program                                                | DQ7 | Toggle | 1      |
| Erase                                                  | 0   | Toggle | N/A    |
| Erase Suspend Read<br>(in Erase Suspend<br>block)      | 1   | 1      | Toggle |
| Erase Suspend Read<br>(outside Erase Suspend<br>block) | DQ7 | DQ6    | DQ2    |
| Erase Suspend Program                                  | DQ7 | Toggle | 1      |

#### STATUS REGISTER BITS

P/E.C. status is indicated during execution by Data Polling on DQ7, detection of Toggle on DQ6 and DQ2, or Error on DQ5 bits. Any read attempt within the Bank being modified and during Program or Erase command execution will automatically output these five Status Register bits. The P/E.C. automatically sets bits DQ2, DQ5, DQ6 and DQ7. Other bits (DQ0, DQ1 and DQ4) are reserved for future use and should be masked (see Tables 15 and 16). Read attemps within the bank not being modified will output array data.

Data Polling Bit (DQ7). When Programming operations are in progress, this bit outputs the complement of the bit being programmed on DQ7. In case of a double word program operation, the complement is done on DQ7 of the last word written to the command interface, i.e. the data written in the fifth cycle. During Erase operation, it outputs a '0'. After completion of the operation, DQ7 will output the bit last programmed or a '1' after erasing. Data Polling is valid and only effective during P/E.C. operation, that is after the fourth W pulse for programming or after the sixth W pulse for erase. It must be performed at the address being programmed or at an address within the block being erased. See Figure 12 for the Data Polling flowchart and Figure 10 for the Data Polling waveforms. DQ7 will also flag the Erase Suspend mode by switching from '0' to '1' at the start of the Erase Suspend. In order to monitor DQ7 in the Erase Suspend mode an address within a block being erased must be provided. For a Read Operation in Suspend mode, DQ7 will output '1' if the read is attempted on a block being erased and the data value on other blocks. During Program operation in Erase Suspend Mode, DQ7 will have the same behaviour as in the normal program execution outside of the suspend mode.

Toggle Bit (DQ6). When Programming or Erasing operations are in progress, successive attempts to read DQ6 will output complementary data. DQ6 will toggle following toggling of either G, or E when G is at V<sub>IL</sub>. The operation is completed when two successive reads yield the same output data. The next read will output the bit last programmed or a '1' after erasing. The toggle bit DQ6 is valid only during P/E.C. operations, that is after the fourth W pulse for programming or after the sixth W pulse for Erase. DQ6 will be set to '1' if a Read operation is attempted on an Erase Suspend block. When erase is suspended DQ6 will toggle during programming operations in a block different from the block in Erase Suspend. Either  $\overline{E}$  or  $\overline{G}$ toggling will cause DQ6 to toggle. See Figure 13 for Toggle Bit flowchart and Figure 11 for Toggle Bit waveforms.

Toggle Bit (DQ2). This toggle bit, together with DQ6, can be used to determine the device status during the Erase operations. During Erase Suspend a read from a block being erased will cause DQ2 to toggle. A read from a block not being erased will output data. DQ2 will be set to '1' during program operation and to '0' in Erase operation. After erase completion and if the error bit DQ5 is set to '1', DQ2 will toggle if the faulty block is addressed.

**Error Bit (DQ5).** This bit is set to '1' by the P/E.C. when there is a failure of programming or block erase, that results in invalid data in the memory block. In case of an error in block erase or program, the block in which the error occurred or to which the programmed data belongs, must be discarded. Other Blocks may still be used. The error bit resets after a Read/Reset (RD) instruction. In case of success of Program or Erase, the error bit will be set to '0'.

**Erase Timer Bit (DQ3).** This bit is set to '0' by the P/E.C. when the last block Erase command has been entered to the Command Interface and it is awaiting the Erase start. When the erase timeout period is finished, DQ3 returns to '1', in the range of 80μs to 120μs.

Table 17. Program, Erase Times and Program, Erase Endurance Cycles

 $(T_A = 0 \text{ to } 70^{\circ}\text{C}; V_{DD} = V_{DDQ} = 1.65\text{V to } 2.2\text{V}, V_{PP} = V_{DD} \text{ unless otherwise specified})$ 

| Parameter                                                | Min     | Max <sup>(1)</sup> | Тур  | Typical after<br>100k W/E Cycles | Unit   |
|----------------------------------------------------------|---------|--------------------|------|----------------------------------|--------|
| Parameter Block (4 KWord) Erase (Preprogrammed)          |         | 2.5                | 0.15 | 0.4                              | S      |
| Main Block (32 KWord) Erase (Preprogrammed)              |         | 10                 | 1    | 3                                | S      |
| Bank Erase (Preprogrammed, Bank A)                       |         |                    | 2    | 6                                | S      |
| Bank Erase (Preprogrammed, Bank B)                       |         |                    | 10   | 30                               | S      |
| Chip Program <sup>(2)</sup>                              |         |                    | 20   | 25                               | s      |
| Chip Program (DPG, V <sub>PP</sub> = 12V) <sup>(2)</sup> |         |                    | 10   |                                  | s      |
| Word Program <sup>(3)</sup>                              |         | 200                | 10   | 10                               | μs     |
| Double Word Program                                      |         | 200                | 10   | 10                               | μs     |
| Program/Erase Cycles (per Block)                         | 100,000 |                    |      |                                  | cycles |

Note: 1. Max values refer to the maximum time allowed by the internal algorithm before error bit is set. Worst case conditions program or erase should perform significantly better.

- 2. Excludes the time needed to execute the sequence for program instruction.
- 3. Same timing value if  $V_{PP} = 12V$ .

#### **POWER CONSUMPTION**

#### **Power Down**

The memory provides Reset/Power Down control input  $\overline{RP}$ . The Power Down function can be activated only if the relevant Configuration Register bit is set to '1'. In this case, when the  $\overline{RP}$  signal is pulled at VSS the supply current drops to typically ICC2 (see Table 22), the memory is deselected and the outputs are in high impedance.If  $\overline{RP}$  is pulled to VSS during a Program or Erase operation, this operation is aborted in tPLQ7V and the memory content is no longer valid (see Reset/Power Down input description).

#### **Power Up**

The memory Command Interface is reset on Power Up to Read Array. Either  $\overline{E}$  or  $\overline{W}$  must be tied to  $V_{IH}$  during Power Up to allow maximum security and the possibility to write a command on the first rising edge of  $\overline{W}$ .

#### Supply Rails

Normal precautions must be taken for supply voltage decoupling; each device in a system should have the  $V_{DD}$  rails decoupled with a  $0.1\mu F$  capacitor close to the  $V_{DD}$ ,  $V_{DDQ}$  and  $V_{SS}$  pins. The PCB trace widths should be sufficient to carry the required  $V_{DD}$  program and erase currents.

#### **COMMON FLASH INTERFACE (CFI)**

The Common Flash Interface (CFI) specification is a JEDEC approved, standardised data structure that can be read from the Flash memory device. CFI allows a system software to query the flash device to determine various electrical and timing parameters, density information and functions supported by the device. CFI allows the system to easily interface to the Flash memory, to learn about its features and parameters, enabling the software to configure itself when necessary.

Tables 18, 19, 20 and 21 show the address used to retrieve each data.

The CFI data structure gives information on the device, such as the sectorization, the command set and some electrical specifications. Tables 18, 19, 20 and 21 show the addresses used to retrieve each data. The CFI data structure contains also a security area; in this section, a 64 bit unique security number is written, starting at address 81h. This area can be accessed only in read mode and there are no ways of changing the code after it has been written by ST. Write a read instruction to return to Read mode. Refer to the CFI Query instruction to understand how the M59DR016 enters the CFI Query mode.

**Table 18. Query Structure Overview** 

| Offset | Sub-section Name                                  | Description                                                           |
|--------|---------------------------------------------------|-----------------------------------------------------------------------|
| 00h    | Reserved                                          | Reserved for algorithm-specific information                           |
| 10h    | CFI Query Identification String                   | Command set ID and algorithm data offset                              |
| 1Bh    | System Interface Information                      | Device timing & voltage information                                   |
| 27h    | Device Geometry Definition                        | Flash device layout                                                   |
| Р      | Primary Algorithm-specific Extended Query table   | Additional information specific to the Primary Algorithm (optional)   |
| А      | Alternate Algorithm-specific Extended Query table | Additional information specific to the Alternate Algorithm (optional) |

Note: The Flash memory display the CFI data structure when CFI Query command is issued. In this table are listed the main sub-sections detailled in Tables 19, 20 and 21. Query data are always presented on the lowest order data outputs.

Table 19. CFI Query Identification String

| Offset  | Data                          | Description                                                                |  |  |  |
|---------|-------------------------------|----------------------------------------------------------------------------|--|--|--|
| 00h     | 0020h                         | Manufacturer Code                                                          |  |  |  |
| 01h     | 2293h - top<br>2294h - bottom | Device Code                                                                |  |  |  |
| 02h-0Fh | reserved                      | Reserved                                                                   |  |  |  |
| 10h     | 0051h                         | Query Unique ASCII String "QRY"                                            |  |  |  |
| 11h     | 0052h                         | Query Unique ASCII String "QRY"                                            |  |  |  |
| 12h     | 0059h                         | Query Unique ASCII String "QRY"                                            |  |  |  |
| 13h     | 0002h                         | Primary Algorithm Command Set and Control Interface ID code 16 bit ID code |  |  |  |
| 14h     | 0000h                         | defining a specific algorithm                                              |  |  |  |
| 15h     | offset = P = 0040h            | Address for Primary Algorithm extended Query table                         |  |  |  |
| 16h     | 0000h                         | Address for Primary Algorithm extended Query table                         |  |  |  |
| 17h     | 0000h                         | Alternate Vendor Command Set and Control Interface ID Code second vendor   |  |  |  |
| 18h     | 0000h                         | - specified algorithm supported (note: 0000h means none exists)            |  |  |  |
| 19h     | value = A = 0000h             | Address for Alternate Algorithm extended Query table                       |  |  |  |
| 1Ah     | 0000h                         | note: 0000h means none exists                                              |  |  |  |

Note: Query data are always presented on the lowest - order data outputs (DQ7-DQ0) only. DQ8-DQ15 are '0'.

Table 20. CFI Query System Interface Information

| Offset | Data  | Description                                                                                                                                                                                                 |
|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1Bh    | 0017h | V <sub>DD</sub> Logic Supply Minimum Program/Erase or Write voltage bit 7 to 4 BCD value in volts bit 3 to 0 BCD value in 100 millivolts                                                                    |
| 1Ch    | 0022h | V <sub>DD</sub> Logic Supply Maximum Program/Erase or Write voltage bit 7 to 4 BCD value in volts bit 3 to 0 BCD value in 100 millivolts                                                                    |
| 1Dh    | 0000h | V <sub>PP</sub> [Programming] Supply Minimum Program/Erase voltage bit 7 to 4 HEX value in volts bit 3 to 0 BCD value in 100 millivolts Note: This value must be 0000h if no V <sub>PP</sub> pin is present |
| 1Eh    | 00C0h | V <sub>PP</sub> [Programming] Supply Maximum Program/Erase voltage bit 7 to 4 HEX value in volts bit 3 to 0 BCD value in 100 millivolts Note: This value must be 0000h if no V <sub>PP</sub> pin is present |
| 1Fh    | 0004h | Typical timeout per single byte/word program (multi-byte program count = 1), 2 <sup>n</sup> μs (if supported; 0000h = not supported)                                                                        |
| 20h    | 0000h | Typical timeout for maximum-size multi-byte program or page write, 2 <sup>n</sup> µs (if supported; 0000h = not supported)                                                                                  |
| 21h    | 000Ah | Typical timeout per individual block erase, 2 <sup>n</sup> ms (if supported; 0000h = not supported)                                                                                                         |
| 22h    | 0000h | Typical timeout for full chip erase, 2 <sup>n</sup> ms (if supported; 0000h = not supported)                                                                                                                |
| 23h    | 0004h | Maximum timeout for byte/word program, 2 <sup>n</sup> times typical (offset 1Fh) (0000h = not supported)                                                                                                    |
| 24h    | 0000h | Maximum timeout for multi-byte program or page write, 2 <sup>n</sup> times typical (offset 20h) (0000h = not supported)                                                                                     |
| 25h    | 0004h | Maximum timeout per individual block erase, 2 <sup>n</sup> times typical (offset 21h) (0000h = not supported)                                                                                               |
| 26h    | 0000h | Maximum timeout for chip erase, 2 <sup>n</sup> times typical (offset 22h) (0000h = not supported)                                                                                                           |

**Table 21. Device Geometry Definition** 

| Offset Word<br>Mode | Data      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27h                 | 0015h     | Device Size = 2 <sup>n</sup> in number of bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 28h                 | 0001h     | Flock Device Interfere Code description, Asymphysics v46                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 29h                 | 0000h     | Flash Device Interface Code description: Asynchronous x16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2Ah                 | 0000h     | Manifestory was been at his table in mostly his to manage and manage of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2Bh                 | 0000h     | Maximum number of bytes in multi-byte program or page = 2 <sup>n</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2Ch                 | 0002h     | Number of Erase Block Regions within device bit 7 to 0 = x = number of Erase Block Regions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                     |           | Note:1. x = 0 means no erase blocking, i.e. the device erases at once in "bulk."  2. x specifies the number of regions within the device containing one or more contiguous Erase Blocks of the same size. For example, a 128KB device (1Mb) having blocking of 16KB, 8KB, four 2KB, two 16KB, and one 64KB is considered to have 5 Erase Block Regions. Even though two regions both contain 16KB blocks, the fact that they are not contiguous means they are separate Erase Block Regions.  3. By definition, symmetrically block devices have only one blocking region. |
| M59DR016C           | M59DR016C | Erase Block Region Information                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2Dh                 | 001Eh     | bit 31 to 16 = z, where the Erase Block(s) within this Region are (z) times 256 bytes in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2Eh                 | 0000h     | size. The value $z = 0$ is used for 128 byte block size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2Fh                 | 0000h     | e.g. for 64KB block size, z = 0100h = 256 => 256 * 256 = 64K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 30h                 | 0001h     | bit 15 to 0 = y, where y+1 = Number of Erase Blocks of identical size within the Erase                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31h                 | 0007h     | Block Region:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 32h                 | 0000h     | e.g. y = D15-D0 = FFFFh => y+1 = 64K blocks [maximum number]<br>y = 0 means no blocking (# blocks = y+1 = "1 block")                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 33h                 | 0020h     | Note: y = 0 value must be used with number of block regions of one as indicated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 34h                 | 0000h     | by $(x) = 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| M59DR016D           | M59DR016D |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2Dh                 | 0007h     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2Eh                 | 0000h     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2Fh                 | 0020h     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 30h                 | 0000h     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31h                 | 001Eh     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 32h                 | 0000h     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 33h                 | 0000h     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 34h                 | 0001h     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**Table 22. AC Measurement Conditions** 

| Input Rise and Fall Times             | ≤ 4ns                 |
|---------------------------------------|-----------------------|
| Input Pulse Voltages                  | 0 to V <sub>DDQ</sub> |
| Input and Output Timing Ref. Voltages | V <sub>DDQ</sub> /2   |

Figure 3. Testing Input/Output Waveforms



Figure 4. AC Testing Load Circuit



Table 23. Capacitance  $(T_A = 25 \text{ °C}, f = 1 \text{ MHz})$ 

| Symbol           | Parameter          | Test Condition        | Min | Max | Unit |
|------------------|--------------------|-----------------------|-----|-----|------|
| C <sub>IN</sub>  | Input Capacitance  | $V_{IN} = 0V$         |     | 6   | pF   |
| C <sub>OUT</sub> | Output Capacitance | V <sub>OUT</sub> = 0V |     | 12  | pF   |

Note: 1. Sampled only, not 100% tested.

## M59DR016C, M59DR016D

Table 24. DC Characteristics (TA = 0 to 70°C or -40 to 85°C;  $V_{DD} = V_{DDQ} = 1.65V$  to 2.2V)

| Symbol                          | Parameter                                            | Test Condition                                                      | Min                   | Тур | Max                    | Unit |
|---------------------------------|------------------------------------------------------|---------------------------------------------------------------------|-----------------------|-----|------------------------|------|
| ILI                             | Input Leakage Current                                | $0V \le V_{IN} \le V_{DD}$                                          |                       |     | ±1                     | μA   |
| ILO                             | Output Leakage Current                               | $0V \le V_{OUT} \le V_{DD}$                                         |                       |     | ±5                     | μA   |
| I <sub>CC1</sub>                | Supply Current<br>(Read Mode)                        | $\overline{E} = V_{IL}, \overline{G} = V_{IH}, f = 6MHz$            |                       | 10  | 20                     | mA   |
| I <sub>CC2</sub>                | Supply Current<br>(Power Down)                       | $\overline{RP} = V_{SS} \pm 0.2V$                                   |                       | 2   | 10                     | μA   |
| I <sub>CC3</sub>                | Supply Current (Standby)                             | $\overline{E} = V_{DD} \pm 0.2V$                                    |                       | 15  | 50                     | μA   |
| I <sub>CC4</sub> <sup>(1)</sup> | Supply Current<br>(Program or Erase)                 | Word Program, Block Erase in progress                               |                       | 10  | 20                     | mA   |
| I <sub>CC5</sub> <sup>(1)</sup> | Supply Current<br>(Dual Bank)                        | Program/Erase in progress<br>in one Bank, Read in the<br>other Bank |                       | 20  | 40                     | mA   |
| I <sub>PP1</sub>                | V <sub>PP</sub> Supply Current<br>(Program or Erase) | V <sub>PP</sub> = 12V ± 0.6V                                        |                       | 5   | 10                     | mA   |
| lane                            | V <sub>PP</sub> Supply Current                       | V <sub>PP</sub> ≤ V <sub>CC</sub>                                   |                       | 0.2 | 5                      | μA   |
| I <sub>PP2</sub>                | (Standby or Read)                                    | V <sub>PP</sub> = 12V ± 0.6V                                        |                       | 100 | 400                    | μA   |
| VIL                             | Input Low Voltage                                    |                                                                     | -0.5                  |     | 0.4                    | V    |
| V <sub>IH</sub>                 | Input High Voltage                                   |                                                                     | V <sub>DDQ</sub> -0.4 |     | V <sub>DDQ</sub> + 0.4 | V    |
| V <sub>OL</sub>                 | Output Low Voltage                                   | I <sub>OL</sub> = 100μA                                             |                       |     | 0.1                    | V    |
| V <sub>OH</sub>                 | Output High Voltage<br>CMOS                          | I <sub>OH</sub> = -100μA                                            | V <sub>DDQ</sub> -0.1 |     |                        | V    |
| V <sub>PP</sub> (2,3)           | V <sub>PP</sub> Supply Voltage                       |                                                                     | -0.4                  |     | V <sub>DD</sub> + 0.4  | V    |
| VPP (=,=)                       | (Program or Erase)                                   | Double Word Program                                                 | 11.4                  |     | 12.6                   | V    |

Note: 1. Sampled only, not 100% tested.
2. V<sub>PP</sub> may be connected to 12V power supply for a total of less than 100 hrs.
3. For standard program/erase operation V<sub>PP</sub> is don't care.

**Table 25. Read AC Characteristics** 

(TA = 0 to 70°C or -40 to 85°C;  $V_{DD} = V_{DDQ} = 1.65V$  to 2.2V)

|                       |                  |                                                  |                                                |     | M59DR016 |     |     |      |
|-----------------------|------------------|--------------------------------------------------|------------------------------------------------|-----|----------|-----|-----|------|
| Symbol                | Alt              | Parameter                                        | Test Condition                                 | 100 |          | 120 |     | Unit |
|                       |                  |                                                  |                                                | Min | Max      | Min | Max |      |
| t <sub>AVAV</sub>     | t <sub>RC</sub>  | Address Valid to Next<br>Address Valid           | $\overline{E} = V_{IL}, \overline{G} = V_{IL}$ | 100 |          | 120 |     | ns   |
| t <sub>AVQV</sub>     | t <sub>ACC</sub> | Address Valid to Output<br>Valid (Random)        | $\overline{E} = V_{IL}, \overline{G} = V_{IL}$ |     | 100      |     | 120 | ns   |
| t <sub>AVQV1</sub>    | tPAGE            | Address Valid to Output<br>Valid (Page)          | $\overline{E} = V_{IL}, \overline{G} = V_{IL}$ |     | 35       |     | 45  | ns   |
| t <sub>ELQX</sub> (1) | t <sub>LZ</sub>  | Chip Enable Low to Output Transition             | G = V <sub>IL</sub>                            | 0   |          | 0   |     | ns   |
| t <sub>ELQV</sub> (2) | t <sub>CE</sub>  | Chip Enable Low to Output<br>Valid               | G = V <sub>IL</sub>                            |     | 100      |     | 120 | ns   |
| t <sub>GLQX</sub> (1) | t <sub>OLZ</sub> | Output Enable Low to<br>Output Transition        | E = V <sub>IL</sub>                            | 0   |          | 0   |     | ns   |
| t <sub>GLQV</sub> (2) | toE              | Output Enable Low to<br>Output Valid             | E = V <sub>IL</sub>                            |     | 25       |     | 35  | ns   |
| t <sub>EHQX</sub>     | toH              | Chip Enable High to Output Transition            | G = V <sub>IL</sub>                            | 0   |          | 0   |     | ns   |
| t <sub>EHQZ</sub> (1) | t <sub>HZ</sub>  | Chip Enable High to Output<br>Hi-Z               | G = V <sub>IL</sub>                            |     | 25       |     | 35  | ns   |
| t <sub>GHQX</sub>     | toH              | Output Enable High to Output Transition          | E = V <sub>IL</sub>                            | 0   |          | 0   |     | ns   |
| t <sub>GHQZ</sub> (1) | t <sub>DF</sub>  | Output Enable High to<br>Output Hi-Z             | E = V <sub>IL</sub>                            |     | 25       |     | 35  | ns   |
| t <sub>AXQX</sub>     | tон              | Address Transition to<br>Output Transition       | $\overline{E} = V_{IL}, \overline{G} = V_{IL}$ | 0   |          | 0   |     | ns   |
| t <sub>PHQ7V1</sub>   |                  | RP High to Data Valid (Read Mode)                |                                                |     | 150      |     | 150 | ns   |
| t <sub>PHQ7V2</sub>   |                  | RP High to Data Valid (Power Down enabled)       |                                                |     | 50       |     | 50  | μs   |
| t <sub>PLQ7V</sub>    |                  | RP Low to Reset Complete<br>During Program/Erase |                                                |     |          |     | 15  | μs   |
| t <sub>PLPH</sub>     | t <sub>RP</sub>  | RP Pulse Width                                   |                                                | 100 |          | 100 |     | ns   |

Note: 1. Sampled only, not 100% tested.
2.  $\overline{G}$  may be delayed by up to t<sub>ELQV</sub> - t<sub>GLQV</sub> after the falling edge of  $\overline{E}$  without increasing t<sub>ELQV</sub>.

Figure 5. Random Read AC Waveforms



**A7/** 





## M59DR016C, M59DR016D

# Table 26. Write AC Characteristics, Write Enable Controlled ( $T_A = 0$ to 70 °C or -40 to 85 °C; $V_{DD} = V_{DDQ} = 1.65V$ to 2.2V)

|                    |                  |                                               |     | M59D | R016 |     |      |
|--------------------|------------------|-----------------------------------------------|-----|------|------|-----|------|
| Symbol             | Alt              | Parameter                                     | 100 |      | 120  |     | Unit |
|                    |                  |                                               | Min | Max  | Min  | Max |      |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Address Valid to Next Address Valid           | 100 |      | 120  |     | ns   |
| t <sub>ELWL</sub>  | t <sub>CS</sub>  | Chip Enable Low to Write Enable Low           | 0   |      | 0    |     | ns   |
| twLwH              | t <sub>WP</sub>  | Write Enable Low to Write Enable High         | 50  |      | 50   |     | ns   |
| t <sub>DVWH</sub>  | t <sub>DS</sub>  | Input Valid to Write Enable High              | 50  |      | 50   |     | ns   |
| twhox              | t <sub>DH</sub>  | Write Enable High to Input Transition         | 0   |      | 0    |     | ns   |
| twheh              | tcH              | Write Enable High to Chip Enable High         | 0   |      | 0    |     | ns   |
| t <sub>WHWL</sub>  | t <sub>WPH</sub> | Write Enable High to Write Enable Low         | 30  |      | 30   |     | ns   |
| t <sub>AVWL</sub>  | t <sub>AS</sub>  | Address Valid to Write Enable Low             | 0   |      | 0    |     | ns   |
| t <sub>WLAX</sub>  | t <sub>AH</sub>  | Write Enable Low to Address Transition        | 50  |      | 50   |     | ns   |
| tgHWL              |                  | Output Enable High to Write Enable Low        | 0   |      | 0    |     | ns   |
| tvdhel             | t <sub>VCS</sub> | V <sub>DD</sub> High to Chip Enable Low       | 50  |      | 50   |     | μs   |
| twhGL              | toeh             | Write Enable High to Output Enable Low        | 30  |      | 30   |     | ns   |
| t <sub>PLQ7V</sub> |                  | RP Low to Reset Complete During Program/Erase |     | 15   |      | 15  | μs   |

**47/** 24/37

Table 27. Write AC Characteristics, Chip Enable Controlled ( $T_A = 0$  to 70 °C or -40 to 85 °C;  $V_{DD} = V_{DDQ} = 1.65 V$  to 2.2V)

|                    |                  |                                               |     | M59E | R016 |     |      |
|--------------------|------------------|-----------------------------------------------|-----|------|------|-----|------|
| Symbol             | Alt              | Parameter                                     | 100 |      | 120  |     | Unit |
|                    |                  |                                               | Min | Max  | Min  | Max |      |
| t <sub>AVAV</sub>  | t <sub>WC</sub>  | Address Valid to Next Address Valid           | 100 |      | 120  |     | ns   |
| t <sub>WLEL</sub>  | t <sub>WS</sub>  | Write Enable Low to Chip Enable Low           | 0   |      | 0    |     | ns   |
| teleh              | t <sub>CP</sub>  | Chip Enable Low to Chip Enable High           | 50  |      | 50   |     | ns   |
| t <sub>DVEH</sub>  | t <sub>DS</sub>  | Input Valid to Chip Enable High               | 50  |      | 50   |     | ns   |
| t <sub>EHDX</sub>  | t <sub>DH</sub>  | Chip Enable High to Input Transition          | 0   |      | 0    |     | ns   |
| tehwh              | twH              | Chip Enable High to Write Enable High         | 0   |      | 0    |     | ns   |
| t <sub>EHEL</sub>  | t <sub>CPH</sub> | Chip Enable High to Chip Enable Low           | 30  |      | 30   |     | ns   |
| t <sub>AVEL</sub>  | t <sub>AS</sub>  | Address Valid to Chip Enable Low              | 0   |      | 0    |     | ns   |
| t <sub>ELAX</sub>  | t <sub>AH</sub>  | Chip Enable Low to Address Transition         | 50  |      | 50   |     | ns   |
| tGHEL              |                  | Output Enable High Chip Enable Low            | 0   |      | 0    |     | ns   |
| t∨DHWL             | t <sub>VCS</sub> | V <sub>DD</sub> High to Write Enable Low      | 50  |      | 50   |     | μs   |
| tEHGL              | toeh             | Chip Enable High to Output Enable Low         | 30  |      | 30   |     | ns   |
| t <sub>PLQ7V</sub> |                  | RP Low to Reset Complete During Program/Erase |     | 15   |      | 15  | μs   |



Figure 7. Write AC Waveforms,  $\overline{\mathbf{W}}$  Controlled

Note: Address are latched on the falling edge of  $\overline{W}$ , Data is latched on the rising edge of  $\overline{W}$ .



Figure 8. Write AC Waveforms,  $\overline{\mathbf{E}}$  Controlled

Note: Address are latched on the falling edge of  $\overline{E}$ , Data is latched on the rising edge of  $\overline{E}$ .

## M59DR016C, M59DR016D

Table 28. Data Polling and Toggle Bits AC Characteristics  $^{(1)}$  (T<sub>A</sub> = 0 to 70 °C or -40 to 85 °C;  $V_{DD} = V_{DDQ} = 1.65V$  to 2.2V)

| Symbol             | Parameter                                                  | M59E | Unit |       |
|--------------------|------------------------------------------------------------|------|------|-------|
|                    | rarameter                                                  | Min  | Max  | Oilit |
| turio-1            | Write Enable High to DQ7 Valid (Program, W Controlled)     | 10   | 200  | μs    |
| twhq7v             | Write Enable High to DQ7 Valid (Block Erase, W Controlled) | 1    | 10   | S     |
| trucry             | Chip Enable High to DQ7 Valid (Program, E Controlled)      | 10   | 200  | μs    |
| teHQ7V             | Chip Enable High to DQ7 Valid (Block Erase, E Controlled)  | 1    | 10   | S     |
| t <sub>Q7VQV</sub> | Q7 Valid to Output Valid (Data Polling)                    |      | 0    | ns    |
| turnov             | Write Enable High to Output Valid (Program)                |      | 200  | μs    |
| twhqv              | Write Enable High to Output Valid (Block Erase)            | 1    | 10   | S     |
| truov              | Chip Enable High to Output Valid (Program)                 | 10   | 200  | μs    |
| t <sub>EHQV</sub>  | Chip Enable High to Output Valid (Block Erase)             | 1    | 10   | s     |

Note: 1. All other timings are defined in Read AC Characteristics table.



Figure 10. Data Polling DQ7 AC Waveforms AI04111 MEMORY — ARRAY READ CYCLE VALID VALID ADDRESS (WITHIN BLOCKS) tazvav <del>|</del> DATA POLLING (LAST) CYCLE IGNORE DQ7 tGLQV — tELQV tEHQ7V tAVQV tWHQ7V ← LAST WRITE → → DATA POLLING → CYCLE OF READ CYCLES

PROGRAM

OR ERASE
INSTRUCTION DQ0-DQ6/ DQ8-DQ15 A0-A19 DQ7 ۱≥ Ιш lΩ



**A**7/

Figure 12. Data Polling Flowchart



Figure 13. Data Toggle Flowchart



**Table 29. Ordering Information Scheme** 



T = Tape & Reel packing

Devices are shipped from the factory with the memory content bits erased to '1'.

Table 30. Daisy Chain Ordering Scheme



For a list of available options (Speed, Package, etc...) or for further information on any aspect of this device, please contact the STMicroelectronics Sales Office nearest to you.

## M59DR016C, M59DR016D

## **Table 31. Revision History**

| Date       | Version | Revision Details |
|------------|---------|------------------|
| March 2001 | -01     | First Issue      |

Table 32. TFBGA48 - 8 x 6 balls array, 0.75 mm pitch, Package Mechanical Data

| Symbol |        | millimeters |        |        | inches |        |
|--------|--------|-------------|--------|--------|--------|--------|
| Symbol | Тур    | Min         | Max    | Тур    | Min    | Max    |
| А      |        |             | 1.350  |        |        | 0.0531 |
| A1     | 0.300  | 0.200       | 0.350  | 0.0118 | 0.0079 | 0.0138 |
| A2     |        |             | 1.000  |        |        | 0.0394 |
| b      |        | 0.300       | 0.550  |        | 0.0118 | 0.0217 |
| D      | 7.000  | 6.900       | 7.100  | 0.2756 | 0.2717 | 0.2795 |
| D1     | 5.250  | -           | _      | 0.2067 | _      | -      |
| ddd    |        |             | 0.100  |        |        | 0.0039 |
| E      | 12.000 | 11.900      | 12.100 | 0.4724 | 0.4685 | 0.4764 |
| E1     | 3.750  | -           | _      | 0.1476 | -      | -      |
| е      | 0.750  | -           | _      | 0.0295 | -      | -      |
| SD     | 0.375  | -           | _      | 0.0148 | -      | -      |
| SE     | 0.375  | _           | _      | 0.0148 | -      | _      |
| FE     | 4.125  | _           | _      | 0.1624 | -      | -      |
| FD     | 0.875  | _           | _      | 0.0344 | _      | _      |

Figure 14. TFBGA48 - 8 x 6 balls array, 0.75 mm pitch, Package Outline D D1 **←**SD FΕ 0000000 0000000 0000000 SE Е E1 OOQOOQQQ BALL "A1" BGA-Z03

Drawing is not to scale.



Figure 15. TFBGA48 Daisy Chain - Package Connections (Top view through package

Figure 16. TFBGA48 Daisy Chain - PCB Connections proposal (Top view through package) START POINT С D Е END POINT AI03080

Information furnished is believed to be accurate and reliable. However, STMicroelectronics assumes no responsibility for the consequences of use of such information nor for any infringement of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of STMicroelectronics. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied. STMicroelectronics products are not authorized for use as critical components in life support devices or systems without express written approval of STMicroelectronics.

The ST logo is registered trademark of STMicroelectronics All other names are the property of their respective owners.

© 2001 STMicroelectronics - All Rights Reserved

STMicroelectronics GROUP OF COMPANIES

Australia - Brazil - China - Finland - France - Germany - Hong Kong - India - Italy - Japan - Malaysia - Malta - Morocco - Singapore - Spain - Sweden - Switzerland - United Kingdom - U.S.A.

www.st.com

