# Intel®® Embedded Flash Memory (J3 v. D) 

(32, 64, and 128 Mbit)

## Datasheet

## Product Features

## - Architecture

—High-density symmetrical 128-Kbyte blocks

- 128 Mbit (128 blocks)
-64 Mbit (64 blocks)
- 32 Mbit (32 blocks)
- Performance
— 75 ns Initial Access Speed (128/64/32 -Mbit densities)
—25 ns 8-word and 4-word
Asynchronous page-mode reads
-32-Byte Write buffer
$-4 \mu \mathrm{~s}$ per Byte Effective programming time
- System Voltage and Power
$-\mathrm{V}_{\mathrm{CC}}=2.7 \mathrm{~V}$ to 3.6 V
$-\mathrm{V}_{\mathrm{CCQ}}=2.7 \mathrm{~V}$ to 3.6 V
- Security
-Enhanced security options for code protection
- 128-bit Protection Register
-64-bit Unique device identifier
-64-bit User-programmable OTP cells
-Absolute protection with $\mathrm{V}_{\mathrm{PEN}}=\mathrm{GND}$
-Individual block locking
—Block erase/program lockout during power transitions
- Software
-Program and erase suspend support
-Flash Data Integrator (FDI), Common Flash Interface (CFI) Compatible
- Quality and Reliability
-Operating temperature:
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- 100 K Minimum erase cycles per block
$-0.13 \mu \mathrm{~m} \mathrm{ETOX}^{\mathrm{TM}}$ VIII Process
- Packaging
-56-Lead TSOP package
-64-Ball Intel ${ }^{\oplus}$ Easy BGA package

The Intel® Embedded Flash Memory J3 Version D (J3 v. D) provides improved mainstream performance with enhanced security features, taking advantage of the high quality and reliability of the NOR-based Intel $0.13 \mu \mathrm{~m}$ ETOX ${ }^{\mathrm{TM}}$ VIII process technology. Offered in 128-Mbit (16-Mbyte), 64-Mbit, and 32-Mbit densities, the J 3 v . D device brings reliable, low-voltage capability ( 3 V read, program, and erase) with high speed, low-power operation.

The J3 v. D device takes advantage of the proven manufacturing experience and is ideal for code and data applications where high density and low cost are required, such as in networking, telecommunications, digital set top boxes, audio recording, and digital imaging.

Intel Flash Memory components also deliver a new generation of forward-compatible software support. By using the Common Flash Interface (CFI) and Scalable Command Set (SCS), customers can take advantage of density upgrades and optimized write capabilities of future Intel® Flash Memory devices.

Notice: This document contains information on new products in production. The specifications are subject to change without notice. Verify with your local Intel sales office that you have the latest datasheet before finalizing a design.

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.
Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined." Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them.
The Intel® Embedded Flash Memory ( $\mathrm{J} 3 \mathrm{v} . \mathrm{D}$ ) 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 by calling 1-800-548-4725 or by visiting Intel's website at http://www.intel.com.
Copyright © 2005, Intel Corporation. All rights reserved.
Intel and ETOX are trademarks or registered trademarks of Intel Corporation or its subsidiaries in the United States and other countries.
*Other names and brands may be claimed as the property of others.

## Contents

1.0 Introduction ..... 6
1.1 Nomenclature ..... 6
1.2 Acronyms ..... 6
1.3 Conventions ..... 6
$2.0 \quad$ Functional Overview ..... 8
2.1 Block Diagram ..... 10
2.2 Memory Map ..... 11
3.0 Package Information ..... 12
$3.1 \quad$ 56-Lead TSOP Package ..... 12
3.2 Easy BGA Package ..... 13
4.0 Ballouts and Signal Descriptions ..... 15
4.1 Easy BGA Ballout (32/64/128 Mbit) ..... 15
4.2 56-Lead TSOP Package Pinout (32/64/128 Mbit) ..... 16
4.3 Signal Descriptions ..... 17
5.0 Maximum Ratings and Operating Conditions ..... 19
5.1 Absolute Maximum Ratings ..... 19
5.2 Operating Conditions ..... 19
5.3 Power Up/Down ..... 20
5.3.1 Power-Up/Down Characteristics ..... 20
5.3.2 Power Supply Decoupling ..... 20
5.4 Reset ..... 20
6.0 Electrical Characteristics ..... 21
6.1 DC Current Specifications ..... 21
6.2 DC Voltage specifications ..... 22
6.3 Capacitance ..... 23
7.0 AC Characteristics ..... 24
7.1 Read Specifications ..... 25
7.2 Write Specifications ..... 28
7.3 Program, Erase, Block-Lock Specifications ..... 30
7.4 Reset Specifications ..... 31
7.5 AC Test Conditions ..... 32
8.0 Bus Interface ..... 33
8.1 Bus Reads ..... 34
8.1.1 Asynchronous Page Mode Read ..... 34
8.1.1.1 Enhanced Configuration Register (ECR) ..... 34
8.1.2 Output Disable ..... 35
8.2 Bus Writes ..... 35
8.3 Standby ..... 36
8.3.1 Reset/Power-Down ..... 36
8.4 Device Commands ..... 36
9.0 Flash Operations ..... 38
9.1 Status Register ..... 38
9.1.1 Clearing the Status Register ..... 39
9.2 Read Operations ..... 39
9.2.1 Read Array ..... 39
9.2.2 Read Status Register ..... 40
9.2.3 Read Device Information ..... 40
9.2.4 CFI Query ..... 41
9.3 Programming Operations ..... 41
9.3.1 Single-Word/Byte Programming ..... 41
9.3.2 Buffered Programming ..... 42
9.4 Block Erase Operations ..... 43
9.5 Suspend and Resume ..... 44
9.6 Status Signal (STS) ..... 45
9.7 Security and Protection ..... 46
9.7.1 Normal Block Locking ..... 46
9.7.2 Configurable Block Locking ..... 47
9.7.3 OTP Protection Registers ..... 47
9.7.4 Reading the OTP Protection Register ..... 48
9.7.5 Programming the OTP Protection Register ..... 48
9.7.6 Locking the OTP Protection Register ..... 48
9.7.7 VPP/ VPEN Protection ..... 50
Appendix A Device Command Codes ..... 51
Appendix B J3 v. D ID Codes ..... 52
Appendix C Flow Charts ..... 53
C. 1 Write to Buffer ..... 53
C. 2 Status Register ..... 54
C. 3 Byte/Word Programming ..... 55
C. 4 Program Suspend/Resume ..... 56
C. 5 Block Erase. ..... 57
C. 6 Block Erase Suspend/Resume ..... 58
C. 7 Block Locking ..... 59
C. 8 Unlock Block ..... 60
C. 9 OTP Protection Register Programming ..... 61
Appendix D Common Flash Interface ..... 62
D. 2 Query Structure Overview ..... 63
D. 3 Block Status Register ..... 64
D. 4 CFI Query Identification String ..... 64
D. 5 System Interface Information ..... 65
D. 6 Device Geometry Definition ..... 66
D. 7 Primary-Vendor Specific Extended Query Table ..... 67
Appendix E Additional Information ..... 69
Appendix F Ordering Information ..... 70

Revision History

| Date of Revision | Version | Description |
| :---: | :---: | :--- |
| July 2005 | 001 | Initial release |
| September 2005 | 002 | -Marketing name was changed from 28FxxxJ3 to J3 v. D <br> - Table 18 "Command Bus Operations for J3 v. D" on page 37 was updated <br> - - Section 9.2.2, "Read Status Register" on page 40 <br> - - Section 9.3.2, "Buffered Programming" on page 42 <br> - Table 27 "Valid Commands During Suspend" on page 44 <br> - Table 28 "STS Configuration Register" on page 45 was added |

### 1.0 Introduction

This document contains information pertaining to the Intel® Embedded Flash Memory (J3 v. D) device features, operation, and specifications.

### 1.1 Nomenclature

| AMIN: | All Densities | AMIN $=\mathrm{A} 0$ for x 8 |
| :--- | :--- | :--- |
|  | All Densities | AMIN $=\mathrm{A} 1$ for x 16 |

### 1.2 Acronyms

| CUI: | Command User Interface |
| :--- | :--- |
| OTP: | One Time Programmable |
| PLR: | Protection Lock Register |
| PR: | Protection Register |
| PRD: | Protection Register Data |
| RFU: | Reserved for Future Use |
| SR: | Status Register |
| SRD: | Status Register Data |
| WSM: | Write State Machine |
| ECR: | Enhanced Configuration Register |

### 1.3 Conventions

| h: | Hexadecimal Affix |
| :--- | :--- |
| k (noun): | 1,000 |
| M (noun): | $1,000,000$ |
| Nibble | 4 bits |
| Byte: | 8 bits |


| Word: | 16 bits |
| :--- | :--- |
| Kword: | 1,024 words |
| Kb: | 1,024 bits |
| KB: | 1,024 bytes |
| Mb: | $1,048,576$ bits |
| MB: | $1,048,576$ bytes |
| Brackets: | Square brackets ([]) will be used to designate group membership or to define a |
|  | group of signals with similar function (i.e. A[21:1], SR[4,1] and D[15:0]). |
| 00FFh: | Denotes 16-bit hexadecimal numbers |
| 00FF 00FFh: | Denotes 32-bit hexadecimal numbers |
| DQ[15:0]: | Data I/O signals |

### 2.0 Functional Overview

## Product Description

The Intel® Embedded Flash Memory (J3 v. D) family contains high-density memory organized in any of the following configurations:

- 16 Mbytes or 8 Mword (128-Mbit), organized as one-hundred-twenty-eight 128-Kbyte (131,072 bytes) erase blocks
- 8 Mbytes or 4 Mword (64-Mbit), organized as sixty-four 128-Kbyte erase blocks
- 4 Mbytes or 2 Mword (32-Mbit), organized as thirty-two 128-Kbyte erase blocks

These devices can be accessed as 8- or 16-bit words. See Figure 1, "J3 v. D Memory Block Diagram" on page 10 for further details.

A 128-bit Protection Register has multiple uses, including unique flash device identification.
The Intel® Embedded Flash Memory (J3 v. D) device includes new security features that were not available on the (previous) $0.25 \mu \mathrm{~m}$ and $0.18 \mu \mathrm{~m}$ versions of the J 3 family. These new security features prevent altering of code through different protection schemes that can be implemented, based on user requirements.

The J3 v. D device optimized architecture and interface dramatically increases read performance by supporting page-mode reads. This read mode is ideal for non-clock memory systems.

A Common Flash Interface (CFI) permits software algorithms to be used for entire families of devices. This allows device-independent, JEDEC ID-independent, and forward- and backwardcompatible software support for the specified flash device families. Flash vendors can standardize their existing interfaces for long-term compatibility.

Scalable Command Set (SCS) allows a single, simple software driver in all host systems to work with all SCS-compliant flash memory devices, independent of system-level packaging (e.g., memory card, SIMM, or direct-to-board placement). Additionally, SCS provides the highest system/device data transfer rates and minimizes device and system-level implementation costs.

A Command User Interface (CUI) serves as the interface between the system processor and internal operation of the device. A valid command sequence written to the CUI initiates device automation. An internal Write State Machine (WSM) automatically executes the algorithms and timings necessary for block erase, program, and lock-bit configuration operations.

A block erase operation erases one of the device's 128-Kbyte blocks typically within one second, independent of other blocks. Each block can be independently erased 100,000 times. Block erase suspend mode allows system software to suspend block erase to read or program data from any other block. Similarly, program suspend allows system software to suspend programming (byte/ word program and write-to-buffer operations) to read data or execute code from any other block that is not being suspended.

Each device incorporates a Write Buffer of 32 bytes ( 16 words) to allow optimum programming performance. By using the Write Buffer, data is programmed in buffer increments.

Blocks are selectively and individually lockable in-system. Individual block locking uses block lock-bits to lock and unlock blocks. Block lock-bits gate block erase and program operations. Lock-bit configuration operations set and clear lock-bits (using the Set Block Lock-Bit and Clear Block Lock-Bits commands).

The Status Register indicates when the WSM's block erase, program, or lock-bit configuration operation is finished.

The STS (STATUS) output gives an additional indicator of WSM activity by providing both a hardware signal of status (versus software polling) and status masking (interrupt masking for background block erase, for example). Status indication using STS minimizes both CPU overhead and system power consumption. When configured in level mode (default mode), it acts as a RY/ BY\# signal. When low, STS indicates that the WSM is performing a block erase, program, or lockbit configuration. STS-high indicates that the WSM is ready for a new command, block erase is suspended (and programming is inactive), program is suspended, or the device is in reset/powerdown mode. Additionally, the configuration command allows the STS signal to be configured to pulse on completion of programming and/or block erases.

Three CE signals are used to enable and disable the device. A unique CE logic design (see Table 15, "Chip Enable Truth Table" on page 33) reduces decoder logic typically required for multi-chip designs. External logic is not required when designing a single chip, a dual chip, or a 4chip miniature card or SIMM module.

The BYTE\# signal allows either x 8 or $\mathrm{x} 16 \mathrm{read} / \mathrm{writes}$ to the device:

- BYTE\#-low enables 8-bit mode; address A0 selects between the low byte and high byte.
- BYTE\#-high enables16-bit operation; address A1 becomes the lowest order address and address A0 is not used (don't care).

Figure 1, "J3 v. D Memory Block Diagram" on page 10 shows a device block diagram.
When the device is disabled (see Table 15, "Chip Enable Truth Table" on page 33), with CEx at VIH and RP\# at VIH, the standby mode is enabled. When RP\# is at VIL, a further power-down mode is enabled which minimizes power consumption and provides write protection during reset. A reset time (tPHQV) is required from RP\# going high until data outputs are valid. Likewise, the device has a wake time (tPHWL) from RP\#-high until writes to the CUI are recognized. With RP\# at VIL, the WSM is reset and the Status Register is cleared.

### 2.1 Block Diagram

Figure 1. J3 v. D Memory Block Diagram

2.2 Memory Map

Figure 2. J3 v. D Memory Map


### 3.0 Package Information

### 3.1 56-Lead TSOP Package

Figure 3. 56-Lead TSOP Package Mechanical


Table 1. 56-Lead TSOP Dimension Table (Sheet 1 of 2)

|  |  | Millimeters |  |  | Inches |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Nom | Max | Min | Nom | Max |
| Package Height |  |  |  | 1.200 |  |  | 0.047 |
| Standoff | $\mathrm{A}_{1}$ | 0.050 |  |  | 0.002 |  |  |
| Package Body Thickness | $\mathrm{A}_{2}$ | 0.965 | 0.995 | 1.025 | 0.038 | 0.039 | 0.040 |
| Lead Width | b | 0.100 | 0.150 | 0.200 | 0.004 | 0.006 | 0.008 |
| Lead Thickness | c | 0.100 | 0.150 | 0.200 | 0.004 | 0.006 | 0.008 |
| Package Body Length | $\mathrm{D}_{1}$ | 18.200 | 18.400 | 18.600 | 0.717 | 0.724 | 0.732 |
| Package Body Width | E | 13.800 | 14.000 | 14.200 | 0.543 | 0.551 | 0.559 |
| Lead Pitch | e |  | 0.500 |  |  | 0.0197 |  |
| Terminal Dimension | D | 19.800 | 20.00 | 20.200 | 0.780 | 0.787 | 0.795 |
| Lead Tip Length | L | 0.500 | 0.600 | 0.700 | 0.020 | 0.024 | 0.028 |
| Lead Count | N |  | 56 |  |  | 56 |  |

## inted

Table 1. 56-Lead TSOP Dimension Table (Sheet 2 of 2)

|  |  | Millimeters |  |  | Inches |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Sym | Min | Nom | Max | Min | Nom | Max |
| Lead Tip Angle | $\theta$ | $0^{\circ}$ | $3^{\circ}$ | $5^{\circ}$ | $0^{\circ}$ | $3^{\circ}$ | $5^{\circ}$ |
| Seating Plane Coplanarity | Y |  |  | 0.100 |  |  | 0.004 |
| Lead to Package Offset | Z | 0.150 | 0.250 | 0.350 | 0.006 | 0.010 | 0.014 |

### 3.2 Easy BGA Package

Figure 4. Easy BGA Mechanical Specifications


Table 2. Easy BGA Package Dimensions Table

|  |  | Millimeters |  |  |  | Inches |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Symbol | Min | Nom | Max | Notes | Min | Nom | Max |
| Package Height | A |  |  | 1.200 |  |  |  | 0.0472 |
| Ball Height | A1 | 0.250 |  |  |  | 0.0098 |  |  |
| Package Body Thickness | A2 |  | 0.780 |  |  |  | 0.0307 |  |
| Ball (Lead) Width | b | 0.330 | 0.430 | 0.530 |  | 0.0130 | 0.0169 | 0.0209 |
| Package Body Width ( $32 \mathrm{Mb}, 64 \mathrm{Mb}, 128 \mathrm{Mb}$ ) | D | 9.900 | 10.000 | 10.100 | 1 | 0.3898 | 0.3937 | 0.3976 |
| Package Body Length ( $32 \mathrm{Mb}, 64 \mathrm{Mb}, 128 \mathrm{Mb}$ ) | E | 12.900 | 13.000 | 13.100 | 1 | 0.5079 | 0.5118 | 0.5157 |
| Pitch | [e] |  | 1.000 |  |  |  | 0.0394 |  |
| Ball (Lead) Count | N |  | 64 |  |  |  | 64 |  |
| Seating Plane Coplanarity | Y |  |  | 0.100 |  |  |  | 0.0039 |
| Corner to Ball A1 Distance Along D (32/64/128 Mb) | S1 | 1.400 | 1.500 | 1.600 | 1 | 0.0551 | 0.0591 | 0.0630 |
| Corner to Ball A1 Distance Along E (32/64/128 Mb) | S2 | 2.900 | 3.000 | 3.100 | 1 | 0.1142 | 0.1181 | 0.1220 |

## NOTES:

1. For Daisy Chain Evaluation Unit information refer to the Intel Flash Memory Packaging Technology Web page at: www.intel.com/design/packtech/index.htm
2. For Packaging Shipping Media information refer to the Intel Flash Memory Packaging Technology Web page at: www.intel.com/ design/packtech/index.htm

### 4.0 Ballouts and Signal Descriptions

Intel® Embedded Flash Memory (J3 v. D) is available in two package types. Each density of the J3 v. D is supported on both 64-ball Easy BGA and 56-lead Thin Small Outline Package (TSOP) packages. Figure 5, and Figure 6 show the pinouts.

### 4.1 Easy BGA Ballout (32/64/128 Mbit)

Figure 5. Easy BGA Ballout (32/64/128 Mbit)


NOTES:

1. Address A22 is only valid on 64-Mbit densities and above, otherwise, it is a no connect (NC).
2. Address A23 is only valid on 128 -Mbit densities and above, otherwise, it is a no connect (NC).

### 4.2 56-Lead TSOP Package Pinout (32/64/128 Mbit)

Figure 6. 56-Lead TSOP Package Pinout (32/64/128 Mbit)


NOTES:

1. A22 exists on 64- and 128- densities. On 32-Mbit density this signal is a no-connect (NC).
2. A23 exists on 128 -Mbit densities. On 32 - and 64 -Mbit densities this signal is a no-connect (NC)

### 4.3 Signal Descriptions

Table 3 lists the active signals used on J 3 v . D and provides a description of each.
Table 3. Signal Descriptions for J3 v. D (Sheet 1 of 2)

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| A0 | Input | BYTE-SELECT ADDRESS: Selects between high and low byte when the device is in $\times 8$ mode. This address is latched during a $\times 8$ program cycle. Not used in $\times 16$ mode (i.e., the A0 input buffer is turned off when BYTE\# is high). |
| A[MAX:1] | Input | ADDRESS INPUTS: Inputs for addresses during read and program operations. Addresses are internally latched during a program cycle: $\begin{aligned} & 32-\text { Mbit - A[21:1] } \\ & \text { 64-Mbit - A[22:1] } \\ & \text { 128-Mbit - A[23:1] } \end{aligned}$ |
| D[7:0] | Input/Output | LOW-BYTE DATA BUS: Inputs data during buffer writes and programming, and inputs commands during CUI writes. Outputs array, CFI, identifier, or status data in the appropriate read mode. Data is internally latched during write operations. |
| D[15:8] | Input/Output | HIGH-BYTE DATA BUS: Inputs data during $\times 16$ buffer writes and programming operations. Outputs array, CFI, or identifier data in the appropriate read mode; not used for Status Register reads. Data is internally latched during write operations in $\times 16$ mode. D[15-8] float in x8 mode |
| CE[2:0] | Input | CHIP ENABLES: Activate the 32-, 64- and 128 Mbit devices' control logic, input buffers, decoders, and sense amplifiers. When the device is de-selected (see Table 15, "Chip Enable Truth Table" on page 33), power reduces to standby levels. <br> All timing specifications are the same for these three signals. Device selection occurs with the first edge of CE0\#, CE1\#, or CE2\# that enables the device. Device deselection occurs with the first edge of CE0\#, CE1\#, or CE2\# that disables the device (see Table 15, "Chip Enable Truth Table" on page 33). |
| RP\# | Input | RESET: RP\#-low resets internal automation and puts the device in power-down mode. RP\#-high enables normal operation. Exit from reset sets the device to read array mode. When driven low, RP\# inhibits write operations which provides data protection during power transitions. |
| OE\# | Input | OUTPUT ENABLE: Activates the device's outputs through the data buffers during a read cycle. OE\# is active low. |
| WE\# | Input | WRITE ENABLE: Controls writes to the CUI, the Write Buffer, and array blocks. WE\# is active low. Addresses and data are latched on the rising edge of WE\#. |
| STS | Open Drain Output | STATUS: Indicates the status of the internal state machine. When configured in level mode (default), it acts as a RY/BY\# signal. When configured in one of its pulse modes, it can pulse to indicate program and/or erase completion. For alternate configurations of the STATUS signal, see the Configurations command and Section 9.6, "Status Signal (STS)" on page 45. STS is to be tied to VCCQ with a pull-up resistor. |
| BYTE\# | Input | BYTE ENABLE: BYTE\#-low places the device in $x 8$ mode; data is input or output on D[7:0], while $\mathrm{D}[15: 8$ ] is placed in High-Z. Address A0 selects between the high and low byte. BYTE\#-high places the device in $x 16$ mode, and turns off the A0 input buffer. Address A1 becomes the lowest-order address bit. |
| VPEN | Input | ERASE / PROGRAM / BLOCK LOCK ENABLE: For erasing array blocks, programming data, or configuring lock-bits. <br> With $\mathrm{V}_{\text {PEN }} \leq \mathrm{V}_{\text {PENLK }}$, memory contents cannot be altered. |
| VCC | Power | CORE Power Supply: Core (logic) source voltage. Writes to the flash array are inhibited when $\mathrm{V}_{\mathrm{CC}}$ $\leq \mathrm{V}_{\text {LKO }}$. <br> Caution: Device operation at invalid Vcc voltages should not be attempted. |
| VCCQ | Power | I/O Power Supply: Power supply for Input/Output buffers. This ball can be tied directly to $\mathrm{V}_{\mathrm{CC}}$ - |

Table 3. Signal Descriptions for J3v. D (Sheet 2 of 2)

| Symbol | Type | Name and Function |
| :---: | :---: | :--- |
| GND | Supply | Ground: Ground reference for device logic voltages. Connect to system ground. |
| NC | - | No Connect: Lead is not internally connected; it may be driven or floated. |
| RFU | - | Reserved for Future Use: Balls designated as RFU are reserved by Intel for future device <br> functionality and enhancement. |

### 5.0 Maximum Ratings and Operating Conditions

### 5.1 Absolute Maximum Ratings

Warning: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only.

> NOTICE: This document contains information available at the time of its release. The specifications are subject to change without notice. Verify with your local Intel sales office that you have the latest datasheet before finalizing a design.

Table 4. Absolute Maximum Ratings

| Parameter | Min | Max | Unit | Notes |
| :--- | :---: | :---: | :---: | :---: |
| Temperature under Bias Expanded (T $\mathrm{A}_{\mathrm{A}}$, Ambient) | -40 | +85 | ${ }^{\circ} \mathrm{C}$ | - |
| Storage Temperature | -65 | +125 | ${ }^{\circ} \mathrm{C}$ | - |
| VCC Voltage | -2.0 | +5.6 | V | 2 |
| VCCQ | -2.0 | +5.6 | V | 2 |
| Voltage on any input/output signal (except VCC, VCCQ) | -2.0 | $\mathrm{~V}_{\mathrm{CCQ}}(\mathrm{max})+2.0$ | V | 1 |
| $\mathrm{I}_{\text {SH }}$ Output Short Circuit Current | - | 100 | mA | 3 |

NOTES:

1. Voltage is referenced to $\mathrm{V}_{\mathrm{SS}}$. During infrequent non-periodic transitions, the voltage potential between $\mathrm{V}_{\mathrm{SS}}$ and input/output pins may undershoot to -2.0 V for periods $<20 \mathrm{~ns}$ or overshoot to $\mathrm{V}_{\mathrm{CCQ}}(\max )+2.0 \mathrm{~V}$ for periods $<20$ ns.
2. During infrequent non-periodic transitions, the voltage potential between $\mathrm{V}_{\mathrm{CC}}$ and the supplies may undershoot to 2.0 V for periods $<20 \mathrm{~ns}$ or $\mathrm{V}_{\text {SUPPLY }}(\max )+2.0 \mathrm{~V}$ for periods $<20 \mathrm{~ns}$.
3. Output shorted for no more than one second. No more than one output shorted at a time

### 5.2 Operating Conditions

Warning: Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

Table 6. Temperature and VCC Operating Condition of J3 v. D

| Symbol | Parameter | Min | Max | Unit | Test Condition |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{A}}$ |  | -40.0 | +85 | ${ }^{\circ} \mathrm{C}$ | Ambient Temperature |
| $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Voltage | 2.70 | 3.6 | V | - |
| $\mathrm{V}_{\mathrm{CCQ}}$ | $\mathrm{V}_{\mathrm{CCQ}}$ Supply Voltage | 2.70 | 3.6 | V | - |

### 5.3 Power Up/Down

This section provides an overview of system level considerations with regards to the flash device. It includes a brief description of power-up, power-down and decoupling design considerations.

### 5.3.1 Power-Up/Down Characteristics

To prevent any condition that may result in a spurious write or erase operation, it is recommended to power-up and power-down VCC and VCCQ together. It is also recommended to:

- Power-up VPEN after VCC=VCCmin
- Power-down VPEN with or before VCC


### 5.3.2 Power Supply Decoupling

When the device is enabled, many internal conditions change. Circuits are energized, charge pumps are switched on, and internal voltage nodes are ramped. All of this internal activities produce transient signals. The magnitude of the transient signals depends on the device and system loading. To minimize the effect of these transient signals, a $0.1 \mu \mathrm{~F}$ ceramic capacitor is required across each VCC/VSS and VCCQ signal. Capacitors should be placed as close as possible to device connections.

Additionally, for every eight flash devices, a $4.7 \mu \mathrm{~F}$ electrolytic capacitor should be placed between VCC and VSS at the power supply connection. This $4.7 \mu \mathrm{~F}$ capacitor should help overcome voltage slumps caused by PCB (printed circuit board) trace inductance.

### 5.4 Reset

By holding the flash device in reset during power-up and power-down transitions, invalid bus conditions may be masked. The flash device enters reset mode when RP\# is driven low. In reset, internal flash circuitry is disabled and outputs are placed in a high-impedance state. After return from reset, a certain amount of time is required before the flash device is able to perform normal operations. After return from reset, the flash device defaults to asynchronous page mode. If RP\# is driven low during a program or erase operation, the program or erase operation will be aborted and the memory contents at the aborted block or address are no longer valid. See Figure 12, "AC Waveform for Reset Operation" on page 31 for detailed information regarding reset timings.

### 6.0 Electrical Characteristics

### 6.1 DC Current Specifications

Table 7. DC Current Characteristics (Sheet 1 of 2)

| $\mathrm{V}_{\text {CCQ }}$ |  |  | 2.7-3.6V |  |  | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ |  |  | 2.7-3.6V |  |  |  |  |
| Symbol | Parameter |  | Typ | Max | Unit |  |  |
| $\mathrm{l}_{\mathrm{LI}}$ | Input and $\mathrm{V}_{\text {PEN }}$ Load Current |  |  | $\pm 1$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}} \text { Max; } \mathrm{V}_{\mathrm{CCQ}}=\mathrm{V}_{\mathrm{CCQ}} \operatorname{Max} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CCQ}} \text { or } \mathrm{V}_{\mathrm{SS}} \end{aligned}$ | 1 |
| lo | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}} \operatorname{Max} ; \mathrm{V}_{\mathrm{CCQ}}=\mathrm{V}_{\mathrm{CCQ}} \operatorname{Max} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CCQ}} \text { or } \mathrm{V}_{\mathrm{SS}} \end{aligned}$ | 1 |
| Iccs | $\mathrm{V}_{\text {CC }}$ Standby Current |  | 50 | 120 | $\mu \mathrm{A}$ | CMOS Inputs, $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}} \mathrm{Max}$; $\mathrm{Vccq}=$ VccqMax <br> Device is disabled (see Table 15, "Chip Enable Truth Table" on page 33), $\mathrm{RP} \#=\mathrm{V}_{\mathrm{CCQ}} \pm 0.2 \mathrm{~V}$ | 1,2,3 |
|  |  |  | 0.71 | 2 | mA | TTL Inputs, $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}}$ Max, <br> $\mathrm{Vccq}=\mathrm{VccqMax}$ <br> Device is disabled (see Table 15, "Chip <br> Enable Truth Table" on page 33), RP\# = $\mathrm{V}_{\mathrm{IH}}$ |  |
| $\mathrm{I}_{\text {CCD }}$ | $\mathrm{V}_{\text {CC }}$ Power-Down Current |  | 50 | 120 | $\mu \mathrm{A}$ | RP\# = GND $\pm 0.2 \mathrm{~V}$, I $\mathrm{IOUT}^{\text {(STS) }}$ = 0 mA |  |
| ICCR <br> $\mathrm{V}_{\mathrm{CC}}$ Page Mode Read Current |  | 4Word Page | 15 | 20 | mA | CMOS Inputs, $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}}$ Max, $\mathrm{V}_{\mathrm{CCQ}}=$ $\mathrm{V}_{\text {CCQ }}$ Max <br> Device is enabled (see Table 15, "Chip Enable Truth Table" on page 33) $\mathrm{f}=5 \mathrm{MHz}, \mathrm{I}_{\mathrm{OUT}}=0 \mathrm{~mA}$ | 1,3 |
|  |  | 24 | 29 | mA | $\begin{aligned} & \text { CMOS Inputs, } \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}} \mathrm{Max}, \mathrm{~V}_{\mathrm{CCQ}}= \\ & \mathrm{V}_{\mathrm{CCQ}} \mathrm{Max} \\ & \text { Device is enabled (see Table 15, "Chip } \\ & \text { Enable Truth Table" on page 33) } \\ & \mathrm{f}=33 \mathrm{MHz} \text {, IouT }=0 \mathrm{~mA} \end{aligned}$ |  |  |
|  |  | 8- <br> Word <br> Page | 10 | 15 | mA | CMOS Inputs, $\mathrm{V}_{C C}=\mathrm{V}_{\mathrm{CC}}$ Max, $\mathrm{V}_{\mathrm{CCQ}}=$ $\mathrm{V}_{\mathrm{CCQ}}$ Max using standard 8 word page mode reads. <br> Device is enabled (see Table 15, "Chip Enable Truth Table" on page 33) $\mathrm{f}=5 \mathrm{MHz}$, $\mathrm{I}_{\text {OUT }}=0 \mathrm{~mA}$ |  |
|  |  | 30 | 54 | mA | CMOS Inputs, $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}}$ Max, $\mathrm{V}_{\mathrm{CCQ}}=$ $\mathrm{V}_{\mathrm{CCQ}}$ Max using standard 8 word page mode reads. <br> Device is enabled (see Table 15, "Chip Enable Truth Table" on page 33) $\mathrm{f}=33 \mathrm{MHz}, \mathrm{I}_{\text {OUT }}=0 \mathrm{~mA}$ <br> Density: 128-, 64-, and 32- Mbit |  |  |
| I ccw | $\mathrm{V}_{\mathrm{CC}}$ Program or Set Lock-Bit Current |  |  | 35 | 60 | mA | CMOS Inputs, $\mathrm{V}_{\text {PEN }}=\mathrm{V}_{\text {CC }}$ | 1,4 |
|  |  |  | 40 | 70 | mA | TTL Inputs, $\mathrm{V}_{\text {PEN }}=\mathrm{V}_{\text {CC }}$ |  |  |

Table 7. DC Current Characteristics (Sheet 2 of 2)

| $\mathrm{V}_{\text {cco }}$ |  | 2.7-3.6V |  |  | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ |  | 2.7-3.6V |  |  |  |  |
| Symbol | Parameter | Typ | Max | Unit |  |  |
| $I_{\text {CCE }}$ | $\mathrm{V}_{\mathrm{CC}}$ Block Erase or Clear Block Lock-Bits Current | 35 | 70 | mA | CMOS Inputs, $\mathrm{V}_{\text {PEN }}=\mathrm{V}_{\text {CC }}$ | 1,4 |
|  |  | 40 | 80 | mA | TTL Inputs, $\mathrm{V}_{\text {PEN }}=\mathrm{V}_{\mathrm{CC}}$ |  |
| I Ccws $I_{\text {CCEs }}$ | $\mathrm{V}_{\mathrm{CC}}$ Program Suspend or Block Erase Suspend Current |  | 10 | mA | Device is enabled (see Table 15, "Chip Enable Truth Table" on page 33) | 1,5 |

## NOTES:

1. All currents are in RMS unless otherwise noted. These currents are valid for all product versions (packages and speeds). Contact Intel's Application Support Hotline or your local sales office for information about typical specifications
2. Includes STS.
3. CMOS inputs are either $\mathrm{V}_{\mathrm{CC}} \pm 0.2 \mathrm{~V}$ or $\mathrm{GND} \pm 0.2 \mathrm{~V}$. TTL inputs are either $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$.
4. Sampled, not $100 \%$ tested.
5. I $\mathrm{I}_{\text {Cww }}$ and $\mathrm{I}_{\text {CCES }}$ are specified with the device selected. If the device is read or written while in erase suspend mode, the device's current draw is $I_{C C R}$ and $I_{\text {Ccws }}$.

### 6.2 DC Voltage specifications

Table 8. DC Voltage Characteristics (Sheet 1 of 2)

| $\mathrm{V}_{\text {cco }}$ |  | 2.7-3.6 V |  |  | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ |  | 2.7-3.6 V |  |  |  |  |
| Symbol | Parameter | Min | Max | Unit |  |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | V |  | 2, 6, 7 |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{CCQ}}+0.5 \mathrm{~V}$ | V |  | 2, 6, 7 |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}} \mathrm{Min} \\ & \mathrm{~V}_{\mathrm{CCQ}}=\mathrm{V}_{\mathrm{CCQ}} \mathrm{Min} \\ & \mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA} \end{aligned}$ | 1, 2 |
|  |  |  | 0.2 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CC}} \operatorname{Min} \\ & \mathrm{~V}_{\mathrm{CCQ}}=\mathrm{V}_{\mathrm{CCQ}} \mathrm{Min} \\ & \mathrm{I}_{\mathrm{OL}}=100 \mu \mathrm{~A} \end{aligned}$ |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $0.85 \times \mathrm{V}_{\mathrm{CCQ}}$ |  | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CCMIN}} \\ & \mathrm{~V}_{\mathrm{CCQ}}=\mathrm{V}_{\mathrm{CCQ}} \mathrm{Min} \\ & \mathrm{I}_{\mathrm{OH}}=-2.5 \mathrm{~mA} \end{aligned}$ | 1,2 |
|  |  | $\mathrm{V}_{\mathrm{CCQ}}-0.2$ |  | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{CCMIN}} \\ & \mathrm{~V}_{\mathrm{CCQ}}=\mathrm{V}_{\mathrm{CCQ}} \operatorname{Min} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \end{aligned}$ |  |
| $V_{\text {PENLK }}$ | $\mathrm{V}_{\text {PEN }}$ Lockout during <br> Program, Erase and Lock-Bit Operations |  | 2.2 | V |  | 2, 3, 4 |

Table 8. DC Voltage Characteristics (Sheet 2 of 2)

| $\mathrm{V}_{\text {cCQ }}$ |  | 2.7-3.6 V |  |  | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ |  | 2.7-3.6 V |  |  |  |  |
| Symbol | Parameter | Min | Max | Unit |  |  |
| $V_{\text {PENH }}$ | $\mathrm{V}_{\text {PEN }}$ during Block Erase, <br> Program, or Lock-Bit <br> Operations | 2.7 | 3.6 | V |  | 3, 4 |
| $\mathrm{V}_{\text {LKO }}$ | $\mathrm{V}_{\text {CC }}$ Lockout Voltage | 2.0 |  | V |  | 5 |

## NOTES:

1. Includes STS.
2. Sampled, not $100 \%$ tested.
3. Block erases, programming, and lock-bit configurations are inhibited when $\mathrm{V}_{\text {PEN }} \leq \mathrm{V}_{\text {PENLK }}$, and not guaranteed in the range between $V_{\text {PENLK }}(\max )$ and $V_{\text {PENH }}(m i n)$, and above $V_{\text {PENH }}(m a x)$.
4. Typically, $\mathrm{V}_{\text {PEN }}$ is connected to $\mathrm{V}_{\mathrm{CC}}(2.7 \mathrm{~V}-3.6 \mathrm{~V})$.
5. Block erases, programming, and lock-bit configurations are inhibited when $\mathrm{V}_{\mathrm{CC}}<\mathrm{V}_{\mathrm{LKO}}$, and not guaranteed in the range between $\mathrm{V}_{\text {LKO }}(\mathrm{min})$ and $\mathrm{V}_{\mathrm{CC}}(\mathrm{min})$, and above $\mathrm{V}_{\mathrm{CC}}(\mathrm{max})$.
6. Includes all operational modes of the device including standby and power-up sequences
7. Input/Output signals can undershoot to -1.0 v referenced to $\mathrm{V}_{\mathrm{SS}}$ and can overshoot to $\mathrm{V}_{\mathrm{CCQ}}=1.0 \mathrm{v}$ for duration of 2 ns or less, the $\mathrm{V}_{\mathrm{CCQ}}$ valid range is referenced to $\mathrm{V}_{\mathrm{SS}}$.

### 6.3 Capacitance

Table 9. J3 v. D Capacitance

| Symbol | Parameter $^{1}$ | Type | Max | Unit | Condition $^{2}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 6 | 8 | pF | $\mathrm{V}_{\text {IN }}=0.0 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 8 | 12 | pF | $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ |

NOTES:

1. sampled. not $100 \%$ tested.
2. $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHZ}$

### 7.0 AC Characteristics

Timing symbols used in the timing diagrams within this document conform to the following convention:


| Signal | Code | State | Code |
| :---: | :---: | :--- | :---: |
| Address | A | High | H |
| Data - Read | Q | Low | L |
| Data - Write | D | High-Z | Z |
| Chip Enable (CE\#) | E | Low-Z | X |
| Output Enable (OE\#) | G | Valid | V |
| Write Enable (WE\#) | W | Invalid | I |
| Address Valid (ADV\#) | V |  |  |
| Reset (RST\#) | P |  |  |
| Clock (CLK) | C |  |  |
| WAIT | T |  |  |

Note: Exceptions to this convention include tACC and tAPA. tACC is a generic timing symbol that refers to the aggregate initial-access delay as determined by tAVQV, tELQV, and tGLQV (whichever is satisfied last) of the flash device. tAPA is specified in the flash device's data sheet, and is the address-to-data delay for subsequent page-mode reads.

### 7.1 Read Specifications

Table 10. Read Operations

| Asynchronous Specifications$\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=2.7 \mathrm{~V}-3.6 \mathrm{~V}^{(3)} \\ & \mathrm{V}_{\mathrm{ccQ}}=2.7 \mathrm{~V}-3.6 \mathrm{~V}^{(3)} \end{aligned}$ |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \# | Sym | Parameter | Density | -75 |  | -95 |  | Unit | Notes |
|  |  |  |  | Min | Max | Min | Max |  |  |
| R1 | $\mathrm{t}_{\text {AVAV }}$ | Read/Write Cycle Time | 32 Mbit | 75 |  |  |  | ns | 1,2 |
|  |  |  | 64 Mbit | 75 |  |  |  |  | 1,2 |
|  |  |  | 128 Mbit | 75 |  |  |  |  | 1,2 |
| R2 | $\mathrm{t}_{\text {AVQV }}$ | Address to Output Delay | 32 Mbit |  | 75 |  |  | ns | 1,2 |
|  |  |  | 64 Mbit |  | 75 |  |  |  | 1,2 |
|  |  |  | 128 Mbit |  | 75 |  |  |  | 1,2 |
| R3 | telqv | CEx to Output Delay | 32 Mbit |  | 75 |  |  | ns | 1,2 |
|  |  |  | 64 Mbit |  | 75 |  |  |  | 1,2 |
|  |  |  | 128 Mbit |  | 75 |  |  |  | 1,2 |
| R4 | $\mathrm{t}_{\text {GLQV }}$ | OE\# to Non-Array Output Delay |  |  | 25 |  | 25 | ns | 1,2,4 |
| R5 | $\mathrm{t}_{\text {PHQV }}$ | RP\# High to Output Delay | 32 Mbit |  | 150 |  |  | ns | 1,2 |
|  |  |  | 64 Mbit |  | 180 |  |  |  | 1,2 |
|  |  |  | 128 Mbit |  | 210 |  |  |  | 1,2 |
| R6 | teLQx | CEx to Output in Low Z | All | 0 |  | 0 |  | ns | 1,2,5 |
| R7 | $\mathrm{t}_{\text {GLQX }}$ | OE\# to Output in Low Z |  | 0 |  | 0 |  | ns | 1,2,5 |
| R8 | tehQz | CEx High to Output in High Z |  |  | 25 |  | 25 | ns | 1,2,5 |
| R9 | $\mathrm{t}_{\text {GHQZ }}$ | OE\# High to Output in High Z |  |  | 15 |  | 15 | ns | 1,2,5 |
| R10 | $\mathrm{t}_{\mathrm{OH}}$ | Output Hold from Address, CEx, or OE\# Change, Whichever Occurs First |  | 0 |  | 0 |  | ns | 1,2,5 |
| R11 | $\begin{aligned} & \mathrm{t}_{\mathrm{ELFL}} \\ & \mathrm{t}_{\mathrm{ELFH}} \end{aligned}$ | CEx Low to BYTE\# High or Low |  |  | 10 |  | 10 | ns | 1,2,5 |
| R12 | $\begin{aligned} & \text { tFLQV/ } \\ & \mathrm{t}_{\text {FHQV }} \end{aligned}$ | BYTE\# to Output Delay |  |  | 1 |  | 1 | $\mu \mathrm{s}$ | 1,2 |
| R13 | tflaz | BYTE\# to Output in High Z |  |  | 1 |  | 1 | $\mu \mathrm{s}$ | 1,2,5 |
| R14 | $t_{\text {EHEL }}$ | CEx High to CEx Low |  | 0 |  | 0 |  | ns | 1,2,5 |
| R15 | $\mathrm{t}_{\text {APA }}$ | Page Address Access Time | All |  | 25 |  | 25 | ns | 5, 6 |

NOTES:
CEX low is defined as the first edge of CE0, CE1, or CE2 that enables the device. CEX high is defined at the first edge of CE0,
CE1, or CE2 that disables the device (see Table 15, "Chip Enable Truth Table" on page 33).

1. See AC Input/Output Reference Waveforms for the maximum allowable input slew rate.
2. OE\# may be delayed up to $t_{E L Q v}{ }^{-t} \mathrm{t}_{\mathrm{GLQV}}$ after the first edge of CE0, CE1, or CE2 that enables the device (see Table 15, "Chip Enable Truth Table" on page 33) without impact on $t_{E L Q V}$.
3. See Figure 13, "AC Input/Output Reference Waveform" on page 32 and Figure 14, "Transient Equivalent Testing Load Circuit" on page 32 for testing characteristics
4. Sampled, not $100 \%$ tested.
5. For devices configured to standard word/byte read mode, R15 ( $\mathrm{t}_{\text {APA }}$ ) will equal R2 ( $\mathrm{t}_{\text {AVQV }}$ ).

Figure 7. Single Word Asynchronous Read Waveform


NOTES:

1. $C E_{X}$ low is defined as the last edge of CEO, CE1, or CE2 that enables the device. $C E_{x}$ high is defined at the first edge of CEO, CE1, or CE2 that disables the device (see Table 15, "Chip Enable Truth Table" on page 33).
2. When reading the flash array a faster $\mathrm{t}_{\mathrm{GL} \mathrm{qv}}(\mathrm{R} 16)$ applies. For non-array reads, R 4 applies (i.e., Status Register reads, query reads, or device identifier reads).

Figure 8. 4-Word Asynchronous Page Mode Read Waveform


NOTE: $C E_{X}$ low is defined as the last edge of CE0, CE1, or CE2 that enables the device. $C E_{X}$ high is defined at the first edge of CE0, CE1, or CE2 that disables the device (see Table 15, "Chip Enable Truth Table" on page 33).

Figure 9. 8-Word Asynchronous Page Mode Read


NOTES:

1. $C E_{X}$ low is defined as the last edge of CE0, CE1, or CE2 that enables the device. $C E_{X}$ high is defined at the first edge of CE0, CE1, or CE2 that disables the device (see Table 15, "Chip Enable Truth Table" on page 33).
2. In this diagram, BYTE\# is asserted high

### 7.2 Write Specifications

Table 11. Write Operations

| \# | Symbol | Parameter | Density | Valid for All Speeds |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min | Max |  |  |
| W1 | $\mathrm{t}_{\text {PHWL }}\left(\mathrm{t}_{\text {PHEL }}\right)$ | RP\# High Recovery to WE\# ( $\mathrm{CE}_{\mathrm{X}}$ ) Going Low | 32 Mbit | 150 |  | ns | 1,2,3 |
|  |  |  | 64 Mbit | 180 |  |  |  |
|  |  |  | 128 Mbit | 210 |  |  |  |
| W2 | $\mathrm{t}_{\text {ELWL }}\left(\mathrm{t}_{\text {WLEL }}\right)$ | $\mathrm{CE}_{\mathrm{X}}$ (WE\#) Low to WE\# ( $\mathrm{CE}_{\mathrm{X}}$ ) Going Low | All | 0 |  |  | 1,2,4 |
| W3 | twp | Write Pulse Width |  | 60 |  |  | 1,2,4 |
| W4 | $\mathrm{t}_{\text {DVWH }}\left(\mathrm{t}_{\text {DVEH }}\right)$ | Data Setup to WE\# ( $\mathrm{CE}_{\mathrm{X}}$ ) Going High |  | 50 |  |  | 1,2,5 |
| W5 | $\mathrm{t}_{\text {AVWH }}\left(\mathrm{t}_{\text {AVEH }}\right)$ | Address Setup to WE\# ( $\mathrm{CE}_{\mathrm{X}}$ ) Going High |  | 55 |  |  | 1,2,5 |
| W6 | $\mathrm{t}_{\text {WHEH }}\left(\mathrm{t}_{\text {EHWH }}\right)$ | CE ${ }_{\text {X }}$ (WE\#) Hold from WE\# ( $C E_{X}$ ) High |  | 0 |  |  | 1,2, |
| W7 | $\mathrm{t}_{\text {Whbx }}\left(\mathrm{t}_{\text {EHDX }}\right)$ | Data Hold from WE\# (CEx) High |  | 0 |  |  | 1,2, |
| W8 | $\mathrm{t}_{\text {whax }}\left(\mathrm{t}_{\text {EHAX }}\right)$ | Address Hold from WE\# ( $\mathrm{CE}_{\mathrm{X}}$ ) High |  | 0 |  |  | 1,2, |
| W9 | $\mathrm{t}_{\text {WP }}$ | Write Pulse Width High |  | 30 |  |  | 1,2,6 |
| W11 | $\mathrm{t}_{\text {VPWH }}\left(\mathrm{t}_{\text {vPE }}\right)$ | $\mathrm{V}_{\text {PEN }}$ Setup to WE\# ( $C E_{\text {X }}$ ) Going High |  | 0 |  |  | 1,2,3 |
| W12 | $\mathrm{t}_{\text {WHGL }}\left(\mathrm{t}_{\text {EHGL }}\right)$ | Write Recovery before Read |  | 35 |  |  | 1,2,7 |
| W13 | $\mathrm{t}_{\text {WhrL }}\left(\mathrm{t}_{\text {EHRL }}\right)$ | WE\# (CE ${ }_{\text {X }}$ ) High to STS Going Low |  |  | 500 |  | 1,2,8 |
| W15 | $\mathrm{t}_{\text {QVVL }}$ | $\mathrm{V}_{\text {PEN }}$ Hold from Valid SRD, STS Going High |  | 0 |  |  | 1,2,3,8,9 |

NOTES:
CE $X$ low is defined as the first edge of CE0, CE1, or CE2 that enables the device. CE ${ }_{X}$ high is defined at the first edge of CE0, CE1, or CE2 that disables the device (see Table 15, "Chip Enable Truth Table" on page 33)

1. Read timing characteristics during block erase, program, and lock-bit configuration operations are the same as during read-only operations. Refer to AC Characteristics-Read-Only Operations.
2. A write operation can be initiated and terminated with either $\mathrm{CE}_{X}$ or WE\#.
3. Sampled, not $100 \%$ tested.
4. Write pulse width ( $t_{W P}$ ) is defined from $C E_{X}$ or WE\# going low (whichever goes low last) to $C E_{X}$ or WE\# going high (whichever goes high first). Hence, $t_{W P}=t_{W L W H}=t_{E L E H}=t_{W L E H}=t_{E L W H}$.
5. Refer to Table 16, "Enhanced Configuration Register" on page 35 for valid $A_{I N}$ and $D_{I N}$ for block erase, program, or lock-bit configuration.
6. Write pulse width high ( $t_{W P H}$ ) is defined from $\mathrm{CE}_{X}$ or WE\# going high (whichever goes high first) to $\mathrm{CE}_{\mathrm{X}}$ or WE\# going low (whichever goes low first). Hence, $t_{W P H}=t_{W H W L}=t_{E H E L}=t_{W H E L}=t_{E H W L}$
7. For array access, $\mathrm{t}_{\mathrm{AVQV}}$ is required in addition to $\mathrm{t}_{\mathrm{WHGL}}$ for any accesses after a write.
8. STS timings are based on STS configured in its RY/BY\# default mode.
9. $\mathrm{V}_{\text {PEN }}$ should be held at $\mathrm{V}_{\text {PENH }}$ until determination of block erase, program, or lock-bit configuration success (SR[1,3,4,5] = 0).

Figure 10. Asynchronous Write Waveform


Figure 11. Asynchronous Write to Read Waveform


### 7.3 Program, Erase, Block-Lock Specifications

Table 12. Configuration Performance

| \# | Symbol | Parameter | Typ | Max ${ }^{(8)}$ | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W16 |  | Write Buffer Byte Program Time <br> (Time to Program 32 bytes/16 words) | 128 | 654 | $\mu \mathrm{s}$ | 1,2,3,4,5,6,7 |
| W16 | twhovs $\mathrm{t}_{\text {EHQV }}$ | Byte Program Time (Using Word/Byte Program Command) | 40 | 175 | $\mu \mathrm{s}$ | 1,2,3,4 |
|  |  | Block Program Time (Using Write to Buffer Command) | 0.53 | 2.4 | sec | 1,2,3,4 |
| W16 | $t_{\text {WHQV4 }}$ teHQV4 | Block Erase Time | 1.0 | 4.0 | sec | 1,2,3,4 |
| W16 | $t_{\text {WHQV5 }}$ $t_{\text {EHQV5 }}$ | Set Lock-Bit Time | 50 | 60 | $\mu \mathrm{s}$ | 1,2,3,4,9 |
| W16 | $t_{\text {WHQV6 }}$ $t_{\text {EHQV6 }}$ | Clear Block Lock-Bits Time | 0.5 | 0.70 | sec | 1,2,3,4,9 |
| W16 | $t_{\text {WHRH }} 1$ <br> $\mathrm{t}_{\text {EHRH1 }}$ | Program Suspend Latency Time to Read | 15 | 20 | $\mu \mathrm{s}$ | 1,2,3,9 |
| W16 | $t_{\text {WHRH }}$ <br> tehri | Erase Suspend Latency Time to Read | 15 | 20 | $\mu \mathrm{s}$ | 1,2,3,9 |
| WY | ${ }_{\text {t }}^{\text {STS }}$ | STS Pulse Width Low Time | 500 |  | ns | 1 |
| WX | twhwh | Resume Latency to Program/Erase | 475 |  | $\mu \mathrm{s}$ | 1, 10 |

NOTES:

1. Typical values measured at $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and nominal voltages. Assumes corresponding lock-bits are not set. Subject to change based on device characterization.
2. These performance numbers are valid for all speed versions.
3. Sampled but not $100 \%$ tested.
4. Excludes system-level overhead.
5. These values are valid when the buffer is full, and the start address is aligned on a 32 -byte boundary.
6. Effective per-byte program time ( $\left.\mathrm{t}_{\mathrm{WHQV}}^{1}{ }_{1}, \mathrm{t}_{\mathrm{EHQV}}^{1} 1\right)$ is $4 \mu \mathrm{~s} /$ byte (typical).
7. Effective per-word program time ( $\mathrm{t}_{\mathrm{WHQV}}$, $\mathrm{t}_{\mathrm{EHQV} 2}$ ) is $8 \mu \mathrm{~s} /$ word (typical).
8. Max values are measured at worst case temperature, data pattern and $\mathrm{V}_{\mathrm{CC}}$ corner after 100 k cycles (except as noted).
9. Max values are expressed at $25^{\circ} \mathrm{C} /-40^{\circ} \mathrm{C}$.
10.WX is the minimum time from Erase Resume to an Erase Suspend state. Repeatedly suspending the device more often may have undetermined effects.

### 7.4 Reset Specifications

Figure 12. AC Waveform for Reset Operation


NOTE: STS is shown in its default mode (RY/BY\#)

Table 13. Reset Specifications

| \# | Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| P1 | $t_{\text {PLPH }}$ | RP\# Pulse Low Time (If RP\# is tied to $\mathrm{V}_{\mathrm{CC}}$, this specification is not applicable) | 25 |  | $\mu \mathrm{s}$ | 1,2 |
| P2 | $\mathrm{t}_{\text {PHRH }}$ | RP\# High to Reset during Block Erase, Program, or Lock-Bit Configuration |  | 100 | ns | 1,3 |
| P3 | $\mathrm{t}_{\mathrm{VCCPH}}$ | Vcc Power Valid to RP\# de-assertion (high) | 60 |  | $\mu \mathrm{s}$ |  |

## NOTES:

1. These specifications are valid for all product versions (packages and speeds).
2. If RP\# is asserted while a block erase, program, or lock-bit configuration operation is not executing then the minimum required RP\# Pulse Low Time is 100 ns .
3. A reset time, $\mathrm{t}_{\text {PHQV, }}$, is required from the latter of STS (in RY/BY\# mode) or RP\# going high until outputs are valid.

### 7.5 AC Test Conditions

Figure 13. AC Input/Output Reference Waveform


NOTE: AC test inputs are driven at $\mathrm{V}_{\mathrm{CCQ}}$ for a Logic "1" and 0.0 V for a Logic " 0.0 " Input timing begins, and output timing ends, at $\mathrm{V}_{\mathrm{CCQ}} / 2 \mathrm{~V}\left(50 \%\right.$ of $\left.\mathrm{V}_{\mathrm{CCQ}}\right)$. Input rise and fall times $(10 \%$ to $90 \%)<5 \mathrm{~ns}$.

Figure 14. Transient Equivalent Testing Load Circuit


NOTE: $\mathrm{C}_{\mathrm{L}}$ Includes Jig Capacitance

| Test Configuration | $\mathrm{C}_{\mathrm{L}}(\mathbf{p F})$ |
| :---: | :---: |
| $\mathrm{V}_{\mathrm{CCQ}}=\mathrm{V}_{\mathrm{CCQMIN}}$ | 30 |

### 8.0 Bus Interface

This section provides an overview of Bus operations. Basically, there are three operations you can do with flash memory: Read, Program (Write), and Erase.The on-chip Write State Machine (WSM) manages all erase and program algorithms. The system CPU provides control of all in-system read, write, and erase operations through the system bus. All bus cycles to or from the flash memory conform to standard microprocessor bus cycles. Table 14 summarizes the necessary states of each control signal for different modes of operations.

Table 14. Bus Operations

| Mode | RP\# | CE $_{\mathrm{x}}{ }^{(1)}$ | OE\# $^{(2)}$ | WE\# $^{(2)}$ | $\mathbf{V}_{\text {PEN }}$ | $\mathbf{D Q}_{15: 0^{(3)}}$ | STS <br> (Default Mode) | Notes |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Async., Status, Query and Identifier Reads | $\mathrm{V}_{\mathrm{IH}}$ | Enabled | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | X | $\mathrm{D}_{\mathrm{OUT}}$ | High Z | 4,6 |
| Output Disable | $\mathrm{V}_{\mathrm{IH}}$ | Enabled | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | X | High Z | High Z |  |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | Disabled | X | X | X | High Z | High Z |  |
| Reset/Power-down | $\mathrm{V}_{\mathrm{IL}}$ | X | X | X | X | High Z | High Z |  |
| Command Writes | $\mathrm{V}_{\mathrm{IH}}$ | Enabled | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | X | $\mathrm{D}_{\mathrm{IN}}$ | High Z | 6,7 |
| Array Writes ${ }^{(8)}$ | $\mathrm{V}_{\mathrm{IH}}$ | Enabled | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{PENH}}$ | X | $\mathrm{V}_{\mathrm{IL}}$ | 8,5 |

NOTES:

1. See Table 15 for valid $C E_{\mathrm{x}}$ Configurations.
2. OE\# and WE\# should never be asserted simultaneously. If done so, OE\# overrides WE\#.
3. DQ refers to DQ[7:0\} when BYTE\# is low and DQ[15:0] if BYTE\# is high.
4. Refer to DC characteristics. When $V_{\text {PEN }} \leq \mathrm{V}_{\text {PENLK }}$, memory contents can be read but not altered.
5. $X$ should be $V_{I L}$ or $V_{I H}$ for the control pins and $V_{\text {PENLK }}$ or $V_{\text {PENH }}$ for $V_{\text {PEN }}$. For outputs, $X$ should be $V_{\text {OL }}$ or $V_{\text {OH- }}$
6. In default mode, STS is $V_{\text {OL }}$ when the WSM is executing internal block erase, program, or a lock-bit configuration algorithm. It is $\mathrm{V}_{\mathrm{OH}}$ (pulled up by an external pull up resistance $\sim=10 \mathrm{k}$ ) when the WSM is not busy, in block erase suspend mode (with programming inactive), program suspend mode, or reset powerdown mode.
7. See Table 18, "Command Bus Operations for J3 v. D" on page 37 for valid DIN (user commands) during a Write operation
8. Array writes are either program or erase operations. /

Table 15. Chip Enable Truth Table

| CE2 | CE1 | CE0 | DEVICE |
| :--- | :--- | :--- | :--- |
| $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | Enabled |
| $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | Disabled |
| $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | Disabled |
| $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | Disabled |
| $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | Enabled |
| $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | Enabled |
| $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{HH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | Enabled |
| $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | Disabled |

NOTE: For single-chip applications, CE2 and CE1 can be connected to GND.
The next few sections detail each of the basic flash operations and some of the advanced features available on flash memory.

### 8.1 Bus Reads

Reading from flash memory outputs stored information to the processor or chipset, and does not change any contents. Reading can be performed an unlimited number of times. Besides array data, other types of data such as device information and device status is available from the flash.

To perform a bus read operation, CEx (refer to Table 15 on page 33) and OE\# must be asserted. CEx is the device-select control; when active, it enables the flash memory device. OE\# is the dataoutput control; when active, the addressed flash memory data is driven onto the I/O bus. For all read states, WE\# and RP\# must be de-asserted. See Section 9.2, "Read Operations" on page 39.

### 8.1.1 Asynchronous Page Mode Read

There are two Asynchronous Page mode configurations available on J3 v. D, depending on the system design requirements:

- Four-Word Page mode: This is the default mode on power-up or reset. Array data can be sensed up to four words (8 Bytes) at a time.
- Eight-Word Page mode: Array data can be sensed up to eight words (16 Bytes) at a time. This mode must be enabled on power-up or reset by using the command sequence described in Table 18 on page 37. Address bits A[3:1] determine which word is output during a read operation, and $\mathrm{A}[3: 0]$ determine which byte is output for a x 8 bus width.

After the initial access delay, the first word out of the page buffer corresponds to the initial address. In Four-Word Page mode, address bits A[2:1] determine which word is output from the page buffer for a x 16 bus width, and $\mathrm{A}[2: 0]$ determine which byte is output from the page buffer for a x 8 bus width. Subsequent reads from the device come from the page buffer. These reads are output on $\mathrm{D}[15: 0]$ for a x 16 bus width and $\mathrm{D}[7: 0]$ for a x 8 bus width after a minimum delay as long as $\mathrm{A}[2: 0]$ (Four-Word Page mode) or A[3:0] (Eight-Word Page mode).

Data can be read from the page buffer multiple times, and in any order. In Four-Word Page mode, if address bits A[MAX:3] (A[MAX:4] for Eight-Word Page Mode) change at any time, or if CE\# is toggled, the device will sense and load new data into the page buffer. Asynchronous Page mode is the default read mode on power-up or reset.

To perform a Page mode read after any other operation, the Read Array command must be issued to read from the flash array. Asynchronous Page mode reads are permitted in all blocks and are used to access register information. During register access, only one word is loaded into the page buffer.

### 8.1.1.1 Enhanced Configuration Register (ECR)

The Enhanced Configuration Register (ECR) is a volatile storage register that when addressed by the Set Enhanced Configuration Register command can select between Four-Word Page mode and Eight-Word Page mode. The ECR is volatile; all bits will be reset to default values when RP\# is deasserted or power is removed from the device. To modify ECR settings, use the Set Enhanced Configuration Register command. The Set Enhanced Configuration Register command is written along with the configuration register value, which is placed on the lower 16 bits of the address bus $\mathrm{A}[15: 0]$. This is followed by a second write that confirms the operation and again presents the Enhanced Configuration Register data on the address bus. After executing this command, the device returns to Read Array mode.

The ECR is shown in Table 16. 8-word page mode Command Bus-Cycle is captured in Table 17.

Note: For forward compatibility reasons, if the 8-word Asynchronous Page mode is used on J3 v. D, a Clear Status Register command must be executed after issuing the Set Enhanced Configuration Register command. See Table 17 for further details.

Table 16. Enhanced Configuration Register

| Reserved |  | Page | Reserved |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{\|c} \text { ECR } \\ 15 \end{array}$ | $\begin{gathered} \text { ECR } \\ 14 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 13 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 12 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 11 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 10 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 9 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 8 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 7 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 6 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 5 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 4 \end{gathered}$ | $\begin{gathered} \mathrm{ECR} \\ 3 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 2 \end{gathered}$ | $\begin{gathered} \text { ECR } \\ 1 \end{gathered}$ | $\begin{gathered} \mathrm{ECR} \\ 0 \end{gathered}$ |
| BITS |  | DESCRIPTION |  |  |  |  |  |  |  | NOTES |  |  |  |  |  |
| ECR[15:14] |  | RFU |  |  |  |  |  |  |  | All bits should be set to 0 . |  |  |  |  |  |
| ECR[13] |  | - "1" = 8 Word Page mode <br> - " 0 " $=4$ Word Page mode |  |  |  |  |  |  |  |  |  |  |  |  |  |
| ECR[12:0] |  | RFU |  |  |  |  |  |  |  | All bits should be set to 0 . |  |  |  |  |  |

Table 17. J3 v. D Asynchronous 8-Word Page Mode Command Bus-Cycle Definition

| Command | Bus <br> Cycles <br> Required | First Bus Cycle |  |  | Second Bus Cycle |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Addr $^{(1)}$ | Data | Oper | Addr $^{(1)}$ | Data |  |
| Set Enhanced Configuration <br> Register (Set ECR) |  | Write | ECD | 0060 h | Write | ECD | 0004 h |

1. $\mathrm{X}=$ Any valid address within the device. $\mathrm{ECD}=$ Enhanced Configuration Register Data

### 8.1.2 Output Disable

With CEx asserted, and OE\# at a logic-high level $\left(\mathrm{V}_{\mathrm{IH}}\right)$, the device outputs are disabled. Output signals $\mathrm{D}[15: 0]$ are placed in a high-impedance state.

### 8.2 Bus Writes

Writing or Programming to the device, is where the host writes information or data into the flash device for non-volatile storage. When the flash device is programmed, 'ones' are changed to 'zeros'. 'Zeros' cannot be programed back to 'ones'. To do so, an erase operation must be performed. Writing commands to the Command User Interface (CUI) enables various modes of operation, including the following:

- Reading of array data
- Common Flash Interface (CFI) data
- Identifier codes, inspection, and clearing of the Status Register
- Block Erasure, Program, and Lock-bit Configuration (when $\mathrm{V}_{\text {PEN }}=\mathrm{V}_{\mathrm{PENH}}$ )

Erasing is performed on a block basis - all flash cells within a block are erased together. Any information or data previously stored in the block will be lost. Erasing is typically done prior to programming. The Block Erase command requires appropriate command data and an address within the block to be erased. The Byte/Word Program command requires the command and
address of the location to be written. Set Block Lock-Bit commands require the command and block within the device to be locked. The Clear Block Lock-Bits command requires the command and address within the device to be cleared.

The CUI does not occupy an addressable memory location. It is written when the device is enabled and WE\# is active. The address and data needed to execute a command are latched on the rising edge of WE\# or the first edge of CE0, CE1, or CE2 that disables the device (see Table 15 on page 33). Standard microprocessor write timings are used.

### 8.3 Standby

CE0, CE1, and CE2 can disable the device (see Table 15 on page 33 ) and place it in standby mode. This manipulation of CEx substantially reduces device power consumption. D[15:0] outputs are placed in a high-impedance state independent of OE\#. If deselected during block erase, program, or lock-bit configuration, the WSM continues functioning, and consuming active power until the operation completes.

### 8.3.1 Reset/Power-Down

RP\# at $\mathrm{V}_{\text {IL }}$ initiates the reset/power-down mode.
In read modes, RP\#-low deselects the memory, places output drivers in a high-impedance state, and turns off numerous internal circuits. RP\# must be held low for a minimum of $t_{P L P H}$. Time $t_{P H Q V}$ is required after return from reset mode until initial memory access outputs are valid. After this wakeup interval, normal operation is restored. The CUI is reset to read array mode and Status Register is set to 0080h.

During Block Erase, Program, or Lock-Bit Configuration modes, RP\#-low will abort the operation. In default mode, STS transitions low and remains low for a maximum time of $\mathrm{t}_{\text {PLPH }}+\mathrm{t}_{\text {PHRH }}$ until the reset operation is complete. Memory contents being altered are no longer valid; the data may be partially corrupted after a program or partially altered after an erase or lock-bit configuration. Time $\mathrm{t}_{\text {PHWL }}$ is required after RP\# goes to logic-high $\left(\mathrm{V}_{\mathrm{IH}}\right)$ before another command can be written.

As with any automated device, it is important to assert RP\# during system reset. When the system comes out of reset, it expects to read from the flash memory. Automated flash memories provide status information when accessed during Block Erase, Program, or Lock-Bit Configuration modes. If a CPU reset occurs with no flash memory reset, proper initialization may not occur because the flash memory may be providing status information instead of array data. Intel ${ }^{\circledR}$ Flash memories allow proper initialization following a system reset through the use of the RP\# input. In this application, RP\# is controlled by the same RESET\# signal that resets the system CPU.

### 8.4 Device Commands

When the $\mathrm{V}_{\text {PEN }}$ voltage $\leq \mathrm{V}_{\text {PENLK }}$, only read operations from the Status Register, CFI, identifier codes, or blocks are enabled. Placing $\mathrm{V}_{\mathrm{PENH}}$ on $\mathrm{V}_{\text {PEN }}$ additionally enables block erase, program, and lock-bit configuration operations. Device operations are selected by writing specific commands to the Command User Interface (CUI). The CUI does not occupy an addressable memory location. It is the mechanism through which the flash device is controlled.

A command sequence is issued in two consecutive write cycles - a Setup command followed by a Confirm command. However, some commands are single-cycle commands consisting of a setup command only. Generally, commands that alter the contents of the flash device, such as Program or Erase, require at least two write cycles to guard against inadvertent changes to the flash device. Flash commands fall into two categories: Basic Commands and Extended Commands. Basic commands are recognized by all Intel ${ }^{\circledR}$ Flash devices, and are used to perform common flash operations such as selecting the read mode, programming the array, or erasing blocks. Extended commands are product-dependant; they are used to perform additional features such as software block locking. Table 18 describes all applicable commands on Intel® Embedded Flash Memory (J3 v. D).

Table 18. Command Bus Operations for J3 v. D

| Command |  | Setup Write Cycle |  | Confirm Write Cycle |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Address Bus | Data Bus | Address Bus | Data Bus |
|  | Program Enhanced Configuration Register | Register Data | 0060h | Register Data | 0004h |
|  | Program OTP Register | Device Address | 00COh | Register Offset | Register Data |
|  | Clear Status Register | Device Address | 0050h | --- | --- |
|  | Program STS Configuration Register | Device Address | 00BS8h | Device Address | Register Data |
|  | Read Array | Device Address | 00FFh | --- | --- |
|  | Read Status Register | Device Address | 0070h | --- | --- |
|  | Read Identifier Codes (Read Device Information) | Device Address | 0090h | --- | --- |
|  | CFI Query | Device Address | 0098h | --- | --- |
|  | Word/Byte Program | Device Address | $\begin{aligned} & \text { 0040h/ } \\ & 0010 \mathrm{~h} \end{aligned}$ | Device Address | Array Data |
|  | Buffered Program | Word Address | 00E8h | Device Address | 00DOh |
|  | Block Erase | Device Address | 0020h | Block Address | 00DOh |
|  | Program/Erase Suspend | Device Address | 00BOh | --- | --- |
|  | Program/Erase Resume | Device Address | 00DOh | --- | --- |
|  | Lock Block | Block Address | 0060h | Block Address | 0001h |
|  | Unlock Block | Block Address | 0060h | Block Address | 00DOh |

### 9.0 Flash Operations

This section describes the operational features of flash memory. Operations are command-based, wherein command codes are first issued to the device, then the device performs the desired operation. All command codes are issued to the device using bus-write cycles (see Chapter 8.0, "Bus Interface"). A complete list of available command codes can be found in Appendix A, "Device Command Codes".

### 9.1 Status Register

The Status Register (SR) is an 8-bit, read-only register that indicates device status and operation errors. To read the Status Register, issue the Read Status Register command. Subsequent reads output Status Register information on $\mathrm{DQ}[7: 0]$, and 00 h on $\mathrm{DQ}[15: 8]$.

SR status bits are set and cleared by the device. SR error bits are set by the device, but must be cleared using the Clear Status Register command. Upon power-up or exit from reset, the Status Register defaults to 80h. Page-mode reads are not supported in this read mode. Status Register contents are latched on the falling edge of OE\# or the first edge of CEx that enables the device. OE\# must toggle to $\mathrm{V}_{\mathrm{IH}}$ or the device must be disabled before further reads to update the Status Register latch. The Read Status Register command functions independently of $\mathrm{V}_{\text {PEN }}$ voltage. Table 19 shows Status Register bit definitions.

Table 19. Status Register Bit Definitions

| Status Register (SR) |  |  |  |  |  | Default Value $=80 \mathrm{~h}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Ready Status | Erase Suspend Status | Erase Error | Program Error | Program /Erase Voltage Error | Program Suspend Status | Block- <br> Locked Error | Reserved |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Bit | Name |  | Description |  |  |  |  |
| 7 | Ready Status |  | $0=$ Device is busy; SR[6:0] are invalid (Not driven); <br> 1 = Device is ready; SR[6:0] are valid. |  |  |  |  |
| 6 | Erase Suspend Status |  | $0=$ Erase suspend not in effect. <br> 1 = Erase suspend in effect. |  |  |  |  |
| 5 | Erase Error | Command Sequence Error | $\begin{array}{rl} \frac{\text { SR5 }}{0} & \frac{\text { SR4 }}{0} \\ =\text { Program or erase operation successful. } \\ 0 & 1 \\ 1 & =\text { Program error }- \text { operation aborted. } \\ 1 & 0 \\ =\text { Erase error }- \text { operation aborted. } \\ 1 & 1 \end{array}$ |  |  |  |  |
| 4 | Program Error |  |  |  |  |  |  |
| 3 | $V_{\text {PEN }}$ Error |  | $0=\mathrm{V}_{\text {PEN }}$ within acceptable limits during program or erase operation. <br> $1=\mathrm{V}_{\text {PEN }}$ not within acceptable limits during program or erase operation. Operation aborted. |  |  |  |  |
| 2 | Program Suspend Status |  | $0=$ Program suspend not in effect. <br> 1 = Program suspend in effect. |  |  |  |  |
| 1 | Block-Locked Error |  | 0 = Block NOT locked during program or erase - operation successful. <br> 1 = Block locked during program or erase - operation aborted. |  |  |  |  |
| 0 | Reserved |  | Not used - Reserved for future use. |  |  |  |  |

### 9.1.1 Clearing the Status Register

The Status Register (SR) contain status and error bits which are set by the device. SR status bits are cleared by the device, however SR error bits are cleared by issuing the Clear Status Register command (see Table 20). Resetting the device also clears the Status Register.

Table 20. Clear Status Register Command Bus-Cycle

| Command | Setup Write Cycle |  | Confirm Write Cycle |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Address Bus | Data Bus | Address Bus | Data Bus |
| Clear Status Register | Device Address | 0050 h | --- | --- |

Issuing the Clear Status Register command places the device in Read Status Register mode.
Note: Care should be taken to avoid Status Register ambiguity. If a command sequence error occurs while in an Erase Suspend condition, the Status Register will indicate a Command Sequence error by setting SR4 and SR5. When the erase operation is resumed (and finishes), any errors that may have occurred during the erase operation will be masked by the Command Sequence error. To avoid this situation, clear the Status Register prior to resuming a suspended erase operation. The Clear Status Register command functions independent of the voltage level on VPEN.

### 9.2 Read Operations

Four types of data can be read from the device: array data, device information, CFI data, and device status. Upon power-up or return from reset, the device defaults to Read Array mode. To change the device's read mode, the appropriate command must be issued to the device. Table 21 shows the command codes used to configure the device for the desired read mode. The following sections describe each read mode.

Table 21. Read Mode Command Bus-Cycles

| Command | Setup Write Cycle |  | Confirm Write Cycle |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Address Bus | Data Bus | Address Bus | Data Bus |
| Read Array | Device Address | $00 F F h$ | --- | --- |
| Read Status Register | Device Address | 0070 h | --- | --- |
| Read Device Information | Device Address | 0090 h | --- | --- |
| CFI Query | Device Address | 0098 h | --- | --- |

### 9.2.1 Read Array

Upon power-up or return from reset, the device defaults to Read Array mode. Issuing the Read Array command places the device in Read Array mode. Subsequent reads output array data on $\mathrm{DQ}[15: 0]$. The device remains in Read Array mode until a different read command is issued, or a program or erase operation is performed, in which case, the read mode is automatically changed to Read Status.

To change the device to Read Array mode while it is programming or erasing, first issue the Suspend command. After the operation has been suspended, issue the Read Array command. When the program or erase operation is subsequently resumed, the device will automatically revert back to Read Status mode.

Note: Issuing the Read Array command to the device while it is actively programming or erasing causes subsequent reads from the device to output invalid data. Valid array data is output only after the program or erase operation has finished.

The Read Array command functions independent of the voltage level on VPEN.

### 9.2.2 Read Status Register

Issuing the Read Status Register command places the device in Read Status Register mode. Subsequent reads output Status Register information on DQ[7:0], and 00h on DQ[15:8]. The device remains in Read Status Register mode until a different read-mode command is issued. Performing a program, erase, or block-lock operation also changes the device's read mode to Read Status Register mode.

The Status Register is updated on the falling edge of CE\#, or OE\# when CE\# is low. Status Register contents are valid only when SR7 $=1$. When WSM us active, SR7 indicates the WSM's state and SR[6:0] are in hig-Z state.

The Read Status Register command functions independent of the voltage level on VPEN.

### 9.2.3 Read Device Information

Issuing the Read Device Information command places the device in Read Device Information mode. Subsequent reads output device information on DQ [15:0] (see Table 22).

Table 22. Device Information Summary

| Device Information | Word Address | DQ[15:0] |
| :--- | :--- | :--- |
| Device Manufacturer Code (Intel) | Device Base Address + 00h | 0089h |
| Device ID Code | Device Base Address + 01h | (See Appendix B, "J3 v. D ID Codes") |
| Block Lock Status | Block Base Address + 02h | DQ0 = 0 Unlocked <br> DQ0 $=1$ Locked <br> DQ[15:1] = RFU |
| OTP Lock Register | Device Base Address + 80h | Lock Register 0 Data |
| OTP Register - Factory Segment | Device Base Address + 81h to 84h | Factory-Programmed Data |
| OTP Register - User-Programmable Segment | Device Base Address + 85h to 88h | User Data |

The device remains in Read Device Information mode until a different read command is issued. Also, performing a program, erase, or block-lock operation changes the device to Read Status Register mode.

The Read Device Information command functions independent of the voltage level on VPEN.

### 9.2.4 CFI Query

The query table contains an assortment of flash product information such as block size, density, allowable command sets, electrical specifications, and other product information. The data contained in this table conforms to the Common Flash Interface (CFI) protocol.

Issuing the CFI Query command places the device in CFI Query mode. Subsequent reads output CFI information on DQ[15:0] (see Appendix D, "Common Flash Interface").

The device remains in CFI Query mode until a different read command is issued, or a program or erase operation is performed, which changes the read mode to Read Status Register mode.

The CFI Query command functions independent of the voltage level on VPEN.

### 9.3 Programming Operations

Programming the flash array changes 'ones' to 'zeros'. To change zeros to ones, an erase operation must be performed (see Section 9.4, "Block Erase Operations"). Only one programming operation can occur at a time. Programming is permitted during an erase suspend.

Information is programmed into the flash array by issuing the appropriate command. J3 v. D supports two different programming methods: Byte/Word and Write-to-Buffer. Table 24 shows the two-cycle command sequences used for each method.

Table 24. Program Command Bus-Cycles

| Command |  | Setup Write Cycle |  | Confirm Write Cycle |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Data Bus | Address Bus | Data Bus |  |
| Single-Word/Byte Program | Device Address | $0040 \mathrm{~h} / 0010 \mathrm{~h}$ | Device Address | Array Data |  |
| Buffered Program | Device Address | 00 E 8 h | Device Address | 00DOh |  |

Note: All programming operations require the addressed block to be unlocked, and a valid VPEN voltage applied throughout the programming operation. Otherwise, the programming operation will abort, setting the appropriate Status Register error bit(s).

The following sections describe each programming method.

### 9.3.1 Single-Word/Byte Programming

Array programming is performed by first issuing the Single-Word/Byte Program command. This is followed by writing the desired data at the desired array address. The read mode of the device is automatically changed to Read Status Register mode, which remains in effect until another readmode command is issued.

During programming, STS and the Status Register indicate a busy status (SR7 = 0). Upon completion, STS and the Status Register indicate a ready status (SR7 = 1). The Status Register should be checked for any errors (SR4), then cleared.

Note: Issuing the Read Array command to the device while it is actively programming causes subsequent reads from the device to output invalid data. Valid array data is output only after the program operation has finished.

Standby power levels are not be realized until the programming operation has finished. Also, asserting RP\# aborts the programming operation, and array contents at the addressed location are indeterminate. The addressed block should be erased, and the data re-programmed. If a SingleWord/Byte program is attempted when the corresponding block lock-bit is set, SR1 and SR4 will be set.

### 9.3.2 Buffered Programming

Buffered programming operations simultaneous program multiple words into the flash memory array, significantly reducing effective word-write times. User-data is first written to a write buffer, then programmed into the flash memory array in buffer-size increments. Appendix C, "Flow Charts" contains a flow chart of the buffered-programming operation.

Note: Optimal performance and power consumption is realized only by aligning the start address on 32word boundaries (i.e., $\mathrm{A}[4: 0]=0 \mathrm{~b} 00000$ ). Crossing a 32 -word boundary during a buffered programming operation can cause programming time to double.

To perform a buffered programming operation, first issue the Buffered Program setup command at the desired starting address. The read mode of the device/addressed partition is automatically changed to Read Status Register mode.

Polling SR7 determines write-buffer availability ( $0=$ not available, $1=$ available $)$. If the write buffer is not available, re-issue the setup command and check SR7; repeat until SR7 $=1$.

Next, issue the word count at the desired starting address. The word count represents the total number of words to be written into the write buffer, minus one. This value can range from 00h (one word) to a maximum of 1 Fh ( 32 words). Exceeding the allowable range causes an abort.

Following the word count, the write buffer is filled with user-data. Subsequent bus-write cycles provide addresses and data, up to the word count. All user-data addresses must lie between <starting address> and <starting address + word count>, otherwise the WSM continues to run as normal but, user may advertently change the content in unexpected address locations.

Note: User-data is programmed into the flash array at the address issued when filling the write buffer.
After all user-data is written into the write buffer, issue the confirm command. If a command other than the confirm command is issued to the device, a command sequence error occurs and the operation aborts.

After issuing the confirm command, write-buffer contents are programmed into the flash memory array. The Status Register indicates a busy status $(\mathrm{SR} 7=0)$ during array programming.

Note: Issuing the Read Array command to the device while it is actively programming or erasing causes subsequent reads from the device to output invalid data. Valid array data is output only after the program or erase operation has finished.

Upon completion of array programming, the Status Register indicates ready ( $\mathrm{SR} 7=1$ ). A full Status Register check should be performed to check for any programming errors, then cleared by using the Clear Status Register command.

Additional buffered programming operations can be initiated by issuing another setup command, and repeating the buffered programming bus-cycle sequence. However, any errors in the Status Register must first be cleared before another buffered programming operation can be initiated.

### 9.4 Block Erase Operations

Erasing a block changes 'zeros' to 'ones'. To change ones to zeros, a program operation must be performed (see Section 9.3, "Programming Operations"). Erasing is performed on a block basis an entire block is erased each time an erase command sequence is issued. Once a block is fully erased, all addressable locations within that block read as logical ones (FFFFh). Only one blockerase operation can occur at a time, and is not permitted during a program suspend.

To perform a block-erase operation, issue the Block Erase command sequence at the desired block address. Table 25 shows the two-cycle Block Erase command sequence.

Table 25. Block-Erase Command Bus-Cycle

| Command | Setup Write Cycle |  | Confirm Write Cycle |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Address Bus | Data Bus | Address Bus | Data Bus |
|  | Device Address | 0020 h | Block Address | 00D0h |

Note: A block-erase operation requires the addressed block to be unlocked, and a valid voltage applied to VPEN throughout the block-erase operation. Otherwise, the operation will abort, setting the appropriate Status Register error bit(s).

The Erase Confirm command latches the address of the block to be erased. The addressed block is preconditioned (programmed to all zeros), erased, and then verified. The read mode of the device is automatically changed to Read Status Register mode, and remains in effect until another read-mode command is issued.

During a block-erase operation, STS and the Status Register indicates a busy status ( $\mathrm{SR} 7=0$ ). Upon completion, STS and the Status Register indicates a ready status (SR7 = 1). The Status Register should be checked for any errors, then cleared. If any errors did occur, subsequent erase commands to the device are ignored unless the Status Register is cleared.

The only valid commands during a block erase operation are Read Array, Read Device Information, CFI Query, and Erase Suspend. After the block-erase operation has completed, any valid command can be issued.

Note: Issuing the Read Array command to the device while it is actively erasing causes subsequent reads from the device to output invalid data. Valid array data is output only after the block-erase operation has finished.

Standby power levels are not be realized until the block-erase operation has finished. Also, asserting RP\# aborts the block-erase operation, and array contents at the addressed location are indeterminate. The addressed block should be erased before programming within the block is attempted.

### 9.5 Suspend and Resume

An erase or programming operation can be suspended to perform other operations, and then subsequently resumed. Table 26 shows the Suspend and Resume command bus-cycles.

Note: All erase and programming operations require the addressed block to remain unlocked with a valid voltage applied to VPEN throughout the suspend operation. Otherwise, the block-erase or programming operation will abort, setting the appropriate Status Register error bit(s). Also, asserting RP\# aborts suspended block-erase and programming operations, rendering array contents at the addressed location(s) indeterminate.

Table 26. Suspend and Resume Command Bus-Cycles

| Command | Setup Write Cycle |  | Confirm Write Cycle |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Address Bus | Data Bus | Address Bus | Data Bus |
| Suspend | Device Address | $00 \mathrm{B0h}$ | --- | --- |
| Resume | Device Address | 00 D 0 h | --- | --- |

To suspend an on-going erase or program operation, issue the Suspend command to any device address. The program or erase operation suspends at pre-determined points during the operation after a delay of $\mathrm{t}_{\text {SUSP }}$ Suspend is achieved when STS (in RY/BY\# mode) goes high, SR[7,6] = 1 (erase-suspend) or $\operatorname{SR}[7,2]=1$ (program-suspend).

Note: Issuing the Suspend command does not change the read mode of the device. The device will be in Read Status Register mode from when the erase or program command was first issued, unless the read mode was changed prior to issuing the Suspend command.

Not all commands are allowed when the device is suspended. Table 27 shows which device commands are allowed during Program Suspend or Erase Suspend.

Table 27. Valid Commands During Suspend (Sheet 1 of 2)

| Device Command | Program Suspend | Erase Suspend |
| :--- | :---: | :---: |
| STS Configuration | Allowed | Allowed |
| Read Array | Allowed | Allowed |
| Read Status Register | Allowed | Allowed |
| Clear Status Register | Allowed | Allowed |
| Read Device Information | Allowed | Allowed |
| CFI Query | Allowed | Allowed |
| Word Program | Not Allowed | Allowed |
| Buffered Program | Not Allowed | Allowed |
| Block Erase | Not Allowed | Not Allowed |
| Program Suspend | Not Allowed | Allowed |
| Erase Suspend | Not Allowed | Not Allowed |
| Program/Erase Resume | Allowed | Allowed |

Table 27. Valid Commands During Suspend (Sheet 2 of 2)

| Device Command | Program Suspend | Erase Suspend |
| :--- | :---: | :---: |
| Lock Block | Not Allowed | Not Allowed |
| Unlock Block | Not Allowed | Not Allowed |
| Program OTP Register | Not Allowed | Not Allowed |

During Suspend, array-read operations are not allowed in blocks being erased or programmed.
A block-erase under program-suspend is not allowed. However, word-program under erasesuspend is allowed, and can be suspended. This results in a simultaneous erase-suspend/ programsuspend condition, indicated by $\operatorname{SR}[7,6,2]=1$.

To resume a suspended program or erase operation, issue the Resume command to any device address. The read mode of the device is automatically changed to Read Status Register. The operation continues where it left off, STS (in RY/BY\# mode) goes low, and the respective Status Register bits are cleared.

When the Resume command is issued during a simultaneous erase-suspend/ program-suspend condition, the programming operation is resumed first. Upon completion of the programming operation, the Status Register should be checked for any errors, and cleared. The resume command must be issued again to complete the erase operation. Upon completion of the erase operation, the Status Register should be checked for any errors, and cleared.

### 9.6 Status Signal (STS)

The STATUS (STS) signal can be configured to different states using the STS Configuration command. Once the STS signal has been configured, it remains in that configuration until another Configuration command is issued or RP\# is asserted low. Initially, the STS signal defaults to RY/ BY\# operation where RY/BY\# low indicates that the WSM is busy. RY/BY\# high indicates that the state machine is ready for a new operation or suspended. Table 29 displays possible STS configurations.

Table 28. STS Configuration Register

| Command | Setup Write Cycle |  | Confirm Write Cycle |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Address Bus | Data Bus | Address Bus | Data Bus |
| STS Configuration | Device Address $^{1}$ | $00 B 8 \mathrm{~h}$ | Device Address $^{2}$ | Register Data |

## NOTES:

1. In case of 256 Mb device ( $2 \times 128$ ), the command sequence must be repeated for each die at its base address 2. In case of 256 Mb device ( $2 \times 128$ ), keep the second cycle to the same address. (ie. Do not toggle A24 for the second cycle)

To reconfigure the STATUS (STS) signal to other modes, the Configuration command is given followed by the desired configuration code. The three alternate configurations are all pulse mode for use as a system interrupt as described in the following paragraphs. For these configurations, bit 0 controls Erase Complete interrupt pulse, and bit 1 controls Program Complete interrupt pulse. Supplying the $0 \times 00$ configuration code with the Configuration command resets the STS signal to
the default RY/BY\# level mode. The Configuration command may only be given when the device is not busy or suspended. Check SR. 7 for device status. An invalid configuration code will result in SR. 4 and SR. 5 being set.

Note: STS Pulse mode is not supported in the Clear Lock Bits and Set Lock Bit commands

Table 29. STS Configuration Coding Definitions

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  | Pulse on Program Complete (1) | Pulse on Erase Complete (1) |
| D[1:0] = STS Configuration Codes |  |  | Notes |  |  |  |  |
| $00=$ default, level mode; device ready indication |  |  | Controls HOLD to a memory controller to prevent accessing a flash memory subsystem while any flash device's WSM is busy. |  |  |  |  |
| 01 = pulse on Erase Complete |  |  | Generates a system interrupt pulse when any flash device in an array has completed a block erase. Helpful for reformatting blocks after file system free space reclamation or "cleanup." |  |  |  |  |
| 10 = pulse on Program Complete |  |  | Not supported on this device. |  |  |  |  |
| $11=\begin{gathered}\text { pulse on Erase or Program } \\ \text { Complete }\end{gathered}$ Complete |  |  | Generates system interrupts to trigger servicing of flash arrays when either erase or program operations are completed, when a common interrupt service routine is desired. |  |  |  |  |

## NOTES:

1. When configured in one of the pulse modes, STS pulses low with a typical pulse width of 250 ns .
2. An invalid configuration code will result in both SR4 and SR5 being set.
3. Reserved bits are invalid should be ignored.

### 9.7 Security and Protection

Intel ${ }^{\circledR}$ Embedded Flash Memory (J3 v. D) device offer both hardware and software security features. Block lock operations, PRs and VPEN allow users to implement various levels of data protection.

### 9.7.1 Normal Block Locking

J3 v. D has the unique capability of Flexible Block Locking (locked blocks remain locked upon reset or power cycle): All blocks are unlocked at the factory. Blocks can be locked individually by issuing the Set Block Lock Bit command sequence to any address within a block. Once locked, blocks remain locked when power is removed, or when the device is reset.

All locked blocks are unlocked simultaneously by issuing the Clear Block Lock Bits command sequence to any device address. Locked blocks cannot be erased or programmed. Table 30 summarizes the command bus-cycles.

Table 30. Block Locking Command Bus-Cycles

| Command | Setup Write Cycle |  | Confirm Write Cycle |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Address Bus | Data Bus | Address Bus | Data Bus |
| Set Block Lock Bit | Block Address | 0060 h | Block Address | 0001 h |
| Clear Block Lock Bits | Device Address | 0060 h | Device Address | 00D0h |

After issuing the Set Block Lock Bit setup command or Clear Block Lock Bits setup command, the device's read mode is automatically changed to Read Status Register mode. After issuing the confirm command, completion of the operation is indicated by STS (in RY/BY\# mode) going high and SR7 $=1$.

Blocks cannot be locked or unlocked while programming or erasing, or while the device is suspended. Reliable block lock and unlock operations occur only when $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\text {PEN }}$ are valid. When $\mathrm{V}_{\text {PEN }} \leq \mathrm{V}_{\text {PENLK }}$, block lock-bits cannot be changed.

When the set lock-bit operation is complete, SR4 should be checked for any error. When the clear lock-bit operation is complete, SR5 should be checked for any error. Errors bits must be cleared using the Clear Status Register command.

Block lock-bit status can be determined by first issuing the Read Device Information command, and then reading from <block base address> +02 h . DQ0 indicates the lock status of the addressed block ( $0=$ unlocked, $1=$ locked ).

### 9.7.2 Configurable Block Locking

One of the unique new features on the J 3 v . D , non-existent on the previous generations of this product family, is the ability to protect and/or secure the user's system by offering multiple level of securities: Non-Volatile Temporary; Non-Volatile Semi-Permanently or Non-Volatile Permanently. For additional information and collateral request, please contact your filed representative.

### 9.7.3 OTP Protection Registers

J3 v. D includes a 128-bit Protection Register (PR) that can be used to increase the security of a system design. For example, the number contained in the PR can be used to "match" the flash component with other system components such as the CPU or ASIC, hence preventing device substitution.

The 128-bits of the PR are divided into two 64-bit segments:

- One segment is programmed at the Intel factory with a unique unalterable 64-bit number.
- The other segment is left blank for customer designers to program as desired. Once the customer segment is programmed, it can be locked to prevent further programming.


### 9.7.4 Reading the OTP Protection Register

The Protection Register is read in Identification Read mode. The device is switched to this mode by issuing the Read Identifier command ( 0090 h ). Once in this mode, read cycles from addresses shown in Table 31 or Table 32 retrieve the specified information. To return to Read Array mode, write the Read Array command (00FFh).

### 9.7.5 Programming the OTP Protection Register

Protection Register bits are programmed using the two-cycle Protection Program command. The 64 -bit number is programmed 16 bits at a time for word-wide configuration and eight bits at a time for byte-wide configuration. First write the Protection Program Setup command, 00C0h. The next write to the device will latch in address and data and program the specified location. The allowable addresses are shown in Table 31, "Word-Wide Protection Register Addressing" on page 49 or Table 32, "Byte-Wide Protection Register Addressing" on page 50. See Figure 24, "Protection Register Programming Flowchart" on page 61. Any attempt to address Protection Program commands outside the defined PR address space will result in a Status Register error (SR. 4 will be set). Attempting to program a locked PR segment will result in a Status Register error (SR. 4 and SR. 1 will be set).

### 9.7.6 Locking the OTP Protection Register

The user-programmable segment of the Protection Register is lockable by programming Bit 1 of the Protection Lock Register (PLR) to 0 . Bit 0 of this location is programmed to 0 at the Intel factory to protect the unique device number. Bit 1 is set using the Protection Program command to program "0xFFFD" to the PLR. 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 (SR. 4 and SR. 1 will be set). PR lockout state is not reversible.

Figure 15. Protection Register Memory Map


NOTE: A0 is not used in $\times 16$ mode when accessing the protection register map. See Table 31 for $\times 16$ addressing. If $x 8$ mode $A 0$ is used, see Table 32 for $x 8$ addressing.

Table 31. Word-Wide Protection Register Addressing

| Word | Use | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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: All address lines not specified in the above table must be 0 when accessing the Protection Register |  |  |  |  |  |  |  |  |  |
| (i.e., A[MAX:9] 0.) |  |  |  |  |  |  |  |  |  |

Table 32. Byte-Wide Protection Register Addressing

| Byte | Use | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LOCK | Both | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| LOCK | Both | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 0 | Factory | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| 1 | Factory | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
| 2 | Factory | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
| 3 | Factory | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 |
| 4 | Factory | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| 5 | Factory | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
| 6 | Factory | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 7 | Factory | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |
| 8 | User | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |
| 9 | User | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 |
| A | User | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 |
| B | User | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |
| C | User | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
| D | User | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| E | User | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| F | User | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |

NOTE: All address lines not specified in the above table must be 0 when accessing the Protection Register, i.e., $A[M A X: 9]=0$.

### 9.7.7 VPP/ VPEN Protection

When it's necessary to protect the entire array, global protection can be achieved using a hardware mechanism. using VPP or VPEN. Whenever a valid voltage is present on VPP or VPEN, blocks within the main flash array can be erased or programmed. By grounding VPP or VPEN, blocks within the main array cannot be altered - attempts to program or erase blocks will fail resulting in the setting of the appropriate error bit in the Status Register. By holding VPP or VPEN low, absolute write protection of all blocks in the array can be achieved.

## Appendix A Device Command Codes

For a complete definition on device operations refer to Section 8.4, "Device Commands" on page 36. The list of all applicable commands are included here one more time for the conveninece.

Table 33. Command Bus Operations for J3 v. D

| Command |  | Setup Write Cycle |  | Confirm Write Cycle |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Address Bus | Data Bus | Address Bus | Data Bus |
|  | Program Enhanced Configuration Register | Register Data | 0060h | Register Data | 0004h |
|  | Program OTP Register | Device Address | 00COh | Register Offset | Register Data |
|  | Clear Status Register | Device Address | 0050h | --- | --- |
|  | Program STS Configuration Register | Device Address | 00B8h | --- | --- |
|  | Read Array | Device Address | 00FFh | --- | --- |
|  | Read Status Register | Device Address | 0070h | --- | --- |
|  | Read Identifier Codes (Read Device Information) | Device Address | 0090h | --- | --- |
|  | CFI Query | Device Address | 0098h | --- | --- |
|  | Word/Byte Program | Device Address | $\begin{aligned} & 0040 \mathrm{~h} / \\ & 0010 \mathrm{~h} \end{aligned}$ | Device Address | Array Data |
|  | Buffered Program | Word Address | 00E8h | Device Address | 00DOh |
|  | Block Erase | Device Address | 0020h | Block Address | 00D0h |
|  | Program/Erase Suspend | Device Address | 00B0h | --- | --- |
|  | Program/Erase Resume | Device Address | 00D0h | --- | --- |
| 글む心 | Lock Block | Block Address | 0060h | Block Address | 0001h |
|  | Unlock Block | Block Address | 0060h | Block Address | 00DOh |

## Appendix B J3 v. D ID Codes

Table 34. Read Identifier Codes

| Code |  | Address | Data |
| :---: | :---: | :---: | :---: |
| Device Code | 32-Mbit | 00001 | 0016 |
|  | 64-Mbit | 00001 | 0017 |
|  | 128-Mbit | 00001 | 0018 |

## Appendix C Flow Charts

## C. 1 Write to Buffer

Figure 16. Write to Buffer Flowchart


## C. 2 Status Register

Figure 17. Status Register Flowchart


## C. 3 Byte/Word Programming

Figure 18. Byte/Word Program Flowchart


## C. 4 Program Suspend/Resume

Figure 19. Program Suspend/Resume Flowchart


## C. 5 Block Erase

Figure 20. Block Erase Flowchart


## C. $6 \quad$ Block Erase Suspend/Resume

Figure 21. Block Erase Suspend/Resume Flowchart


## C. $7 \quad$ Block Locking

Figure 22. Set Block Lock-Bit Flowchart


## C. 8 Unlock Block

Figure 23. Clear Lock-Bit Flowchart


## C. $9 \quad$ OTP Protection Register Programming

Figure 24. Protection Register Programming Flowchart


## Appendix D Common Flash Interface


#### Abstract

The Common Flash Interface(CFI) specification outlines device and host system software interrogation handshake which allows specific vendor-specified software algorithms to be used for entire families of devices. This allows device independent, JEDEC ID-independent, and forwardand backward-compatible software support for the specified flash device families. It allows flash vendors to standardize their existing interfaces for long-term compatibility.


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.

## D. $1 \quad$ Query Structure Output

The Query "database" allows system software to gain 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 ( $\mathrm{D}[7: 0]$ ) 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 10 h , which is a word address for x 16 devices.

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

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 " 00 h ," the leading " 00 " has been dropped from the table notation and only the lower byte value is shown. Any x 16 device outputs can be assumed to have 00 h on the upper byte in this mode.

Table 35. Summary of Query Structure Output as a Function of Device and Mode

| Device Type/ Mode | Query start location in maximum device bus width addresses | Query data with maximum device bus width addressing |  |  | Query data with byte addressing |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { Hex } \\ & \text { Offset } \end{aligned}$ | Hex Code | ASCII | $\begin{gathered} \text { Hex } \\ \text { Offset } \end{gathered}$ | Hex Code | ASCI Value |
| x16 device x16 mode | 10h | 10: | 0051 | "Q" | 20: | 51 | "Q" |
|  |  | 11: | 0052 | "R" | 21: | 00 | "Null" |
|  |  | 12: | 0059 | "Y" | 22: | 52 | "R" |
| x16 device x8 mode | $N / A^{(1)}$ | $\mathrm{N} / \mathrm{A}^{(1)}$ |  |  | 20: | 51 | "Q" |
|  |  |  |  |  | 21: | 51 | "Q" |
|  |  |  |  |  | 22: | 52 | "R" |

NOTE:

1. The system must drive the lowest order addresses to access all the device's array data when the device is configured in x8 mode. Therefore, word addressing, where these lower addresses are not toggled by the system, is "Not Applicable" for x8-configured devices.

Table 36. Example of Query Structure Output of a x16- and x8-Capable Device

| Word Addressing |  |  | Byte Addressing |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Offset | Hex Code | Value | Offset | Hex Code | Value |
| $\mathrm{A}_{15}-\mathrm{A}_{0}$ | D15-D |  | $\mathrm{A}_{7}-\mathrm{A}_{0}$ | $\mathrm{D}_{7}-\mathrm{D}_{0}$ |  |
| 0010h | 0051 | "Q" | 20h | 51 | "Q" |
| 0011h | 0052 | "R" | 21h | 51 | "Q" |
| 0012h | 0059 | "Y" | 22h | 52 | "R" |
| 0013h | P_ID ${ }_{\text {Lo }}$ | PrVendor | 23h | 52 | "R" |
| 0014h | $\mathrm{P}_{-} \mathrm{ID}_{\mathrm{HI}}$ | ID \# | 24h | 59 | "Y" |
| 0015h | PLo | PrVendor | 25h | 59 | "Y" |
| 0016h | $\mathrm{P}_{\mathrm{HI}}$ | TbIAdr | 26h | P_ID ${ }_{\text {LO }}$ | PrVendor |
| 0017h | A_ID ${ }_{\text {LO }}$ | AltVendor | 27h | P_IDLO | ID \# |
| 0018h | A_ID ${ }_{\text {HI }}$ | ID \# | 28h | $\mathrm{P}_{-} \mathrm{ID}_{\mathrm{HI}}$ | ID \# |
| ... | ... | ... | ... | ... | ... |

## D. 2 Query Structure Overview

The Query command causes the flash component to display the Common Flash Interface (CFI) Query structure or "database." The structure sub-sections and address locations are summarized below. See AP-646 Common Flash Interface (CFI) and Command Sets (order number 292204) for a full description of CFI.

The following sections describe the Query structure sub-sections in detail.

Table 37. Query Structure

| Offset | Sub-Section Name | Description | Notes |
| :---: | :--- | :--- | :---: |
| 00 h |  | Manufacturer Code | 1 |
| 01 h |  | Device Code | 1 |
| $(B A+2) \mathrm{h}^{(2)}$ | Block Status Register | Block-Specific Information | 1,2 |
| $04-0 \mathrm{Fh}$ | Reserved | Reserved for Vendor-Specific Information | 1 |
| 10 h | CFI Query Identification String | Reserved for Vendor-Specific Information | 1 |
| 1 Bh | System Interface Information | Command Set ID and Vendor Data Offset | 1 |
| 27 h | Device Geometry Definition | Flash Device Layout | 1 |
| $P^{(3)}$ | Primary Intel-Specific Extended <br> Query Table | Vendor-Defined Additional Information <br> Specific to the Primary Vendor Algorithm | 1,3 |

## NOTES:

1. Refer to the Query Structure Output section and offset 28 h for the detailed definition of offset address as a function of device bus width and mode.
2. $\mathrm{BA}=$ Block Address beginning location (i.e., 02000h is block 2's beginning location when the block size is 128 Kbyte).
3. Offset 15 defines "P" which points to the Primary Intel-Specific Extended Query Table.

## D. $3 \quad$ Block Status Register

The Block Status Register indicates whether an erase operation completed successfully or whether a given block is locked or can be accessed for flash program/erase operations.

Table 38. Block Status Register

| Offset | Length | Description | Address | Value |
| :---: | :---: | :--- | :---: | :---: |
| $(B A+2) h^{(1)}$ | 1 | Block Lock Status Register | $B A+2:$ | --00 or --01 |
|  |  | BSR.0 Block Lock Status <br> $0=$ Unlocked <br> $1=$ Locked | $B A+2:$ | (bit 0 ): 0 or 1 |
|  |  | BSR 1-15: Reserved for Future Use | $B A+2:$ | (bit $1-15): 0$ |

## NOTE:

1. $\mathrm{BA}=$ The beginning location of a Block Address (i.e., 008000 h is block 1 's ( $64-\mathrm{KB}$ block) beginning location in word mode).

## D. $4 \quad$ CFI Query Identification String

The CFI Query Identification String provides verification that the component supports the Common Flash Interface specification. It also indicates the specification version and supported vendor-specified command set(s).

Table 39. CFI Identification (Sheet 1 of 2)

| Offset | Length | Description | Add. | Hex <br> Code | Value |
| :---: | :---: | :--- | :---: | :---: | :---: |
| 10 h | 3 | Query-unique ASCII string "QRY" | 10 | --51 | "Q" |
|  |  |  | $11:$ | --52 | "R" |
|  |  |  | $12:$ | --59 | " Y " |

Table 39. CFI Identification (Sheet 2 of 2)

| Offset | Length | Description <br> 0000h means no second vendor-specified algorithm exists | Add. <br> $18:$ | Hex <br> Code <br> --00 | Value |
| :---: | :---: | :--- | :---: | :---: | :---: |
| 19 h | 2 | Secondary algorithm Extended Query Table address. <br> 0000 h means none exists | $19:$ <br> $1 \mathrm{~A}:$ | -00 <br> --00 |  |

## D. 5 System Interface Information

The following device information can optimize system interface software.
Table 40. System Interface Information

| Offset | Length | Description | Add. | Hex Code | Value |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1Bh | 1 | $\mathrm{V}_{\mathrm{CC}}$ logic supply minimum program/erase voltage bits $0-3$ BCD 100 mV bits 4-7 BCD volts | 1B: | --27 | 2.7 V |
| 1Ch | 1 | $\mathrm{V}_{\mathrm{CC}}$ logic supply maximum program/erase voltage bits 0-3 BCD 100 mV bits $4-7$ BCD volts | 1C: | --36 | 3.6 V |
| 1Dh | 1 | $\mathrm{V}_{\mathrm{PP}}$ [programming] supply minimum program/erase voltage bits 0-3 BCD 100 mV bits 4-7 HEX volts | 1D: | --00 | 0.0 V |
| 1Eh | 1 | $\mathrm{V}_{\mathrm{PP}}$ [programming] supply maximum program/erase voltage bits 0-3 BCD 100 mV bits 4-7 HEX volts | 1E: | --00 | 0.0 V |
| 1Fh | 1 | "n" such that typical single word program time-out $=2^{n} \mu \mathrm{~s}$ | 1F: | --06 | $64 \mu \mathrm{~s}$ |
| 20h | 1 | " n " such that typical max. buffer write time-out $=2^{n} \mu \mathrm{~s}$ | 20: | --07 | 128 ¢ |
| 21h | 1 | "n" such that typical block erase time-out $=2 \mathrm{~ms}$ | 21: | --0A | 1 s |
| 22h | 1 | "n" such that typical full chip erase time-out $=2^{n} \mathrm{~ms}$ | 22: | --00 | NA |
| 23h | 1 | " $n$ " such that maximum word program time-out $=2^{n}$ times typical | 23: | --02 | 256 s |
| 24h | 1 | " n " such that maximum buffer write time-out $=2 \mathrm{n}$ times typical | 24: | --03 | $1024 \mu \mathrm{~s}$ |
| 25h | 1 | " n " such that maximum block erase time-out $=2 n$ times typical | 25: | --02 | 4 s |
| 26h | 1 | " $n$ " such that maximum chip erase time-out $=2^{n}$ times typical | 26: | --00 | NA |

## D. 6 Device Geometry Definition

This field provides critical details of the flash device geometry.
Table 41. Device Geometry Definition

| Offset | Length | Description | Code See Table Below |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 27h | 1 | "n" such that device size = $2^{2}$ in number of bytes | 27: |  |  |
| 28h | 2 | Flash device interface: $\underline{x 8 \text { async } x 16 \text { async } \underline{x} 8 / \times 16 \text { async }}$ 28:00,29:00 28:01,29:00 28:02,29:00 | $\begin{aligned} & 28: \\ & 29: \end{aligned}$ | $\begin{aligned} & -02 \\ & --00 \end{aligned}$ | $\begin{aligned} & \mathrm{x} 8 / \\ & \mathrm{x} 16 \end{aligned}$ |
| 2Ah | 2 | " n " such that maximum number of bytes in write buffer $=2 \mathrm{n}$ | $\begin{aligned} & \text { 2A: } \\ & 2 \mathrm{~B}: \end{aligned}$ | $\begin{aligned} & --05 \\ & --00 \end{aligned}$ | 32 |
| 2Ch | 1 | Number of erase block regions within device: <br> 1. $x=0$ means no erase blocking; the device erases in "bulk" <br> 2. $x$ specifies the number of device or partition regions with one or more contiguous same-size erase blocks <br> 3. Symmetrically blocked partitions have one blocking region <br> 4. Partition size $=$ (total blocks) $\times$ (individual block size) | 2C: | --01 | 1 |
| 2Dh | 4 | Erase Block Region 1 Information bits $0-15=y, y+1=$ number of identical-size erase blocks bits $16-31=z$, region erase block(s) size are $z \times 256$ bytes | $\begin{aligned} & 2 \mathrm{D}: \\ & 2 \mathrm{E}: \\ & 2 \mathrm{~F}: \\ & 30: \end{aligned}$ |  |  |

## Device Geometry Definition

| Address | 32 Mbit | 64 Mbit | 128 Mbit |
| :---: | :---: | :---: | :---: |
| 27: | --16 | --17 | --18 |
| 28: | --02 | --02 | --02 |
| 29: | --00 | --00 | --00 |
| 2A: | --05 | --05 | --05 |
| 2B: | --00 | --00 | --00 |
| 2C: | --01 | --01 | --01 |
| 2D: | --1F | --3F | --7F |
| 2E: | --00 | --00 | --00 |
| 2F: | --00 | --00 | --00 |
| 30 : | --02 | --02 | --02 |

## D. $7 \quad$ Primary-Vendor Specific Extended Query Table

Certain flash features and commands are optional. The Primary Vendor-Specific Extended Query table specifies this and other similar information.

Table 42. Primary Vendor-Specific Extended Query

| $\begin{aligned} & \text { Offset }^{(1)} \\ & P=31 \text { h } \end{aligned}$ | Length | Description (Optional Flash Features and Commands) | Add. | Hex Code | Value |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & (P+0) h \\ & (P+1) h \\ & (P+2) h \end{aligned}$ | 3 | Primary extended query table Unique ASCII string "PRI" | $\begin{aligned} & 31: \\ & 32: \\ & 33: \\ & 33: \end{aligned}$ | $\begin{aligned} & --50 \\ & --52 \\ & --49 \end{aligned}$ | $\begin{aligned} & \text { "P" } \\ & \text { "R" } \\ & \text { " } \mathrm{l} " \end{aligned}$ |
| (P+3)h | 1 | Major version number, ASCII | 34: | --31 | "1" |
| (P+4)h | 1 | Minor version number, ASCII | 35: | --31 | "1" |
| $\begin{aligned} & (\mathrm{P}+5) \mathrm{h} \\ & (\mathrm{P}+6) \mathrm{h} \\ & (\mathrm{P}+7) \mathrm{h} \\ & (\mathrm{P}+8) \mathrm{h} \end{aligned}$ | 4 | Optional feature and command support ( $1=\mathrm{yes}, 0=\mathrm{no}$ ) bits 9-31 are reserved; undefined bits are "0." If bit 31 is " 1 " then another 31 bit field of optional features follows at the end of the bit-30 field. <br> bit 0 Chip erase supported <br> bit 1 Suspend erase supported <br> bit 2 Suspend program supported <br> bit 3 Legacy lock/unlock supported <br> bit 4 Queued erase supported <br> bit 5 Instant Individual block locking supported <br> bit 6 Protection bits supported <br> bit 7 Page-mode read supported <br> bit 8 Synchronous read supported | $\begin{aligned} & 36: \\ & 37: \\ & 38: \\ & 39: \end{aligned}$ | $\begin{aligned} & \hline- \text {-CE } \\ & --00 \\ & --00 \\ & --00 \end{aligned}$ |  |
|  |  |  |  |  | No Yes Yes Yes $^{(1)}$ No No Yes Yes No |
| (P+9)h | 1 | Supported functions after suspend: read Array, Status, Query <br> Other supported operations are: bits 1-7 reserved; undefined bits are "0" bit 0 Program supported after erase suspend | 3A: | 1 | Yes |
| $\begin{aligned} & (P+A) h \\ & (P+B) h \end{aligned}$ | 2 | Block Status Register mask bits 2-15 are Reserved; undefined bits are " 0 " bit 0 Block Lock-Bit Status register active bit 1 Block Lock-Down Bit Status active | $\begin{aligned} & \text { 3B: } \\ & \text { 3C: } \end{aligned}$ | $\begin{aligned} & \hline-01 \\ & --00 \end{aligned}$ |  |
|  |  |  |  |  | $\begin{aligned} & \text { Yes } \\ & \text { No } \end{aligned}$ |
| $(\mathrm{P}+\mathrm{C}) \mathrm{h}$ | 1 | $\mathrm{V}_{\mathrm{CC}}$ logic supply highest performance program/erase voltage <br> bits $0-3 \mathrm{BCD}$ value in 100 mV <br> bits $4-7$ BCD value in volts | 3D: | --33 | 3.3 V |
| (P+D)h | 1 | $\mathrm{V}_{\mathrm{PP}}$ optimum program/erase supply voltage bits $0-3$ BCD value in 100 mV bits $4-7$ HEX value in volts | 3E: | --00 | 0.0 V |

NOTE:

1. Future devices may not support the described "Legacy Lock/Unlock" function. Thus bit 3 would have a value of " 0 ."

Table 43. Protection Register Information

| $\begin{aligned} & \text { Offset }^{(1)} \\ & \mathrm{P}=31 \mathrm{~h} \end{aligned}$ | Length | Description (Optional Flash Features and Commands) | Add. | Hex Code | Value |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (P+E)h | 1 | Number of Protection register fields in JEDEC ID space. "00h," indicates that 256 protection bytes are available | 3F: | --01 | 01 |
| $\begin{aligned} & (P+F) h \\ & (P+10) h \\ & (P+11) h \\ & (P+12) h \end{aligned}$ | 4 | Protection Field 1: Protection Description <br> This field describes user-available One Time Programmable (OTP) protection register bytes. Some are pre-programmed with device-unique serial numbers. Others are userprogrammable. Bits 0-15 point to the protection register lock byte, the section's first byte. The following bytes are factory pre-programmed and user-programmable. <br> bits 0-7 = Lock/bytes JEDEC-plane physical low address bits 8-15 = Lock/bytes JEDEC-plane physical high address bits $16-23=$ " $n$ " such that $2^{n}=$ factory pre-programmed bytes bits 24-31 = " $n$ " such that $2^{n}=$ user-programmable bytes | $\begin{aligned} & 40: \\ & 41: \\ & 42: \\ & 43: \end{aligned}$ | $\begin{aligned} & --80 \\ & --00 \\ & --03 \\ & --03 \end{aligned}$ | 80h <br> 00h <br> 8bytes <br> 8bytes |

NOTE:

1. The variable $P$ is a pointer which is defined at CFI offset 15 h .

Table 44. Burst Read Information

| Offset ${ }^{(1)}$ <br> $\mathbf{P}=31 \mathrm{~h}$ | Length | Description <br> (Optional Flash Features and Commands) | Add. | Hex <br> Code | Value |
| :---: | :---: | :--- | :---: | :---: | :---: |
| $(P+13) \mathrm{h}$ | 1 | Page Mode Read capability <br> bits 0-7 = "n" such that $2^{n}$ HEX value represents the number <br> of read-page bytes. See offset 28h for device word width to <br> determine page-mode data output width. 00h indicates no <br> read page buffer. | $44:$ | --03 | 8 byte |
| $(P+14) \mathrm{h}$ | 1 | Number of synchronous mode read configuration fields that <br> follow. OOh indicates no burst capability. | $45:$ | --00 | 0 |
| $(\mathrm{P}+15) \mathrm{h}$ |  | Reserved for future use | $46:$ |  |  |

## NOTE:

1. The variable $P$ is a pointer which is defined at CFI offset 15 h.

## Appendix E Additional Information

| Order Number | Document/Tool |
| :---: | :---: |
| 298130 | Intel ${ }^{\text {T }}$ StrataFlash ${ }^{\text {TM }}$ Memory (J3); 28F128J3, 28F640J3, 28F320J3 Specification Update |
| 298136 | Inte ${ }^{\circ}$ Persistent Storage Manager (IPSM) User's Guide Software Manual |
| 297833 | Inte ${ }^{\ldots}$ Flash Data Integrator (FDI) User's Guide Software Manual |
| 290606 | 5 Volt Inte* ${ }^{\text {StrataFlash }}{ }^{\text {TM }}$ Memoryl28F320J5 and 28F640J5 datasheet |
| 292204 | AP-646 Common Flash Interface (CFI) and Command Sets |
| 253418 | Inte ${ }^{\circledR}$ Wireless Communications and Computing Package User's Guide |

1. 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 the Intel home page http://www.intel.com for technical documentation and tools.
3. For the most current information on Intel® Embedded Flash Memory (J3 v. D), visit http:// developer.intel.com/design/flash/isf.

## Appendix F Ordering Information

Figure 25. Decoder:Inte $\circledR^{\circledR}$ Embedded Flash Memory (J3 v. D) Family


Table 45. Order Information: Inte $\circledR^{\circledR}$ Embedded Flash Memory (J3 v. D) Family

| 56-Lead TSOP | 64-Ball Easy BGA |
| :---: | :--- |
| TE28F128J3D-75 | RC28F128J3D-75 |
| TE28F640J3D-75 | RC28F640J3D-75 |
| TE28F320J3D-75 | RC28F320J3D-75 |
| JS28F128J3D-75 | PC28F128J3D-75 |
| JS28F640J3D-75 | PC28F640J3D-75 |
| JS28F320J3D-75 | PC28F320J3D-75 |

1.0 Introduction ..... 6
1.1 Nomenclature ..... 6
1.2 Acronyms ..... 6
1.3 Conventions ..... 6
2.0 Functional Overview ..... 8
2.1 Block Diagram ..... 10
2.2 Memory Map ..... 11
3.0 Package Information ..... 12
$3.1 \quad$ 56-Lead TSOP Package ..... 12
3.2 Easy BGA Package ..... 13
4.0 Ballouts and Signal Descriptions ..... 15
4.1 Easy BGA Ballout (32/64/128 Mbit) ..... 15
$4.2 \quad$ 56-Lead TSOP Package Pinout (32/64/128 Mbit) ..... 16
4.3 Signal Descriptions ..... 17
5.0 Maximum Ratings and Operating Conditions ..... 19
5.1 Absolute Maximum Ratings ..... 19
5.2 Operating Conditions ..... 19
5.3 Power Up/Down ..... 20
5.3.1 Power-Up/Down Characteristics ..... 20
5.3.2 Power Supply Decoupling ..... 20
5.4 Reset ..... 20
6.0 Electrical Characteristics ..... 21
6.1 DC Current Specifications ..... 21
6.2 DC Voltage specifications ..... 22
6.3 Capacitance ..... 23
7.0 AC Characteristics ..... 24
7.1 Read Specifications ..... 25
7.2 Write Specifications ..... 28
7.3 Program, Erase, Block-Lock Specifications ..... 30
7.4 Reset Specifications ..... 31
7.5 AC Test Conditions ..... 32
8.0 Bus Interface ..... 33
8.1 Bus Reads ..... 34
8.1.1 Asynchronous Page Mode Read ..... 34
8.1.1.1 Enhanced Configuration Register (ECR) ..... 34
8.1.2 Output Disable ..... 35
8.2 Bus Writes ..... 35
8.3 Standby ..... 36
8.3.1 Reset/Power-Down ..... 36
8.4 Device Commands ..... 36
9.0 Flash Operations ..... 38
9.1 Status Register ..... 38
9.1.1 Clearing the Status Register ..... 39
9.2 Read Operations ..... 39
9.2.1 Read Array ..... 39
9.2.2 Read Status Register ..... 40
9.2.3 Read Device Information ..... 40
9.2.4 CFI Query ..... 41
9.3 Programming Operations ..... 41
9.3.1 Single-Word/Byte Programming ..... 41
9.3.2 Buffered Programming ..... 42
9.4 Block Erase Operations ..... 43
9.5 Suspend and Resume ..... 44
9.6 Status Signal (STS) ..... 45
9.7 Security and Protection ..... 46
9.7.1 Normal Block Locking ..... 46
9.7.2 Configurable Block Locking ..... 47
9.7.3 OTP Protection Registers ..... 47
9.7.4 Reading the OTP Protection Register ..... 48
9.7.5 Programming the OTP Protection Register ..... 48
9.7.6 Locking the OTP Protection Register ..... 48
9.7.7 VPP/ VPEN Protection ..... 50
Appendix A Device Command Codes ..... 51
Appendix B J3 v. D ID Codes ..... 52
Appendix C Flow Charts ..... 53
C. 1 Write to Buffer ..... 53
C. 2 Status Register ..... 54
C. 3 Byte/Word Programming ..... 55
C. 4 Program Suspend/Resume ..... 56
C. 5 Block Erase ..... 57
C. 6 Block Erase Suspend/Resume ..... 58
C. 7 Block Locking ..... 59
C. 8 Unlock Block ..... 60
C. 9 OTP Protection Register Programming ..... 61
Appendix D Common Flash Interface ..... 62
D. 2 Query Structure Overview ..... 63
D. 3 Block Status Register ..... 64
D. 4 CFI Query Identification String ..... 64
D. 5 System Interface Information ..... 65
D. 6 Device Geometry Definition ..... 66
D. 7 Primary-Vendor Specific Extended Query Table ..... 67
Appendix E Additional Information ..... 69
Appendix F Ordering Information ..... 70

