# intط

# **ADVANCE INFORMATION**

# 1.8 VOLT ADVANCED+ BOOT BLOCK FLASH MEMORY

28F160C18 (x16)

- Flexible SmartVoltage Technology
  - 1.65 V–1.95 V Read/Program/Erase
  - 12 V for Fast Production Programming
- High Performance
  - 1.65 V-1.95 V: 90 ns Max Access Time
- Optimized Architecture for Code Plus Data Storage
  - Eight 4-Kword Blocks,
     Top or Bottom Locations
  - Thirty One 32-Kword Blocks
  - Fast Program Suspend Capability
  - Fast Erase Suspend Capability
- Flexible Block Locking
  - Lock/Unlock Any Block
  - Full Protection on Power-Up
  - WP# Pin for Hardware Block Protection
  - V<sub>PP</sub> = GND Option
  - V<sub>CC</sub> Lockout Voltage
- Low Power Consumption
  - 9 mA Typical Read Power
  - 10 µA Typical Standby Power with Automatic Power Savings Feature
- **■** Extended Temperature Operation
  - -40 °C to +85 °C

- 128-bit Protection Register
  - 64-bit Unique Device Identifier
  - 64-bit User Programmable Cells
- Extended Cycling Capability
  - Minimum 100,000 Block Erase Cycles
- Supports Flash Data Integrator Software
  - Flash Memory Manager
  - System Interrupt Manager
  - Supports Parameter Storage, Streaming Data (e.g., voice)
- Automated Word Program and Block Erase
  - Command User Interface
  - Status Register
- **■** Cross-Compatible Command Support
  - Intel Basic Command Set
  - Common Flash Interface
- x16 I/O
  - 55-Ball, 0.5mm pitch μBGA\*
     Package
  - 48-Lead TSOP Package
- 0.25 µ ETOX™ VI Flash Technology
- Improved 12 V Production Programming
  - Faster Production Programming
  - No Additional System Logic

The 0.25 μm 1.8 Volt Advanced+ Boot Block, manufactured on Intel's latest 0.25 μ technology, represents a feature-rich solution for low power applications. These flash memory devices incorporate low voltage capability (1.65 V read, program and erase) with high-speed, low-power operation. Flexible block locking allows any block to be independently locked or unlocked. A 128-bit protection register enhances customers' ability to develop secure systems. Add to this the Intel-developed Flash Data Integrator (FDI) software and you have a cost-effective, flexible, monolithic code plus data storage solution. 1.8 Volt Advanced+ Boot Block products will be available in 48-lead TSOP and 55-ball μBGA\* packages.

March 1999 Order Number: 290646-002

Information in this document is provided in connection with Intel products. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted by this document. Except as provided in Intel's Terms and Conditions of Sale for such products, Intel assumes no liability whatsoever, and Intel disclaims any express or implied warranty, relating to sale and/or use of Intel products including liability or warranties relating to fitness for a particular purpose, merchantability, or infringement of any patent, copyright or other intellectual property right. Intel products are not intended for use in medical, life saving, or life sustaining applications.

Intel may make changes to specifications and product descriptions at any time, without notice.

The 28F160C18 may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request.

Contact your local Intel sales office or your distributor to obtain the latest specifications and before placing your product order.

Copies of documents which have an ordering number and are referenced in this document, or other Intel literature, may be obtained from:

Intel Corporation
P.O. Box 5937
Denver, CO 80217-9808
or call 1-800-548-4725
or visit Intel's website at http://www.intel.com

COPYRIGHT © INTEL CORPORATION 1999

CG-041493

\*Third-party brands and names are the property of their respective owners.



# **CONTENTS**

| 1.1 1.8 Volt Advanced+ Boot Block Flash Memory Enhancements                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | PAGE                                    | PAGE                                     | Ξ          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------------------------------------|------------|
| 1.1.1.8 Volt Advanced+ Boot Block Flash Memory Enhancements                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1. 0 INTRODUCTION5                      |                                          | 20         |
| Memory Enhancements.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1.1 1.8 Volt Advanced+ Boot Block Flash |                                          |            |
| 3.4.1 Reading the Protection Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •                                       | 5                                        |            |
| 2.0 PRODUCT DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1.2 Product Overview6                   |                                          |            |
| 2.1 Package Pinouts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2. 0 PRODUCT DESCRIPTION6               | •                                        |            |
| 2.2 Block Organization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                         |                                          |            |
| 2.2.1 Parameter Blocks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                         |                                          |            |
| 3.0 PRINCIPLES OF OPERATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                         | 3.5.1 Improved 12 Volt Production        |            |
| 3.0 PRINCIPLES OF OPERATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 2.2.2 Main Blocks9                      |                                          |            |
| 3.1 Bus Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 3 O PRINCIPIES OF OPERATION 0           |                                          |            |
| 3.1.1 Read       10         3.1.2 Output Disable       10         3.1.3 Standby       10         3.1.4 Reset       10         3.1.5 Write       11         3.2 Modes of Operation       11         3.2.1 Read Array       11         3.2.2 Read Configuration       12         3.2.3 Read Status Register       12         3.2.4 Read Query       12         3.2.5 Program Mode       12         3.2.6 Erase Mode       13         3.2.6 Erase Mode       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         3.4.1 Reset       10         3.7.1 RST# Connected To System Reset       24         3.7.2 Vcc, Vpp and RST# Transitions       24         3.8 Power Supply Decoupling       24         4.0 ELECTRICAL SPECIFICATIONS       25         4.1 Absolute Maximum Ratings       26         4.2 Operating Conditions       26         4.3 Capacitance       26         4.5 AC Characteristics—Read Operations—Extended Temperature       36         4.6 AC Characteristics—Write Operations—Extended Temperature                                                           |                                         | •                                        |            |
| 3.1.2 Output Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                         | · · · · · · · · · · · · · · · · · · ·    |            |
| 3.1.3 Standby                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                         |                                          |            |
| 3.1.4 Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                         |                                          |            |
| 3.1.5 Write       11         3.2 Modes of Operation       11         3.2.1 Read Array       11         3.2.2 Read Configuration       12         3.2.3 Read Status Register       12         3.2.4 Read Query       12         3.2.5 Program Mode       12         3.2.6 Erase Mode       13         3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Program       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         3.4 Modes of Operation       12         3.7.1 RST# Colinected To System Reset       24         3.8 Power Supply Decoupling       24         4.0 ELECTRICAL SPECIFICATIONS       25         4.1 Absolute Maximum Ratings       26         4.2 Operating Conditions       25         4.3 Capacitance       26         4.4 DC Characteristics       Read Operations         Extended Temperature       36         4.6 AC Characteristics       37         4.7 Erase and Program Timings       36         4.8 Reset Operations       36         4.9 Characteristics       37<                                                             | •                                       |                                          |            |
| 3.2 Modes of Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                         | -                                        |            |
| 3.2.1 Read Array       11         3.2.2 Read Configuration       12         3.2.3 Read Status Register       12         3.2.3.1 Clearing the Status Register       12         3.2.4 Read Query       12         3.2.5 Program Mode       12         3.2.5.1 Suspending and Resuming Program       13         3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Erase       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                         |                                          |            |
| 3.2.2 Read Configuration       12         3.2.3 Read Status Register       12         3.2.3.1 Clearing the Status Register       12         3.2.4 Read Query       12         3.2.5 Program Mode       12         3.2.5.1 Suspending and Resuming Program       13         3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Erase       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         4.0 ELECTRICAL SPECIFICATIONS       25         4.1 Absolute Maximum Ratings       25         4.2 Operating Conditions       25         4.3 Capacitance       26         4.4 DC Characteristics—Read Operations—       Extended Temperature         4.6 AC Characteristics—Write Operations—       Extended Temperature       32         4.7 Erase and Program Timings       33         4.8 Reset Operations       36         5.0 ORDERING INFORMATION       36         6.0 ADDITIONAL INFORMATION       37                                                                                                                                                        |                                         | 3.8 Power Supply Decoupling              | 24         |
| 3.2.2 Read Configuration       12         3.2.3 Read Status Register       12         3.2.3.1 Clearing the Status Register       12         3.2.4 Read Query       12         3.2.5 Program Mode       12         3.2.5.1 Suspending and Resuming Program       13         3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Erase       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         4.1 Absolute Maximum Ratings       25         4.2 Operating Conditions       25         4.3 Capacitance       26         4.4 DC Characteristics—Read Operations—       Extended Temperature       30         4.6 AC Characteristics—Write Operations—       Extended Temperature       32         4.7 Erase and Program Timings       33         4.8 Reset Operations       36         4.9 C Characteristics—Write Operations—       Extended Temperature         3.2 Colored State       30         4.8 Reset Operations       36         4.9 C Characteristics—Write Operations—         4.1 Absolute Maximum Ratings       25         4.2 Operating Conditions | -                                       | 4 0 FLECTRICAL SPECIFICATIONS            | <b>)</b> ! |
| 3.2.3.1 Clearing the Status Register       12         3.2.4 Read Query       12         3.2.5 Program Mode       12         3.2.5.1 Suspending and Resuming Program       13         3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Erase       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         4.2 Operating Conditions       25         4.3 Capacitance       26         4.4 DC Characteristics—Read Operations—       Extended Temperature       30         4.5 AC Characteristics—Write Operations—       Extended Temperature       32         4.7 Erase and Program Timings       33         4.8 Reset Operations       36         4.9 ORDERING INFORMATION       36         4.1 DC Characteristics—Read Operations—       25         4.5 AC Characteristics—Write Operations—       26         4.7 Erase and Program Timings       33         4.8 Reset Operations—       36         5.0 ORDERING INFORMATION       36         6.0 ADDITIONAL INFORMATION       37                                                                               |                                         |                                          |            |
| 3.2.4 Read Query       12         3.2.5 Program Mode       12         3.2.5.1 Suspending and Resuming Program       13         3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Erase       13         3.2 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         4.3 Capacitance       26         4.4 DC Characteristics—Read Operations       26         4.5 AC Characteristics—Write Operations       27         4.6 AC Characteristics—Write Operations       32         4.7 Erase and Program Timings       33         4.8 Reset Operations       36         4.9 C Characteristics       4.5 AC Characteristics—Write Operations         4.6 AC Characteristics       32         4.7 Erase and Program Timings       33         4.8 Reset Operations       36         5.0 ORDERING INFORMATION       36         6.0 ADDITIONAL INFORMATION       37                                                                                                                                                                                                                        | G                                       |                                          |            |
| 3.2.5 Program Mode       12         3.2.5 Program Mode       12         3.2.5.1 Suspending and Resuming Program       13         3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Erase       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         4.4 DC Characteristics       Read Operations         4.5 AC Characteristics       Write Operations         5.0 ORDERING INFORMATION       36         5.0 ADDITIONAL INFORMATION       37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | S S                                     |                                          |            |
| 3.2.5 Flogram Mode       12         3.2.5.1 Suspending and Resuming Program       13         3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Erase       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         4.5 AC Characteristics—Read Operations—Extended Temperature       30         4.6 AC Characteristics—Write Operations—Extended Temperature       32         4.7 Erase and Program Timings       33         4.8 Reset Operations       36         5.0 ORDERING INFORMATION       36         6.0 ADDITIONAL INFORMATION       37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                         | •                                        |            |
| Program       13       Extended Temperature       30         3.2.6 Erase Mode       13       4.6 AC Characteristics—Write Operations— Extended Temperature       32         3.2.6.1 Suspending and Resuming Erase       13       4.7 Erase and Program Timings       33         3.3.1 Locking Operation       19       4.8 Reset Operations       35         3.3.2 Locked State       19       5.0 ORDERING INFORMATION       36         3.3.3 Unlocked State       19       6.0 ADDITIONAL INFORMATION       37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                         |                                          | _ (        |
| 3.2.6 Erase Mode       13         3.2.6.1 Suspending and Resuming Erase       13         3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         4.6 AC Characteristics—Write Operations—Extended Temperature       32         4.7 Erase and Program Timings       33         4.8 Reset Operations       36         5.0 ORDERING INFORMATION       36         6.0 ADDITIONAL INFORMATION       37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                         |                                          | 30         |
| 3.2.6.1 Suspending and Resuming Erase13       Extended Temperature                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | S .                                     | 4.6 AC Characteristics—Write Operations— |            |
| 3.3 Flexible Block Locking       19         3.3.1 Locking Operation       19         3.3.2 Locked State       19         3.3.3 Unlocked State       19         5.0 ORDERING INFORMATION       36         6.0 ADDITIONAL INFORMATION       37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                         |                                          |            |
| 3.3.1 Locking Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                                          |            |
| 3.3.2 Locked State                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                         | 4.8 Reset Operations                     | 35         |
| 3.3.3 Unlocked State                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                         | 5.0 ORDERING INFORMATION                 | 36         |
| 6.0 ADDITIONAL INFORMATION 37                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                         |                                          |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3.3.4 Lock-Down State19                 | 6.0 ADDITIONAL INFORMATION               | 37         |
| 3.3.5 Reading a Block's Lock Status20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                         |                                          |            |



| APPENDIX A: WSM Current/Next States         | 38 |
|---------------------------------------------|----|
| APPENDIX B: Program/Erase Flowcharts        | 40 |
| APPENDIX C: CFI Query Structure             | 46 |
| APPENDIX D: Architecture Block Diagram      | 48 |
| APPENDIX E: Word-Wide Memory Map<br>Diagram | 49 |
| APPENDIX F: Device ID Table                 | 51 |
| APPENDIX G: Protection Register             | 52 |

# **REVISION HISTORY**

| Date of<br>Revision | Version | Description                                                            |
|---------------------|---------|------------------------------------------------------------------------|
| 03/01/99            | -001    | Original version                                                       |
| 03/23/99            | -002    | Read access speed improved from 100 ns to 90 ns<br>Other minor changes |



### 1.0 INTRODUCTION

This document contains the specifications for the Intel® 1.8 Volt Advanced+ Boot Block flash memory family, which is optimized for low power, portable systems. This family of products features a low V<sub>CC</sub>/V<sub>PP</sub> operating range 1.65 V-1.95 V for read, program, and erase operations. In addition this family is capable of fast programming at 12 V. Throughout this document, the term "1.65 V" refers to the full voltage range 1.65 V-1.95 V (except where noted otherwise) and "VPP = 12 V" refers to 12 V ±5%. Section 1 and 2 provides an overview of the flash memory family including applications, pinouts, pin descriptions and memory organization. Section 3 describes the operation of these products and Section 4 contains electrical specifications. Finally, Section 5 contains ordering information.

# 1.1 1.8 Volt Advanced+ Boot Block Flash Memory Enhancements

The 1.8 Volt Advanced+ Boot Block flash memory features:

- · Zero-latency, flexible block locking
- 128-bit Protection Register
- Simple system implementation for 12 V production programming with 1.65 V in-field programming
- Ultra-low power operation at 1.65 V
- Minimum 100,000 block erase cycles
- Common Flash Interface for software query of device specs and features

Table 1. 1.8 Volt Advanced+ Boot Block Feature Summary

| Feature                           | 16 Mbit                                                                | Reference                 |
|-----------------------------------|------------------------------------------------------------------------|---------------------------|
| V <sub>CC</sub> Operating Voltage | 1.65 V – 1.95 V                                                        | Table 10                  |
| V <sub>PP</sub> Voltage           | Provides complete write protection with optional 12 V Fast Programming | Table 10                  |
| V <sub>CCQ</sub> I/O Voltage      | 1.65 V – 1.95 V                                                        |                           |
| Bus Width                         | 16-bit                                                                 |                           |
| Speed (ns)                        | 90, 120 ns @ 1.65 V                                                    | Section 4.5               |
| Blocking (top or bottom)          | 8 x 4-KW parameter<br>16-Mb: 31 x 32-KW main                           | Section 2.2<br>Appendix E |
| Operating Temperature             | Extended: -40 °C to +85 °C                                             | Table 10                  |
| Program/Erase Cycling             | 100,000 cycles (minimum)                                               | Table 10                  |
| Packages                          | 48-Lead TSOP<br>55-Ball μBGA* CSP                                      | Figures 1, 2              |
| Block Locking                     | Flexible locking of any block with zero latency                        | Section 3.3               |
| Protection Register               | 64-bit unique device number, 64-bit user programmable                  | Section 3.4               |



#### 1.2 Product Overview

The Intel 1.8V Advanced+ Boot Block Flash memory provides secure low voltage memory solutions. A new block locking feature allows instant locking/unlocking of any block with zero-latency. A 128-bit protection register allows unique flash device identification.

Discrete supply pins provide ultra-low voltage read, program, and erase capability at 1.65 V while also allowing 12 V VPP for faster production programming. Improved 12 V production programming, a new feature designed to reduce external logic, simplifies board designs when combining 12 V production programming with 1.65 V in-field programming.

The 1.8 Volt Advanced+ Boot Block flash memory is available in a x16 package in the following density (see Section 5, *Ordering Information*).

 16-Mbit (16,777,216 bit) flash memories organized as either 1024 Kwords of 16 bits each.

Eight 4-Kword parameter blocks are located at either the top (denoted by -T suffix) or the bottom (-B suffix) of the address map in order to accommodate different microprocessor protocols for kernel code location. The remaining memory is grouped into 32-Kword main blocks.

All blocks can be locked or unlocked instantly to provide complete protection for code or data. (see Section 3.3 for details).

The Command User Interface (CUI) serves as the interface between the microprocessor or microcontroller and the internal operation of the flash memory. The internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for program and erase operations, including verification, thereby unburdening the microprocessor or microcontroller.

The status register indicates the status of the WSM by signifying block erase or word program completion and status.

Program and erase automation allows program and erase operations to be executed using an industry-standard two-write command sequence to the CUI. Program operations are performed in word increments. Erase operations erase all locations within a block simultaneously. Both program and erase operations can be suspended by the system software in order to read from any other block. In addition, data can be programmed to another block during an erase suspend.

The 1.8 Volt Advanced+ Boot Block flash memory offers two low power savings features: automatic power savings (APS) and standby mode. The device automatically enters APS mode following the completion of a read cycle. Standby mode is initiated when the system deselects the device by driving CE# inactive. Combined, these two power saving features significantly reduce power consumption.

The device can be reset by lowering RST# to GND. This provides CPU-memory reset synchronization and additional protection against bus noise that may occur during system reset and power-up/down sequences (see Section 3.7).

Refer to the *DC Characteristics* Section 4.4 for complete current and voltage specifications. Refer to the *AC Characteristics* Sections 4.5 and 4.6, for read and write performance specifications. Program and erase times and shown in Section 4.7.

# 2.0 PRODUCT DESCRIPTION

This section provides device pin descriptions and package pinouts for 1.8 Volt Advanced+ Boot Block flash memory, which is available in 48-lead TSOP (Figure 1) and 55-ball µBGA packages (Figure 2).



# 2.1 Package Pinouts



Figure 1. 48-Lead TSOP Package x16 Configurations



Figure 2. 55-Ball µBGA\* Chip Size Package (Top View, Ball Down)

7



Table 2. 1.8 Volt Advanced+ Boot Block Pin Descriptions

| Symbol                            | Туре         | Name and Function                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A <sub>0</sub> -A <sub>19</sub>   | INPUT        | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a program or erase cycle.  16-Mbit x 16: A[0-19]                                                                                                                                                                                                                             |
| DQ <sub>0</sub> -DQ <sub>7</sub>  | INPUT/OUTPUT | DATA INPUTS/OUTPUTS: Inputs array data on the second CE# and WE# cycle during a Program command. Inputs commands to the Command User Interface when CE# and WE# are active. Data is internally latched. Outputs array, configuration and status register data. The data pins float to tri-state when the chip is de-selected or the outputs are disabled. |
| DQ <sub>8</sub> -DQ <sub>15</sub> | INPUT/OUTPUT | <b>DATA INPUTS/OUTPUTS:</b> Inputs array data on the second CE# and WE# cycle during a Program command. Data is internally latched. Outputs array and configuration data. The data pins float to tri-state when the chip is de-selected.                                                                                                                  |
| CE#                               | INPUT        | CHIP ENABLE: Activates the internal control logic, input buffers, decoders and sense amplifiers. CE# is active low. CE# high de-selects the memory device and reduces power consumption to standby levels.                                                                                                                                                |
| OE#                               | INPUT        | OUTPUT ENABLE: Enables the device's outputs through the data buffers during a read operation. OE# is active low.                                                                                                                                                                                                                                          |
| WE#                               | INPUT        | WRITE ENABLE: Controls writes to the Command Register and memory array. WE# is active low. Addresses and data are latched on the rising edge of the second WE# pulse.                                                                                                                                                                                     |
| RST#                              | INPUT        | RESET: Uses two voltage levels (V <sub>IL</sub> , V <sub>IH</sub> ) to control reset mode.                                                                                                                                                                                                                                                                |
|                                   |              | When RST# is at logic low, the device is in reset which drives the outputs to High-Z and resets the Write State Machine.                                                                                                                                                                                                                                  |
|                                   |              | When RST# is at logic high, the device is in standard operation. When RST# transitions from logic-low to logic-high, the device resets all blocks to locked and defaults to the read array mode.                                                                                                                                                          |
| WP#                               | INPUT        | WRITE PROTECT: Controls the lock-down function of the flexible Locking feature                                                                                                                                                                                                                                                                            |
|                                   |              | When WP# is a logic low, the lock-down mechanism is enabled and blocks marked lock-down cannot be unlocked through software.                                                                                                                                                                                                                              |
|                                   |              | When WP# is logic high, the lock-down mechanism is disabled and blocks previously locked-down are now locked and can be unlocked and locked through software. After WP# goes low, any blocks previously marked lock-down revert to that state.                                                                                                            |
|                                   |              | See Section 3.3 for details on block locking.                                                                                                                                                                                                                                                                                                             |
| V <sub>CC</sub>                   | SUPPLY       | <b>DEVICE POWER SUPPLY:</b> [1.65 V–1.95 V] Supplies power for device operations.                                                                                                                                                                                                                                                                         |
| V <sub>CCQ</sub>                  | INPUT        | I/O POWER SUPPLY: Supplies power for input/output buffers.                                                                                                                                                                                                                                                                                                |
|                                   |              | [1.65 V–1.95 V] This input should be tied directly to V <sub>CC</sub> .                                                                                                                                                                                                                                                                                   |



|                           | Table 2. 1.8 Volt Advanced+ Boot Block Pin Descriptions (Continued) |                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|---------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Symbol                    | Туре                                                                | Name and Function                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| V <sub>PP</sub>           | INPUT/<br>SUPPLY                                                    | <b>PROGRAM/ERASE POWER SUPPLY:</b> [0.9 V–1.95 V or 11.4 V–12.6 V] Operates as a input at logic levels to control complete device protection. Supplies power for accelerated program and erase operations in 12 V $\pm$ 5% range. This pin cannot be left floating.                                                                                                                                   |  |  |  |  |  |
|                           |                                                                     | Lower V <sub>PP</sub> ≤ V <sub>PPLK</sub> , to protect all contents against Program and Erase commands.                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|                           |                                                                     | Set V <sub>PP</sub> = V <sub>CC</sub> for in-system read, program and erase operations. In this configuration, V <sub>PP</sub> can drop as low as 0.9 V to allow for resistor or diode drop from the system supply. Note that if V <sub>PP</sub> is driven by a logic signal, V <sub>IH</sub> = 0.9 V. That is, V <sub>PP</sub> must remain above 0.9 V to perform insystem flash modifications.      |  |  |  |  |  |
|                           |                                                                     | Raise V <sub>PP</sub> to 12 V $\pm$ 5% for faster program and erase in a production environment. Applying 12 V $\pm$ 5% to V <sub>PP</sub> can only be done for a maximum of 1000 cycles on the main blocks and 2500 cycles on the parameter blocks. V <sub>PP</sub> may be connected to 12 V for a total of 80 hours maximum. See Section 3.4 for details on V <sub>PP</sub> voltage configurations. |  |  |  |  |  |
| V <sub>SSQ</sub> /<br>GND | SUPPLY                                                              | I/O GROUND / DEVICE GROUND: For all internal circuitry. All ground inputs must be connected.                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| 1                         | 1                                                                   | ·                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |

NO CONNECT: Pin may be driven or left floating.

Table 2. 1.8 Volt Advanced+ Boot Block Pin Descriptions (Continued)

### 2.2 Block Organization

NC

The 1.8 Volt Advanced+ Boot Block is an asymmetrically-blocked architecture that enables system integration of code and data within a single flash device. Each block can be erased independently of the others up to 100,000 times. For the address locations of each block, see the memory maps in Appendix E.

#### 2.2.1 PARAMETER BLOCKS

The 1.8 Volt Advanced+ Boot Block flash memory architecture includes parameter blocks to facilitate storage of frequently updated small parameters (i.e., data that would normally be stored in an EEPROM). Each device contains eight parameter blocks of 4-Kwords.

#### 2.2.2 MAIN BLOCKS

After the parameter blocks, the remainder of the array is divided into equal size 32-Kword main blocks for data or code storage. The 16-Mbit contains 31 main blocks.

#### 3.0 PRINCIPLES OF OPERATION

The 1.8 Volt Advanced+ Boot Block flash memory architecture utilizes a CUI and automated algorithms to simplify program and erase operations. The CUI allows for 100% CMOS-level control inputs and fixed power supplies during erasure and programming.

The internal WSM completely automates program and erase operations while the CUI signals the start of an operation and the status register reports status. The CUI handles the WE# interface to the data and address latches, as well as system status requests during WSM operation.

#### 3.1 Bus Operation

The 1.8 Volt Advanced+ Boot Block flash memory devices read, program and erase in-system via the local CPU or microcontroller. All bus cycles to or from the flash memory conform to standard microcontroller bus cycles. Four control pins dictate the data flow in and out of the flash component: CE#, OE#, WE# and RST#. These bus operations are summarized in Table 3.



Table 3. Bus Operations

| Mode                                             | Note | RST#            | CE#             | OE#             | WE#             | DQ <sub>0-15</sub> |
|--------------------------------------------------|------|-----------------|-----------------|-----------------|-----------------|--------------------|
| Read (Array, Status,<br>Configuration, or Query) | 2,3  | V <sub>IH</sub> | $V_{IL}$        | V <sub>IL</sub> | V <sub>IH</sub> | D <sub>OUT</sub>   |
| Output Disable                                   | 1    | V <sub>IH</sub> | Х               | V <sub>IH</sub> | Х               | High Z             |
| Standby                                          | 1    | $V_{IH}$        | $V_{IH}$        | Х               | Х               | High Z             |
| Reset                                            | 1,5  | $V_{IL}$        | Х               | Х               | Х               | High Z             |
| Write                                            | 4,5  | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | D <sub>IN</sub>    |

#### NOTES:

- X must be V<sub>IL</sub>, V<sub>IH</sub> for control pins and addresses.
- 2. See *DC Characteristics* for V<sub>PPLK</sub>, V<sub>PP1</sub> and V<sub>PP2</sub> voltages.
- 3. Manufacturer and device codes may also be accessed in read configuration mode (A<sub>1</sub>-A<sub>19</sub> = 0). See Table 4.
- 4. Refer to Table 5 for valid D<sub>IN</sub> during a write operation.
- 5. To program or erase the lockable blocks, hold WP# at VIH.

#### 3.1.1 READ

The flash memory has four read modes available: read array, read configuration, read status and read query. These modes are accessible independent of the  $V_{\rm PP}$  voltage. The appropriate read mode command must be issued to the CUI to enter the corresponding mode. Upon initial device power-up or after exit from reset, the device automatically defaults to read array mode.

CE# and OE# must be driven active to obtain data at the outputs. CE# is the device selection control; when active it enables the flash memory device. OE# is the data output control and it drives the selected memory data onto the I/O bus. For all read modes, WE# and RST# must be at  $V_{IH}$ . Figure 7 illustrates a read cycle.

### 3.1.2 OUTPUT DISABLE

With OE# at a logic-high level ( $V_{\rm IH}$ ), the device outputs are disabled. Output pins are placed in a high-impedance state.

#### 3.1.3 STANDBY

Deselecting the device by bringing CE# to a logichigh level ( $V_{\rm IH}$ ) places the device in standby mode, which substantially reduces device power consumption without any latency for subsequent read accesses. In standby, outputs are placed in a high-impedance state independent of OE#. If deselected during program or erase operation, the device continues to consume active power until the program or erase operation is complete.

#### 3.1.4 RESET

From read mode, RST# at  $V_{IL}$  for time  $t_{PLPH}$  deselects the memory, places output drivers in a high-impedance state, and turns off all internal circuits. After return from reset, a time  $t_{PHQV}$  is required until the initial read access outputs are valid. A delay ( $t_{PHWL}$  or  $t_{PHEL}$ ) is required after return from reset before a write can be initiated. After this wake-up interval, normal operation is restored. The CUI resets to read array mode, the status register is set to 80H, and all blocks are locked. This case is shown in Figure 9A.



If RST# is taken low for time t<sub>PLPH</sub> during a program or erase operation, the operation will be aborted and the memory contents at the aborted location (for a program) or block (for an erase) are no longer valid, since the data may be partially erased or written. The abort process goes through the following sequence: When RST# goes low, the device shuts down the operation in progress, a process which takes time t<sub>PLRH</sub> to complete. After this time t<sub>PLRH</sub>, the part will either reset to read array mode (if RST# has gone high during tPLRH, Figure 9B) or enter reset mode (if RST# is still logic low after t<sub>PLRH</sub>, Figure 9C). In both cases, after returning from an aborted operation, the relevant time  $t_{\text{PHQV}}$  or  $t_{\text{PHWL}}/t_{\text{PHEL}}$  must be waited before a read or write operation is initiated, as discussed in the previous paragraph. However, in this case, these delays are referenced to the end of tPLRH rather than when RST# goes high.

As with any automated device, it is important to assert RST# during system reset. When the system comes out of reset, processor expects to read from the flash memory. Automated flash memories provide status information when read during program or block erase operations. If a CPU reset occurs with no flash memory reset, proper CPU initialization may not occur because the flash memory may be providing status information instead of array data. Intel® Flash memories allow proper CPU initialization following a system reset through the use of the RST# input. In this application, RST# is controlled by the same RESET# signal that resets the system CPU.

### 3.1.5 WRITE

A write takes place when both CE# and WE# are low and OE# is high. Commands are written to the Command User Interface (CUI) using standard microprocessor write timings to control flash operations. The CUI does not occupy an addressable memory location. The address and data buses are latched on the rising edge of the second WE# or CE# pulse, whichever occurs first. Figure 8 illustrates a program and erase operation.

The available commands are shown in Table 6, and Appendix A provides detailed information on moving between the different modes of operation using CUI commands.

There are two commands that modify array data: Program (40H) and Erase (20H). Writing either of these commands to the internal Command User Interface (CUI) initiates a sequence of internally-timed functions that culminate in the completion of the requested task (unless that operation is aborted by either RST# being driven to  $V_{IL}$  for  $t_{PLRH}$  or an appropriate suspend command).

### 3.2 Modes of Operation

The flash memory has four read modes and two write modes. The read modes are read array, read configuration, read status, and read query. The write modes are program and block erase. Three additional modes (erase suspend to program, erase suspend to read and program suspend to read) are available only during suspended operations. These modes are reached using the commands summarized in Tables 5 and 6. A comprehensive chart showing the state transitions is in Appendix A.

#### 3.2.1 READ ARRAY

When RST# transitions from  $V_{IL}$  (reset) to  $V_{IH}$ , the device defaults to read array mode and will respond to the read control inputs (CE#, address inputs, and OE#) without any additional CUI commands.

When the device is in read array mode, four control signals control data output:

- WE# must be logic high (V<sub>IH</sub>)
- CE# must be logic low (V<sub>IL</sub>)
- OE# must be logic low (V<sub>IL</sub>)
- RST# must be logic high (V<sub>IH</sub>)

In addition, the address of the desired location must be applied to the address pins. If the device is not in read array mode, as would be the case after a program or erase operation, the Read Array command (FFH) must be written to the CUI before array reads can take place.



#### 3.2.2 READ CONFIGURATION

The read configuration mode outputs three types of information: the manufacturer/device identifier, the block locking status, and the protection register. The device is switched to this mode by writing the Read Configuration command (90H). Once in this mode, read cycles from addresses shown in Table 4 retrieve the specified information. To return to read array mode, write the Read Array command (FFH).

**Table 4. Read Configuration Table** 

| Item                        | Address  | Data                |
|-----------------------------|----------|---------------------|
| Manufacturer Code (x16)     | 00000    | 0089                |
| Device ID (See Appendix F)  | 00001    | ID                  |
| Block Lock Configuration(2) | XX002(1) | LOCK                |
| Block Is Unlocked           |          | $DQ_0 = 0$          |
| Block Is Locked             |          | $DQ_0 = 1$          |
| Block Is Locked-Down        |          | DQ <sub>1</sub> = 1 |
| Protection Register Lock(3) | 80       | PR-LOCK             |
| Protection Register         | 81–88    | PR                  |

#### NOTES:

- "XX" specifies the block address of lock configuration being read.
- 2. See Section 3.3 for valid lock status outputs.
- 3. See Section 3.4 for protection register information.
- Other locations within the configuration address space are reserved by Intel for future use.

### 3.2.3 READ STATUS REGISTER

The status register indicates the status of device operations, and the success/failure of that operation. The Read Status Register (70H) command causes subsequent reads to output data from the status register until another command is issued. To return to reading from the array, issue a Read Array (FFH) command.

The status register bits are output on  $DQ_0$ – $DQ_7$ . The upper byte,  $DQ_8$ – $DQ_{15}$ , outputs 00H during a Read Status Register command.

The contents of the status register are latched on the falling edge of OE# or CE#, whichever occurs last. This prevents possible bus errors which might occur if status register contents change while being read. CE# or OE# must be toggled with each subsequent status read, or the status register will not indicate completion of a program or erase operation.

When the WSM is active, SR.7 will indicate the status of the WSM; the remaining bits in the status register indicate whether the WSM was successful in performing the desired operation (see Table 7).

#### 3.2.3.1 Clearing the Status Register

The WSM sets status bits 1 through 7 to "1," and clears bits 2, 6 and 7 to "0," but cannot clear status bits 1 or 3 through 5 to "0." Because bits 1, 3, 4 and 5 indicate various error conditions, these bits can only be cleared through the use of the Clear Status Register (50H) command. By allowing the system software to control the resetting of these bits, several operations may be performed (such as cumulatively programming several addresses or erasing multiple blocks in sequence) before reading the status register to determine if an error occurred during that series. Clear the Status Register before beginning another command or sequence. Note that the Read Array command must be issued before data can be read from the memory array. Resetting the device also clears the status register.

#### 3.2.4 READ QUERY

The Read Query mode outputs Common Flash Interface (CFI) data when the device is read. This can be accessed by writing the Read Query Command (98H). The CFI data structure contains information such as block size, density, command set and electrical specifications. Once in this mode, read cycles from addresses shown in Appendix C retrieve the specified information. To return to read array mode, write the Read Array command (FFH).

### 3.2.5 PROGRAM MODE

Programming is executed using a two-write sequence. The Program Setup command (40H) is written to the CUI followed by a second write which specifies the address and data to be programmed.



The WSM will execute a sequence of internally timed events to program desired bits of the addressed location, then verify the bits are sufficiently programmed. Programming the memory results in specific bits within an address location being changed to a "0." If the user attempts to program "4"s, the memory cell contents do not change and no error occurs.

The status register indicates programming status: while the program sequence executes, status bit 7 is "0." The status register can be polled by toggling either CE# or OE#. While programming, the only valid commands are Read Status Register, Program Suspend, and Program Resume.

When programming is complete, the Program Status bits should be checked. If the programming operation was unsuccessful, bit SR.4 of the status register is set to indicate a program failure. If SR.3 is set then  $V_{PP}$  was not within acceptable limits, and the WSM did not execute the program command. If SR.1 is set, a program operation was attempted on a locked block and the operation was aborted.

The status register should be cleared before attempting the next operation. Any CUI instruction can follow after programming is completed; however, to prevent inadvertent status register reads, be sure to reset the CUI to read array mode.

# 3.2.5.1 Suspending and Resuming Program

The Program Suspend command halts an inprogress program operation so that data can be read from other locations of memory. Once the programming process starts, writing the Program Suspend command to the CUI requests that the WSM suspend the program sequence (at predetermined points in the program algorithm). The device continues to output status register data after the Program Suspend command is written. Polling status register bits SR.7 and SR.2 will determine when the program operation has been suspended (both will be set to "1"). twhRh1/tehRh1 specify the program suspend latency.

A Read Array command can now be written to the CUI to read data from blocks other than that which is suspended. The only other valid commands, while program is suspended, are Read Status Register, Read Configuration, Read Query, and

Program Resume. After the Program Resume command is written to the flash memory, the WSM will continue with the programming process and status register bits SR.2 and SR.7 will automatically be cleared. The device automatically outputs status register data when read (see Figure 11 in Appendix B, *Program Suspend/Resume Flowchart*) after the Program Resume command is written. V<sub>PP</sub> must remain at the same V<sub>PP</sub> level used for program while in program suspend mode. RST# must also remain at V<sub>IH</sub>.

#### 3.2.6 ERASE MODE

To erase a block, write the Erase Set-up and Erase Confirm commands to the CUI, along with an address identifying the block to be erased. This address is latched internally when the Erase Confirm command is issued. Block erasure results in all bits within the block being set to "1." Only one block can be erased at a time. The WSM will execute a sequence of internally timed events to program all bits within the block to "0," erase all bits within the block are sufficiently erased. While the erase executes, status bit 7 is a "0."

When the status register indicates that erasure is complete, check the erase status bit to verify that the erase operation was successful. If the Erase operation was unsuccessful, SR.5 of the status register will be set to a "1," indicating an erase failure. If  $V_{\rm PP}$  was not within acceptable limits after the Erase Confirm command was issued, the WSM will not execute the erase sequence; instead, SR.5 of the status register is set to indicate an erase error, and SR.3 is set to a "1" to identify that  $V_{\rm PP}$  supply voltage was not within acceptable limits.

After an erase operation, clear the status register (50H) before attempting the next operation. Any CUI instruction can follow after erasure is completed; however, to prevent inadvertent status register reads, it is advisable to place the flash in read array mode after the erase is complete.

## 3.2.6.1 Suspending and Resuming Erase

Since an erase operation requires on the order of seconds to complete, an Erase Suspend command is provided to allow erase-sequence interruption in order to read data from or program data to another



block in memory. Once the erase sequence is started, writing the Erase Suspend command to the CUI suspends the erase sequence at a predetermined point in the erase algorithm. The device continues to output status register data after the Erase Suspend command is written. Polling status register bits SR.6 and SR.7 will determine when the erase operation has been suspended (both will be set to "1"). twhrhighter specify the program suspend latency.

A Read Array/Program command can now be written to the CUI to read/program data from/to blocks other than that which is suspended. This nested Program command can subsequently be suspended to read yet another location. The only other valid commands while erase is suspended are Read Status Register, Read Configuration, Read

Query, Program Setup, Program Resume, Erase Resume, and Lock Setup. During erase suspend mode, the chip can be placed in a pseudo-standby mode by taking CE# to  $V_{IH}$ . This reduces active current consumption.

Issuing the Erase Resume command continues the erase sequence (when CE# =  $V_{IL}$ ) and status register bits SR.6 and SR.7 will automatically be cleared. The device automatically outputs status register data when read (see Figure 13 in Appendix B, *Erase Suspend/Resume Flowchart*) after the Erase Resume command is written. RST# must also remain at  $V_{IH}$ .

As with the end of a standard erase operation, the status register must be read and cleared before the next instruction is issued.



Table 5. Command Bus Definitions

|                       |       | First Bus Cycle |      |         | Second Bus Cyc |      | ycle |
|-----------------------|-------|-----------------|------|---------|----------------|------|------|
| Command               | Notes | Oper            | Addr | Data    | Oper           | Addr | Data |
| Read Array            | 4     | Write           | ВА   | FFH     |                |      |      |
| Read Configuration    | 2, 4  | Write           | IA   | 90H     | Read           | IA   | ID   |
| Read Query            | 2, 4  | Write           | QA   | 98H     | Read           | QA   | QD   |
| Read Status Register  | 4     | Write           | BA   | 70H     | Read           | BA   | SRD  |
| Clear Status Register | 4     | Write           | BA   | 50H     |                |      |      |
| Program               | 3,4   | Write           | WA   | 40H/10H | Write          | WA   | WD   |
| Block Erase/Confirm   | 4     | Write           | BA   | 20H     | Write          | BA   | D0H  |
| Program/Erase Suspend | 4     | Write           | BA   | ВОН     |                |      |      |
| Program/Erase Resume  | 4     | Write           | BA   | D0H     |                |      |      |
| Lock Block            | 4     | Write           | BA   | 60H     | Write          | BA   | 01H  |
| Unlock Block          | 4     | Write           | BA   | 60H     | Write          | BA   | D0H  |
| Lock-Down Block       | 4     | Write           | ВА   | 60H     | Write          | BA   | 2FH  |
| Protection Program    | 4     | Write           | PA   | C0H     | Write          | PA   | PD   |

- 1. Bus operations are defined in Table 3.
- Following the Read Configuration or Read Query commands, read operations output device configuration or CFI query information, respectively. See Section 3.2.2 and 3.2.4.
- 3. Either 40H or 10H command is valid, but the Intel standard is 40H.
- 4. When writing commands, the upper data bus [DQ8-DQ15] should be either VIL or VIH, to minimize current draw.
- First cycle command addresses should be the same as the operation's target address. Examples: the first-cycle address for the Read Device Identification Codes command should be the same as the Identification Code address (IA); the first cycle address for the Program command should be the same as the word address (WA) to be programmed; the first cycle address for the Erase/Program Suspend command should be the same as the address within the block to be suspended; etc.
  - IA = Identification code address.

  - PA = Address within the block..
    PA = User programmable 4-word protection address in the device identification plane.
  - QA = Query code address.
  - WA = Word address of memory location to be written.
  - SRD = Data read from the status register.
  - WD = Data to be written at location WA is latched on the rising edge of WE# or CE# (whichever goes high first).
  - ID = Identification code data.
  - PD = User programmable 4-word protection data.
  - QD = Query code data.



**Table 6. Command Codes and Descriptions** 

| Code | Device Mode                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FF   | Read Array                             | Places device in read array mode, such that array data will be output on the data pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 40   | Program<br>Set-Up                      | This is a two-cycle command. The first cycle prepares the CUI for a program operation. The second cycle latches addresses and data information and initiates the WSM to execute the Program algorithm. The flash outputs status register data when CE# or OE# is toggled. A Read Array command is required after programming to read array data. See Section 3.2.5.                                                                                                                                                                                                      |
| 20   | Erase<br>Set-Up                        | Prepares the CUI for the Erase Confirm command. If the next command is not an Erase Confirm command, then the CUI will (a) set both SR.4 and SR.5 of the status register to a "1," (b) place the device into the read status register mode, and (c) wait for another command. See Section 3.2.6.                                                                                                                                                                                                                                                                         |
| D0   | Erase Confirm                          | If the previous command was an Erase Set-Up command, then the CUI will close the address and data latches, and begin erasing the block indicated on the address pins. During program/erase, the device will respond only to the Read Status Register, Program Suspend and Erase Suspend commands and will output status register data when CE# or OE# is toggled.                                                                                                                                                                                                        |
|      | Program/Erase<br>Resume                | If a program or erase operation was previously suspended, this command will resume that operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      | Unlock Block                           | If the previous command was Configuration Set-Up, the CUI will latch the address and unlock the block indicated on the address pins. If the block had been previously set to Lock-Down, this operation will have no effect. (Sect. 3.3)                                                                                                                                                                                                                                                                                                                                  |
| ВО   | Program<br>Suspend<br>Erase<br>Suspend | Issuing this command will begin to suspend the currently executing program/erase operation. The status register will indicate when the operation has been successfully suspended by setting either the program suspend (SR.2) or erase suspend (SR.6) and the WSM Status bit (SR.7) to a "1" (ready). The WSM will continue to idle in the SUSPEND state, regardless of the state of all input control pins except RST#, which will immediately shut down the WSM and the remainder of the chip if RST# is driven to V <sub>IL</sub> . See Sections 3.2.5.1 and 3.2.6.1. |
| 70   | Read Status<br>Register                | This command places the device into read status register mode. Reading the device will output the contents of the status register, regardless of the address presented to the device. The device automatically enters this mode after a program or erase operation has been initiated. See Section 3.2.3.                                                                                                                                                                                                                                                                |
| 50   | Clear Status<br>Register               | The WSM can set the Block Lock Status (SR.1) , V <sub>PP</sub> Status (SR.3), Program Status (SR.4), and Erase Status (SR.5) bits in the status register to "1," but it cannot clear them to "0." Issuing this command clears those bits to "0."                                                                                                                                                                                                                                                                                                                         |
| 90   | Read<br>Configuration                  | Puts the device into the Read Configuration mode, so that reading the device will output the manufacturer/device codes or block lock status. Section 3.2.2.                                                                                                                                                                                                                                                                                                                                                                                                              |
| 60   | Configuration<br>Set-Up                | Prepares the CUI for changes to the device configuration, such as block locking changes. If the next command is not Block Unlock, Block Lock, or Block Lock-Down, then the CUI will set both the Program and Erase Status register bits to indicate a command sequence error. See Section 3.3.                                                                                                                                                                                                                                                                           |



Table 6. Command Codes and Descriptions (Continued)

| Code | Device Mode                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 01   | Lock-Block                     | If the previous command was Configuration Set-Up, the CUI will latch the address and lock the block indicated on the address pins. (Section 3.3)                                                                                                                                                                                                                                                                                    |
| 2F   | Lock-Down                      | If the previous command was a Configuration Set-Up command, the CUI will latch the address and lock-down the block indicated on the address pins. (Section 3.3)                                                                                                                                                                                                                                                                     |
| 98   | Read<br>Query                  | Puts the device into the read query mode, so that reading the device will output Common Flash Interface information. See Section 3.2.4 and Appendix C.                                                                                                                                                                                                                                                                              |
| C0   | Protection<br>Program<br>Setup | This is a two-cycle command. The first cycle prepares the CUI for an program operation to the protection register. The second cycle latches addresses and data information and initiates the WSM to execute the Protection Program algorithm to the protection register. The flash outputs status register data when CE# or OE# is toggled. A Read Array command is required after programming to read array data. See Section 3.4. |
| 10   | Alt. Prog Set-Up               | Operates the same as Program Set-up command. (See 40H/Program Set-Up)                                                                                                                                                                                                                                                                                                                                                               |
| 00   | Invalid/<br>Reserved           | Unassigned commands that should not be used. Intel reserves the right to redefine these codes for future functions.                                                                                                                                                                                                                                                                                                                 |

### NOTE:

See Appendix A for mode transition information.



Table 7. Status Register Bit Definition

| WSMS                                | ESS                                                           | ES                      | PS    | VPPS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | PSS                                                    | BLS             | R                                                                                      |  |
|-------------------------------------|---------------------------------------------------------------|-------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|-----------------|----------------------------------------------------------------------------------------|--|
| 7                                   | 6                                                             | 5                       | 4     | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2                                                      | 1               | 0                                                                                      |  |
|                                     | •                                                             |                         |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | NO                                                     | TES:            |                                                                                        |  |
| SR.7 WRITE<br>1 = Ready<br>0 = Busy | STATE MAC<br>(WSMS                                            |                         | S     | Check Write State Machine bit first to determine Word Program or Block Erase completion, before checking Program or Erase Status bits.                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                        |                 |                                                                                        |  |
| 1 = Erase S                         | SE-SUSPENE<br>Suspended<br>n Progress/Co                      | •                       | SS)   | execution an                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Suspend is is a sets both Wains set to "1" issued.     | SMS and ES      | S bits to "1."                                                                         |  |
| 1 = Error In                        | SE STATUS (<br>Block Erase<br>sful Block Era                  | ,                       |       | max. numbe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | t is set to "1,"<br>r of erase puls<br>rify successful | ses to the bloc | k and is still                                                                         |  |
| 1 = Error in                        | GRAM STATI<br>Programming<br>sful Programn                    | l ,                     |       | When this bit is set to "1," WSM has attempted but failed to program a word.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                        |                 |                                                                                        |  |
|                                     | STATUS (VPF<br>w Detect, Ope                                  |                         |       | The V <sub>PP</sub> status bit does not provide continuous indication of V <sub>PP</sub> level. The WSM interrogates V <sub>PP</sub> level only after the Program or Erase command sequences have been entered, and informs the system if V <sub>PP</sub> has not been switched on. The V <sub>PP</sub> is also checked before the operation is verified by the WSM. The V <sub>PP</sub> status bit is not guaranteed to report accurate feedback between V <sub>PPLK</sub> max and V <sub>PP1</sub> min or between V <sub>PP1</sub> max and V <sub>PP2</sub> min. |                                                        |                 | gates V <sub>PP</sub> mmand rms the . The V <sub>PP</sub> is ified by the ed to report |  |
| 1 = Progra                          | GRAM SUSP<br>m Suspended<br>m in Progress                     |                         | (PSS) | When Program Suspend is issued, WSM halts execution and sets both WSMS and PSS bits to "1." PSS bit remains set to "1" until a Program Resume command is issued.                                                                                                                                                                                                                                                                                                                                                                                                   |                                                        |                 | S bits to "1."                                                                         |  |
| 1 = Prog/E<br>block;                | CK LOCK STA<br>rase attempte<br>Operation aboration to locker | d on a locked<br>orted. |       | If a program or erase operation is attempted to one of the locked blocks, this bit is set by the WSM. The operation specified is aborted and the device is returned to read status mode.                                                                                                                                                                                                                                                                                                                                                                           |                                                        |                 | WSM. The                                                                               |  |
|                                     | ERVED FOR HANCEMENT                                           |                         |       | This bit is reserved for future use and should be masked out when polling the status register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                        |                 |                                                                                        |  |

### NOTE:

1. A Command Sequence Error is indicated when SR.4, SR.5, and SR.7 are set



# 3.3 Flexible Block Locking

The Intel 1.8 Volt Advanced+ Boot Block architecture offers an instant, individual block locking scheme that allows any block to be locked or unlocked with no latency, enabling instant code and data protection.

This locking scheme offers two levels of protection. The first level allows software-only control of block locking (useful for data blocks that change frequently), while the second level requires hardware interaction before locking can be changed (useful for code blocks that change infrequently).

The following sections will discuss the operation of the locking system. The term "state [XYZ]" will be used to specify locking states; e.g., "state [001]," where X = value of WP#, Y = bit DQ1 of the Block Lock status register, and Z = bit DQ0 of the Block Lock status register. Table 9 defines all of these possible locking states.

#### 3.3.1 LOCKING OPERATION

The following concisely summarizes the locking functionality.

- All blocks power-up locked, then can be unlocked or locked with the Unlock and Lock commands
- The Lock-Down command locks a block and prevents it from being unlocked when WP# = 0.
  - When WP# = 1, Lock-Down is overridden and commands can unlock/lock lockeddown blocks.
  - When WP# returns to 0, locked-down blocks return to Lock-Down.
  - Lock-Down is cleared only when the device is reset or powered-down.

The locking status of each block can set to Locked, Unlocked, and Lock-Down, each of which will be described in the following sections. A comprehensive state table for the locking functions is shown in Table 9, and a flowchart for locking operations is shown in Figure 14.

#### 3.3.2 LOCKED STATE

The default status of all blocks upon power-up or reset is locked (states [001] or [101]). Locked blocks are fully protected from alteration. Any program or erase operations attempted on a locked block will return an error on bit SR.1 of the status register. The status of a locked block can be changed to Unlocked or Lock-Down using the appropriate software commands. An Unlocked block can be locked by writing the Lock command sequence, 60H followed by 01H.

#### 3.3.3 UNLOCKED STATE

Unlocked blocks (states [000], [100], [110]) can be programmed or erased. All unlocked blocks return to the Locked state when the device is reset or powered down. The status of an unlocked block can be changed to Locked or Locked-Down using the appropriate software commands. A Locked block can be unlocked by writing the Unlock command sequence, 60H followed by DOH.

#### 3.3.4 LOCK-DOWN STATE

Blocks that are Locked-Down (state [011]) are protected from program and erase operations (just like Locked blocks), but their protection status cannot be changed using software commands alone. A Locked or Unlocked block can be Lockeddown by writing the Lock-Down command sequence, 60H followed by 2FH. Locked-Down blocks revert to the Locked state when the device is reset or powered down.

The Lock-Down function is dependent on the WP# input pin. When WP# = 0, blocks in Lock-Down [011] are protected from program, erase, and lock status changes. When WP# = 1, the Lock-Down function is disabled ([111]) and locked-down blocks can be individually unlocked by software command to the [110] state, where they can be erased and programmed. These blocks can then be relocked [111] and unlocked [110] as desired while WP# remains high. When WP# goes low, blocks that were previously locked-down return to the Lock-Down state [011] regardless of any changes made while WP# was high. Device reset or power-down resets all blocks, including those in Lock-Down, to Locked state.



#### 3.3.5 READING A BLOCK'S LOCK STATUS

The lock status of every block can be read in the configuration read mode of the device. To enter this mode, write 90H to the device. Subsequent reads at Block Address + 00002 will output the lock status of that block. The lock status is represented by the lowest two output pins,  $\mathsf{DQ}_0$  and  $\mathsf{DQ}_1$ .  $\mathsf{DQ}_0$  indicates the Block Lock/Unlock status and is set by the Lock command and cleared by the Unlock command. It is also automatically set when entering Lock-Down.  $\mathsf{DQ}_1$  indicates Lock-Down status and is set by the Lock-Down command. It cannot be cleared by software, only by device reset or power-down.

Table 8. Block Lock Status

| Item                     | Address | Data                |
|--------------------------|---------|---------------------|
| Block Lock Configuration | XX002   | LOCK                |
| Block Is Unlocked        |         | $DQ_0 = 0$          |
| Block Is Locked          |         | DQ <sub>0</sub> = 1 |
| Block Is Locked-Down     |         | DQ <sub>1</sub> = 1 |

# 3.3.6 LOCKING OPERATIONS DURING ERASE SUSPEND

Changes to block lock status can be performed during an erase suspend by using the standard locking command sequences to unlock, lock, or lock-down a block. This is useful in the case when another block needs to be updated while an erase operation is in progress.

To change block locking during an erase operation, first write the erase suspend command (B0H), then check the status register until it indicates that the erase operation has been suspended. Next write the desired lock command sequence to a block and

the lock status will be changed. After completing any desired lock, read, or program operations, resume the erase operation with the Erase Resume command (D0H).

If a block is locked or locked-down during a suspended erase of the same block, the locking status bits will be changed immediately, but when the erase is resumed, the erase operation will complete.

Locking operations cannot be performed during a program suspend. Refer to Appendix A for detailed information on which commands are valid during erase suspend.

# 3.3.7 STATUS REGISTER ERROR CHECKING

Using nested locking or program command sequences during erase suspend can introduce ambiguity into status register results.

Since locking changes are performed using a two cycle command sequence, e.g., 60H followed by 01H to lock a block, following the Configuration Setup command (60H) with an invalid command will produce a lock command error (SR.4 and SR.5 will be set to 1) in the status register. If a lock command error occurs during an erase suspend, SR.4 and SR.5 will be set to 1, and will remain at 1 after the erase is resumed. When erase is complete, any possible error during the erase cannot be detected via the status register because of the previous locking command error.

A similar situation happens if an error occurs during a program operation error nested within an erase suspend.



|     |                 | Curren | t State            | Erase/Prog | Lock Comma    | and Input Resul | t [Next State] |
|-----|-----------------|--------|--------------------|------------|---------------|-----------------|----------------|
| WP# | DQ <sub>1</sub> | $DQ_0$ | Name               | Allowed?   | Lock          | Unlock          | Lock-Down      |
| 0   | 0               | 0      | "Unlocked"         | Yes        | Goes To [001] | No Change       | Goes To [011]  |
| 0   | 0               | 1      | "Locked" (Default) | No         | No Change     | Goes To [000]   | Goes To [011]  |
| 0   | 1               | 1      | "Locked-Down"      | No         | No Change     | No Change       | No Change      |
| 1   | 0               | 0      | "Unlocked"         | Yes        | Goes To [101] | No Change       | Goes To [111]  |
| 1   | 0               | 1      | "Locked"           | No         | No Change     | Goes To [100]   | Goes To [111]  |
| 1   | 1               | 0      | Lock-Down Disabled | Yes        | Goes To [111] | No Change       | Goes To [111]  |
| 1   | 1               | 1      | Lock-Down Disabled | No         | No Change     | Goes To [110]   | No Change      |

**Table 9. Block Locking State Transitions** 

#### NOTES:

- In this table, the notation [XYZ] denotes the locking state of a block, where X = WP#, Y = DQ<sub>1</sub>, and Z = DQ<sub>0</sub>. The current locking state of a block is defined by the state of WP# and the two bits of the block lock status (DQ<sub>0</sub>, DQ<sub>1</sub>). DQ<sub>0</sub> indicates if a block is locked (1) or unlocked (0). DQ<sub>1</sub> indicates if a block has been locked-down (1) or not (0).
- At power-up or device reset, all blocks default to Locked state [001] (if WP# = 0). Holding WP# = 0 is the recommended default
- The "Erase/Program Allowed?" column shows whether erase and program operations are enabled (Yes) or disabled (No) in that block's current locking state.
- 4. The "Lock Command Input Result [Next State]" column shows the result of writing the three locking commands (Lock, Unlock, Lock-Down) in the current locking state. For example, "Goes To [001]" would mean that writing the command to a block in the current locking state would change it to [001].

### 3.4 128-Bit Protection Register

The Advanced+ Boot Block architecture includes a 128-bit protection register than can be used to increase the security of a system design. For example, the number contained in the protection register can be used to "mate" the flash component with other system components such as the CPU or ASIC, preventing device substitution. Additional application information can be found in Intel application note AP-657 Designing with the Advanced+ Boot Block Flash Memory Architecture.

The 128-bits of the protection register are divided into two 64-bit segments. One of the segments is programmed at the Intel factory with a unique 64-bit number, which is unchangeable. The other segment is left blank for customer designs to program as desired. Once the customer segment is programmed, it can be locked to prevent reprogramming.

# 3.4.1 READING THE PROTECTION REGISTER

The protection register is read in the configuration read mode. The device is switched to this mode by writing the Read Configuration command (90H). Once in this mode, read cycles from addresses shown in Appendix G retrieve the specified information. To return to read array mode, write the Read Array command (FFH).

# 3.4.2 PROGRAMMING THE PROTECTION REGISTER

The protection register bits are programmed using the two-cycle Protection Program command. The 64-bit number is programmed 16 bits at a time. First write the Protection Program Setup command, COH. The next write to the device will latch in address and data and program the specified location. The allowable addresses are shown in Appendix G. See Figure 15 for the *Protection Register Programming Flowchart*.



Attempts to address Protection Program commands outside the defined protection register address space should not be attempted. This space is reserved for future use. Attempting to program to a previously locked protection register segment will result in a status register error (program error bit SR.4 and lock error bit SR.1 will be set to 1).

# 3.4.3 LOCKING THE PROTECTION REGISTER

The user-programmable segment of the protection register is lockable by programming Bit 1 of the PR-LOCK location to 0. Bit 0 of this location is programmed to 0 at the Intel factory to protect the unique device number. This bit is set using the Protection Program command to program "FFFD" to the PR-LOCK location. After these bits have been programmed, no further changes can be made to the values stored in the protection register. Protection Program commands to a locked section will result in a status register error (Program Error bit SR.4 and Lock Error bit SR.1 will be set to 1). Protection register lockout state is not reversible.



Figure 3. Protection Register Memory Map

# 3.5 V<sub>PP</sub> Program and Erase Voltages

Intel 1.8 Volt Advanced+ Boot Block products provide in-system programming and erase in the 0.9 V-1.95 V range. For fast production programming, it also includes a low-cost, backward-compatible 12 V programming feature.

# 3.5.1 IMPROVED 12 VOLT PRODUCTION PROGRAMMING

When  $V_{PP}$  is between 0.9 V and 1.95 V, all program and erase current is drawn through the  $V_{CC}$  pin. Note that if  $V_{PP}$  is driven by a logic signal,  $V_{IH}$  min = 0.9 V. That is,  $V_{PP}$  must remain above 0.9 V to perform in-system flash modifications. When  $V_{PP}$  is connected to a 12 V power supply, the device draws program and erase current directly from the  $V_{PP}$  pin. This eliminates the need for an external switching transistor to control the voltage  $V_{PP}$ . Figure 4 shows examples of how the flash power supplies can be configured for various usage models

The 12 V V<sub>PP</sub> mode enhances programming performance during the short period of time typically found in manufacturing processes; however, it is not intended for extended use. 12 V may be applied to V<sub>PP</sub> during program and erase operations for a maximum of 1000 cycles on the main blocks and 2500 cycles on the parameter blocks. V<sub>PP</sub> may be connected to 12 V for a total of 80 hours maximum. Stressing the device beyond these limits may cause permanent damage.

# $\begin{array}{ll} \textbf{3.5.2} & \textbf{V}_{PP} \leq \textbf{V}_{PPLK} \ \textbf{FOR COMPLETE} \\ \textbf{PROTECTION} \end{array}$

In addition to the flexible block locking, the  $V_{PP}$  programming voltage can be held low for absolute hardware write protection of all blocks in the flash device. When  $V_{PP}$  is below  $V_{PPLK}$ , any program or erase operation will result in a error, prompting the corresponding status register bit (SR.3) to be set.





Figure 4. Example Power Supply Configurations

### 3.6 Power Consumption

Intel's flash devices have a tiered approach to power savings that can significantly reduce overall system power consumption. The Automatic Power Savings (APS) feature reduces power consumption when the device is selected but idle. If the CE# is deasserted, the flash enters its standby mode, where current consumption is even lower. The combination of these features can minimize memory power consumption, and therefore, overall system power consumption.

# 3.6.1 ACTIVE POWER (Program/Erase/Read)

With CE# at a logic-low level and RST# at a logic-high level, the device is in the active mode. Refer to the DC Characteristic tables for  $I_{CC}$  current values. Active power is the largest contributor to overall system power consumption. Minimizing the active current could have a profound effect on system power consumption, especially for battery-operated devices.

#### 3.6.2 AUTOMATIC POWER SAVINGS (APS)

Automatic Power Savings provides low-power operation during read mode. After data is read from the memory array and the address lines are quiescent, APS circuitry places the device in a mode where typical current is comparable to I<sub>CCS</sub>. The flash stays in this static state with outputs valid until a new location is read.

#### 3.6.3 STANDBY POWER

With CE# at a logic-high level (VIH) and device in read mode, the flash memory is in standby mode, which disables much of the device's circuitry and substantially reduces power consumption. Outputs are placed in a high-impedance state independent of the status of the OE# signal. If CE# transitions to a logic-high level during erase or program operations, the device will continue to perform the operation and consume corresponding active power until the operation is completed.



System engineers should analyze the breakdown of standby time versus active time and quantify the respective power consumption in each mode for their specific application. This will provide a more accurate measure of application-specific power and energy requirements.

### 3.7 Power-Up/Down Operation

The device is protected against accidental block erasure or programming during power transitions. Power supply sequencing is not required, since the device is indifferent as to which power supply,  $V_{PP}$  or  $V_{CC}$ , powers-up first.

# 3.7.1 RST# CONNECTED TO SYSTEM RESET

The use of RST# during system reset is important with automated program/erase devices since the system expects to read from the flash memory when it comes out of reset. If a CPU reset occurs without a flash memory reset, proper CPU initialization will not occur because the flash memory may be providing status information instead of array data. Intel recommends connecting RST# to the system CPU RESET# signal to allow proper CPU/flash initialization following system reset.

System designers must guard against spurious writes when  $V_{CC}$  voltages are above  $V_{LKO}$ . Since both WE# and CE# must be low for a command write, driving either signal to  $V_{IH}$  will inhibit writes to the device. The CUI architecture provides additional protection since alteration of memory contents can only occur after successful completion of the two-step command sequences. The device is also disabled until RST# is brought to  $V_{IH}$ , regardless of the state of its control inputs. By holding the device in reset (RST# connected to system PowerGood) during power-up/down, invalid bus conditions during power-up can be masked, providing yet another level of memory protection.

#### 3.7.2 V<sub>CC</sub>, V<sub>PP</sub> AND RST# TRANSITIONS

The CUI latches commands as issued by system software and is not altered by  $V_{PP}$  or CE# transitions or WSM actions. Its default state upon power-up, after exit from reset mode or after  $V_{CC}$  transitions above  $V_{LKO}$  (Lockout voltage), is read array mode.

After any program or block erase operation is complete (even after  $V_{PP}$  transitions down to  $V_{PPLK}$ ), the CUI must be reset to read array mode via the Read Array command if access to the flash memory array is desired.

### 3.8 Power Supply Decoupling

Flash memory's power switching characteristics require careful device decoupling. System designers should consider three supply current issues:

- 1. Standby current levels (I<sub>CCS</sub>)
- 2. Read current levels (I<sub>CCR</sub>)
- Transient peaks produced by falling and rising edges of CE#.

Transient current magnitudes depend on the device outputs' capacitive and inductive loading. Two-line control and proper decoupling capacitor selection will suppress these transient voltage peaks. Each flash device should have a 0.1  $\mu F$  ceramic capacitor connected between each  $V_{CC}$  and GND, and between its  $V_{PP}$  and GND. These high-frequency, inherently low-inductance capacitors should be placed as close as possible to the package leads.



### 4.0 ELECTRICAL SPECIFICATIONS

# 4.1 Absolute Maximum Ratings

| Extended Operating Temperature                                                                                   |
|------------------------------------------------------------------------------------------------------------------|
| During Read40 °C to +85 °C                                                                                       |
| During Block Erase and Program40 °C to +85 °C                                                                    |
| Temperature Under Bias40 °C to +85 °C                                                                            |
| Storage Temperature65 °C to +125 °C                                                                              |
| Voltage on Any Pin (except $V_{CC}$ and $V_{PP}$ ) with Respect to GND0.5 V to +3.0 V <sup>1</sup>               |
| V <sub>PP</sub> Voltage (for Block<br>Erase and Program)<br>with Respect to GND0.5 V to +13.5 V <sup>1,2,4</sup> |
| $V_{CC}$ and $V_{CCQ}$ Supply Voltage with Respect to GND0.2 V to +3.7 $V^5$                                     |
| Output Short Circuit Current100 mA <sup>3</sup>                                                                  |

**NOTICE:** This datasheet contains information on products in the sampling and initial phases of development. Do not finalize a design with this information. Revised information will be published when the product is available. Verify with your local Intel Sales office that you have the latest datasheet before finalizing a design.

\* WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may effect device reliability.

#### NOTES:

- Minimum DC voltage is –0.5 V on input/output pins, with allowable undershoot to –2.0 V for periods < 20 ns. Maximum DC voltage on input/output pins is V<sub>CC</sub> + 0.5 V, with allowable overshoot to V<sub>CC</sub> + 1.5 V for periods < 20 ns.</li>
- 2. Maximum DC voltage on  $V_{PP}$  may overshoot to +14.0 V for periods < 20 ns.
- 3. Output shorted for no more than one second. No more than one output shorted at a time.
- 4. V<sub>PP</sub> voltage is normally 0.9 V–1.95 V. Connection to supply of 11.4 V–12.6 V can only be done for 1000 cycles on the main blocks and 2500 cycles on the parameter blocks during program/erase. V<sub>PP</sub> may be connected to 12 V for a total of 80 hours maximum. See Section 3.5 for details.
- 5. Minimum DC voltage is -0.5 V on V<sub>CC</sub> and V<sub>CCQ</sub>, with allowable undershoot to -2.0 V for periods < 20 ns. Maximum DC voltage on V<sub>CC</sub> and V<sub>CCQ</sub> pins is V<sub>CC</sub> + 0.5 V, with allowable overshoot to V<sub>CC</sub> + 1.5 V for periods < 20 ns.

# 4.2 Operating Conditions

**Table 10. Temperature and Voltage Operating Conditions** 

| Symbol            | Parameter                                  | Notes | Min     | Max  | Units  |
|-------------------|--------------------------------------------|-------|---------|------|--------|
| T <sub>A</sub>    | Operating Temperature                      |       | -40     | +85  | °C     |
| V <sub>CC1</sub>  | V <sub>CC</sub> Supply Voltage             | 1     | 1.65    | 1.95 | Volts  |
| V <sub>CCQ1</sub> | I/O Supply Voltage                         | 1     | 1.65    | 1.95 | Volts  |
| V <sub>PP1</sub>  | Supply Voltage, when used as logic control | 1     | 0.9     | 1.95 | Volts  |
| V <sub>PP2</sub>  |                                            | 1, 2  | 11.4    | 12.6 | Volts  |
| Cycling           | Block Erase Cycling                        | 2     | 100,000 |      | Cycles |

#### NOTES:

- 1.  $V_{CC}$  and  $V_{CCQ}$  must share the same supply.
- Applying V<sub>PP</sub> = 11.4 V−12.6 V during a program/erase can only be done for a maximum of 1000 cycles on the main blocks and 2500 cycles on the parameter blocks. V<sub>PP</sub> may be connected to 12 V for a total of 80 hours maximum. See Section 3.5 for details.

25



# 4.3 Capacitance

 $T_A = 25$  °C, f = 1 MHz

| Sym  | Sym Parameter      |   | Тур | Max | Units | Conditions             |
|------|--------------------|---|-----|-----|-------|------------------------|
| CIN  | Input Capacitance  | 1 | 6   | 8   | pF    | $V_{IN} = 0 V$         |
| Соит | Output Capacitance | 1 | 10  | 12  | pF    | V <sub>OUT</sub> = 0 V |

# NOTE:

# 4.4 DC Characteristics

|                    |                                 | Vcc              | 1.65 V  | 1.65 V–1.95 V |      |                                                                                                                                                                                                   |
|--------------------|---------------------------------|------------------|---------|---------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |                                 | V <sub>CCQ</sub> | 1.65 V- | -1.95 V       |      |                                                                                                                                                                                                   |
| Sym                | Parameter                       | Note             | Тур     | Max           | Unit | Test Conditions                                                                                                                                                                                   |
| ILI                | Input Load Current              | 1,7              |         | ± 1           | μA   | $V_{CC} = V_{CC}Max$<br>$V_{CCQ} = V_{CCQ}Max$<br>$V_{IN} = V_{CCQ}$ or GND                                                                                                                       |
| I <sub>LO</sub>    | Output Leakage Current          | 1,7              | 0.2     | ± 1           | μA   | $V_{CC} = V_{CC}Max$<br>$V_{CCQ} = V_{CCQ}Max$<br>$V_{IN} = V_{CCQ}$ or GND                                                                                                                       |
| I <sub>CCS</sub>   | V <sub>CC</sub> Standby Current | 1                | 10      | 15            | μА   | $V_{CC} = V_{CC}Max$ $CE\# = RST\# = V_{CCQ}$ $RST\# = WP\# = V_{CCQ} \text{ or GND}$ $V_{IN} = V_{CCQ} \text{ or GND}$                                                                           |
| I <sub>CCR</sub>   | V <sub>CC</sub> Read Current    | 1,5,7            | 9       | 15            | mA   | $\begin{split} &V_{CC} = V_{CC} Max \\ &V_{CCQ} = V_{CCQ} Max \\ &OE\# = V_{IH}, CE\# = V_{IL} \\ &f = 5 \text{ MHz, } I_{OUT} = 0 \text{ mA} \\ &Inputs = V_{IL} \text{ or } V_{IH} \end{split}$ |
| I <sub>CCW+</sub>  | Program Current                 | 1,4              | 30      | 55            | mA   | V <sub>PP</sub> = V <sub>PP1</sub><br>Program in Progress                                                                                                                                         |
|                    |                                 |                  | 18      | 35            | mA   | V <sub>PP</sub> = V <sub>PP2</sub> (12 V)<br>Program in Progress                                                                                                                                  |
| I <sub>CCE +</sub> | Erase Current                   | 1,4              | 30      | 45            | mA   | V <sub>PP</sub> = V <sub>PP1</sub><br>Erase in Progress                                                                                                                                           |
|                    |                                 |                  | 16      | 35            | mA   | V <sub>PP</sub> = V <sub>PP2</sub> (12 V)<br>Erase in Progress                                                                                                                                    |

<sup>1.</sup> Sampled, not 100% tested.



# 4.4 DC Characteristics, Continued

|                   |                                            | Vcc              | 1.65 V | 1.65 V–1.95 V |      |                                                                             |
|-------------------|--------------------------------------------|------------------|--------|---------------|------|-----------------------------------------------------------------------------|
|                   |                                            | V <sub>CCQ</sub> | 1.65 V | –1.95 V       |      |                                                                             |
| Sym               | Parameter                                  | Note             | Тур    | Max           | Unit | Test Conditions                                                             |
| I <sub>CCES</sub> | V <sub>CC</sub> Erase Suspend<br>Current   | 1,2,4            | 5      | 15            | μA   | CE# = V <sub>IH</sub> , Erase Suspend in Progress                           |
| I <sub>ccws</sub> | V <sub>CC</sub> Program Suspend<br>Current | 1,2,4            | 5      | 15            | μΑ   | CE# = V <sub>IH</sub> , Program<br>Suspend in Progress                      |
| I <sub>PPS</sub>  | V <sub>PP</sub> Standby Current            | 1                | 0.5    | 1             | μΑ   | $V_{PP} \le V_{CC}$                                                         |
| I <sub>PPR</sub>  | V <sub>PP</sub> Read Current               | 1                | 0.5    | 1             | μΑ   | $V_{PP} \le V_{CC}$                                                         |
|                   |                                            | 1,4              | 50     | 200           | μΑ   | $V_{PP} \ge V_{CC}$                                                         |
| I <sub>PPES</sub> | V <sub>PP</sub> Erase Suspend Current      | 1,4              | 0.5    | 1             | μA   | V <sub>PP</sub> = V <sub>PP1</sub><br>Erase Suspend in Progress             |
|                   |                                            |                  | 50     | 200           | μA   | V <sub>PP</sub> = V <sub>PP2</sub> (12 V)<br>Erase Suspend in Progress      |
| I <sub>PPWS</sub> | V <sub>PP</sub> Program Suspend Current    | 1,4              | 0.5    | 1             | μA   | V <sub>PP</sub> = V <sub>PP1</sub><br>Program Suspend in<br>Progress        |
|                   |                                            |                  | 50     | 200           | μA   | V <sub>PP</sub> = V <sub>PP2</sub> (12 V)<br>Program Suspend in<br>Progress |



# 4.4 DC Characteristics, Continued

|                  |                                         | V <sub>CC</sub>  | 1.65 V-                  | 1.65 V-1.95 V            |          |                                                                                                          |
|------------------|-----------------------------------------|------------------|--------------------------|--------------------------|----------|----------------------------------------------------------------------------------------------------------|
|                  |                                         | V <sub>CCQ</sub> | 1.65 V-                  | 1.65 V-1.95 V            |          |                                                                                                          |
| Sym              | Parameter                               | Note             | Min                      | Max                      | Unit     | Test Conditions                                                                                          |
| $V_{IL}$         | Input Low Voltage                       |                  | -0.4                     | 0.4                      | V        |                                                                                                          |
| V <sub>IH</sub>  | Input High Voltage                      |                  | V <sub>CCQ</sub> - 0.4 V | V <sub>CCQ</sub> + 0.3 V | ٧        |                                                                                                          |
| V <sub>OL</sub>  | Output Low Voltage                      | 7                | -0.10                    | 0.10                     | <b>V</b> | $V_{CC} = V_{CC}Min$ $V_{CCQ} = V_{CCQ}Min$ $I_{OL} = 100 \mu A$                                         |
| V <sub>OH</sub>  | Output High Voltage                     | 7                | V <sub>CCQ</sub> - 0.1 V |                          | ٧        | $\begin{aligned} &V_{CC} = V_{CC} Min \\ &V_{CCQ} = V_{CCQ} Min \\ &I_{OH} = -100 \ \mu A \end{aligned}$ |
| $V_{PPLK}$       | V <sub>PP</sub> Lock-Out Voltage        | 3                |                          | 0.4                      | V        | Complete Write Protection                                                                                |
| V <sub>PP1</sub> | V <sub>PP</sub> during Program / Erase  | 3                | 0.9                      | 1.95                     | V        |                                                                                                          |
| V <sub>PP2</sub> | Operations                              | 3,6              | 11.4                     | 12.6                     |          |                                                                                                          |
| $V_{LKO}$        | V <sub>CC</sub> Prog/Erase Lock Voltage |                  | 1.0                      |                          | V        |                                                                                                          |

- 1. All currents are in RMS unless otherwise noted. Typical values at nominal  $V_{CC}$ ,  $T_A$  = +25 °C.
- I<sub>CCES</sub> and I<sub>CCWS</sub> are specified with device de-selected. If device is read while in erase suspend, current draw is sum of I<sub>CCES</sub> and I<sub>CCR</sub>. If the device is read while in program suspend, current draw is the sum of I<sub>CCWS</sub> and I<sub>CCR</sub>.
- 3. Erase and Program are inhibited when  $V_{PP} < V_{PPLK}$  and not guaranteed outside the valid  $V_{PP}$  ranges of  $V_{PP1}$  and  $V_{PP2}$ .
- 4. Sampled, not 100% tested.
- 5. Automatic Power Savings (APS) reduces I<sub>CCR</sub> to approximately standby levels in static operation (CMOS inputs).
- Applying V<sub>PP</sub> = 11.4 V-12.6 V during program/erase can only be done for a maximum of 1000 cycles on the main blocks and 2500 cycles on the parameter blocks. V<sub>PP</sub> may be connected to 12 V for a total of 80 hours maximum. See Section 3.5 for details
- 7. The test conditions V<sub>CC</sub>Max, V<sub>CC</sub>Min, and V<sub>CCQ</sub>Min refer to the maximum or minimum V<sub>CC</sub> or V<sub>CCQ</sub> voltage listed at the top of each column.





Figure 5. Input/Output Reference Waveform



Figure 6. Test Configuration

# **Test Configuration Component Values Table**

| Test Configuration             | C <sub>L</sub> (pF) | <b>R</b> <sub>1</sub> (Ω) | R <sub>2</sub> (Ω) |
|--------------------------------|---------------------|---------------------------|--------------------|
| 1.65 V–1.95 V Standard<br>Test | 50                  | 14.5K                     | 14.5K              |

#### NOTE:

C<sub>L</sub> includes jig capacitance.



# 4.5 AC Characteristics—Read Operations<sup>(1,4)</sup>—Extended Temperature

|     |                   |                                                              |              | Product   |     | 16 Mbit |     |     |      |
|-----|-------------------|--------------------------------------------------------------|--------------|-----------|-----|---------|-----|-----|------|
|     |                   | Access T                                                     |              | Γime (ns) | 9   | 90      |     | 20  |      |
| #   | Symbol            | Paran                                                        | neter        | Note      | Min | Max     | Min | Max | Unit |
| R1  | t <sub>AVAV</sub> | Read Cycle 1                                                 | īme          |           | 90  |         | 120 |     | ns   |
| R2  | t <sub>AVQV</sub> | Address to O                                                 | utput Delay  |           |     | 90      |     | 120 | ns   |
| R3  | t <sub>ELQV</sub> | CE# to Outpu                                                 | ıt Delay     | 2         |     | 90      |     | 120 | ns   |
| R4  | t <sub>GLQV</sub> | OE# to Outpu                                                 | ut Delay     | 2         |     | 45      |     | 45  | ns   |
| R5  | t <sub>PHQV</sub> | RST# to Outp                                                 | out Delay    |           |     | 150     |     | 150 | ns   |
| R6  | t <sub>ELQX</sub> | CE# to Outpu                                                 | ıt in Low Z  | 3         | 0   |         | 0   |     | ns   |
| R7  | t <sub>GLQX</sub> | OE# to Outpu                                                 | ut in Low Z  | 3         | 0   |         | 0   |     | ns   |
| R8  | t <sub>EHQZ</sub> | CE# to Outpu                                                 | ıt in High Z | 3         |     | 25      |     | 25  | ns   |
| R9  | t <sub>GHQZ</sub> | OE# to Outpu                                                 | ut in High Z | 3         |     | 25      |     | 25  | ns   |
| R10 | t <sub>OH</sub>   | Output Hold f<br>Address, CEa<br>Change, Whi<br>Occurs First | #, or OE#    | 3         | 0   |         | 0   |     | ns   |

- 1. See Figure 7: AC Waveform: Read Operations.
- 2. OE# may be delayed up to  $t_{ELQV}$ - $t_{GLQV}$  after the falling edge of CE# without impact on  $t_{ELQV}$ .
- 3. Sampled, but not 100% tested.
- 4. See Figure 5: Input/Output Reference Waveformfor timing measurements and maximum allowable input slew rate.





Figure 7. AC Waveform: Read Operations



4.6 AC Characteristics—Write Operations(1,5,6)—Extended Temperature

|     |                     |                                            | Pr            | oduct  | 16 [ | <b>Vibit</b> |      |
|-----|---------------------|--------------------------------------------|---------------|--------|------|--------------|------|
|     |                     |                                            | Access Tim    | e (ns) | 90   | 120          |      |
| #   | Symbol              | Parameter                                  |               | Note   | Min  | Min          | Unit |
| W1  | t <sub>PHWL</sub> / | RST# High Recovery to WE# (CE              | E#) Going Low |        | 150  | 150          | ns   |
|     | t <sub>PHEL</sub>   |                                            |               |        |      |              |      |
| W2  | t <sub>ELWL</sub> / | CE# (WE#) Setup to WE# (CE#)               | Going Low     |        | 0    | 0            | ns   |
|     | t <sub>WLEL</sub>   |                                            |               |        |      |              |      |
| W3  | t <sub>WLWH</sub> / | WE# (CE#) Pulse Width                      |               | 4      | 70   | 70           | ns   |
|     | t <sub>ELEH</sub>   |                                            |               |        |      |              |      |
| W4  | t <sub>DVWH</sub> / | Data Setup to WE# (CE#) Going              | High          | 2      | 70   | 70           | ns   |
|     | t <sub>DVEH</sub>   |                                            |               |        |      |              |      |
| W5  | t <sub>AVWH</sub> / | Address Setup to WE# (CE#) Go              | ing High      | 2      | 70   | 70           | ns   |
|     | t <sub>AVEH</sub>   |                                            |               |        |      |              |      |
| W6  | t <sub>WHEH</sub> / | CE# (WE#) Hold Time from WE#               | (CE#) High    |        | 0    | 0            | ns   |
|     | t <sub>EHWH</sub>   |                                            |               |        |      |              |      |
| W7  | t <sub>WHDX</sub> / | Data Hold Time from WE# (CE#)              | High          | 2      | 0    | 0            | ns   |
|     | t <sub>EHDX</sub>   |                                            |               |        |      |              |      |
| W8  | t <sub>WHAX</sub> / | Address Hold Time from WE# (C              | E#) High      | 2      | 0    | 0            | ns   |
|     | t <sub>EHAX</sub>   |                                            |               |        |      |              |      |
| W9  | t <sub>WHWL</sub> / | WE# (CE#) Pulse Width High                 |               | 4      | 30   | 30           | Ns   |
|     | t <sub>EHEL</sub>   |                                            |               |        |      |              |      |
| W10 | t <sub>VPWH</sub> / | V <sub>PP</sub> Setup to WE# (CE#) Going H | ligh          | 3      | 200  | 200          | ns   |
|     | t <sub>VPEH</sub>   |                                            |               |        |      |              |      |
| W11 | t <sub>QVVL</sub>   | V <sub>PP</sub> Hold from Valid SRD        |               | 3      | 0    | 0            | ns   |
| W12 | t <sub>BHWH</sub> / | WP# Setup to WE# (CE#) Going               | High          | 3      | 0    | 0            | ns   |
|     | t <sub>BHEH</sub>   |                                            |               |        |      |              |      |
| W13 | t <sub>QVBL</sub>   | WP# Hold from Valid SRD                    |               | 3      | 0    | 0            | ns   |
| W14 | t <sub>WHGL</sub>   | Write Recovery before Read                 |               | 3,7    | 30   |              | ns   |

- 1. Write timing characteristics during erase suspend are the same as during write-only operations.
- 2. Refer to Table 5 for valid  $A_{IN}$  or  $D_{IN}$ .
- 3. Sampled, but not 100% tested.
- 4. Write pulse width (t<sub>WP</sub>) is defined from CE# or WE# going low (whichever goes low last) to CE# or WE# going high (whichever goes high first). Hence, t<sub>WP</sub> = t<sub>WLWH</sub> = t<sub>ELEH</sub> = t<sub>WLEH</sub> = t<sub>ELWH</sub>. Similarly, Write pulse width high (t<sub>WPH</sub>) is defined from CE# or WE# going high (whichever goes high first) to CE# or WE# going low (whichever goes low first). Hence, t<sub>WPH</sub> = t<sub>WHWL</sub> = t<sub>EHEL</sub> = t<sub>WHEL</sub> = t<sub>EHWL</sub>.
- 5. See Figure 5: Input/Output Reference Waveform for timing measurements and maximum allowable input slew rate.
- 6. See Figure 8: AC Waveform: Program and Erase Operations
- 7. Delay is defined from WE#(CE#) high to OE# going low.



# 4.7 Erase and Program Timings<sup>(1)</sup>

|                                         |                                             | V <sub>PP</sub> | 0.9 V-1.95 V |     | 11.4 V- | -12.6 V |      |
|-----------------------------------------|---------------------------------------------|-----------------|--------------|-----|---------|---------|------|
| Symbol                                  | Parameter                                   | Note            | Typ(1)       | Max | Typ(1)  | Max     | Unit |
| t <sub>BWPB</sub>                       | 4-KW Parameter Block<br>Program Time (Word) | 2, 3            | 0.1          | 0.3 | 0.03    | 0.1     | s    |
| t <sub>BWMB</sub>                       | 32-KW Main Block<br>Program Time(Word)      | 2, 3            | 0.8          | 2.4 | 0.24    | 0.80    | s    |
| t <sub>WHQV1</sub> / t <sub>EHQV1</sub> | Word Program Time                           | 2, 3            | 22           | 200 | 8       | 185     | μs   |
| t <sub>WHQV2</sub> / t <sub>EHQV2</sub> | 4-KW Parameter Block<br>Erase Time (Word)   | 2, 3            | 1            | 4   | 0.8     | 4       | S    |
| t <sub>WHQV3</sub> / t <sub>EHQV3</sub> | 32-KW Main Block<br>Erase Time (Word)       | 2, 3            | 1.8          | 5   | 1.1     | 5       | S    |
| t <sub>WHRH1</sub> / t <sub>EHRH1</sub> | Program Suspend Latency                     | 3               | 5            | 10  | 5       | 10      | μs   |
| t <sub>WHRH2</sub> / t <sub>EHRH2</sub> | Erase Suspend Latency                       | 3               | 5            | 20  | 5       | 20      | μs   |

- 1. Typical values measured at  $T_A = +25$  °C and nominal voltages.
- 2. Excludes external system-level overhead.
- 3. Sampled, but not 100% tested.





- D. Automated Program or Erase Delay.
- E. Read Status Register Data (SRD): reflects completed program/erase operation.
- F. Write Read Array Command.

Figure 8. AC Waveform: Program and Erase Operations



# 4.8 Reset Operations



Figure 9. AC Waveform: Reset Operation

Table 11. Reset Specifications(1)

|                    |                                                                                                           |       | V <sub>CC</sub> 1.65 V-1.95 V |     |      |
|--------------------|-----------------------------------------------------------------------------------------------------------|-------|-------------------------------|-----|------|
| Symbol             | Parameter                                                                                                 | Notes | Min                           | Max | Unit |
| t <sub>PLPH</sub>  | RST# Low to Reset during Read (If RST# is tied to V <sub>CC</sub> , this specification is not applicable) | 2,4   | 100                           |     | ns   |
| t <sub>PLRH1</sub> | RST# Low to Reset during Block Erase                                                                      | 3,4   |                               | 22  | μs   |
| t <sub>PLRH2</sub> | RST# Low to Reset during Program                                                                          | 3,4   |                               | 12  | μs   |

- 1. See Section 3.1.4 for a full description of these conditions.
- 2. If  $t_{PLPH}$  is < 100 ns the device may still reset but this is not guaranteed.
- 3. If RST# is asserted while a block erase or word program operation is not executing, the reset will complete within 100 ns.
- 4. Sampled, but not 100% tested.



# 5.0 ORDERING INFORMATION





## 6.0 ADDITIONAL INFORMATION(1,2)

| Order Number                         | Document/Tool                                                               |
|--------------------------------------|-----------------------------------------------------------------------------|
| 210830                               | Flash Memory Databook                                                       |
| 292215                               | AP-657 Designing with the Advanced+ Boot Block Flash Memory<br>Architecture |
| 292204                               | AP-646 Common Flash Interface (CFI) and Command Sets                        |
| Contact your Intel<br>Representative | Flash Data Integrator (FDI) Software Developer's Kit                        |
| 297874                               | FDI Interactive: Play with Intel's Flash Data Integrator on Your PC         |

#### NOTES:

- Please call the Intel Literature Center at (800) 548-4725 to request Intel documentation. International customers should contact their local Intel or distribution sales office.
- 2. Visit Intel's World Wide Web home page at http://www.Intel.com or http://intel.com/design/flash for technical documentation and tools.



# APPENDIX A WSM CURRENT/NEXT STATES

|                            |      |                      |                                | <b>O O</b> · · · ·                   |                         | 1-/\.                     | <u> </u>                     |                            |                         |                          |
|----------------------------|------|----------------------|--------------------------------|--------------------------------------|-------------------------|---------------------------|------------------------------|----------------------------|-------------------------|--------------------------|
|                            |      |                      | Command Input (and Next State) |                                      |                         |                           |                              |                            |                         |                          |
| Current<br>State           | SR.7 | Data<br>When<br>Read | Read<br>Array<br>(FFH)         | Program<br>Setup<br>(10/40H)         | Erase<br>Setup<br>(20H) | Erase<br>Confirm<br>(D0H) | Prog/Ers<br>Suspend<br>(B0H) | Prog/Ers<br>Resume<br>(D0) | Read<br>Status<br>(70H) | Clear<br>Status<br>(50H) |
| Read Array                 | "1"  | Array                | Read Array                     | Program Setup                        | Erase<br>Setup          | Read Array                |                              |                            | Read<br>Status          | Read<br>Array            |
| Read Status                | "1"  | Status               | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |
| Read<br>Config.            | "1"  | Config               | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |
| Read Query                 | "1"  | CFI                  | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |
| Lock Setup                 | "1"  | Status               | Lo                             | ock Command Err                      | or                      | Lock<br>(Done)            | Lock<br>Cmd. Error           | Lock<br>(Done)             | Lock Cn                 | nd. Error                |
| Lock Cmd.<br>Error         | "1"  | Status               | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |
| Lock Oper.<br>(Done)       | "1"  | Status               | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |
| Prot. Prog.<br>Setup       | "1"  | Status               |                                |                                      | Pro                     | otection Regis            | ster Program                 |                            |                         |                          |
| Prot. Prog.<br>(Not Done)  | "0"  | Status               |                                |                                      | Protection              | n Register Pr             | ogram (Not D                 | one)                       |                         |                          |
| Prot. Prog.<br>(Done)      | "1"  | Status               | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |
| Prog. Setup                | "1"  | Status               |                                |                                      |                         | Progra                    | am                           |                            |                         |                          |
| Program<br>(Not Done)      | "0"  | Status               |                                | Program (No                          | ot Done)                |                           | Prog. Sus.<br>Status         | S. Program (Not Done)      |                         |                          |
| Prog. Susp.<br>Status      | "1"  | Status               | Prog. Sus.<br>Read Array       | Program S<br>Read A                  |                         | Program<br>(Not Done)     | Prog. Sus.<br>Rd. Array      | Program<br>(Not Done)      | Prog. Sus.<br>Status    | Prog. Sus.<br>Rd. Array  |
| Prog. Susp.<br>Read Array  | "1"  | Array                | Prog. Sus.<br>Read Array       | Program S<br>Read A                  |                         | Program<br>(Not Done)     | Prog. Sus.<br>Rd. Array      | Program<br>(Not Done)      | Prog. Sus.<br>Status    | Prog. Sus.<br>Rd. Array  |
| Prog. Susp.<br>Read Config | "1"  | Config               | Prog. Sus.<br>Read Array       | Program S<br>Read A                  |                         | Program<br>(Not Done)     | Prog. Sus.<br>Rd. Array      | Program<br>(Not Done)      | Prog. Sus.<br>Status    | Prog. Sus.<br>Rd. Array  |
| Prog. Susp.<br>Read Query  | "1"  | CFI                  | Prog. Sus.<br>Read Array       | Program S<br>Read A                  |                         | Program<br>(Not Done)     | Prog. Sus.<br>Rd. Array      | Program<br>(Not Done)      | Prog. Sus.<br>Status    | Prog. Sus.<br>Rd. Array  |
| Program<br>(Done)          | "1"  | Status               | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |
| Erase Setup                | "1"  | Status               | En                             | ase Command Er                       | ror                     | Erase<br>(Not Done)       | Erase<br>Cmd. Error          | Erase<br>(Not Done)        | Erase Com               | mand Error               |
| Erase Cmd.<br>Error        | "1"  | Status               | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |
| Erase<br>(Not Done)        | "0"  | Status               | Erase (Not Done)               |                                      |                         |                           | Erase Sus.<br>Status         | Е                          | rase (Not Don           | e)                       |
| Ers. Susp.<br>Status       | "1"  | Status               | Erase Sus.<br>Read Array       | Program Setup                        | Ers. Sus.<br>Rd. Array  | Erase                     | Ers. Sus.<br>Rd. Array       | Erase                      | Erase Sus.<br>Status    | Ers. Sus.<br>Rd. Array   |
| Erase Susp.<br>Array       | "1"  | Array                | Erase Sus.<br>Read Array       | Program Setup                        | Ers. Sus.<br>Rd. Array  | Erase                     | Ers. Sus.<br>Rd. Array       | Erase                      | Erase Sus.<br>Status    | Ers. Sus.<br>Rd. Array   |
| Ers. Susp.<br>Read Config  | "1"  | Config               | Erase Sus.<br>Read Array       | Program Setup Ers. Sus.<br>Rd. Array |                         | Erase                     | Ers. Sus.<br>Rd. Array       | Erase                      | Erase Sus.<br>Status    | Ers. Sus.<br>Rd. Array   |
| Ers. Susp.<br>Read Query   | "1"  | CFI                  | Erase Sus.<br>Read Array       | Program Setup                        | Ers. Sus.<br>Rd. Array  | Erase                     | Ers. Sus.<br>Rd. Array       | Erase                      | Erase Sus.<br>Status    | Ers. Sus.<br>Rd. Array   |
| Erase<br>(Done)            | "1"  | Status               | Read Array                     | Program Setup                        | Erase<br>Setup          |                           | Read Array                   |                            | Read<br>Status          | Read<br>Array            |



# APPENDIX A WSM CURRENT/NEXT STATES (Continued)

|                             | 770101                         | <u> </u>                    | , ,                                       | VI OIA                     | . <b>_</b>                          | illiueu)                      |                            |  |
|-----------------------------|--------------------------------|-----------------------------|-------------------------------------------|----------------------------|-------------------------------------|-------------------------------|----------------------------|--|
|                             | Command Input (and Next State) |                             |                                           |                            |                                     |                               |                            |  |
| Current State               | Read Config<br>(90H)           | Read Query<br>(98H)         | Lock Setup<br>(60H)                       | Prot. Prog.<br>Setup (C0H) | Lock Confirm<br>(01H)               | Lock Down<br>Confirm<br>(2FH) | Unlock<br>Confirm<br>(D0H) |  |
| Read Array                  | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     |                               |                            |  |
| Read Status                 | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     | Read Array                    |                            |  |
| Read Config.                | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     | Read Array                    |                            |  |
| Read Query                  | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     | Read Array                    |                            |  |
| Lock<br>Setup               |                                | Locking Cor                 | nmand Error                               |                            | Lo                                  | ck Operation (Dor             | ne)                        |  |
| Lock Cmd.<br>Error          | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     | Read Array                    |                            |  |
| Lock Operation (Done)       | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     | Read Array                    |                            |  |
| Prot. Prog.<br>Setup        |                                |                             | Prote                                     | ection Register Pro        | ogram                               |                               |                            |  |
| Prot. Prog.<br>(Not Done)   |                                |                             | Protection                                | Register Program           | (Not Done)                          |                               |                            |  |
| Prot. Prog.<br>(Done)       | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       | Read Array                          |                               |                            |  |
| Prog. Setup                 |                                |                             |                                           | Program                    |                                     |                               |                            |  |
| Program<br>(Not Done)       |                                |                             | I                                         | Program (Not Done          | e)                                  |                               |                            |  |
| Prog. Susp.<br>Status       | Prog. Susp.<br>Read Config.    | Prog. Susp.<br>Read Query   |                                           | Program Susp               | end Read Array                      |                               | Program<br>(Not Done)      |  |
| Prog. Susp.<br>Read Array   | Prog. Susp.<br>Read Config.    | Prog. Susp.<br>Read Query   |                                           | Program Susp               | end Read Array                      |                               | Program<br>(Not Done)      |  |
| Prog. Susp.<br>Read Config. | Prog. Susp.<br>Read Config.    | Prog. Susp.<br>Read Query   |                                           | Program Susp               | end Read Array                      |                               | Program<br>(Not Done)      |  |
| Prog. Susp.<br>Read Query.  | Prog. Susp.<br>Read Config.    | Prog. Susp.<br>Read Query   |                                           | Program Susp               | end Read Array                      |                               | Program<br>(Not Done)      |  |
| Program<br>(Done)           | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     | Read Array                    |                            |  |
| Erase<br>Setup              |                                |                             | Erase Con                                 | nmand Error                |                                     |                               | Erase<br>(Not Done)        |  |
| Erase Cmd.<br>Error         | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     | Read Array                    |                            |  |
| Erase<br>(Not Done)         |                                |                             |                                           | Erase (Not Done)           |                                     |                               |                            |  |
| Erase Suspend<br>Status     | Erase Suspend<br>Read Config.  | Erase Suspend<br>Read Query | Lock Setup                                | Eras                       | se Suspend Read A                   | Array                         | Erase<br>(Not Done)        |  |
| Erase Suspend<br>Array      | Erase Suspend<br>Read Config.  | Erase Suspend<br>Read Query | Lock Setup Erase Suspend Read Array Erase |                            |                                     |                               | Erase<br>(Not Done)        |  |
| Eras Sus. Read<br>Config    | Erase Suspend<br>Read Config.  | Erase Suspend<br>Read Query |                                           |                            |                                     |                               | Erase<br>(Not Done)        |  |
| Eras Sus. Read<br>Query     | Erase Suspend<br>Read Config.  | Erase Suspend<br>Read Query | Lock Setup                                | Eras                       | Erase Suspend Read Array Era (Not D |                               |                            |  |
| Ers.(Done)                  | Read Config.                   | Read Query                  | Lock Setup                                | Prot. Prog.<br>Setup       |                                     | Read Array                    |                            |  |
|                             |                                |                             |                                           |                            |                                     |                               |                            |  |



## APPENDIX B PROGRAM/ERASE FLOWCHARTS



Figure 10. Automated Word Programming Flowchart





Figure 11. Program Suspend/Resume Flowchart





Figure 12. Automated Block Erase Flowchart





Figure 13. Erase Suspend/Resume Flowchart





Figure 14. Locking Operations Flowchart





Figure 15. Protection Register Programming Flowchart



## APPENDIX C COMMON FLASH INTERFACE QUERY STRUCTURE

This appendix defines the data structure or "database" returned by the Common Flash Interface (CFI) Query command. System software should parse this structure to gain critical information such as block size, density, x8/x16, and electrical specifications. Once this information has been obtained, the software will know which command sets to use to enable flash writes, block erases, and otherwise control the flash component. The Query is part of an overall specification for multiple command set and control interface descriptions called Common Flash Interface, or CFI.

### C.1 QUERY STRUCTURE OUTPUT

The Query "database" allows system software to gain critical information for controlling the flash component. This section describes the device's CFI-compliant interface that allows the host system to access Query data.

Query data are always presented on the lowest-order data outputs ( $DQ_{0-7}$ ) only. The numerical offset value is the address relative to the maximum bus width supported by the device. On this family of devices, the Query table device starting address is a 10h, which is a word address for x16 devices.

For a word-wide (x16) device, the first two bytes of the Query structure, "Q", "R", and "Y" in ASCII, appear on the low byte at word addresses 10h, 11h, and 12h. This CFI-compliant device outputs 00H data on upper bytes. Thus, the device outputs ASCII "Q" in the low byte ( $DQ_{0-7}$ ) and 00h in the high byte ( $DQ_{8-15}$ ).

At Query addresses containing two or more bytes of information, the least significant data byte is presented at the lower address, and the most significant data byte is presented at the higher address.

In all of the following tables, addresses and data are represented in hexadecimal notation, so the "h" suffix has been dropped. In addition, since the upper byte of word.wide devices is always "00h," the leading "00" has been dropped from the table notation and only the lower byte value is shown. Any x16 device outputs can be assumed to have 00h on the upper byte in this mode.

Table C1. Summary of Query Structure Output As a Function of Device and Mode

| Device           | Location | Query Data<br>(Hex, ASCII) |
|------------------|----------|----------------------------|
| 16-Mbit x 16     | 10       | 51 "Q"                     |
| (Word Addresses) | 11       | 52 "R"                     |
|                  | 12       | 59 "Y"                     |



Table C2. Example of Query Structure Output for x16 Devices

| Device                                                                    | Word Addressing:                                                                                                                                                                                                                         |  |  |  |  |
|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Address                                                                   | Query Data                                                                                                                                                                                                                               |  |  |  |  |
| A <sub>19</sub> -A <sub>0</sub>                                           | D <sub>15</sub> –D <sub>0</sub>                                                                                                                                                                                                          |  |  |  |  |
| 000010h<br>000011h<br>000012h<br>000013h<br>000014h<br>000015h<br>000016h | 0051h "Q" 0052h "R" 0059h "Y"  P_ID <sub>LO</sub> PrVendor ID# (Lo byte)  P_ID <sub>HI</sub> PrVendor ID# (HI byte)  P <sub>LO</sub> PrVendor TblAddr (Lo)  P <sub>HI</sub> PrVendor TblAddr (Hi)  A_ID <sub>LO</sub> AltVendor ID# (LO) |  |  |  |  |
| 000018h                                                                   | A_ID <sub>HI</sub> AltVendor ID# (Hi)                                                                                                                                                                                                    |  |  |  |  |
|                                                                           |                                                                                                                                                                                                                                          |  |  |  |  |

### C.2 QUERY STRUCTURE OVERVIEW

The Query command causes the flash component to display the Common Flash Interface (CFI) Query structure or "database."

### NOTE:

Detailed sections describe the Query structure sub-sections in detail are TBD.



## APPENDIX D ARCHITECTURE BLOCK DIAGRAM





## APPENDIX E WORD-WIDE MEMORY MAP DIAGRAMS

## 16-Mbit Word-Wide Memory Addressing

|              | Top Boot                        | Е            | Bottom Boot                      |
|--------------|---------------------------------|--------------|----------------------------------|
| Size<br>(KW) | 16M                             | Size<br>(KW) | 16M                              |
| 4            | FF000-FFFFF                     | 32           |                                  |
| 4            | FE000-FEFFF                     | 32           |                                  |
| 4            | FD000-FDFFF                     | 32           |                                  |
| 4            | FC000-FCFFF                     | 32           |                                  |
| 4            | FB000-FBFFF                     | 32           |                                  |
| 4            | FA000-FAFFF                     | 32           |                                  |
| 4            | F9000-F9FFF                     | 32           |                                  |
| 4            | F8000-F8FFF                     | 32           |                                  |
| 32           | F0000-F7FFF                     | 32           |                                  |
| 32           | E8000-EFFFF                     | 32           |                                  |
| 32           | E0000-E7FFF                     | 32           |                                  |
| 32           | D8000-DFFFF                     | 32           |                                  |
| 32           | D0000-D7FFF                     | 32           |                                  |
| 32           | C8000-CFFFF                     | 32           |                                  |
| 32           | C0000-C7FFF                     | 32           |                                  |
| 32           | B8000-BFFFF                     | 32           |                                  |
| 32           | B0000-B7FFF                     | 32           |                                  |
| 32           | A8000-AFFFF                     | 32           |                                  |
| 32           | A0000-A7FFF                     | 32           |                                  |
| 32           | 98000-9FFFF                     | 32           |                                  |
| 32           | 90000-97FFF                     | 32           |                                  |
| 32           | 88000-8FFFF                     | 32           |                                  |
| 32           | 80000-87FFF                     | 32           |                                  |
| 32           | 78000-7FFFF                     | 32           |                                  |
| 32           | 70000-77FFF                     | 32           |                                  |
| 32           | 68000-6FFFF                     | 32           |                                  |
| 32           | 60000-67FFF                     | 32           |                                  |
| 32           | 58000-5FFFF                     | 32           |                                  |
| 32           | 50000-57FFF                     | 32           |                                  |
| 32           | 48000-4FFFF                     | 32           |                                  |
| 32           | 40000-47FFF                     | 32           |                                  |
| 32           | 38000-3FFFF                     | 32           |                                  |
|              | olumn continued<br>in next page |              | column continued<br>on next page |



16-Mbit Word-Wide Memory Addressing (Continued)

|              | Top Boot    | Bottom Boot  |             |  |  |
|--------------|-------------|--------------|-------------|--|--|
| Size<br>(KW) | 16M         | Size<br>(KW) | 16M         |  |  |
| 32           | 30000-37FFF | 32           | F8000-FFFFF |  |  |
| 32           | 28000-2FFFF | 32           | F0000-F7FFF |  |  |
| 32           | 20000-27FFF | 32           | E8000-EFFFF |  |  |
| 32           | 18000-1FFFF | 32           | E0000-E7FFF |  |  |
| 32           | 10000-17FFF | 32           | D8000-DFFFF |  |  |
| 32           | 08000-0FFFF | 32           | D0000-D7FFF |  |  |
| 32           | 00000-07FFF | 32           | C8000-CFFFF |  |  |
| 32           |             | 32           | C0000-C7FFF |  |  |
| 32           |             | 32           | B8000-BFFFF |  |  |
| 32           |             | 32           | B0000-B7FFF |  |  |
| 32           |             | 32           | A8000-AFFFF |  |  |
| 32           |             | 32           | A0000-A7FFF |  |  |
| 32           |             | 32           | 98000-9FFFF |  |  |
| 32           |             | 32           | 90000-97FFF |  |  |
| 32           |             | 32           | 88000-8FFFF |  |  |
| 32           |             | 32           | 80000-87FFF |  |  |
| 32           |             | 32           | 78000-7FFFF |  |  |
| 32           |             | 32           | 70000-77FFF |  |  |
| 32           |             | 32           | 68000-6FFFF |  |  |
| 32           |             | 32           | 60000-67FFF |  |  |
| 32           |             | 32           | 58000-5FFFF |  |  |
| 32           |             | 32           | 50000-57FFF |  |  |
| 32           |             | 32           | 48000-4FFFF |  |  |
| 32           |             | 32           | 40000-47FFF |  |  |
| 32           |             | 32           | 38000-3FFFF |  |  |
| 32           |             | 32           | 30000-37FFF |  |  |
| 32           |             | 32           | 28000-2FFFF |  |  |
| 32           |             | 32           | 20000-27FFF |  |  |
| 32           |             | 32           | 18000-1FFFF |  |  |
| 32           |             | 32           | 10000-17FFF |  |  |
| 32           |             | 32           | 08000-0FFFF |  |  |
| 32           |             | 4            | 07000-07FFF |  |  |
| 32           |             | 4            | 06000-06FFF |  |  |
| 32           |             | 4            | 05000-05FFF |  |  |
| 32           |             | 4            | 04000-04FFF |  |  |
| 32           |             | 4            | 03000-03FFF |  |  |
| 32           |             | 4            | 02000-02FFF |  |  |
| 32           |             | 4            | 01000-01FFF |  |  |
| 32           |             | 4            | 00000-00FFF |  |  |



## APPENDIX F DEVICE ID TABLE

### **Read Configuration Addresses and Data**

| Item              |     | Address | Data |
|-------------------|-----|---------|------|
| Manufacturer Code | x16 | 00000   | 0089 |
| Device Code       |     |         |      |
| 16-Mbit x 16-T    | x16 | 00001   | 88C2 |
| 16-Mbit x 16-B    | x16 | 00001   | 88C3 |

**NOTE:** Other locations within the configuration address space are reserved by Intel for future use.



## APPENDIX G PROTECTION REGISTER ADDRESSING

## **Word-Wide Protection Register Addressing**

| Word | Use     | A7 | A6 | A5 | A4 | А3 | A2 | <b>A</b> 1 | Α0 |
|------|---------|----|----|----|----|----|----|------------|----|
| LOCK | Both    | 1  | 0  | 0  | 0  | 0  | 0  | 0          | 0  |
| 0    | Factory | 1  | 0  | 0  | 0  | 0  | 0  | 0          | 1  |
| 1    | Factory | 1  | 0  | 0  | 0  | 0  | 0  | 1          | 0  |
| 2    | Factory | 1  | 0  | 0  | 0  | 0  | 0  | 1          | 1  |
| 3    | Factory | 1  | 0  | 0  | 0  | 0  | 1  | 0          | 0  |
| 4    | User    | 1  | 0  | 0  | 0  | 0  | 1  | 0          | 1  |
| 5    | User    | 1  | 0  | 0  | 0  | 0  | 1  | 1          | 0  |
| 6    | User    | 1  | 0  | 0  | 0  | 0  | 1  | 1          | 1  |
| 7    | User    | 1  | 0  | 0  | 0  | 1  | 0  | 0          | 0  |

#### NOTE:

<sup>1.</sup> All address lines not specified in the above table must be 0 when accessing the Protection Register, i.e., A<sub>19</sub>-A<sub>8</sub> = 0.