# Parallel NOR and PSRAM 56-Ball MCP Combination Memory ### MT38M4041A3034EZZI.XK6 MT38M5041A3034EZZI.XR6 #### **Features** - Micron<sup>®</sup> Parallel NOR Flash and PSRAM components - RoHS-compliant, "green" package - Multiplexed address/data bus - Deep power-down (DPD) mode on both devices - NOR: 2µA (TYP) - PSRAM: 10µA (TYP) - Space-saving multichip package (MCP) - Low-voltage operation (1.70–1.95V) - Industrial temperature range: -40°C to +85°C #### **NOR Flash-Specific Features** - 256Mb or 512Mb multiple-bank, Parallel NOR Flash - · Synchronous/asynchronous read - Synchronous burst reads: 133 MHz (266MB/sec) - Random access times: 96ns - Programming times - 2.0 µs/word (TYP) buffered programming - 0.9 s/block (TYP) for block erase - 20µs (TYP) program/erase suspend - 10µs by word (TYP) for fast factory program - Double/quadruple word program option - · Memory blocks - Multiple bank memory array: Eight 32Mb banks - Uniform blocks1 - · Synchronous burst read suspend - Dual operations - Program erase in 1 bank, read in others - No delay between READ and WRITE operations - Block locking - All blocks locked at power-up - Any combination of blocks can be locked - WP# for block lock-down - Security - 2112-bit user programmable OTP cells - 64-bit unique device number - · Common Flash interface - 100,000 PROGRAM/ERASE cycles per block - Electronic signature - 256Mb: 8904h - 512Mb: 9815h #### Figure 1: MCP Block Diagram #### **PSRAM-Specific Features** - · Synchronous/asynchronous read - Synchronous burst read mode: 133 MHz - Random access: 70ns - Asynchronous page mode: 20ns - Partial-array self refresh (PAR) - Automatic temperature-compensated self-refresh (TCR) Notes: - 1. Contact factory for availability of version. - 2. For physical part markings, see Part Numbering Information (page 2). #### **Part Numbering Information** Micron NOR Flash and PSRAM devices are available in different configurations and densities. The MCP/PoP part numbering guide is available at www.micron.com/numbering. **Figure 2: Part Number Chart** #### **Device Marking** Due to the size of the package, the Micron-standard part number is not printed on the top of the device. Instead, an abbreviated device mark consisting of a 5-digit alphanumeric code is used. The abbreviated device marks are cross-referenced to the Micron part numbers at the FBGA Part Marking Decoder site: www.micron.com/decoder. To view the location of the abbreviated mark on the device, refer to customer service note CSN-11, "Product Mark/Label," at www.micron.com/csn. ### **Contents** | MCP General Description | ( | |-------------------------------------------------|----| | Ball Assignments and Descriptions | | | Electrical Specifications | 13 | | Device Diagrams | 15 | | Package Dimensions | 16 | | 256Mb, 512Mb, 1Gb StrataFlash® Memory | 17 | | Features | | | General Description | 18 | | Functional Overview | 18 | | Configuration and Memory Map | 20 | | Device ID | | | Bus Interface | 24 | | Reset | 24 | | Standby | 24 | | Output Disable | 25 | | Asynchronous Read | 25 | | Synchronous Read | 25 | | Burst Wrapping | 25 | | End-of-Wordline Delay | 26 | | Write | 27 | | Command Definitions | 28 | | Status Register | 31 | | Clear Status Register | 32 | | Read Configuration Register | 33 | | Programming the Read Configuration Register | | | Latency Count Code and Clock Frequency | | | Extended Configuration Register | 36 | | Deep Power Down Control | | | Output Driver Control | 36 | | Programming the Extended Configuration Register | 38 | | Read Operations | | | Read Array | 39 | | Read ID | 39 | | Read CFI | 4( | | Read Status Register | 4( | | WAIT Operation | 4] | | Programming Modes | 42 | | Control Mode | 42 | | Object Mode | 43 | | Program Operations | 47 | | Single-Word Programming | 47 | | Single-Word Programming | | | Buffered Programming | 48 | | Buffered Programming | | | Buffered Enhanced Factory Programming | | | Erase Operations | | | BLOCK ERASE | | | SUSPEND and RESUME Operations | | | SUSPEND Operation | | | RESUME Operation | 54 | | BLANK CHECK Operation | | |---------------------------------------------------------------------------------------------|------------| | Block Lock | | | One-Time Programmable Operations | 58 | | Programming OTP Area | 60 | | Reading OTP Area | | | Global Main-Array Protection | 61 | | Dual Operation | 62 | | Power and Reset Specifications | 63 | | Initialization | 63 | | Power-Up and Down | 63 | | Reset | 63 | | Automatic Power Saving | 65 | | Deep Power-Down | | | Power Supply Decoupling | | | Electrical Specifications | | | Electrical Specifications – DC Current and Voltage Characteristics and Operating Conditions | | | Electrical Specifications – AC Characteristics and Operating Conditions | | | AC Test Conditions | | | AC Read Specifications | | | AC Read Timing | | | AC Write Specifications | | | Electrical Specifications – Program/Erase Characteristics | | | Common Flash Interface | | | READ CFI Structure Output | | | CFI ID String | | | System Interface Information | | | Device Geometry Definition | | | Primary Micron-Specific Extended Query | | | Flowcharts | 102 | | AADM Mode | | | AADM Feature Overview | | | AADM Mode Enable (RCR[4] = 1) | | | Bus Cycles and Address Capture | | | WAIT Behavior | | | Asynchronous READ and WRITE Cycles | | | Asynchronous READ Cycles | | | Asynchronous WRITE Cycles | | | Synchronous READ and WRITE Cycles | | | Synchronous READ Cycles | | | Synchronous WRITE Cycles | | | System Boot | | | Revision History | | | Rev. B – 7/15 | | | | 120<br>12Ω | # **List of Tables** | Table 1: | x16 NOR Ball Descriptions | 10 | |-----------|---------------------------------------------------------------------------------|----| | | x16 PSRAM Ball Descriptions | | | Table 3: | NOR/PSRAM Shared Ball Descriptions | 12 | | | Absolute Maximum Ratings | | | | Recommended Operating Conditions | | | Table 6: | Operating Modes – Standard Asynchronous Operation | 14 | | | Main Array Memory Map – 256Mb | | | | Main Array Memory Map – 512Mb, 1Gb | | | | Device ID Codes | | | Table 10: | Bus Control Signals | 24 | | Table 11: | Command Set | 29 | | Table 12: | Status Register Bit Definitions (Default Value = 0080h) | 31 | | Table 13: | CLEAR STATUS REGISTER Command Bus Cycles | 32 | | | Read Configuration Register Bit Definitions | | | | PROGRAM READ CONFIGURATION REGISTER Bus Cycles | | | | Supported Latency and Clock Frequency | | | Table 17: | Extended Configuration Register Bit Definitions (Default Value = 0004h) | 36 | | Table 18: | Output Driver Control Characteristics | 36 | | | Program Extended Configuration Register Command Bus Cycles | | | | READ MODE Command Bus Cycles | | | Table 21: | Device Information | 40 | | Table 22: | WAIT Behavior Summary – Non-MUX | 41 | | | WAIT Behavior Summary – A/D MUX | | | | Programming Region Next State | | | | PROGRAM Command Bus Cycles | | | | BEFP Requirements and Considerations | | | Table 27: | BEFP Requirements and Considerations | 50 | | | ERASE Command Bus Cycle | | | | Valid Commands During Suspend | | | | SUSPEND and RESUME Command Bus Cycles | | | | BLANK CHECK Command Bus Cycles | | | | BLOCK LOCK Command Bus Cycles | | | | Block Lock Configuration | | | | Program OTP Area Command Bus Cycles | | | | Dual Operation Restrictions | | | | Power Sequencing | | | | Reset Specifications | | | Table 38: | Deep Power-Down Specifications | 65 | | | Absolute Maximum Ratings | | | | Operating Conditions | | | | DC Current Characteristics and Operating Conditions | | | | DC Voltage Characteristics and Operating Conditions | | | | AC Input Requirements | | | Table 44: | Test Configuration Load Capacitor Values for Worst Case Speed Conditions | 71 | | | Capacitance | | | | AC Read Specifications (CLK-Latching, 133 MHz), V <sub>CCQ</sub> = 1.7V to 2.0V | | | | AC Write Specifications | | | | Program/Erase Characteristics | | | | Example of CFI Output (x16 Device) as a Function of Device and Mode | | | | CFI Database: Addresses and Sections | | | Table 51: | CFI ID String | 93 | |-----------|---------------------------------------------------------------|-----| | Table 52: | System Interface Information | 93 | | Table 53: | Device Geometry | 94 | | | Block Region Map Information | | | | Primary Micron-Specific Extended Query | | | | One Time Programmable (OTP) Space Information | | | Table 57: | Burst Read Informaton | 98 | | Table 58: | Partition and Block Erase Region Information | 99 | | Table 59: | Partition Region 1 Information: Top and Bottom Offset/Address | 99 | | Table 60: | Partition and Erase Block Map Information | 101 | | | AADM Asynchronous and Latching Timings | | | Table 62: | AADM Asynchronous Write Timings | 123 | | | AADM Synchronous Timings | | # **List of Figures** | Figure 1: | MCP Block Diagram | 1 | |------------|--------------------------------------------------------------------------------|-----| | Figure 2: | Part Number Chart | 2 | | Figure 3: | 56-Ball TFBGA (NOR x16; PSRAM x16) Ball Assignments (Top View Through Package) | 10 | | | Functional Block Diagram (NOR with PSRAM) | | | Figure 5: | 56-Ball VFBGA (Package Code: 4EZ) | 16 | | Figure 6: | Main Array Word Lines | 26 | | Figure 7: | Wrap/No-Wrap Example | 26 | | Figure 8: | End-of-Wordline Delay | 26 | | Figure 9: | Two-Cycle Command Sequence | 28 | | Figure 10: | Single-Cycle Command Sequence | 28 | | Figure 11: | READ Cycle Between WRITE Cycles | 28 | | | Illegal Command Sequence | | | Figure 13: | Configurable Programming Regions: Control Mode and Object Mode | 43 | | | Configurable Programming Regions: Control Mode and Object Mode Segments | | | Figure 15: | BLOCK LOCK Operations | 57 | | Figure 16: | OTP Area Map | 59 | | Figure 17: | V <sub>PP</sub> Supply Connection Example | 61 | | | RESET Operation Waveforms | | | 0 | Deep Power-Down Operation Timing | | | | Reset During Deep Power-Down Operation Timing | | | Figure 21: | AC Input/Output Reference Waveform | 71 | | | Transient Equivalent Testing Load Circuit | | | Figure 23: | Clock Input AC Waveform | 72 | | | Asynchronous Page-Mode Read (Non-MUX) | | | | Synchronous 8- or 16-Word Burst Read (Non-MUX) | | | | Synchronous Continuous Misaligned Burst Read (Non-MUX) | | | | Synchronous Burst with Burst Interrupt Read (Non-MUX) | | | Figure 28: | Asynchronous Single-Word Read | 79 | | | Synchronous 8- or 16-Word Burst Read (A/D MUX) | | | | Synchronous Continuous Misaligned Burst Read (A/D MUX) | | | | Synchronous Burst with Burst-Interrupt (AD-MUX) | | | | Write Timing | | | | Write to Write (Non-MUX) | | | 0 | Async Read to Write (Non-MUX) | | | | Write to Async Read (Non-MUX) | | | | Sync Read to Write (Non-MUX) | | | | Write to Sync Read (Non-MUX) | | | | Write to Write (A/D-MUX) | | | | Async Read to Write (A/D-MUX) | | | | Write to Async Read (A/D-MUX) | | | | Sync Read to Write (A/D-MUX) | | | | Write to Sync Read (A/D-MUX) | | | | Word Program Procedure | | | | Word Program Full Status Check Procedure | | | | Program Suspend/Resume Procedure | | | 0 | Buffer Programming Procedure | | | Figure 47: | Buffered Enhanced Factory Programming (BEFP) Procedure | 108 | | | Block Erase Procedure | | | | Block Erase Full Status Check Procedure | | | | Erase Suspend/Resume Procedure | | | | | | | Figure 51: | Block Lock Operations Procedure | 114 | |------------|---------------------------------------------------------------------------------|-----| | Figure 52: | Protection Register Programming Procedure | 115 | | Figure 53: | Protection Register Programming Full Status Check Procedure | 117 | | Figure 54: | Blank Check Procedure | 118 | | Figure 55: | Blank Check Full Status Check Procedure | 119 | | Figure 56: | AADM Asynchronous READ Cycle (Latching A[MAX:0]) | 122 | | Figure 57: | AADM Asynchronous READ Cycle (Latching A[15:0] only) | 122 | | Figure 58: | AADM Asynchronous WRITE Cycle (Latching A[MAX:0]) | 123 | | Figure 59: | AADM Asynchronous WRITE Cycle (Latching A[15:0] only) | 124 | | Figure 60: | AADM Synchronous Burst READ Cycle (ADV# De-asserted Between Address Cycles) | 126 | | Figure 61: | AADM Synchronous Burst READ Cycle (ADV# Not De-asserted Between Address Cycles) | 126 | | Figure 62: | AADM Synchronous Burst READ Cycle (Latching A[15:0] only) | 127 | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM MCP General Description # **MCP General Description** Micron MCP products combine NOR Flash and PSRAM devices in a single MCP. Recommended operating conditions do not allow more than one device to be active at a time. A common example of this scenario is running simultaneous READ operations on the NOR device and on the PSRAM device. Doing this results in data bus contention. To prevent this, one device must be High-Z when reading the selected device. The PSRAM ADM device is W957D6H. For device specifications and complete PSRAM features documentation, contact your local Micron sales office. # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Ball Assignments and Descriptions # **Ball Assignments and Descriptions** Figure 3: 56-Ball TFBGA (NOR x16; PSRAM x16) Ball Assignments (Top View Through Package) **Table 1: x16 NOR Ball Descriptions** | Symbol | Alternate<br>Symbol | Туре | Description | |--------|---------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CE# | E# | Input | Chip enable: Activates the memory control logics, input buffers, decoders, and sense amplifiers. When CE# is LOW and RESET is HIGH, the device is in active mode. When HIGH, the NOR device is deselected, the outputs are High-Z, and the power consumption is reduced to the standby level. | | DPD | - | Input | Deep power-down: When enabled in the extended configuration register, DPD is used to enter and exit deep power-down mode. | | WP# | - | Input | Write protect: Provides additional hardware protection for each block. When WP# is LOW, lock-down is enabled and the protection status of the locked-down blocks cannot be changed. When WP# is HIGH, lock-down is disabled and the locked-down blocks can be locked or unlocked. | | RP# | - | Input | Reset: Provides a hardware reset of the memory. When RP# is LOW, the device is in reset mode; the outputs are High-Z and the current consumption is reduced to IDD2. After RP#, all blocks are in the locked state and the configuration register is reset. When RP# is HIGH, the device is in normal operation. Upon exiting reset mode, the device enters asynchronous read mode, but a negative transition of CE# or ADV# is required to ensure valid data outputs. | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Ball Assignments and Descriptions #### **Table 1: x16 NOR Ball Descriptions (Continued)** | Symbol | Alternate<br>Symbol | Туре | Description | |-----------------|---------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | V <sub>PP</sub> | _ | Supply | Both a NOR control input and power supply pin. The two functions are selected by the voltage range applied to the pin. When $V_{PP} = 0V - V_{CCQ}$ , it functions as a control input. In this case, a voltage lower than $V_{PPLKF}$ provides absolute protection against program or erase, while $V_{PP} > V_{PP1F}$ enables these functions. $V_{PP}$ is only sampled at the beginning of a program or erase; a change in its value after the operation has started does not have any effect, and PROGRAM or ERASE operations continue. When $V_{PP}$ is in the range of $V_{PPH}$ , it acts as a power supply pin. In this condition, $V_{PP}$ must be stable until the program/erase algorithm is completed. | ### **Table 2: x16 PSRAM Ball Descriptions** | Symbol | Alternate<br>Symbol | Туре | Description | |--------|---------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CE# | E# | Input | Chip enable: When LOW, CE# activates the memory state machine, address buffers and decoders, enabling READ and WRITE operations. When HIGH, all other pins are ignored and the device is automatically put in low-power standby mode. | | CRE | CR | Input | Configuration register enable: When HIGH, bus READ or WRITE operations access either the value of the refresh configuration register or the bus configuration register, according to the value of A19. | | UB# | - | Input | Upper byte enable: Gates the data on the upper byte data I/Os (DQ[15:8]) to or from the upper part of the selected address during a WRITE or READ operation. | | LB# | - | Input | Lower byte enable: Gates the data on the lower byte data I/Os (DQ[7:0]) to or from the lower part of the selected address during a WRITE or READ operation. | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Ball Assignments and Descriptions **Table 3: NOR/PSRAM Shared Ball Descriptions** | Symbol | Туре | Description | | | | |------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | A[MAX:16] | Input | Shared address: Select the cells in the memory array to access during bus READ operations. During bus WRITE operations they control the commands sent to the command interface of NOR memory program/erase controller, and they select the cells to access in the PSRAM. | | | | | ADQ[15:0] | Input/ Output | Shared data inputs/outputs: The bidirectional I/Os output the data stored at the selected address during a NOR bus READ operation or inputs a command or the data to be programmed during a bus WRITE operation. | | | | | | | For both NOR and PSRAM, the ADQ[15:0], in conjunction with A[23:16] address lines, select the cells in the memory array to access during bus READ operations. | | | | | | | The upper byte data inputs/outputs carry the data to or from the upper part of the selected address during a PSRAM WRITE or READ operation, when UB# is driven LOW. Likewise, the lower byte data I/Os carry the data to or from the lower part of the selected address during a WRITE or READ operation, when LB# is driven LOW. | | | | | CLK | Input | Shared clock. | | | | | WE# | Input | Common to Flash memory and PSRAM components. Refer to the respective memory component data sheets for details. | | | | | OE# | Input | Shared output enable. | | | | | ADV# | Input | Shared latch enable input. | | | | | WAIT | Output | Shared WAIT data in burst mode. | | | | | V <sub>SS</sub> | Supply | Shared ground. | | | | | V <sub>CC</sub> | Supply | Shared power supply. | | | | | V <sub>CCQ</sub> | Supply | Shared I/O power supply. | | | | | NC | _ | Not connected. | | | | Note: 1. Each device in a system should have $V_{CC}$ , $V_{CCQ}$ , and $V_{PP}$ decoupled with a 0.1 $\mu$ F ceramic capacitor close to the pin (high-frequency, inherently low inductance capacitors should be as close as possible to the package). The PCB track widths should be sufficient to carry the required $V_{PP}$ program and erase currents. # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Electrical Specifications # **Electrical Specifications** Stresses greater than those listed may cause permanent damage to the device. This is a stress rating only, and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. **Table 4: Absolute Maximum Ratings** | Parameters/Conditions | Symbol | Min | Max | Unit | |----------------------------------------------|-------------------|------|------|-------| | Ambient operating temperature | T <sub>A</sub> | -40 | 85 | °C | | | T <sub>BIAS</sub> | -40 | 85 | °C | | Storage temperature range | T <sub>STG</sub> | -55 | 125 | °C | | Input voltage | V <sub>IN</sub> | -0.2 | 2.45 | V | | Core supply voltage | V <sub>CC</sub> | -0.2 | 2.45 | V | | I/O supply voltage | V <sub>CCQ</sub> | -0.2 | 2.45 | V | | Flash V <sub>PP</sub> program voltage | V <sub>PP</sub> | -0.2 | 10 | V | | Output short circuit current | Io | | 100 | mA | | Time for V <sub>PP</sub> at V <sub>PPH</sub> | <sup>t</sup> VPPH | | 100 | hours | **Table 5: Recommended Operating Conditions** | Parameters | Symbol | Min | Max | Unit | |----------------------------------------------------------------|------------------|------|------------------------|------| | Core supply voltage | V <sub>CC</sub> | 1.70 | 1.95 | V | | I/O supply voltage | V <sub>CCQ</sub> | 1.70 | 1.95 | V | | Flash V <sub>PP</sub> supply voltage (application environment) | V <sub>PP</sub> | -0.4 | V <sub>CCQ</sub> + 0.4 | V | | Flash V <sub>PP</sub> supply voltage (factory environment) | V <sub>PP</sub> | 8.5 | 9.5 | V | | Operating temperature range | _ | -40 | +85 | °C | ### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM **Electrical Specifications** #### **Table 6: Operating Modes - Standard Asynchronous Operation** X = "Don't Care" | Operation | RP# | CE# | OE# | WE# | ADV# | CLK <sup>1</sup> | UB# | LB# | CRE | CE# | ADQ[15:0] | WAIT <sup>2</sup> | |------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|------------------|-----------------|-----------------|-----------------|-----------------|---------------------------------------------|-------------------| | FLASH | ' | | | • | | | • | | | | | • | | READ | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х | Х | Х | V <sub>IH</sub> | Address in/<br>data out | Low-Z | | WRITE | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Х | Х | Х | V <sub>IH</sub> | Address in/<br>data in | Low-Z | | ADDRESS LATCH | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Х | V <sub>IL</sub> | V <sub>IL</sub> | Х | Х | Х | V <sub>IH</sub> | Data out or<br>High-Z <sup>3</sup> | Low-Z | | OUTPUT DISABLE | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IH</sub> | $V_{IL}$ | Х | Х | Х | V <sub>IH</sub> | High-Z | Low-Z | | STANDBY | V <sub>IH</sub> | V <sub>IH</sub> | Х | Х | Х | V <sub>IL</sub> | Any P | SRAM r | node al | lowed | High-Z | High-Z | | RESET | V <sub>IL</sub> | Х | Х | Х | Х | V <sub>IL</sub> | | | | | High-Z | High-Z | | PSRAM | | | | | | | • | | | | | • | | READ | Х | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | \_/ | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | Address in/<br>data out | Low-Z | | WRITE | Х | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IL</sub> | V | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | Address in/<br>data in | High-Z | | READ<br>CONFIGURATION<br>REGISTER | х | V <sub>IH</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Address in/<br>BCR, RCR, or<br>DIDR content | Low-Z | | SET CONFIGURATION<br>REGISTER<br>4 | Х | V <sub>IH</sub> | V <sub>IH</sub> | V <sub>IL</sub> | \_/ | V <sub>IL</sub> | Х | Х | V <sub>IH</sub> | V <sub>IL</sub> | BCR/RCR data | Low-Z | | OUTPUT DISABLE (No operation) | Х | V <sub>IH</sub> | V <sub>IH</sub> | Х | Х | Х | Х | Х | V <sub>IL</sub> | V <sub>IL</sub> | High-Z | Low-Z | | DEEP POWER DOWN <sup>5</sup> | Any | Flash | Х | Х | Х | $V_{IL}$ | Х | Х | Х | V <sub>IH</sub> | High-Z | High-Z | | STANDBY | | ode<br>wed | Х | Х | Х | V <sub>IL</sub> | Х | Х | Х | V <sub>IH</sub> | High-Z | High-Z | - Notes: 1. CLK must remain LOW when the PSRAM device is operating in asynchronous mode. - 2. For the Flash device, WAIT polarity is configured using the SET CONFIGURATION REGIS-TER command. - 3. See the NOR data sheet for more information. - 4. BCR and RCR only. - 5. The device enters deep power-down mode by driving the CE# from LOW to HIGH, with bit 4 of the RCR set to 0. The device remains in deep power-down mode until CE# goes LOW again and is held LOW for <sup>t</sup>DPDX. # **Device Diagrams** Figure 4: Functional Block Diagram (NOR with PSRAM) Note: 1. The devices share the same power supplies and the same ground. They are distinguished by two CE# inputs. Recommended operating conditions do not allow more than one device to be active at a time, which would result in a data bus contention. One device should be placed in High-Z when the selected device is operating. # **Package Dimensions** Figure 5: 56-Ball VFBGA (Package Code: 4EZ) Note: 1. All dimensions are in millimeters. # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM 256Mb, 512Mb, 1Gb StrataFlash® Memory # 256Mb, 512Mb, 1Gb StrataFlash® Memory #### **Features** - · High-performance read, program, and erase - 96ns initial read access - 108 MHz with zero wait-state synchronous burst reads: 7ns clock-to-data output - 133 MHz with zero wait-state synchronous burst reads: 5.5ns clock-to-data output - 8-, 16-, and continuous-word synchronous-burst reads - Programmable WAIT configuration - Customer-configurable output driver impedance - Buffered programming: 2.0 μs/Word (TYP), 512Mb, 65nm - Block erase: 0.9s per block (TYP) - 20µs (TYP) program/erase suspend - Architecture - 16-bit wide data bus - Multilevel cell technology - Symmetrically-blocked array architecture - 256KB erase blocks - 1Gb device: Eight 128Mb partitions - 512Mb device: Eight 64Mb partitions - 256Mb device: Eight 32Mb partitions - READ-While-PROGRAM and READ-While-ERASE commands - Status register for partition/device status - Blank check feature - Temperature Range - Expanded temperature: –40°C to +85°C - JESD47H-compliant - Minimum 100,000 ERASE cycles per block 17 - Data retention: 20 years (TYP) #### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM General Description - Power - Core voltage: 1.7–2.0VI/O voltage: 1.7–2.0V - Standby current: 60µA (TYP) for 512Mb, 65nm - Automatic power savings mode - 16-word synchronous-burst read current: 23mA (TYP) @ 108 MHz; 24mA (TYP) @ 133 MHz - Software - Micron<sup>®</sup> Flash data integrator (FDI) optimized - Basic command set (BCS) and extended command set (ECS) compatible - Common Flash interface (CFI) capable - Security - One-time programmable (OTP) space 64 unique factory device identifier bits 2112 user-programmable OTP bits - Absolute write protection: $V_{PP} = GND$ - Power-transition erase/program lockout - Individual zero latency block locking - Individual block lock-down - · Density and packaging - 256Mb, 512Mb, and 1Gb - Address-data multiplexed and non-multiplexed interfaces ### **General Description** Micron's 65nm device is the latest generation of StrataFlash® memory featuring flexible, multiple-partition, dual-operation architecture. The device provides high-performance, asynchronous read mode and synchronous-burst read mode using 1.8V low-voltage, multilevel cell (MLC) technology. The multiple-partition architecture enables background programming or erasing to occur in one partition while code execution or data reads take place in another partition. This dual-operation architecture also allows two processors to interleave code operations while PROGRAM and ERASE operations take place in the background. The multiple partitions allow flexibility for system designers to choose the size of the code and data segments. The device is manufactured using 65nm process technologies and is available in industry-standard chip scale packaging. #### **Functional Overview** This device provides high read and write performance at low voltage on a 16-bit data bus. The multi-partition architecture provides read-while-write and read-while-erase capability, with individually erasable memory blocks sized for optimum code and data storage. The device supports synchronous burst reads up to 133 MHz using CLK latching. Upon initial power-up or return from reset, the device defaults to asynchronous read mode. Configuring the read configuration register enables synchronous burst mode reads. In synchronous burst mode, output data is synchronized with a user-supplied # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Functional Overview clock signal. In continuous-burst mode, a data read can traverse partition boundaries. A WAIT signal simplifies synchronizing the CPU to the memory. Designed for low-voltage applications, the device supports READ operations with $V_{CC}$ at 1.8V, and ERASE and PROGRAM operations with $V_{PP}$ at 1.8V or 9.0V. $V_{CC}$ and $V_{PP}$ can be tied together for a simple, ultra low-power design. In addition to voltage flexibility, a dedicated $V_{PP}$ connection provides complete data protection when $V_{PP}$ is less than $V_{PPLK}$ . A status register provides status and error conditions of ERASE and PROGRAM operations. One-time programmable (OTP) area enables unique identification that can be used to increase security. Additionally, the individual block lock feature provides zero-latency block locking and unlocking to protect against unwanted program or erase of the array. The device offers power-savings features, including automatic power savings mode, standby mode, and deep power-down mode. For power savings, the device automatically enters APS following a READ cycle. Standby is initiated when the system deselects the device by de-asserting CE#. Deep power-down mode starts when the device is properly configured (ECR15 is set) and the DPD signal is asserted. In deep power-down mode, the device has the lowest power consumption. # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Configuration and Memory Map # **Configuration and Memory Map** The device features a symmetrical block architecture. The main array of the 256Mb device is divided into eight 32Mb partitions. Each partition is divided into sixteen 256KB blocks ( $8 \times 16 = 128 \text{ blocks}$ ). The main array of the 512Mb device is divided into eight 64Mb partitions. Each partition is divided into thirty-two 256KB blocks (8 $\times$ 32 = 256 blocks). The main array of the 1Gb device is divided into eight 128Mb partitions. Each partition is divided into sixty-four 256KB blocks (8 $\times$ 64 = 512 blocks). Each block is divided into as many as 256 1KB programming regions. Each region is divided into as many as thirty-two 32-byte segments Table 7: Main Array Memory Map - 256Mb | Partition | Size<br>(Mb) | Block # | Address Range | |-----------|--------------|---------|-----------------| | 7 | 32 | 127 | FF0000-FFFFFF | | | | | | | | | | | | | | | • | | | | 112 | FD0000-FDFFFF | | 6 | 32 | 111 | 0DE0000-0DFFFFF | | | | • | | | | | | · | | | | • | · | | | | 96 | 0C00000-0C1FFFF | | 5 | 32 | 95 | OBEO000-OBFFFFF | | | | | | | | | | • | | | | • | • | | | | 80 | 0A00000-0A1FFFF | | 4 | 32 | 79 | 09E0000-09FFFFF | | | | | | | | | - | | | | | • | · | | | | 64 | 0800000-081FFFF | | 3 | 32 | 63 | 07E0000-07FFFFF | | | | | | | | | | · | | | | | · | | | | 48 | 0600000-061FFFF | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Configuration and Memory Map **Table 7: Main Array Memory Map - 256Mb (Continued)** | Partition | Size<br>(Mb) | Block # | Address Range | |-----------|--------------|---------|-----------------| | 2 | 32 | 47 | 05E0000-05FFFFF | | | | | | | | | | | | | | | • | | | | 32 | 0400000-041FFFF | | 1 | 32 | 31 | 03E0000-03FFFFF | | | | | | | | | | | | | | | | | | | 16 | 0200000-021FFFF | | 0 | 32 | 15 | 01E0000-01FFFFF | | | | | | | | | | | | | | | • | | | | 0 | 000000-001FFFF | Table 8: Main Array Memory Map - 512Mb, 1Gb | | 512Mb | | | | 1Gb | | |-----------|--------------|---------|-----------------|--------------|---------|-----------------| | Partition | Size<br>(Mb) | Block # | Address Range | Size<br>(Mb) | Block # | Address Range | | 7 | 64 | 255 | 1FE0000-1FFFFFF | 128 | 511 | 3FE0000-3FFFFFF | | | | | | | | | | | | | | | | | | | | | | | | | | | | 224 | 1C00000-1C1FFFF | | 448 | 3800000-381FFFF | | 6 | 64 | 223 | 1BE0000-1BFFFFF | 128 | 447 | 37E0000-37FFFF | | | | | | | | | | | | | | | | | | | | | | | | | | | | 192 | 1800000-181FFFF | | 384 | 3000000-301FFFF | | 5 | 64 | 191 | 17E0000-17FFFF | 128 | 383 | 2FE0000-2FFFFFF | | | | | | | | | | | | | | | | | | | | • | | | • | | | | | 160 | 1400000-141FFFF | | 320 | 2800000-281FFFF | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Configuration and Memory Map Table 8: Main Array Memory Map - 512Mb, 1Gb (Continued) | 512Mb | | | | | 1Gb | | |-----------|--------------|---------|-----------------|--------------|---------|-----------------| | Partition | Size<br>(Mb) | Block # | Address Range | Size<br>(Mb) | Block # | Address Range | | 4 | 64 | 159 | 13E0000-13FFFFF | 128 | 319 | 27E0000-27FFFF | | | | | | | | | | | | | | | | • | | | | | | _ | | | | | | 128 | 1000000-101FFFF | | 256 | 2000000-201FFFF | | 3 | 64 | 127 | 0FE0000-0FFFFF | 128 | 255 | 1FE0000-1FFFFFF | | | | | | | | | | | | | | | | | | | | • | | | • | | | | | 96 | 0300000-031FFFF | | 192 | 1800000-181FFFF | | 2 | 64 | 95 | OBEO000-OBFFFFF | 128 | 191 | 17E0000-17FFFF | | | | | | | | | | | | | | | | | | | | | | | | | | | | 64 | 0800000-081FFFF | | 128 | 1000000-101FFFF | | 1 | 64 | 63 | 07E0000-07FFFF | 128 | 127 | 0FE0000-0FFFFF | | | | | | | | | | | | | | | | | | | | | | | | | | | | 32 | 0400000-041FFFF | | 64 | 0800000-081FFFF | | 0 | 64 | 31 | 03E0000-03FFFFF | 128 | 63 | 07E0000-07FFFF | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0 | 0000000-001FFFF | | 0 | 0000000-001FFFF | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Device ID # **Device ID** #### **Table 9: Device ID Codes** | Density | Product | Device Identifier Code (Hex) | |---------|---------|------------------------------| | 256Mb | Non-MUX | 8901 | | | A/D MUX | 8904 | | 512Mb | Non-MUX | 887E | | | A/D MUX | 8881 | | 1024Mb | Non-MUX | 88B0 | | | A/D MUX | 88B1 | #### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Bus Interface ### **Bus Interface** The bus interface uses CMOS-compatible address, data, and bus control signals for all bus WRITE and bus READ operations. The address signals are input only, the data signals are input/output (I/O), and the bus control signals are input only. The address inputs are used to specify the internal device location during bus READ and bus WRITE operations. The data I/Os carry commands, data, or status to and from the device. The control signals are used to select and deselect the device, indicate a bus READ or bus WRITE operation, synchronize operations, and reset the device. Do not float any inputs. All inputs must be driven or terminated for proper device operation. Some features may use additional signals. See Signal Descriptions for descriptions of these signals. The following table shows the logic levels that must be applied to the bus control signal inputs for the bus operations listed. #### **Table 10: Bus Control Signals** $X = Don't Care; High = V_{IH}; Low = V_{IL}$ | <b>Bus Operations</b> | RST# | CE# | CLK | ADV# | OE# | WE# | Address | Data I/O | |-----------------------|------|------|---------|--------|------|------|---------|----------| | RESET | LOW | Х | Х | Х | Х | Х | Х | High-Z | | STANDBY | HIGH | HIGH | Х | Х | Х | Х | Х | High-Z | | OUTPUT DISABLE | HIGH | Х | Х | Х | HIGH | Х | Х | High-Z | | Asynchronous<br>READ | HIGH | LOW | Х | LOW | LOW | HIGH | Valid | Output | | Synchronous READ | HIGH | LOW | Running | Toggle | LOW | HIGH | Valid | Output | | WRITE | HIGH | LOW | Х | Х | HIGH | LOW | Valid | Input | #### Reset RST# LOW places the device in reset, where device operations are disabled; inputs are ignored, and outputs are placed in High-Z. Any ongoing ERASE or PROGRAM operation will be aborted and data at that location will be indeterminate. RST# HIGH enables normal device operations. A minimum delay is required before the device is able to perform a bus READ or bus WRITE operation. See AC specifications. ### Standby RST# HIGH and CE# HIGH place the device in standby, where all other inputs are ignored, outputs are placed in High-Z (independent of the level placed on OE#), and power consumption is substantially reduced. Any ongoing ERASE or PROGRAM operation continues in the background and the device draws active current until the operation has finished. #### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Bus Interface #### **Output Disable** When OE# is de-asserted with CE# asserted, the device outputs are disabled. Output pins are placed in High-Z. WAIT is de-asserted in A/D-MUX devices and driven to High-Z in non-MUX devices. #### **Asynchronous Read** For RCR15 = 1 (default), CE# LOW and OE# LOW place the device in asynchronous bus read mode: - RST# and WE# must be held HIGH; CLK must be tied either HIGH or LOW. - Address inputs must be held stable throughout the access, or latched with ADV#. - ADV# must be held LOW or can be toggled to latch the address. - Valid data is output on the data I/Os after <sup>t</sup>AVQV, <sup>t</sup>ELQV, <sup>t</sup>VLQV, or <sup>t</sup>GLQV, whichever is satisfied last. Asynchronous READ operations are independent of the voltage level on V<sub>PP</sub>. For asynchronous page reads, subsequent data words are output <sup>t</sup>APA after the least significant address bit(s) are toggled: 16-word page buffer, A[3:0]. #### **Synchronous Read** For RCR15 = 0, CE# LOW, OE# LOW, and ADV# LOW place the device in synchronous bus read mode: - RST# and WE# must be held HIGH. - CLK must be running. - The first data word is output <sup>t</sup>CHQV after the latency count has been satisfied. - For array reads, the next address data is output <sup>t</sup>CHQV after valid CLK edges until the burst length is satisfied. - For nonarray reads, the same address data is output <sup>t</sup>CHQV after valid CLK edges until the burst length is satisfied. The address for synchronous read operations is latched on the ADV# rising edge or the first rising CLK edge after ADV# LOW, whichever occurs first for devices that support up to 108 MHz. For devices that support up to 133 MHz, the address is latched on the last CLK edge when ADV# is LOW. ### **Burst Wrapping** Data stored within the memory array is arranged in rows or word lines. During synchronous burst reads, data words are sensed in groups from the array. The starting address of a synchronous burst read determines which word within the wordgroup is output first, and subsequent words are output in sequence until the burst length is satisfied. The setting of the burst wrap bit (RCR3) determines whether synchronous burst reads will wrap within the wordgroup or continue on to the next wordgroup. **Figure 6: Main Array Word Lines** Figure 7: Wrap/No-Wrap Example ### **End-of-Wordline Delay** Output delays may occur when the burst sequence crosses the first end-of-wordline boundary onto the start of the next wordline. No delays occur if the starting address is sense-group aligned or if the burst sequence never crosses a wordline boundary. However, if the starting address is not sense-group aligned, the worst-case end-of-wordline delay is one clock cycle less than the initial access latency count used. This delay occurs only once during the burst access. WAIT informs the system of this delay when it occurs. Figure 8: End-of-Wordline Delay #### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Bus Interface #### Write CE# LOW and WE# LOW place the device in bus write mode, where RST# and OE# must be HIGH, CLK and ADV# are ignored, input data and address are sampled on the rising edge of WE# or CE#, whichever occurs first. During a WRITE operation in MUX devices, address is latched during the rising edge of ADV# OR CE# whichever occurs first and data is latched during the rising edge of WE# OR CE# whichever occurs first. Bus WRITE cycles are asynchronous only. The following conditions apply when a bus WRITE cycle occurs immediately before, or immediately after, a bus READ cycle: - When transitioning from a bus READ cycle to a bus WRITE cycle, CE# or ADV# must toggle after OE# goes HIGH. - When in synchronous read mode (RCR15 = 0; burst clock running), bus WRITE cycle timings tVHWL (ADV# HIGH to WE# LOW), tCHWL (CLK HIGH to WE# LOW), and tWHCH (WE# HIGH to CLK HIGH) must be met. - When transitioning from a bus WRITE cycle to a bus READ cycle, CE# or ADV# must toggle after WE# goes HIGH. # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Command Definitions #### **Command Definitions** Commands are written to the device to control all operations. Some commands are two-cycle commands that use a SETUP and a CONFIRM command; other commands are single-cycle commands that use only a SETUP command followed by a data READ cycle or data WRITE cycle. Valid commands and their associated command codes are shown in the table below. The device supports READ-While-WRITE and READ-While-ERASE operations with bus cycle granularity, not command granularity. That is, both bus WRITE cycles of a two-cycle command do not need to occur as back-to-back bus WRITE cycles to the device; READ cycles may occur between the two WRITE cycles of a two-cycle command. However, a WRITE operation must not occur between the two bus WRITE cycles of a two-cycle command; this will cause a command sequence error (SR[7,5,4] = 1). Due to the large buffer size of devices, the system interrupt latency may be impacted during the buffer fill phase of a buffered programming operation. Refer to the relevant technical note to implement a software solution. **Figure 9: Two-Cycle Command Sequence** **Figure 10: Single-Cycle Command Sequence** Figure 11: READ Cycle Between WRITE Cycles Figure 12: Illegal Command Sequence **Table 11: Command Set** | Command | Code<br>(Setup/Confirm) | Description | |----------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Register Operations | | | | PROGRAM READ CONFIGURA-<br>TION REGISTER | 0060h/0003h | Programs the read configuration register. The desired read configuration register value is placed on the address bus, and written to the read configuration register when the CONFIRM command is issued. | | PROGRAM EXTENDED CONFIGU-<br>RATION REGISTER | 0060h/0004h | Programs the extended configuration register. The desired extended configuration register value is placed on the address bus, and written to the read configuration register when the CONFIRM command is issued. | | PROGRAM OTP AREA | 00C0h | Programs OTP area and OTP lock registers. The desired register data is written to the addressed register on the next WRITE cycle. | | CLEAR STATUS REGISTER | 0050h | Clears all error bits in the status register. | | Read Mode Operations | | | | READ ARRAY | 00FFh | Places the addressed partition in read array mode. Subsequent reads outputs array data. | | READ STATUS REGISTER | 0070h | Places the addressed partition in read status mode. Subsequent reads outputs status register data. | | READ ID | 0090h | Places the addressed partition in read ID mode. Subsequent reads from specified address offsets output unique device information. | | READ CFI | 0098h | Places the addressed partition in read CFI mode. Subsequent reads from specified address offsets output CFI data. | | <b>Array Programming Operations</b> | 5 | | | SINGLE-WORD PROGRAM | 0041h | Programs a single word into the array. Data is written to the array on the next WRITE cycle. The addressed partition automatically switches to read status register mode. | | BUFFERED PROGRAM | 00E9h/00D0h | Initiates and executes a BUFFERED PROGRAM operation. Additional bus READ/WRITE cycles are required between the and confirm commands to properly perform this operation. The addressed partition automatically switches to read status register mode. | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Command Definitions #### **Table 11: Command Set (Continued)** | Command | Code<br>(Setup/Confirm) | Description | |--------------------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BUFFERED ENHANCED FACTORY<br>PROGRAM | 0080h/00D0h | Initiates and executes a BUFFERED ENHANCED FACTORY PRO-<br>GRAM operation. Additional bus READ/WRITE cycles are re-<br>quired after the CONFIRM command to properly perform this<br>operation. The addressed partition automatically switches to<br>read status register mode. | | Block Erase Operations | | | | BLOCK ERASE | 0020h/00D0h | Erases a single, addressed block. The ERASE operation commences when the CONFIRM command is issued. The addressed partition automatically switches to read status register mode. | | Security Operations | | | | Lock Block | 0060h/0001h | Sets the lock bit of the addressed block. | | Unlock Block | 0060h/00D0h | Clears the lock bit of the addressed block. | | Lock-Down Block | 0060h/002Fh | Sets the lock-down bit of the addressed block. | | Other Operations | | | | SUSPEND | 00B0h | Initiates a suspend of a PROGRAM or BLOCK ERASE operation already in progress when issued to any device address SR[6] = 1 indicates erase suspend SR[2] = 1 indicates program suspend | | RESUME | 00D0h | Resumes a suspended PROGRAM or BLOCK ERASE operation when issued to any device address. A program suspend nested within an erase suspend is resumed first. | | BLANK CHECK | 00BCh/00D0h | Performs a blank check of an addressed block. The addressed partition automatically switches to read status register mode. | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Status Register # **Status Register** The status register is a 16-bit, read-only register that indicates device status, region status, and operating errors. Upon power-up or exit from reset, the status register defaults to 0080h (device ready, no errors). The status register has status bits and error bits. Status bits are set and cleared by the device; error bits are only set by the device. Error bits are cleared using the CLEAR STATUS REGISTER command or by resetting the device. To read from the status register, first issue the READ STATUS REGISTER command and then read from the device. Note that some commands automatically switch from read mode to read status register mode. **Table 12: Status Register Bit Definitions (Default Value = 0080h)** | Bit | Name | Description | |-------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15:10 | Reserved | Reserved for future use; these bits will always be set to zero | | 9:8 | Partition program error | SR[9]/SR[8] 0 0 = Region program successful 1 0 = Region program error: Attempted write with object data to control mode region 0 1= Region-program error: Attempted rewrite to object mode region 1 1 = Region-program error: Attempted write using illegal command (SR[4] will also be set along with SR[8,9] for the above error conditions) | | 7 | Device status | 0 = Device is busy; SR[9,8,6:1] are invalid, SR[0] is valid<br>1 = Device is ready; SR[9:8], SR[6:1] are valid | | 6 | Erase suspend | 0 = Erase suspend not in effect<br>1 = Erase suspend in effect | | 5:4 | Erase error/blank check error program error (command sequence error) | SR[5]/SR[4] 0 0 = PROGRAM or ERASE operation successful 0 1 = Program error: operation aborted 1 0 = Erase error: Operation aborted; Blank check error: Operation failed 1 1 = Command sequence error: Command aborted | | 3 | V <sub>PP</sub> error | $0 = V_{PP}$ within acceptable limits during program or erase $1 = V_{PP} < V_{PPLK}$ during program or erase; operation aborted | | 2 | Program suspend | 0 = Program suspend not in effect<br>1 = Program suspend in effect | | 1 | Block lock error | 0 = Block not locked during program or erase; operation successful<br>1 = Block locked during program or erase; operation aborted | | 0 | Partition status | SR[7]/SR[0] 0 0 = Active PROGRAM or ERASE operation in addressed partition BEFP: Program or verify complete, or ready for data 0 1 = Active PROGRAM or ERASE operation in other partition BEFP: Program or Verify in progress 1 0 = No active PROGRAM or ERASE operation in any partition BEFP: Operation complete 1 1 = Reserved | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Status Register #### **Clear Status Register** The status register has status bits and error bits. Status bits are set and cleared by the device; error bits are only set by the device. Error bits are cleared using the CLEAR STATUS REGISTER command or by resetting the device. **Note:** Care should be taken to avoid status register ambiguity. If a command sequence error occurs while in erase suspend, SR[5:4] will be set, indicating a command sequence error. 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 any suspended ERASE operation. The CLEAR STATUS REGISTER command functions independent of the voltage level on $V_{pp}$ . Issuing the CLEAR STATUS REGISTER command places the addressed partition in read status register mode. Other partitions are not affected. **Table 13: CLEAR STATUS REGISTER Command Bus Cycles** | Command | Setup WRITE Cycle<br>Address Bus | Setup WRITE Cycle<br>Data Bus | Confirm WRITE Cycle Address Bus | Confirm WRITE Cycle<br>Data Bus | |--------------------------|----------------------------------|-------------------------------|---------------------------------|---------------------------------| | CLEAR STATUS<br>REGISTER | Device address | 0050h | - | - | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Read Configuration Register # **Read Configuration Register** The read configuration register is a volatile, 16-bit read/write register used to select bus read modes and to configure synchronous burst read behavior of the device. The read configuration register is programmed using the PROGRAM READ CONFIGURATION REGISTER command. To read the read configuration register, issue the READ ID command and then read from offset 0005h. Upon power-up or exit from reset, the read configuration register defaults to asynchronous mode (RCR15 = 1; all other bits are ignored). **Table 14: Read Configuration Register Bit Definitions** | Bit | Name | Description | | |-------|---------------|--------------------------------------------------------------------|--| | 15 | Read mode | 0 = Synchronous burst mode | | | | | 1 = Asynchronous mode (default) | | | 14:11 | Latency count | 0 0 1 1 = Code 3 | | | | | 0 1 0 0 = Code 4 | | | | | 0 1 0 1 = Code 5 | | | | | 0 1 1 0 = Code 6 | | | | | 0 1 1 1 = Code 7 | | | | | 1 0 0 0 = Code 8 | | | | | 1 0 0 1 = Code 9 | | | | | 1 0 1 0 = Code 10 | | | | | 1 0 1 1 = Code 11 | | | | | 1 1 0 0 = Code 12 | | | | | 1 1 0 1 = Code 13 | | | | | 1 1 1 0 = Code 14 | | | | | Other bit settings are reserved; see the table below for supported | | | | | clock frequencies | | | 10 | WAIT polarity | 0 = WAIT signal is LOW-true | | | | | 1 = WAIT signal is HIGH-true | | | 9 | Reserved | Write 0 to reserved bits | | | 8 | WAIT delay | 0 = WAIT de-asserted with valid data | | | | | 1 = WAIT de-asserted one clock cycle before valid data | | | 7:5 | Reserved | Write 0 to reserved bits | | | 4 | Bus interface | 0 = Non-MUX or A/D MUX (default) | | | | | 1 = AA/D MUX | | | 3 | Reserved | Write 0 to reserved bits | | | 2:0 | Burst length | 0 1 0 = 8-word burst, wrap only | | | | _ | 0 1 1 = 16-word burst, wrap only | | | | | 1 1 1 = Continuous-burst: linear, no-wrap only | | | | | Other bit settings are reserved | | #### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Read Configuration Register ### **Programming the Read Configuration Register** The read configuration register is programmed by issuing the PROGRAM READ CONFIGURATION REGISTER command. The desired RCR[15:0] settings are placed on A[15:0], while the PROGRAM READ CONFIGURATION REGISTER SETUP command is placed on the data bus. Upon issuing the SETUP command, the read mode of the addressed partition is automatically changed to read status register mode. Next, the CONFIRM command is placed on the data bus while the desired settings for RCR[15:0] are again placed on A[15:0]. Upon issuing the CONFIRM command, the read mode of the addressed partition is automatically switched to read array mode. Because the desired read configuration register value is placed on the address bus, any hardware-connection offsets between the host's address outputs and the device's address inputs must be taken into account. For example, if the host's address outputs are aligned to the device's address inputs such that host address bit A1 is connected to address bit A0, the desired register value must be left-shifted by one (for example, 2532h << 4A64h) before programming the read configuration register Synchronous read accesses cannot occur until both the device and the host are in synchronous read mode. Therefore, the software instructions used to perform read configuration register programming and host chip select configuration must be guaranteed not to fetch from the device (instructions must be in system RAM or locked in cache). This also applies when switching back to asynchronous read mode from synchronous read mode. **Table 15: PROGRAM READ CONFIGURATION REGISTER Bus Cycles** | Command | Setup WRITE Cycle | Setup WRITE Cycle | Confirm WRITE Cycle | Confirm WRITE Cycle | |-------------------------------------------|-------------------|-------------------|---------------------|---------------------| | | Address Bus | Data Bus | Address Bus | Data Bus | | PROGRAM READ<br>CONFIGURATION<br>REGISTER | RCR settings | 0060h | RCR settings | 0003h | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Read Configuration Register ### **Latency Count Code and Clock Frequency** #### **Table 16: Supported Latency and Clock Frequency** | Latency Count Code | Clock Frequency<br>V <sub>CCQ</sub> = 1.7V to 2.0V | | |--------------------|----------------------------------------------------|--| | 3 | ≤32.6 MHz | | | 4 | ≤43.5 MHz | | | 5 | ≤54.3 MHz | | | 6 | ≤65.2 MHz | | | 7 | ≤76.1 MHz | | | 8 | ≤87.0 MHz | | | 9 | ≤97.8 MHz | | | 10 | ≤108.7 MHz | | | 11 | ≤119.6 MHz | | | 12 | 12 ≤130.4 MHz | | | 13 | ≤133.3 MHz | | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Extended Configuration Register # **Extended Configuration Register** The extended configuration register is a volatile 16-bit, read/write register used to enable deep-power down and select output-driver strength of the device. Upon power-up or exit from reset, the extended configuration register defaults to 0004h. Table 17: Extended Configuration Register Bit Definitions (Default Value = 0004h) | Bit | Name | Description | |------|----------------------------|---------------------------------| | 15 | Deep power down (DPD) mode | 0 = DPD disabled (default) | | | | 1 = DPD enabled | | 14 | DPD pin polarity | 0 = LOW-true (default) | | | | 1 = HIGH-true | | 13:3 | Reserved | Write 0 to reserved bits | | 2:0 | Output driver control | 0 0 1 = Code 1 | | | | 0 1 0 = Code 2 | | | | 0 1 1 = Code 3 | | | | 1 0 0 = Code 4 (default) | | | | 1 0 1 = Code 5 | | | | 1 1 0 = Code 6 | | | | Other bit settings are reserved | #### **Deep Power Down Control** The Deep Power-Down Mode Bit (ECR15) enables the deep power down mode. The device can only enter deep power down mode by asserting the DPD pin while in standby mode. When the device is in deep power down mode, de-asserting DPD causes the device to revert to standby mode. Note: When ECR15 is reset (DPD disabled), DPD must be connected to $V_{CC}$ or $V_{CC}$ . Deep Power-Down Polarity Bit (ECR14) sets the polarity of the DPD signal. When ECR14 = 0, DPD is active LOW (default). When ECR14 = 1, DPD is active HIGH. #### **Output Driver Control** The output driver control bits of the extended configuration register enable adjustment of the device's output-driver strength for DQ[15:0] and WAIT. Upon power-up or reset, ECR[2:0] defaults to 100b for to an output impedance setting of 30 Ohms. To change the output-driver strength, program ECR[2:0] to the desired setting. **Table 18: Output Driver Control Characteristics** | ECR[2:0] | Driver Impedance<br>(at V <sub>CCQ</sub> /2) | Driver Multiplier | Load (Same Speed) | |----------|----------------------------------------------|-------------------|-------------------| | 0 0 1 | 90 Ohms | 1/3 | 10pF | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Extended Configuration Register ### **Table 18: Output Driver Control Characteristics (Continued)** | ECR[2:0] | Driver Impedance<br>(at V <sub>CCQ</sub> /2) | Driver Multiplier | Load (Same Speed) | |----------|----------------------------------------------|-------------------|-------------------| | 0 1 0 | 60 Ohms | 1/2 | 15pF | | 0 1 1 | 45 Ohms | 2/3 | 20pF | | 1 0 0 | 30 Ohms | 1 | 30pF | | 1 0 1 | 20 Ohms | 1–1/2 | 35pF | | 110 | 15 Ohms | 2 | 40pF | ### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Extended Configuration Register ### **Programming the Extended Configuration Register** The extended configuration register is programmed by issuing the PROGRAM EXTENDED CONFIGURATION REGISTER command. The desired ECR[15:0] settings are placed on A[15:0], while the PROGRAM EXTENDED CONFIGURATION REGISTER SET-UP command is placed on the data bus. Upon issuing the SETUP command, the read mode of the addressed partition is automatically changed to read status register mode. Next, the CONFIRM command is placed on the data bus while the desired settings for ECR[15:0] are again placed on A[15:0]. Upon issuing the CONFIRM command, the read mode of the addressed partition is automatically switched to read array mode. Because the desired ECR value is placed on the address bus, any hardware-connection offsets between the host's address outputs and the device's address inputs must be taken into account. For example, if the host's address outputs are aligned to the device's address inputs such that host address bit A1 is connected to address bit A0, the desired register value must be left-shifted by one (for example, 2532h << 4A64h) before programming the ECR. Programming the ECR functions independently of the voltage on V<sub>PP</sub>. **Table 19: Program Extended Configuration Register Command Bus Cycles** | Command | Setup WRITE Cycle<br>Address Bus | Setup WRITE Cycle<br>Data Bus | Confirm WRITE Cycle<br>Address Bus | Confirm WRITE Cycle<br>Data Bus | |------------------|----------------------------------|-------------------------------|------------------------------------|---------------------------------| | PROGRAM EXTENDED | Register Data | 0060h | Register Data | 0004h | | CONFIGURATION | | | | | | REGISTER | | | | | ### **Read Operations** The following types of data can be read from the device: array data (read array), device information (read ID), CFI data (read CFI), and device status (read status register). Upon power-up or return from reset, the device defaults to read array mode. To change the read mode, the appropriate command must be issued to the device. The table below shows the command codes used to configure the device for the desired read mode. #### **Table 20: READ MODE Command Bus Cycles** | Command | Setup WRITE Cycle<br>Address Bus | Setup WRITE Cycle<br>Data Bus | Confirm WRITE Cycle<br>Address Bus | Confirm WRITE Cycle<br>Data Bus | |-------------------------|----------------------------------|-------------------------------|------------------------------------|---------------------------------| | READ ARRAY | Partition address | 00FFh | _ | _ | | READ STATUS<br>REGISTER | Partition address | 0070h | - | - | | READ ID | Partition address | 0090h | - | - | | READ CFI | Partition address | 0098h | - | - | ### **Read Array** Upon power-up or exit from reset, the device defaults to read array mode. Issuing the READ ARRAY command places the addressed partition in read array mode and can be issued only to a partition that is not actively programming or erasing. Subsequent READ operations output array data from that partition. The addressed partition remains in read array mode until a different READ command is issued, a PROGRAM or ERASE operation is performed, or a BLOCK LOCK SETUP command is issued in that partition, in which case the read mode automatically changes to read status. To change a partition that is actively programming or erasing to read array mode, first issue the SUSPEND command. After the operation has been suspended, issue the READ ARRAY command to the partition. When the PROGRAM or ERASE operation is subsequently resumed, the partition will automatically revert back to read status mode. The READ ARRAY command functions independently of the voltage level on V<sub>PP</sub>. Issuing the READ ARRAY command to a partition that is actively programming or erasing causes subsequent reads from that partition to output invalid data. Valid array data is output only after the PROGRAM or ERASE operation has completed. ### **Read ID** Issuing the READ ID command places the addressed partition in read ID mode. Subsequent reads output device information such as manufacturer code, device identifier code, block lock status, OTP data, or read configuration register data. The addressed partition remains in read ID mode until a different READ command is issued, or a PROGRAM or ERASE operation is performed in that partition, in which case the read mode automatically changes to read status. The READ ID command functions independently of the voltage level on V<sub>pp</sub>. Issuing the READ ID command to a partition that is actively programming or erasing changes that partition's read mode to read ID mode. Subsequent reads from that partition will not output device information until the PROGRAM or ERASE operation has completed. **Table 21: Device Information** | <b>Device Information</b> | Address Bus | Data Bus | |-----------------------------------------|--------------------------------------|-------------------------------------------| | Device manufacturer code | Partition base address + 00h | 0089h | | Device ID code | Partition base address + 01h | Device ID | | Block lock status | Block base address + 02h | D0 = Lock status<br>D1 = Lock-down status | | Read configuration register | Partition base address + 05h | Configuration register data | | Extended configuration register | Partition base address + 06h | Extended configuration register data | | OTP lock register 0 | Partition base address + 80h | Lock register 0 data | | OTP block 0 – factory segment | Partition base address + 81h to 84h | Factory-programmed data | | OTP block 1 – user-programmable segment | Partition base address + 85h to 88h | User data | | OTP lock register 1 | Partition base address + 89h | Lock register 1 data | | OTP blocks 2–17 | Partition base address + 8Ah to 109h | User data | #### Read CFI Issuing the READ CFI command places the addressed partition in read CFI mode. Subsequent reads from that partition output CFI information. The addressed partition remains in read CFI mode until a different READ command is issued, or a PROGRAM or ERASE operation is performed, or a BLOCK LOCK SETUP command is issued, which changes the read mode to read status register mode. The READ CFI command functions independently of the voltage level on V<sub>pp</sub>. Issuing the READ CFI command to a partition that is actively programming or erasing changes that partition's read mode to read CFI mode. Subsequent reads from that partition will return invalid data until the PROGRAM or ERASE operation has completed. After issuing a READ ID (0x90) or READ CFI (0x98) command to a partition, a READ ARRAY (0xFF) command must be issued to any partition address before reading the main array. **Note:** After issuing a READ DEVICE INFORMATION (0x90) or CFI QUERY (0x98) command in any one of the partitions, a READ ARRAY (0xFF) command must be first be issued to any partition address before reading any portion of the main array. ### **Read Status Register** Issuing the READ STATUS REGISTER command places the addressed partition in read status register mode; other partitions are not affected. Subsequent reads from that partition output status register information. Note: CE# or OE# must be toggled to update the status register data. The addressed partition remains in read status register mode until a different READ MODE command is issued to that partition. Performing a PROGRAM, ERASE, or BLOCK LOCK operation also changes the partition's read mode to read status register mode. The READ STATUS REGISTER command functions independently of the voltage level on $V_{\rm PP}$ . Status register contents are valid only when SR[7]=1. ### **WAIT Operation** WAIT indicates the validity of output data during synchronous READ operations. It is asserted when output data is invalid and de-asserted when output data is valid. WAIT changes state only on valid clock edges. Upon power-up or exit from reset, WAIT defaults to LOW true (RCR[10] = 0). WAIT is de-asserted during asynchronous reads. During WRITE operations, WAIT is High-Z on non-MUX devices, and de-asserted on A/D-MUX devices. **Table 22: WAIT Behavior Summary - Non-MUX** | <b>Device Operation</b> | CE# | OE# | WE# | WAIT | |-------------------------------|------|------|------|-------------------------------------------------------------------| | STANDBY (Device not selected) | HIGH | X | Х | High-Z | | OUTPUT DISABLE | LOW | HIGH | HIGH | High-Z | | Synchronous READ | LOW | LOW | HIGH | Active WAIT asserted = invalid data WAIT de-asserted = valid data | | Asynchronous READ | LOW | LOW | HIGH | De-asserted | | WRITE | LOW | HIGH | LOW | High-Z | Note: 1. This table does not apply to AADM devices. See AADM Mode for WAIT behavior in AADM mode. Table 23: WAIT Behavior Summary - A/D MUX | <b>Device Operation</b> | CE# | OE# | WE# | WAIT | |-------------------------------|------|------|------|-------------------------------------------------------------------| | STANDBY (Device not selected) | HIGH | Х | Х | High-Z | | OUTPUT DISABLE | LOW | HIGH | HIGH | De-asserted | | Synchronous READ | LOW | LOW | HIGH | Active WAIT asserted = invalid data WAIT de-asserted = valid data | | Asynchronous READ | LOW | LOW | HIGH | De-asserted | | WRITE | LOW | HIGH | LOW | De-asserted | Note: 1. This table does not apply to AADM devices. See AADM Mode for WAIT behavior in AADM mode. ### **Programming Modes** Each programming region in a block can be configured for either control mode or object mode. The programming mode is automatically set based on the data pattern when a region is first programmed. Selecting either control mode or object mode is done according to the specific needs of the system. In control mode, code or data is frequently changed (such as the flash file system or header information). In object mode, large code or data (such as objects or payloads) is infrequently changed. By implementing the appropriate programming mode, software can efficiently organize how information is stored in the memory array. Control mode programming regions and object mode programming regions can be intermingled within the same erase block. However, the programming mode of any region within a block can be changed only after erasing the entire block. #### **Control Mode** Control mode programming is invoked when only the A-half (A3 = 0) of the programming region is programmed to 0s. The B-half (A3 = 1) remains erased. Control mode allows up to 512 bytes of data to be programmed in the region. The information can be programmed in bits, bytes, or words. Control mode supports the following programming methods: - Single-word programming (0041h) - Buffered programming (00E9h/00D0h) - Buffered enhanced factory programming (0080h/00D0h) When buffered programming is used in control mode, all addresses must be in the A-half of the buffer (A3 = 0). During buffer fill, the B-half (A3 = 1) addresses do not need to be filled with 0xFFFE. Control mode programming is useful for storing dynamic information, such as flash file system headers, file Info, and so on. Typically, control mode programming does not require the entire 512 bytes of data to be programmed at once. It may also contain data that is changed after initial programming using a technique known as "bit twiddling". Header information can be augmented later with additional new information within a control-mode-programmed region. This allows implementation of legacy file systems, as well as transaction-based power-loss recovery. In a control mode region, PROGRAM operations can be performed multiple times. However, care must be taken to avoid programming any zeros in the B-half (A3 = 1) of the region. Violation of this usage will cause SR[4] and SR[9] to be set, and the PROGRAM operation will be aborted. 256KB Block Main Array 256KB 256KB 1KB Programming region in object mode. 256KB 256KB Address Bit A3 = 0: Allows up to 1KB of data to be programmed. 256 programming regions of 1KB in each 256KB block 256KB 512 Bytes 512 Bytes Programming region in control mode A half B half (control mode) (erased) Address Bit A3 = 1: Allows up to 512 bytes of data to be programmed to the A half by bit, byte, or word. Programming region in object mode 1KB Programming region in object mode 1KB 256KB 256KB 256KB Figure 13: Configurable Programming Regions: Control Mode and Object Mode ### **Object Mode** Object mode programming is invoked when one or more bits are programmed to zero in the B-half of the programming region (A3 = 1). Object mode allows up to 1KB to be stored in a programming region. Multiple regions are used to store more than 1KB of information. If the object is less than 1KB, the unused content will remain as 0xFFFF (erased). Object mode supports the following programming methods: - Buffered programming (00E9h/00D0h) - Buffered enhanced factory programming (0080h/00D0h) Single-word programming (0041h) is not supported in object mode. To perform multiple PROGRAM operations within a programming region, control mode must be used. (Object mode is useful for storing static information, such as objects or payloads, that rarely change.) Once the programming region is configured in object mode, it cannot be augmented or overwritten without first erasing the entire block containing the region. Subsequent PROGRAM operations to a programming region configured in object mode will cause SR[4] and SR[8] to be set and the PROGRAM operation to be aborted. Issuing the 41h command to the B-half of an erased region will set error bits SR[8] and SR[9], and the PROGRAM operation will not proceed. Figure 14: Configurable Programming Regions: Control Mode and Object Mode Segments **Table 24: Programming Region Next State** | | Current State of Programming Region | | | | | |--------------------------|-------------------------------------|----------------------------|----------------------------|--|--| | Command Issued | Erased | Control Mode | Object Mode | | | | 0041h to B-half (A3 = 1) | Program fail; Illegal com- | Program fail; Illegal com- | Program fail; Illegal com- | | | | | mand | mand | mand | | | | | SR[4,8,9] = 1 | SR[4,8,9] = 1 | SR[4,8,9] = 1 | | | | 0041h to A-half (A3 = 0) | Program successful | Program successful | Program fail; Rewrite to | | | | | SR[4,8,9] = 0 | SR[4,8,9] = 0 | object mode region | | | | | Region configured to control | | SR[4,8] = 1 | | | | | mode | | SR[9] = 0 | | | | 00E9h to B-half (A3 = 1) | Program successful | Program fail; Object data | Program fail; Rewrite to | | | | | SR[4,8,9] = 0 | to control mode region | object mode region | | | | | Region configured to object | SR[4,9] = 1 | SR[4,8] = 1 | | | | | mode | SR[8] = 0 | SR[9] = 0 | | | | 00E9h to A-half (A3 = 0) | Program successful | Program successful | Program fail; Rewrite to | | | | | SR[4,8,9] = 0 | SR[4,8,9] = 0 | object mode region | | | | | Region configured to control | | SR[4,8] = 1 | | | | | mode | | SR[9] = 0 | | | ### **Program Operations** Programming the array changes 1s to 0s. To change 0s to 1s, an ERASE operation must be performed. Only one PROGRAM operation can occur at a time. Programming is permitted during erase suspend. Information is programmed into the array by issuing the appropriate command. All PROGRAM operations require the addressed block to be unlocked and a valid $V_{PP}$ voltage applied throughout the PROGRAM operation. Otherwise, the PROGRAM operation will abort, setting the appropriate status register error bit(s). If the device is deselected during a PROGRAM or ERASE operation, the device continues to consume active power until the PROGRAM or ERASE operation has completed. **Table 25: PROGRAM Command Bus Cycles** | Command | Setup WRITE Cycle<br>Address Bus | Setup WRITE Cycle<br>Data Bus | Confirm WRITE Cycle<br>Address Bus | Confirm WRITE Cycle<br>Data Bus | |-----------------------------------|----------------------------------|-------------------------------|------------------------------------|---------------------------------| | SINGLE-WORD<br>PROGRAM | Device address | 0041h | Device address | Array data | | BUFFERED PROGRAM | Device address | 00E9h | Device address | 00D0h | | BUFFERED ENHANCED FACTORY PROGRAM | Device address | 0080h | Device address | 00D0h | ### **Single-Word Programming** Single-word programming is performed by issuing the SINGLE-WORD PROGRAM command. This is followed by writing the desired data at the desired address. The read mode of the addressed partition is automatically changed to read status register mode, which remains in effect until another READ MODE command is issued. Issuing the READ STATUS REGISTER command to another partition switches that partition's read mode to read status register mode, thereby enabling programming progress to be monitored from that partition's address. Single-word programming is supported in control mode only. The array address specified must be in the A-half of the programming region. During programming, the status register indicates a busy status (SR[7] = 0). Upon completion, the status register indicates a ready status (SR[7] = 1). The status register should be checked for any errors, then cleared. The only valid commands during programming are READ ARRAY, READ ID, READ CFI, and PROGRAM SUSPEND. After programming completes, any valid command can be issued. Issuing the READ ARRAY, READ ID, or READ CFI command to a partition that is actively programming causes subsequent reads from that partition to output invalid data. Valid data is output only after the PROGRAM operation is complete. Standby power levels are not realized until the PROGRAM operation has completed. Asserting RST# immediately aborts the PROGRAM operation, and array contents at the addressed location are indeterminate. The addressed block should be erased and the data reprogrammed. ### **Single-Word Programming** Single-word programming is performed by issuing the SINGLE-WORD PROGRAM command. This is followed by writing the desired data at the desired address. The read mode of the addressed partition is automatically changed to read status register mode, which remains in effect until another READ MODE command is issued. Issuing the READ STATUS REGISTER command to another partition switches that partition's read mode to read status register mode, thereby enabling programming progress to be monitored from that partition's address. Single-word programming is supported in control mode only. The array address specified must be in the A-half of the programming region. During programming, the status register indicates a busy status (SR[7] = 0). Upon completion, the status register indicates a ready status (SR[7] = 1). The status register should be checked for any errors, then cleared. The only valid command during programming is PROGRAM SUSPEND. After programming completes, any valid command can be issued. Issuing the READ ARRAY, READ ID, or READ CFI command to a partition that is actively programming causes subsequent reads from that partition to output invalid data. Valid data is output only after the PROGRAM operation is complete. Standby power levels are not realized until the PROGRAM operation has completed. Asserting RST# immediately aborts the PROGRAM operation, and array contents at the addressed location are indeterminate. The addressed block should be erased and the data reprogrammed. ### **Buffered Programming** Buffered programming programs multiple words simultaneously into the memory array. Data is first written to a programming buffer and then programmed into the array in buffer-sized increments, significantly reducing the effective word programming time. Optimal performance and power consumption is realized only by aligning the starting address to buffer-sized boundaries within the array. Crossing a buffer-sized boundary can cause the buffered programming time to double. The BUFFERED PROGRAM operation consists of the following fixed, predefined sequence of bus WRITE cycles: 1) Issue the SETUP command; 2) Issue a word count; 3) Fill the buffer with user data; and 4) Issue the CONFIRM command. Once the SETUP command has been issued to an address, subsequent bus WRITE cycles must use addresses within the same block throughout the operation; otherwise, the operation will abort. Bus READ cycles are allowed at any time and at any address. Note: V<sub>PP</sub> must be at V<sub>PPL</sub> or V<sub>PPH</sub> throughout the BUFFERED PROGRAM operation. Upon programming completion, the status register indicates ready (SR7 = 1), and any valid command may be issued. A full status register check should be performed to check for any programming errors. If any error bits are set, the status register should be cleared using the CLEAR STATUS REGISTER command. A subsequent BUFFERED PROGRAM operation can be initiated by issuing another SET-UP command and repeating the buffered programming sequence. Any errors in the status register caused by a previous operation should first be cleared to prevent masking of errors that may occur during a subsequent BUFFERED PROGRAM operation. Valid commands issued to the busy partition during array programming are READ ARRAY, READ ID, READ CFI, READ STATUS, and PROGRAM SUSPEND. Issuing the READ ARRAY, READ ID, or READ CFI command to a partition that is actively programming causes subsequent reads from that partition to output invalid data. Valid data is output only after the PROGRAM operation has completed. ### **Buffered Programming** Buffered programming programs multiple words simultaneously into the memory array. Data is first written to a programming buffer and then programmed into the array in buffer-sized increments, significantly reducing the effective word programming time. Optimal performance and power consumption is realized only by aligning the starting address to buffer-sized boundaries within the array. Crossing a buffer-sized boundary can cause the buffered programming time to double. The BUFFERED PROGRAM operation consists of the following fixed, predefined sequence of bus WRITE cycles: 1) Issue the SETUP command; 2) Issue a word count; 3) Fill the buffer with user data; and 4) Issue the CONFIRM command. Once the SETUP command has been issued to an address, subsequent bus WRITE cycles must use addresses within the same block throughout the operation; otherwise, the operation will abort. Bus READ cycles are allowed at any time and at any address. **Note:** V<sub>PP</sub> must be at V<sub>PPL</sub> or V<sub>PPH</sub> throughout the BUFFERED PROGRAM operation. Upon programming completion, the status register indicates ready (SR7 = 1), and any valid command may be issued. A full status register check should be performed to check for any programming errors. If any error bits are set, the status register should be cleared using the CLEAR STATUS REGISTER command. A subsequent BUFFERED PROGRAM operation can be initiated by issuing another SET-UP command and repeating the buffered programming sequence. Any errors in the status register caused by a previous operation should first be cleared to prevent masking of errors that may occur during a subsequent BUFFERED PROGRAM operation. Valid commands issued to the busy partition during array programming are READ STATUS and PROGRAM SUSPEND. Issuing the READ ARRAY, READ ID, or READ CFI command to a partition that is actively programming causes subsequent reads from that partition to output invalid data. Valid data is output only after the PROGRAM operation has completed. ### **Buffered Enhanced Factory Programming** Buffered enhanced factory programming (BEFP) improves programming performance through the use of the write buffer, elevated programming voltage ( $V_{PPH}$ ), and enhanced programming algorithm. User data is written into the write buffer, and then the buffer contents are automatically written into the array in buffer-sized increments. Internal verification during programming (inherent to MLC technology) and status register error checking are used to determine proper completion of the PROGRAM operation. This eliminates delays incurred when switching between SINGLE-WORD PROGRAM and VERIFY operations. BEFP consists of the following three distinct phases: 1. Setup phase: V<sub>PPH</sub> and block lock checks - 2. Program/verify phase: buffered programming and verification - 3. Exit phase: block error check BEFP is supported in both control mode and object mode. The programming mode selection for the entire array block is driven by the specific type of information, such as header or object data. Header/object data is aligned on a 1KB programming region boundary in the main array block. #### **Table 26: BEFP Requirements and Considerations** | BEFP Requirements | Temperature (T <sub>AMBIENT</sub> ) must be 25 °C, ± 5 °C | | | |----------------------------|-------------------------------------------------------------------------|--|--| | | Voltage on $V_{CC}$ must be within the allowable operating range | | | | | Voltage on V <sub>PP</sub> must be within the allowable operating range | | | | | Block being programmed must be erased and unlocked | | | | <b>BEFP Considerations</b> | Block cycling below 100 ERASE cycles | | | | | Reading from another partition during BEFP (RWW) is not allowed | | | | | BEFP programs within one block at a time | | | | | BEFP cannot be suspended | | | #### **Table 27: BEFP Requirements and Considerations** | <b>BEFP Requirements</b> | Temperature (T <sub>AMBIENT</sub> ) must be 25 °C, ± 5 °C | | | |----------------------------|-------------------------------------------------------------------------|--|--| | | Voltage on V <sub>CC</sub> must be within the allowable operating range | | | | | /oltage on V <sub>PP</sub> must be within the allowable operating range | | | | | Block being programmed must be erased and unlocked | | | | <b>BEFP Considerations</b> | Block cycling below 100 ERASE cycles | | | | | BEFP programs within one block at a time | | | | | BEFP cannot be suspended | | | #### **BEFP Setup Phase** Issuing the BEFP SETUP and CONFIRM command sequence starts the BEFP algorithm. The read mode of the addressed partition is automatically changed to read status register mode. The address used when issuing the SETUP and CONFIRM commands must be buffersize aligned within the block being programmed; buffer contents cannot cross block boundaries. **Note:** The READ STATUS REGISTER command must not be issued; it will be interpreted as data to be written to the write buffer. A setup delay ( ${}^{t}$ BEFP/setup) occurs while the internal algorithm checks $V_{PP}$ and block lock status. If errors are detected, the appropriate status register error bits are set and the operation aborts. The status register should be polled for successful BEFP setup, indicated by SR[7:0] = 0 (device busy, buffer ready for data). #### **BEFP Program/Verify Phase** Data is first written into the write buffer, then programmed into the array. During the buffer fill sequence, the address used must be buffer-size aligned. Use of any other address will cause the operation to abort with a program fail error, and any data previously loaded in the buffer will not be programmed into the array. The buffer fill data is stored in sequential buffer locations starting at address 00h. A word count equal to the maximum buffer size is used; therefore, the buffer must be completely filled. If the amount of data is less than the maximum buffer size, the remaining buffer locations must be padded with FFFFh to completely fill the buffer. Array programming starts as soon as the write buffer is full. Data words from the write buffer are programmed into sequential array locations. SR0 = 1 indicates the write buffer is not available while the BEFP algorithm programs the array. The status register should be polled for SR0 = 0 (buffer ready for data) to determine when the array programming has completed and the write buffer is again available for loading. The internal address is automatically incremented to enable subsequent array programming to continue from where the previous buffer-fill/array program sequence ended within the block. This cycle can be repeated to program the entire block. #### **BEFP Exit Phase** To exit the program/verify phase, write FFFFh to an address outside of the block. The status register should be polled for SR7 = 1 (device ready), indicating the BEFP algorithm has finished running and the device has returned to normal operation. A full status register error check should be performed to ensure the block was programmed successfully. ### **Erase Operations** #### **BLOCK ERASE** Erasing a block changes 0s to 1s. To change 1s to 0s, a PROGRAM operation must be performed. 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 1s (FFFFh). Only one BLOCK ERASE operation can occur at a time. A BLOCK ERASE operation is not permitted during program suspend. All BLOCK ERASE operations require the addressed block to be unlocked, and $V_{PP}$ must be at $V_{PPL}$ or $V_{PPH}$ throughout the BLOCK ERASE operation. Otherwise, the operation aborts, setting the appropriate status register error bit(s). To perform a BLOCK ERASE operation, issue the BLOCK ERASE SETUP command at the desired block address. The read mode of the addressed partition automatically changes to read status register mode and remains in effect until another READ MODE command is issued. The ERASE CONFIRM command latches the address of the block to be erased. The addressed block is preconditioned (programmed to all 0s), erased, and then verified. Issuing the READ STATUS REGISTER command to another partition switches that partition's read mode to the read status register, thereby allowing block erase progress to be monitored from that partition's address. SR0 indicates whether the addressed partition or the other partition is erasing. During a BLOCK ERASE operation, the status register indicates a busy status (SR[7] = 0). Issuing the READ ARRAY command to a partition that is actively erasing a main block causes subsequent reads from that partition to output invalid data. Valid array data is output only after the BLOCK ERASE operation has finished. Upon completion, the status register indicates a ready status (SR[7] = 1). The status register should be checked for any errors, and then cleared. If the device is deselected during an ERASE operation, the device continues to consume active power until the ERASE operation is completed. Asserting RST# immediately aborts the BLOCK ERASE operation, and array contents at the addressed location are indeterminate. The addressed block should be erased again. The only valid commands during a BLOCK ERASE operation are READ ARRAY, READ ID, READ CFI, and ERASE SUSPEND. After the BLOCK ERASE operation has completed, any valid command can be issued. The only valid command during a BLOCK ERASE operation is ERASE SUSPEND. After the BLOCK ERASE operation has completed, any valid command can be issued. #### **Table 28: ERASE Command Bus Cycle** | Command | Setup WRITE Cycle<br>Address Bus | Setup WRITE Cycle<br>Data Bus | Confirm WRITE Cycle Address Bus | Confirm WRITE Cycle Data Bus | |-------------|----------------------------------|-------------------------------|---------------------------------|------------------------------| | BLOCK ERASE | Device address | 0020h | Block address | 00D0h | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM SUSPEND and RESUME Operations ### **SUSPEND and RESUME Operations** PROGRAM and ERASE operations of the main array can be suspended to perform other device operations, and then subsequently resumed. OTP area programming operations cannot be suspended. During erase suspend or program suspend, the addressed block must remain unlocked, $V_{PP}$ must be at $V_{PPL}$ or $V_{PPH}$ , and WP# must remain unchanged. Otherwise, the ERASE or PROGRAM operation will abort, setting the appropriate status register error bit(s). ### **SUSPEND Operation** To suspend an ongoing ERASE or PROGRAM operation, issue the SUSPEND command to any device address. Issuing the SUSPEND command does not change the read mode. Upon issuing a SUSPEND command, the ongoing ERASE or PROGRAM operation suspends after a delay of ${}^{t}$ SUSP. The operation is suspended only when SR[7:6] = 1 (erase suspend) or SR[7:2] = 1 (program suspend). While suspended, reading from a block that was being erased or programmed is not allowed. Also, programming within an erase suspended block is not allowed, and if attempted, will result in a programming error (SR[4] = 1). Erasing under program suspend is not allowed. However, array programming under erase suspend is allowed, and can also be suspended. This results in a simultaneous erase suspend and program suspend condition, indicated by SR[7:6,2] = 1. Additional valid commands while suspended are READ ARRAY, READ STATUS REGISTER, READ ID, READ CFI, CLEAR STATUS REGISTER, and RESUME. No other commands are allowed. During suspend, CE# may be de-asserted, placing the device in standby and reducing active current to standby levels. $V_{PP}$ must remain at $V_{PPL}$ or $V_{PPH}$ , and WP# must remain unchanged. Asserting RST# aborts any suspended BLOCK ERASE and PROGRAM operations; array contents at the addressed locations will be indeterminate. During suspend, CE# may be de-asserted. The device is placed in standby, reducing active current. $V_{PP}$ must remain at $V_{PPL}$ or $V_{PPH}$ , and WP# must remain unchanged. Asserting RST# aborts suspended BLOCK ERASE and PROGRAM operations; array contents at the addressed locations are indeterminate. A BUFFERED PROGRAM command sequence can be terminated during a the BUFFER FILL operation while in an erase suspend by issuing any non-00D0h command (non-confirm command) to the same block address to which the BUFFERED PROGRAM command was written. **Table 29: Valid Commands During Suspend** | Device Command | Program Suspend | Erase Suspend | |-------------------------|-----------------|---------------| | 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 | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM SUSPEND and RESUME Operations **Table 29: Valid Commands During Suspend (Continued)** | Device Command | Program Suspend | Erase Suspend | |----------------------------------------|-----------------|---------------| | BUFFERED PROGRAM | Not Allowed | Allowed | | BUFFERED ENHANCED FACTORY PRO-<br>GRAM | Not Allowed | Not Allowed | | BLOCK ERASE | Not Allowed | Not Allowed | | PROGRAM/ERASE SUSPEND | Not Allowed | Not Allowed | | PROGRAM/ERASE RESUME | Allowed | Allowed | ### **RESUME Operation** To resume a suspended ERASE or PROGRAM operation, issue the RESUME command to any device address. The ERASE or PROGRAM operation continues where it left off, and the respective status register suspend bit is cleared. Issuing the RESUME command does not change the read mode. When the RESUME command is issued during a simultaneous erase suspend or program suspend condition, the PROGRAM operation is resumed first. Upon completion of the PROGRAM operation, the status register should be checked for any errors, and cleared if needed. 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 if needed. **Table 30: SUSPEND and RESUME Command Bus Cycles** | Command | Setup WRITE Cycle<br>Address Bus | Setup WRITE Cycle<br>Data Bus | Confirm WRITE Cycle<br>Address Bus | Confirm WRITE Cycle<br>Data Bus | |---------|----------------------------------|-------------------------------|------------------------------------|---------------------------------| | SUSPEND | Device address | 00B0h | _ | _ | | RESUME | Device address | 00D0h | _ | - | # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM BLANK CHECK Operation ### **BLANK CHECK Operation** Blank check verifies whether a main-array block is completely erased. A BLANK CHECK operation is performed one block at a time, and cannot be used during program suspend or erase suspend. To use blank check, first issue the BLANK CHECK SETUP command followed by the CONFIRM command. The read mode of the addressed partition is automatically changed to read status register mode, which remains in effect until another read mode is issued. During a BLANK CHECK operation, the status register indicates a busy status (SR[7] = 0). Upon completion, the status register indicates a ready status (SR[7] = 1). Issuing the READ STATUS REGISTER command to another partition switches that partition's read mode to read status register mode, thereby allowing the BLANK CHECK operation to be monitored from that partition's address. The status register should be checked for any errors, and then cleared. If the BLANK CHECK operation fails (the block is not completely erased), then the status register will indicate a blank check error (SR[7:5] = 1). The only valid command during a BLANK CHECK operation is read status. Blank check cannot be suspended. After the BLANK CHECK operation has completed, any valid command can be issued. **Table 31: BLANK CHECK Command Bus Cycles** | Command | Setup WRITE Cycle | Setup WRITE Cycle | Confirm WRITE Cycle | Confirm WRITE Cycle | |----------------|-------------------|-------------------|---------------------|---------------------| | | Address Bus | Data Bus | Address Bus | Data Bus | | BLANK<br>CHECK | Block address | 00BCh | Block address | 00D0h | #### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Block Lock ### **Block Lock** Two methods of block lock control are available: software and hardware. Software control uses the BLOCK LOCK and BLOCK UNLOCK commands. Hardware control uses the BLOCK LOCK-DOWN command along with asserting WP#. Upon power-up or exit from reset, all main array blocks are locked, but not locked down. Locked blocks cannot be erased or programmed. BLOCK LOCK and UNLOCK operations are independent of the voltage level on $V_{PP}$ . To lock, unlock, or lock-down a block, first issue the SETUP command to any address within the desired block. The read mode of the addressed partition is automatically changed to read status register mode. Next, issue the desired CONFIRM command to the block's address. Note that the CONFIRM command determines the operation performed. The status register should be checked for any errors, and then cleared. The lock status of a block can be determined by issuing the READ ID command, and then reading from the block's base address + 02h. See the table below table for the lock-bit settings. Blocks cannot be locked or unlocked while being actively programmed or erased. Blocks can be locked or unlocked during erase suspend, but not during program suspend. If a BLOCK ERASE operation is suspended, and then the block is locked or locked down, the lock status of the block will be changed immediately. When resumed, the ERASE operation will still complete. Block lock-down protection is dependent on WP#. A locked-down block can only be unlocked by issuing the BLOCK UNLOCK command with WP# de-asserted. To return an unlocked block to the locked-down state, a BLOCK LOCK-DOWN command must be issued prior to asserting WP#. When WP# = $V_{\rm IL}$ , blocks locked down are locked, and cannot be unlocked using the BLOCK UNLOCK command. When WP# = $V_{IH}$ , block lock-down protection is disabled; locked-down blocks can be individually unlocked using the BLOCK UNLOCK command. Subsequently, when WP# = $V_{\rm IL}$ , previously locked-down blocks are once again locked and locked-down, including locked-down blocks that may have been unlocked while WP# was de-asserted. Issuing the BLOCK LOCK-DOWN command to an unlocked block does not lock the block. However, asserting WP# after issuing the BLOCK LOCK-DOWN command locks (and locks down) the block. Lock-down for all blocks is only cleared upon power-up or exit from reset. **Table 32: BLOCK LOCK Command Bus Cycles** | Command | Setup WRITE Cycle<br>Address Bus | Setup WRITE Cycle<br>Data Bus | Confirm WRITE Cycle<br>Address Bus | Confirm WRITE Cycle<br>Data Bus | |-------------------|----------------------------------|-------------------------------|------------------------------------|---------------------------------| | BLOCK<br>LOCK | Block address | 0060h | Block address | 0001h | | BLOCK UN-<br>LOCK | Block address | 0060h | Block address | 00D0h | **Table 32: BLOCK LOCK Command Bus Cycles (Continued)** | Command | Setup WRITE Cycle<br>Address Bus | Setup WRITE Cycle<br>Data Bus | Confirm WRITE Cycle<br>Address Bus | Confirm WRITE Cycle<br>Data Bus | |---------|----------------------------------|-------------------------------|------------------------------------|---------------------------------| | BLOCK | Block address | 0060h | Block address | 002Fh | | LOCK- | | | | | | DOWN | | | | | **Table 33: Block Lock Configuration** | Block Lock Configuration | Block Base Address | Bit | |--------------------------|---------------------------|-----------| | Block is unlocked | Block base address = 0x02 | DQ0 = 0b0 | | Block is locked | Block base address = 0x02 | DQ0 = 0b1 | | Block is not locked down | Block base address = 0x02 | DQ1 = 0b0 | | Block is locked down | Block base address = 0x02 | DQ1 = 0b1 | **Figure 15: BLOCK LOCK Operations** Software control (LOCK, UNLOCK, LOCK-DOWN command) Hardware control (WP#) Notes: 1. The [n,n,n] denotes logical state of WP#, DQ1,and DQ0, respectively; X = "Don't Care." 2. The [0,1,1] states should be tracked by system software to differentiate between the hardware-locked state and the lock-down state. ### **One-Time Programmable Operations** The device contains sixteen 128-bit one-time programmable (OTP) blocks, two 64-bit OTP blocks, and two 16-bit OTP lock registers. OTP lock register 0 is used for locking OTP blocks 0 and 1 (two 64-bit blocks), and OTP lock register 1 is used for locking OTP blocks 2 through 17 (sixteen 128-bit blocks). Each block contains OTP bits that are factory set to 1 and can only be programmed from 1 to 0; OTP block bits cannot be erased from 0 back to 1. This feature makes the OTP blocks particularly useful for implementing system-level security schemes, permanently storing data, or storing fixed system parameters. OTP block 0 is pre-programmed with a unique 64-bit value and locked at the factory. OTP block 1 contains all 1s and is user-programmable. OTP blocks 1 through 16 contain all 1s and are user-programmable. Each OTP block can be accessed multiple times to program individual bits, as long as the block remains unlocked. When a lock register bit is programmed, the associated OTP block can only be read—it can no longer be programmed. OTP lock register bits lock out subsequent programming of the corresponding OTP block. Each OTP block can be locked by programming its corresponding lock bit to 0. As long as an OTP block remains unlocked (that is, its lock bit = 1), any of its remaining 1 bits can be programmed to 0. **Note:** Once an OTP block is locked, it cannot be unlocked. Attempts to program a locked OTP block will fail with error bits set. Additionally, because the lock register bits themselves are OTP, when programmed, lock register bits cannot be erased. Therefore, when an OTP block is locked, it cannot be unlocked. **Table 34: Program OTP Area Command Bus Cycles** | Command | Setup WRITE Cycle | Setup WRITE Cycle | Confirm WRITE Cycle | Confirm WRITE Cycle | |------------------|-------------------|-------------------|----------------------|---------------------| | | Address Bus | Data Bus | Address Bus | Data Bus | | PROGRAM OTP AREA | Device address | 00C0h | OTP register address | Register data | Figure 16: OTP Area Map ### **Programming OTP Area** OTP area programming is performed 16 bits at a time; only zeros within the data word affect any change to the OTP bits. To program any OTP blocks or lock registers, first issue the PROGRAM OTP AREA SET-UP command at any device address. The read state of that partition changes to read status. Next, write the desired OTP data at the desired OTP address. Attempting to program outside of the OTP area causes a program error (SR[4] = 1). Attempting to program a locked OTP block causes a program error and a lock error (SR[4] = 1, SR[1] = 1). OTP area programming cannot be suspended. Dual operations between the parameter partition and the OTP area are not allowed. ### **Reading OTP Area** The OTP area is read from within the address space of any partition. To read from the OTP area. the following must be done: - 1. Issue the READ ID command at the address of any partition to place that partition in the read ID state. - 2. Perform a READ operation at the base address of that partition, plus the address offset corresponding to the OTP word to be read. Data is read 16 bits at a time. If a PROGRAM or ERASE operation occurs within the device while it is reading from the OTP area, certain restrictions may apply. # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Global Main-Array Protection ### **Global Main-Array Protection** Global main-array protection can be implemented by controlling $V_{PP}$ . When programming or erasing main-array blocks, $V_{PP}$ must be equal to or greater than $V_{PPL, \, min}$ . When $V_{PP}$ is below $V_{PPLK}$ , PROGRAM or ERASE operations are inhibited, thus providing absolute protection of the main array. Various methods exist for controlling $V_{PP}$ , ranging from simple logic control to off-board voltage control. The following figure shows example $V_{PP}$ supply connections that can be used to support PROGRAM or ERASE operations and main-array protection. Figure 17: V<sub>PP</sub> Supply Connection Example ### **Dual Operation** Multipartition architecture of the device enables reading from one partition while a PROGRAM or ERASE operation is occurring in another partition. This is called read-while-program and read-while-erase, respectively. Only status reads are allowed from a partition that is busy programming or erasing. If non-status reads are required from a partition that is busy programming or erasing, the PROGRAM or ERASE operation must be suspended first. #### **Table 35: Dual Operation Restrictions** The following table shows the allowed dual operations between array operations and non-array operations | Read | Program or Erase<br>Main Partition | Program OTP Area | |-----------------|------------------------------------|-----------------------------| | Main Partition | Yes (except busy partition) | Yes (except busy partition) | | Status | Yes | Yes | | ID, OTP, or CFI | Yes (except busy partition) | No | ### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Power and Reset Specifications ### **Power and Reset Specifications** #### **Initialization** Proper device initialization and operation is dependent on the power-up/down sequence, reset procedure, and adequate power-supply decoupling. ### **Power-Up and Down** To avoid conditions that may result in spurious PROGRAM or ERASE operations, the power sequences shown below are recommended. Note that each power supply must be at its minimum voltage range before applying or removing the next supply voltage in the sequence. Also, device inputs must not be driven until all supply voltages have attained their minimum range, and RST# should be LOW during all power transitions. When powering down the device, voltages should reach 0V before power is reapplied to ensure proper device initialization. Otherwise, indeterminate operation could result. When $V_{\text{CCQ}}$ goes below $V_{\text{LKOO}}$ , the device is reset. **Table 36: Power Sequencing** | Power Supply | Power-Up Sequence | | | | l | Power-Dow | n Sequence | • | |----------------------|-------------------|---------------------|--------------------|--------------------|--------|--------------------|---------------------|---------------------| | V <sub>CC,min</sub> | First | First | First <sup>1</sup> | First <sup>1</sup> | Third | Second | Second <sup>1</sup> | Second <sup>1</sup> | | V <sub>CCQ,min</sub> | Second | Second <sup>1</sup> | First <sup>1</sup> | Second | Second | First <sup>1</sup> | Second <sup>1</sup> | First | | V <sub>PP,min</sub> | Third | Second <sup>1</sup> | Second | First <sup>1</sup> | First | First <sup>1</sup> | First | Second <sup>1</sup> | Note: 1. Connected/sequenced together. #### Reset During power-up and power-down, RST# should be asserted to prevent spurious PRO-GRAM or ERASE operations. While RST# is LOW, device operations are disabled, all inputs such as address and control are ignored, and all outputs such as data and WAIT are placed in High-Z. Invalid bus conditions are effectively masked out. Upon power-up, RST# can be de-asserted after <sup>t</sup>VCCPH, allowing the device to exit from reset. Upon exiting from reset, the device defaults to asynchronous read array mode, and the status register defaults to 0080h. Array data is available after <sup>t</sup>PHQV, or a bus WRITE cycle can begin after <sup>t</sup>PHWL. If RST# is asserted during a PROGRAM or ERASE operation, the operation will abort and array contents at that location will be invalid. For proper system initialization, connect RST# to the LOW true reset signal that asserts whenever the processor is reset. This will ensure the device is in the expected read mode (read array) upon startup. **Figure 18: RESET Operation Waveforms** #### **Table 37: Reset Specifications** Note 1 applies to all | tota i applies to all | | | | | | | | |--------------------------------------------------|--------------------|-----|-----|------|---------|--|--| | Parameter | Symbol | Min | Max | Unit | Notes | | | | RST# pulse width LOW | <sup>t</sup> PLPH | 100 | _ | ns | 2, 3, 6 | | | | RST# LOW to device reset during erase | <sup>t</sup> PLRH | _ | 25 | μs | 3, 6 | | | | RST# LOW to device reset during program | | - | 25 | | 3, 6 | | | | $V_{CC}$ power valid to RST# de-assertion (HIGH) | <sup>t</sup> VCCPH | 300 | _ | | 4, 5 | | | - Notes: 1. These specifications are valid for all packages and speeds, and are sampled, not 100% tested. - 2. The device might reset if <sup>t</sup>PLPH is < <sup>t</sup>PLPH MIN, but this is not guaranteed. - 3. Not applicable if RST# is tied to V<sub>CCO</sub>. - 4. If RST# is tied to the $V_{CC}$ supply, the device is not ready until ${}^{t}VCCPH$ after $V_{CC} \ge V_{CC,min}$ . - 5. If RST# is tied to any supply/signal with $V_{CCQ}$ voltage levels, the RST# input voltage must not exceed $V_{CC}$ until $V_{CC} \ge V_{CC,min}$ . - 6. Reset completes within <sup>†</sup>PLPH if RST# is asserted while no ERASE or PROGRAM operation is executing. ### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Power and Reset Specifications ### **Automatic Power Saving** Automatic power saving provides low-power operation following reads during active mode. After data is read from the memory array and the address lines are quiescent, automatic power savings automatically places the device into standby. In automatic power savings, device current is reduced to $I_{CCAPS}$ . ### **Deep Power-Down** The lowest power state of the memory device is deep power-down (DPD). To enter DPD mode, the following three conditions must be met (in any order): - Extended configuration register bit 15 must be set to 1 - RST# and CE# must be de-asserted - The DPD input pin must be asserted If the device is placed in DPD mode during a PROGRAM or ERASE operation, the operation is aborted. The memory contents at the aborted address or block will no longer be valid. If the device is placed in DPD mode while suspended, the operation cannot be resumed. While in DPD state, all inputs are ignored except for DPD and RST#. Partition read modes, configuration register contents, and block lock bit settings are preserved. The status register will be reset to 0080h, and the error bits are cleared. To exit DPD mode, the DPD input pin must be de-asserted. An exit delay occurs before the device returns to standby, and before any operations can be performed (see AC Specifications). **Table 38: Deep Power-Down Specifications** | Parameter | Symbol | Min | Max | Unit | |---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----|-----|------| | DPD asserted pulse width; DPD must remain asserted for the duration of the mode; DPD current levels are achieved 40µs after entering the DPD mode | <sup>t</sup> SLSH<br>( <sup>t</sup> SHSL) | 100 | - | ns | | CE# HIGH to DPD asserted | <sup>t</sup> EHSH<br>( <sup>t</sup> EHSL) | 0 | - | μs | | DPD de-asserted to CE# LOW | <sup>t</sup> SHEL<br>( <sup>t</sup> SLEL) | 75 | - | μs | | RST# HIGH during DPD state to CE# LOW (DPD de-asserted to CE# LOW) | <sup>t</sup> PHEL | 75 | - | μs | **Figure 19: Deep Power-Down Operation Timing** Note: 1. DPD pin is LOW-true (ECR[14] = 0). Figure 20: Reset During Deep Power-Down Operation Timing Note: 1. DPD pin is LOW-true (ECR[14] = 0). ### **Power Supply Decoupling** Flash memory devices require careful power supply decoupling to prevent external transient noise from affecting device operations, and to prevent internally generated transient noise from affecting other devices in the system. Ceramic chip capacitors of $0.01\mu F$ to $0.1\mu F$ should be used between all $V_{CC}$ , $V_{CCQ}$ , and $V_{PP}$ supply connections and system ground. These high-frequency, inherently low-inductance capacitors should be placed as close as possible to the device package, or on the opposite side of the printed circuit board close to the center of the device package footprint. Larger (4.7 $\mu$ F to 33.0 $\mu$ F) electrolytic or tantulum bulk capacitors should also be distributed as needed throughout the system to compensate for voltage sags and surges caused by circuit trace inductance. Transient current magnitudes depend on the capacitive and inductive loading on the device's outputs. For best signal integrity and device performance, high-speed design rules should be used when designing the printed-circuit board. Circuit-trace impedances should match output-driver impedance with adequate ground-return paths. This will help minimize signal reflections (overshoot/undershoot) and noise caused by high-speed signal edge rates. ### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM **Electrical Specifications** ### **Electrical Specifications** Stresses greater than those listed may cause permanent damage to the device. This is a stress rating only. Exposure to absolute maximum rating and operating conditions for extended periods may adversely affect reliability. Stressing the device beyond the absolute maximum ratings may cause permanent damage. These are stress ratings only. **Table 39: Absolute Maximum Ratings** | Parameter | Min | Max | Units | Notes | |-------------------------------------------------------------------------------------------------------|---------|------------------------|--------|---------| | Temperature under bias (T <sub>A</sub> ) | -40 | 85 | °C | 5 | | Storage temperature (T <sub>A</sub> ) | -65 | 125 | °C | 5 | | V <sub>PP</sub> voltage | -2.0 | 11.5 | V | 1, 2, 3 | | V <sub>CC</sub> voltage | -2.0 | V <sub>CCQ</sub> + 2.0 | V | 1 | | Voltage on any input/output signal (except V <sub>CC</sub> , V <sub>CCQ</sub> , and V <sub>PP</sub> ) | -2.0 | V <sub>CCQ</sub> + 2.0 | V | 2 | | V <sub>CCQ</sub> voltage | -0.2 | V <sub>CCQ</sub> + 2.0 | V | 1 | | V <sub>PPH</sub> time | _ | 80 | hours | 3 | | Output short circuit current | _ | 100 | mA | 4 | | Block PROGRAM/ERASE cycles: Main blocks | 100,000 | _ | Cycles | 3 | - Notes: 1. Voltages shown are specified with respect to $V_{SS}$ . During transitions, the voltage potential between V<sub>SS</sub> and input/output and supply pins may undershoot to -1.0V for periods less than 20ns and may overshoot to $V_{CCQ}(MAX) + 1.0V$ for periods less than 20ns. - 2. Voltages shown are specified with respect to V<sub>SS</sub>. During transitions, the voltage potential between V<sub>SS</sub> and supply pins may undershoot to -2.0V for periods less than 20ns and may overshoot to $V_{CC}$ (MAX) + 2.0V for periods less than 20ns. - 3. Operation beyond this limit may degrade performance. - 4. Output shorted for no more than one second; no more than one output shorted at a - 5. Temperature specified is ambient $(T_A)$ , not case $(T_C)$ . #### **Table 40: Operating Conditions** | Symbol | Parameter | Min | Max | Units | Notes | |------------------|----------------------------------------------|-----|-----|-------|-------| | T <sub>A</sub> | Operating temperature | -40 | 85 | °C | 1 | | V <sub>CC</sub> | V <sub>CC</sub> supply voltage | 1.7 | 2.0 | V | | | V <sub>CCQ</sub> | I/O supply voltage | 1.7 | 2.0 | V | | | V <sub>PPL</sub> | V <sub>PP</sub> voltage supply (logic level) | 0.9 | 2.0 | V | | | V <sub>PPH</sub> | Factory programming V <sub>PP</sub> | 8.5 | 9.5 | V | | Note: 1. $T_A = Temperature specified is ambient (<math>T_A$ ), not case ( $T_C$ ). # **Electrical Specifications – DC Current and Voltage Characteristics and Operating Conditions** **Table 41: DC Current Characteristics and Operating Conditions** | | | | Density | 1.7 V | - 2.0 V | | | |---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------|-------------------|------|---------| | Parameter | Symbol | Conditions | | | Мах | Unit | Notes | | Input Load, Output Lea | akage, Stand | lby, Deep Power Down | | | • | | | | Input load<br>current | l <sub>Ll</sub> | $V_{CC} = V_{CC,max}$ ; $V_{CCQ} = V_{CCQ,max}$ ; $V_{IN} = V_{CCQ}$ or $V_{SS}$ | - | _ | ±1 | μА | 1 | | Output leakage current | I <sub>LO</sub> | $V_{CC} = V_{CC,max}$ ; $V_{CCQ} = V_{CCQ,max}$ ; $V_{IN} = V_{CCQ}$ or $V_{SS}$ | - | _ | ±1 | μА | 1 | | V <sub>CC</sub> standby current | I <sub>CCS</sub> ,<br>I <sub>CCD</sub> | $V_{CC} = V_{CC,max}$ ; $V_{CCQ} = V_{CCQ,max}$ ; $CE\# = V_{CCQ}$ ; RST# = $V_{CCQ}$ or GND (for $I_{CCS}$ ); $WP\# = V_{IH}$ | 256<br>512<br>1024 | 50<br>60<br>70 | 130<br>160<br>185 | μА | 1, 2 | | V <sub>CC</sub> deep power down current | I <sub>DPD</sub> | $\begin{split} &V_{CC} = V_{CC,max}; \ V_{CCQ} = \\ &V_{CCQ,max}; \ CE\# = V_{CCQ}; \ RST\# \\ &= V_{CCQ}; \ ECR[15] = V_{CCQ}; \\ &DPD = V_{CCQ} \ or \ V_{SSQ}; \ All \ inputs \ are \ at \ rail-to-rail \ (V_{CCQ} \\ ∨ \ V_{SSQ}) \end{split}$ | - | 2 | 30 | μΑ | 1, 2 | | Average V <sub>CC</sub> Read | | , | | | | • | ' | | Average V <sub>CC</sub> read current; Asychronous single-word read; f = 5 MHz; 1 CLK | I <sub>CCR</sub> | $V_{CC} = V_{CC,max}$ ; CE# = $V_{IL}$ ;<br>OE# = $V_{IH}$ ; Inputs: $V_{IL}$ or $V_{IH}$ | - | 25 | 30 | mA | 1, 3, 4 | | Average V <sub>CC</sub> read current; Page mode read; f = 13 MHz; 17 CLK; Burst = 16-word | I <sub>CCR</sub> | $V_{CC} = V_{CC,max}$ ; CE# = $V_{IL}$ ;<br>OE# = $V_{IH}$ ; Inputs: $V_{IL}$ or $V_{IH}$ | - | 11 | 15 | mA | 1, 3, 4 | | Average V <sub>CC</sub> read current; Sychronous burst read; f = 66 MHz; LC = 7; Burst = 8-word Burst = 16-word; Burst = Continuous | I <sub>CCR</sub> | $V_{CC} = V_{CC,max}$ ; $CE\# = V_{IL}$ ; $OE\# = V_{IH}$ ; $Inputs: V_{IL} \text{ or } V_{IH}$ | - | 22<br>19<br>25 | 32<br>26<br>34 | mA | 1, 3, 4 | | Average V <sub>CC</sub> read current; Sychronous burst read; f = 108 MHz; LC = 10; Burst = 8-word Burst = 16-word; Burst = Continuous | I <sub>CCR</sub> | $V_{CC} = V_{CC,max}$ ; CE# = $V_{IL}$ ;<br>OE# = $V_{IH}$ ; Inputs: $V_{IL}$ or $V_{IH}$ | - | 26<br>23<br>30 | 36<br>30<br>42 | mA | 1, 3, 4 | ### 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Electrical Specifications – DC Current and Voltage Characteristics and Operating Conditions Table 41: DC Current Characteristics and Operating Conditions (Continued) | | | | Density | 1.7 V | - 2.0 V | | | |----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------|-------------------|----------|------------| | Parameter | Symbol | Conditions | (Mb) | Тур | Тур Мах | | Notes | | Average V <sub>CC</sub> read current; Sychronous burst read; f = 133 MHz; LC = 13; Burst = 8-word Burst = 16-word; | I <sub>CCR</sub> | $V_{CC} = V_{CC,max}$ ; CE# = $V_{IL}$ ;<br>OE# = $V_{IH}$ ; Inputs: $V_{IL}$ or $V_{IH}$ | - | 26<br>24<br>40 | 35<br>33<br>46 | mA | 1, 3, 4 | | Burst = Continuous | | | | | | | | | V <sub>CC</sub> Program, Erase, Bl | ank Check | | | | | | | | V <sub>CC</sub> Program<br>V <sub>CC</sub> Erase<br>V <sub>CC</sub> Blank Check | I <sub>CCW</sub> ,<br>I <sub>CCE</sub> ,<br>I <sub>CCBC</sub> | $V_{PP} = V_{PPL}$ or $V_{PP} = V_{PPH}$ ;<br>Program/erase in progress | _ | 45<br>35<br>40 | 55 | mA | 1, 3, 4, 5 | | V <sub>CC</sub> Program suspend<br>V <sub>CC</sub> Erase suspend | I <sub>CCWS</sub> ,<br>I <sub>CCES</sub> | CE# = V <sub>CCQ</sub> ; Suspend in progress | 256<br>512<br>1024 | 50<br>60<br>70 | 130<br>160<br>185 | μА | 1, 3, 6 | | V <sub>PP</sub> Program, Read, Era | ase, Blank Ch | eck, Standby | | | | | | | V <sub>PP</sub> standby current;<br>V <sub>PP</sub> program suspend<br>current; V <sub>PP</sub> erase sus-<br>pend current | I <sub>PPS</sub> ,<br>I <sub>PPWS</sub> ,<br>I <sub>PPES</sub> | V <sub>PP</sub> = V <sub>PPL</sub> ; Suspend in pro-<br>gress | _ | 0.2 | 5 | μА | 3 | | V <sub>PP</sub> read | I <sub>PPR</sub> | V <sub>PP</sub> ≤ V <sub>CC</sub> | _ | 2 | 15 | μΑ | 3 | | V <sub>PP</sub> program current | | | _ | 0.05 | 0.10 | mA | 3 | | V <sub>PP</sub> erase current | I <sub>PPE</sub> | $V_{PP} = V_{PPL} = V_{PPH}$ ; Erase in progress | - | 0.05 | 0.10 | mA | 3 | | V <sub>PP</sub> blank check current | I <sub>PPBC</sub> | $V_{PP} = V_{PPL} = V_{PPH}$ ; Blank check in progress | - | 0.05 | 0.10 | mA | 3 | | <b>Automatic Power Savi</b> | ngs | | 1 | <u>'</u> | ' | <u>'</u> | <u>'</u> | | Automatic power savings | I <sub>CCAPS</sub> | $V_{CC} = V_{CC,max}$ ; $V_{CCQ} = V_{CCQ,max}$ ; $CE\# = V_{SSQ}$ ; RST# = $V_{CCQ}$ ; All inputs are at rail-to-rail ( $V_{CCQ}$ or $V_{SSQ}$ ) | 256<br>512<br>1024 | 50<br>60<br>70 | 130<br>165<br>185 | μА | - | - Notes: 1. All currents are RMS unless noted. Typical values at typical $V_{CCQ}$ , $T_A = +25$ °C. - 2. I<sub>CCS</sub> is the average current measured over any 5ms time interval 5µs after CE# is de-asserted. - 3. Sampled, not 100% tested. - 4. $V_{CC}$ read + program current is the sum of $V_{CC}$ read and $V_{CC}$ program currents. $V_{CC}$ read + erase current is the sum of $V_{CC}$ read and $V_{CC}$ erase currents. - 5. I<sub>CCW</sub>, I<sub>CCE</sub> is measured over typical or max times specified in Program and Erase Characteristics. - 6. IDPD is specified with the device deselected. If the device is read while in erase suspend, current is I<sub>CCES</sub> + I<sub>CCR</sub>. - 7. I<sub>DPD</sub> is the current measured 40µs after enter deep power-down. # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Electrical Specifications – DC Current and Voltage Characteristics and Operating Conditions #### **Table 42: DC Voltage Characteristics and Operating Conditions** | | | | V <sub>CCQ</sub> =<br>1.7V - 2.0V | | | | |---------------------------------|-------------------|-----------------------------------------------------------------------|-----------------------------------|------------------|------|-------| | Parameter | Symbol | Conditions | Min | Max | Unit | Notes | | Input low voltage | V <sub>IL</sub> | _ | 0 | 0.45 | V | 1 | | Input high voltage | V <sub>IH</sub> | _ | V <sub>CCQ</sub> -<br>0.45 | V <sub>CCQ</sub> | V | 1 | | Output low voltage | V <sub>OL</sub> | $V_{CC} = V_{CC,min}$ ; $V_{CCQ} = V_{CCQ,min}$ ; $I_{OL} = 100\mu A$ | - | 0.1 | V | | | Output high voltage | V <sub>OH</sub> | $V_{CC} = V_{CC,min}$ ; $V_{CCQ} = V_{CCQ,min}$ ; $I_{OL} = 100\mu A$ | V <sub>CCQ</sub> - 0.1 | - | V | | | V <sub>PP</sub> lockout voltage | V <sub>PPLK</sub> | _ | _ | 0.4 | V | 2 | | V <sub>CC</sub> lock voltage | V <sub>LKO</sub> | _ | 1.0 | _ | V | | | V <sub>CCQ</sub> lock voltage | $V_{LKOQ}$ | _ | 0.8 | _ | V | | - Notes: 1. Input voltages can undershoot to -1.0V and overshoot to $V_{CCQ}$ + 1V for durations of 2ns or less. - 2. $V_{PP}$ < $V_{PPLK}$ inhibits ERASE and PROGRAM operations. Do not use $V_{PPL}$ and $V_{PPH}$ outside of their valid ranges. ### **Electrical Specifications - AC Characteristics and Operating Conditions** #### **AC Test Conditions** Figure 21: AC Input/Output Reference Waveform Note: 1. AC test inputs are driven at $V_{CCQ}$ for Logic 1, and 0.0V for Logic 0. Input/output timing begins/ends at $V_{CCQ}/2$ . Input rise and fall times (10% to 90%) <5ns. Worst-case speed occurs at $V_{CC} = V_{CC.min}$ . **Table 43: AC Input Requirements** | Parameter | Symbol | Frequency | Min | Max | Unit | Condition | Notes | |----------------------------------------------------------------|------------------------|----------------------|-----|-----|------|-----------------------------------------------------------------------------|-------| | Inputs rise/fall time (Address, CLK, CE#, OE#, ADV#, WE#, WP#) | <sup>t</sup> RISE/FALL | @133 MHz, 108<br>MHz | 0.3 | 1.2 | ns | V <sub>IL</sub> to V <sub>IH</sub> or V <sub>IH</sub><br>to V <sub>II</sub> | - | | CEII, GEII, ABVII, WEII, WI II) | | @66 MHz | 0 | 3 | | to v <sub>IL</sub> | | | Address-address skew | <sup>t</sup> ASKW | | 0 | 3 | ns | @V <sub>CCQ</sub> /2 | 1 | Note: 1. For an address to be latched the skew is defined as the time when the first address bit is valid to the last address bit going valid. **Figure 22: Transient Equivalent Testing Load Circuit** Notes: 1. See Test Configuration Load Capacitor Values for Worst Case Speed Conditions table for component values for the test configurations. 2. C<sub>L</sub> includes jig capacitance. **Table 44: Test Configuration Load Capacitor Values for Worst Case Speed Conditions** | Test Configuration | C <sub>L</sub> (pF) | |--------------------|---------------------| | 1.7V Standard test | 30 | | 2.0V Standard test | 30 | ### Figure 23: Clock Input AC Waveform #### **Table 45: Capacitance** Notes apply to all parameters. | Parameter | Symbol | Signals | Min | Тур | Max | Unit | Test Condition | |-------------------------|------------------|--------------------------------------------------------|-----|-----|-----|------|---------------------------| | Input capacitance | C <sub>IN</sub> | Address, CLK, CE#, OE#,<br>ADV#, WE#, WP#, and<br>RST# | 2 | 4 | 6 | pF | V <sub>IN</sub> = 0–2.0V | | Output capaci-<br>tance | C <sub>OUT</sub> | Data, WAIT | 2 | 5 | 6 | pF | V <sub>OUT</sub> = 0–2.0V | 72 - Notes: 1. $T_A = +25$ °C, f = 1 MHz. - 2. Sampled, not 100% tested. - 3. Silicon die capacitance only. For discrete packages, add 1pF. For stacked packages, total capacitance = 2pF + sum of silicon die capacitances. ## **AC Read Specifications** ### Table 46: AC Read Specifications (CLK-Latching, 133 MHz), $V_{CCQ} = 1.7V$ to 2.0V Note 1 applies to all parameters | | | g | | | | |--------------------------------------------------------------|--------------------|------|------|---------------|-------| | Parameter | Symbol | Min | Max | Unit | Notes | | Asynchronous Specifications | | | | | | | READ cycle time | <sup>t</sup> AVAV | 96 | _ | ns | | | Address to output valid | <sup>t</sup> AVQV | _ | 96 | ns | | | CE# LOW to output valid | <sup>t</sup> ELQV | _ | 96 | ns | | | OE# LOW to output valid | <sup>t</sup> GLQV | _ | 7 | ns | 2 | | RST# HIGH to output valid | <sup>t</sup> PHQV | _ | 150 | ns | | | CE# LOW to output in Low-Z | <sup>t</sup> ELQX | 0 | _ | ns | 3 | | OE# LOW to output in Low-Z | <sup>t</sup> GLQX | 0 | _ | ns | 2, 3 | | CE# HIGH to output in High-Z | <sup>t</sup> EHQZ | _ | 7 | ns | 3 | | OE# HIGH to output in High-Z | <sup>t</sup> GHQZ | _ | 7 | ns | 3 | | Output hold from first occurring address, CE#, or OE# change | <sup>t</sup> OH | 0 | - | ns | 3 | | CE# pulse width HIGH | <sup>t</sup> EHEL | 7 | _ | ns | | | CE# LOW to WAIT valid | <sup>t</sup> ELTV | _ | 8 | ns | | | CE# HIGH to WAIT High-Z | <sup>t</sup> EHTZ | _ | 7 | ns | 3 | | OE# HIGH to WAIT valid (A/D MUX only) | <sup>t</sup> GHTV | _ | 5.5 | ns | | | OE# LOW to WAIT valid | <sup>t</sup> GLTV | _ | 5.5 | ns | | | OE# LOW to WAIT in Low-Z | <sup>t</sup> GLTX | 0 | _ | ns | 3 | | OE# HIGH to WAIT in High-Z (non-MUX only) | <sup>t</sup> GHTZ | 0 | 7 | ns | 3 | | Latching Specifications | | | | | | | Address setup to ADV# HIGH | <sup>t</sup> AVVH | 5 | _ | ns | | | CE# LOW to ADV# HIGH | <sup>t</sup> ELVH | 7 | _ | ns | | | ADV# LOW to output valid | tVLQV | _ | 96 | ns | | | ADV# pulse width LOW | <sup>t</sup> VLVH | 7 | _ | ns | | | ADV# pulse width HIGH | <sup>t</sup> VHVL | 7 | _ | ns | | | Address hold from ADV# HIGH | tVHAX | 5 | _ | ns | | | ADV# HIGH to OE# LOW (A/D MUX only) | <sup>t</sup> VHGL | 2 | _ | ns | | | Page address access (non-MUX only) | <sup>t</sup> APA | _ | 15 | ns | | | RST# HIGH to ADV# HIGH | <sup>t</sup> PHVH | 30 | _ | ns | | | Clock Specifications | I | I. | - | | ' | | CLK frequency | fCLK | _ | 133 | MHz | | | CLK period | <sup>t</sup> CLK | 7.5 | _ | ns | | | CLK HIGH/LOW time | <sup>t</sup> CH/CL | 0.45 | 0.55 | CLK<br>period | | | CLK fall/rise time | tFCLK/RCLK | 0.3 | 1.2 | ns | | #### Table 46: AC Read Specifications (CLK-Latching, 133 MHz), V<sub>CCQ</sub> = 1.7V to 2.0V (Continued) Note 1 applies to all parameters | | 96r | | ins | | | | |----------------------------------------------|-------------------|-----|-----|--------|-------|--| | Parameter | Symbol | Min | Max | Unit | Notes | | | Synchronous Specifications | | | | ' | | | | Address setup to CLK HIGH | <sup>t</sup> AVCH | 2 | _ | ns | | | | ADV# LOW setup to CLK HIGH | tVLCH | 2 | _ | ns | | | | CE# LOW setup to CLK HIGH | <sup>t</sup> ELCH | 2.5 | _ | ns | | | | CLK to output valid | <sup>t</sup> CHQV | _ | 5.5 | ns | | | | Output hold from CLK HIGH | <sup>t</sup> CHQX | 2 | _ | ns | | | | Address hold from CLK HIGH | <sup>t</sup> CHAX | 1.5 | _ | ns | | | | CLK HIGH to WAIT valid | <sup>t</sup> CHTV | _ | 5.5 | ns | | | | ADV# HIGH hold from CLK | <sup>t</sup> CHVL | 2 | _ | ns | | | | WAIT hold from CLK | <sup>t</sup> CHTX | 1.5 | _ | ns | | | | ADV# hold from CLK HIGH | <sup>t</sup> CHVH | 2 | - | ns | | | | CLK to OE# LOW (A/D MUX only) | <sup>t</sup> CHGL | 2 | _ | ns | | | | Read access time from address latching clock | <sup>t</sup> ACC | 96 | _ | ns | | | | ADV# pulse width LOW for sync reads | tVLVH | 1 | 2 | clocks | | | | ADV# HIGH to CLK HIGH | tVHCH | 2 | _ | ns | | | - Notes: 1. See Electrical Specifications AC Characteristics and Operating Conditions for timing measurements and MAX allowable input slew rate. - 2. OE# can be delayed by up to <sup>t</sup>ELQV <sup>t</sup>GLQV after the CE# falling edge without impact to tELQV. - 3. Sampled, not 100% tested. #### **AC Read Timing** The synchronous read timing waveforms apply to both 108 and 133 MHz devices. However, devices that only support up to 108 MHz do not need to meet the following timing specifications: - tCHVH - tCHGL - tACC - tVLVH - tVHCH **Note:** The WAIT signal polarity in all the timing waveforms is low-true (RCR10 = 0). WAIT is shown as de-asserted with valid data (RCR8 = 0). WAIT is de-asserted during asynchronous reads. Figure 24: Asynchronous Page-Mode Read (Non-MUX) Note: 1. WAIT shown active LOW (RCR[10] = 0). Figure 25: Synchronous 8- or 16-Word Burst Read (Non-MUX) Notes: - 1. 8-word and 16-word burst are always wrap-only. - 2. WAIT shown as active LOW (RCR[10] = 0) and asserted with data (RCR[8] = 0). - 3. ADV# may be held LOW throughout the synchronous READ operation. - 4. <sup>t</sup>AVQV, <sup>t</sup>ELQV, and <sup>t</sup>VLQV apply to legacy-latching only. - 5. <sup>t</sup>ACC and <sup>t</sup>VLVH apply to clock-latching only. Figure 26: Synchronous Continuous Misaligned Burst Read (Non-MUX) - Notes: - 1. WAIT shown as active LOW (RCR[10] = 0) and asserted with data (RCR[8] = 0). - 2. ADV# may be held LOW throughout the synchronous READ operation. - 3. <sup>t</sup>AVQV, <sup>t</sup>ELQV, and <sup>t</sup>VLQV apply to legacy-latching only. - 4. <sup>t</sup>ACC and <sup>t</sup>VLVH apply to clock-latching only. Figure 27: Synchronous Burst with Burst Interrupt Read (Non-MUX) Notes: 1. WAIT shown as active LOW (RCR[10] = 0) and asserted with data (RCR[8] = 0). - 2. A burst can be interrupted by toggling CE# or ADV#. - 3. For no-wrap bursts, end-of-wordline WAIT states could occur (not shown in this figure). - 4. <sup>t</sup>AVQV, <sup>t</sup>ELQV, and <sup>t</sup>VLQV apply to legacy-latching only. - 5. tACC and tVLVH apply to clock-latching only. Figure 28: Asynchronous Single-Word Read Notes: - 1. WAIT shown as active LOW (RCR[10] = 0). - 2. Back-to-back READ operations shown. - 3. CE# does not need to toggle between read cycles (i.e., <sup>t</sup>EHEL need not apply). Figure 29: Synchronous 8- or 16-Word Burst Read (A/D MUX) Notes: - 1. 8-word and 16-word burst are always wrap-only. - 2. WAIT shown as active LOW (RCR[10] = 0) and asserted with data (RCR[8] = 0). - 3. <sup>t</sup>AVQV, <sup>t</sup>ELQV, and <sup>t</sup>VLQV apply to legacy-latching only. - 4. <sup>t</sup>ACC and <sup>t</sup>VLVH apply to clock-latching only. Figure 30: Synchronous Continuous Misaligned Burst Read (A/D MUX) otes: 1. 8-word and 16-word burst are always wrap-only. - 2. WAIT shown as active LOW (RCR[10] = 0) and asserted with data (RCR[8] = 0). - 3. <sup>t</sup>AVQV, <sup>t</sup>ELQV, and <sup>t</sup>VLQV apply to legacy-latching only. - 4. <sup>t</sup>ACC and <sup>t</sup>VLVH apply to clock-latching only. Figure 31: Synchronous Burst with Burst-Interrupt (AD-MUX) Notes: 1. <sup>t</sup>AVQV, <sup>t</sup>ELQV, and <sup>t</sup>VLQV apply to legacy-latching only. 2. <sup>t</sup>ACC and <sup>t</sup>VLVH apply to clock-latching only. 3. A burst can be interrupted by toggling CE# or ADV#. ### **AC Write Specifications** #### **Table 47: AC Write Specifications** Notes 1 and 2 apply to all | Parameter | Symbol | Min | Max | Unit | Notes | |--------------------------------------------|-------------------|------------------------|-----|------|----------| | RST# HIGH recovery to WE# LOW | <sup>t</sup> PHWL | 150 | _ | ns | 3 | | CE# setup to WE# LOW | <sup>t</sup> ELWL | 0 | _ | ns | 10 | | WE# write pulse width LOW | tWLWH | 40 | _ | ns | 4 | | Data setup to WE# HIGH | <sup>t</sup> DVWH | 40 | _ | ns | | | Address setup to WE# HIGH | <sup>t</sup> AVWH | 40 | _ | ns | | | CE# hold from WE# HIGH | tWHEH | 0 | _ | ns | | | Data hold from WE# HIGH | tWHDX | 0 | _ | ns | | | Address hold from WE# HIGH | tWHAX | 0 | _ | ns | | | WE# pulse width HIGH | tWHWL | 20 | _ | ns | 5 | | V <sub>PP</sub> setup to WE# HIGH | <sup>t</sup> VPWH | 200 | _ | ns | 3, 7 | | V <sub>PP</sub> hold from status read | <sup>t</sup> QVVL | 0 | _ | ns | 3, 7 | | WP# hold from status read | <sup>t</sup> QVBL | 0 | _ | ns | 3, 7 | | WP# setup to WE# HIGH | <sup>t</sup> BHWH | 200 | _ | ns | 3, 7 | | WE# HIGH to OE# LOW | tWHGL | 0 | _ | ns | 8 | | ADV# LOW to WE# HIGH | <sup>t</sup> VLWH | 55 | _ | ns | | | WE# HIGH to read valid | tWHQV | <sup>t</sup> AVQV + 30 | _ | ns | 3, 6, 9 | | <b>WRITE Operation to Asynchronous Rea</b> | d Transition | | | | | | WE# HIGH to address valid | tWHAV | | | | | | Write to Synchronous Read Specificati | on | | | | | | WE# HIGH to CLK HIGH @ 110 MHz | tWHCH | 15 | _ | ns | 3, 6, 11 | | WE# HIGH to CE# LOW | tWHEL | 9 | _ | ns | 3, 6, 11 | | WE# HIGH to ADV# LOW | <sup>t</sup> WHVL | 7 | _ | ns | 3, 6, 11 | | Write Specifications with Clock Active | | | | | • | | ADV# HIGH to WE# LOW | tVHWL | _ | 30 | ns | 11 | | CLK HIGH to WE# LOW | <sup>t</sup> CHWL | _ | 30 | ns | 11 | Notes - Write timing characteristics during erase suspend are the same as WRITE-only operations. - 2. A WRITE operation can be terminated with either CE# or WE#. - 3. Sampled, not 100% tested. - 4. Write pulse width LOW (tWLWH or tELEH) is defined from CE# or WE# LOW (whichever occurs last) to CE# or WE# HIGH (whichever occurs first). Hence, tWLWH = tELEH = tWLEH = tELWH. - 5. Write pulse width HIGH (tWHWL or tEHEL) is defined from CE# or WE# HIGH (whichever occurs first) to CE# or WE# LOW (whichever occurs last). Hence, tWHWL = tEHEL = tWHEL = tEHW. - 6. <sup>t</sup>WHCH must be met when transitioning from a WRITE cycle to a synchronous burst read. In addition CE# or ADV# must toggle when WE# goes HIGH. - 7. V<sub>PP</sub> and WP# must be at a valid level until erase or program success is determined. - 8. When performing a READ STATUS operation following any command that alters the status register, <sup>t</sup>WHGL is 20ns. - 9. Add 10ns if the WRITE operation results in an RCR or block lock status change for the subsequent READ operation to reflect this change. - 10. Either <sup>t</sup>VHWL or <sup>t</sup>CHWL is required to meet the specification depending on the address latching mechanism; both of these specifications can be ignored if the clock is not toggling during the WRITE cycle. - 11. If ADV# remains LOW after the WRITE cycle completes, a new READ cycle will start. **Figure 32: Write Timing** Figure 33: Write to Write (Non-MUX) Figure 34: Async Read to Write (Non-MUX) Figure 35: Write to Async Read (Non-MUX) Figure 36: Sync Read to Write (Non-MUX) Figure 37: Write to Sync Read (Non-MUX) Figure 38: Write to Write (A/D-MUX) Figure 39: Async Read to Write (A/D-MUX) Figure 40: Write to Async Read (A/D-MUX) Figure 41: Sync Read to Write (A/D-MUX) Figure 42: Write to Sync Read (A/D-MUX) # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Electrical Specifications – Program/Erase Characteristics ## **Electrical Specifications - Program/Erase Characteristics** #### **Table 48: Program/Erase Characteristics** Note 1 applies to all | | | | | V <sub>PPL</sub> or V <sub>PPH</sub> | | | | |----------------------|--------------------------------|----------------------|-----|--------------------------------------|-------|-------|---| | Parameter | Symbol | Min | Тур | Max | Units | Notes | | | <b>Word Program</b> | nming | | | • | • | • | | | Program time | Single word (first word) | <sup>t</sup> PROG/W | - | 115 | 230 | μs | 2 | | | Single word (subsequent word) | | | 65 | 230 | | | | <b>Buffered Prog</b> | gramming | | | | | | | | Program time | Single word | <sup>t</sup> PROG/W | - | 250 | 500 | μs | | | | One buffer (512 words) | <sup>t</sup> PROG/PB | | 1.02 | 2.05 | ms | | | <b>Buffer Enhan</b> | ced Factory Programming (BEFP) | | | | | | | | Program | Single word | tBEFP/W | | 2.0 | | μs | 3 | | | BEFP setup | tBEFP/ | 5 | - | - | μs | 3 | | | | SETUP | | | | | | | Erasing and S | uspending | | | | | | | | Erase time | 128K-word parameter | tERS/MAB | _ | 0.9 | 4 | S | | | Suspend la- | Program suspend | tSUSP/P | - | 20 | 30 | μs | | | tency | Erase suspend | tSUSP/E | - | 20 | 30 | μs | | | Blank Check | | | | | | | | | Main array<br>block | Main array block | <sup>t</sup> BC/MB | _ | 3.2 | _ | ms | | - Notes: 1. Typical values measured at $T_A = 25^{\circ}$ C and nominal voltages. Performance numbers are valid for all speed versions. Excludes overhead. Sampled, but not 100% tested. - 2. Conventional word programming: First and subsequent words refer to first word and subsequent words in control mode programming region. - 3. Averaged over the entire device. BEFP is not validated at V<sub>PPL</sub>. #### **Common Flash Interface** The common Flash interface (CFI) is part of an overall specification for multiple command set and control interface descriptions. System software can parse the CFI database structure to obtain information about the device, such as block size, density, bus width, and electrical specifications. The system software determines which command set to use to properly perform a WRITE, BLOCK ERASE, or READ command, and to otherwise control the device. Information in the CFI database can be viewed by issuing the READ CFI command. ### **READ CFI Structure Output** The READ CFI command obtains CFI database structure information and always outputs it on the lower byte, DQ[7:0], for a word-wide (x16) Flash device. This CFI-compliant device always outputs 00h data on the upper byte (DQ[15:8]). The numerical offset value is the address relative to the maximum bus width that the device supports, with a starting address of 10h, which is a word address for x16 devices. For example, at a starting address of 10h, a READ CFI command outputs an ASCII Q in the lower byte and 00h in the higher byte. In the following tables, address and data are represented in hexadecimal notation. In addition, because the upper byte of word-wide devices is always 00h, the leading 00 has been dropped and only the lower byte value is shown. Table 49: Example of CFI Output (x16 Device) as a Function of Device and Mode | Device | Hex<br>Offset | Hex<br>Code | ASCII Value<br>(DQ[15:8]) | ASCII Value<br>(DQ[7:0]) | |---------|---------------|--------------------|---------------------------|------------------------------| | Address | 00010: | 51 | 00 | Q | | | 00011: | 52 | 00 | R | | | 00012: | 59 | 00 | Y | | | 00013: | P_ID <sub>LO</sub> | 00 | Primary vendor ID | | | 00014: | P_ID <sub>HI</sub> | 00 | | | | 00015: | P <sub>LO</sub> | 00 | Primary vendor table address | | | 00016: | P <sub>HI</sub> | 00 | | | | 00017: | A_ID <sub>LO</sub> | 00 | Alternate vendor ID | | | 00018: | A_ID <sub>HI</sub> | 00 | | | | : | : | : | : | | | : | : | : | : | Table 50: CFI Database: Addresses and Sections | Address | Section Name | Description | |----------|------------------------------|--------------------------------------------------------| | 00001:Fh | Reserved | Reserved for vendor-specific information | | 00010h | CFI ID string | Command set ID (identification) and vendor data offset | | 0001Bh | System interface information | Timing and voltage | | 00027h | Device geometry definition | Layout | #### **Table 50: CFI Database: Addresses and Sections (Continued)** | Address | Section Name | Description | |---------|--------------|-------------------------------------------------------------------| | Р | | Vendor-defined information specific to the primary vendor | | | | algorithm (offset 15 defines <i>P</i> which points to the primary | | | | Micron-specific extended query table) | ### **CFI ID String** The CFI ID string provides verification that the device supports the CFI specification. It also indicates the specification version and supported vendor-specific command sets. #### **Table 51: CFI ID String** | Hex<br>Offset | Length | Description | Address | Hex<br>Code | ASCII Value<br>(DQ[7:0]) | |---------------|--------|--------------------------------------------------------------------------------|---------|-------------|----------------------------| | 10h | 3 | Query unique ASCII string "QRY" | 10: | 51 | Q | | | | | 11: | 52 | R | | | | | 12: | 59 | Y | | 13h | 2 | Primary vendor command set and control | 13: | 00 | Primary vendor ID number | | | | interface ID code;16-bit ID code for vendor-<br>specified algorithms | 14: | 02 | | | 15h | 2 | Extended query table primary algorithm | 15: | 0A | Primary vendor table ad- | | | | address | 16: | 01 | dress, primary algorithm | | 17h | 2 | Alternate vendor command set and control | 17: | 00 | Alternate vendor ID number | | | | interface ID code; 0000h indicates no second vendor-specified algorithm exists | 18: | 00 | | | 19h | 2 | Secondary algorithm extended query table | 19: | 00 | Primary vendor table ad- | | | | address; 0000h indicates none exists | 1A: | 00 | dress, secondary algorithm | ### **System Interface Information** #### **Table 52: System Interface Information** | Hex<br>Offset | Length | Description | Address | Hex<br>Code | ASCII Value<br>(DQ[7:0]) | |---------------|--------|--------------------------------------------------------------------------------------------------------------------|---------|-------------|--------------------------| | 1Bh | 1 | V <sub>CC</sub> logic supply minimum program/erase voltage<br>bits 0–3 BCD 100mV<br>bits 4–7 BCD volts | 1Bh | 17 | 1.7V | | 1Ch | 1 | V <sub>CC</sub> logic supply maximum program/erase voltage<br>bits 0–3 BCD 100mV<br>bits 4– 7 BCD volts | 1Ch | 20 | 2.0V | | 1Dh | 1 | V <sub>PP</sub> [programming] supply minimum program/<br>erase voltage<br>bits 0–3 BCD 100mV<br>bits 4–7 hex volts | 1Dh | 85 | 8.5V | **Table 52: System Interface Information (Continued)** | Hex<br>Offset | Length | Description | Address | Hex<br>Code | ASCII Value<br>(DQ[7:0]) | |---------------|--------|--------------------------------------------------------------------------------------------------------------------|---------|-------------------------------------------|------------------------------------------------| | 1Eh | 1 | V <sub>PP</sub> [programming] supply maximum program/<br>erase voltage<br>bits 0–3 BCD 100mV<br>bits 4–7 hex volts | 1Eh | 95 | 9.5V | | 1Fh | 1 | <i>n</i> such that typical single word program timeout $= 2^{n}\mu s$ | 1Fh | 06 | 64µs | | 20h | 1 | $n$ such that typical full buffer write timeout = $2^{n}\mu s$ | 20h | 0B<br>(1024Mb)<br>0A<br>(256Mb,<br>512Mb) | 2048µs<br>(1024Mb)<br>1023µs (256Mb,<br>512Mb) | | 21h | 1 | $n$ such that typical block erase timeout = $2^n$ ms | 21h | 0A | 1s | | 22h | 1 | $n$ such that typical full chip erase timeout = $2^{n}$ ms | 22h | 00 | NA | | 23h | 1 | n such that maximum word program timeout = 2 <sup>n</sup> times typical | 23h | 02 | 256µs | | 24h | 1 | n such that maximum buffer write timeout = 2 <sup>n</sup> times typical | 24h | 02<br>(256Mb,<br>512Mb<br>01<br>(1024Mb) | 8192μs (256Mb,<br>512Mb)<br>4096μs<br>(1024Mb) | | 25h | 1 | $n$ such that maximum block erase timeout = $2^n$ times typical | 25h | 02 | 4s | | 26h | 1 | $n$ such that maximum chip erase timeout = $2^n$ times typical | 26h | 00 | NA | ### **Device Geometry Definition** #### **Table 53: Device Geometry** | Hex<br>Offset | Length | Description | Address | Hex<br>Code | ASCII Value<br>(DQ[7:0]) | |---------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------|--------------------------| | 27h | 1 | $n$ such that device size in bytes = $2^n$ . | 27: | | See table<br>below | | 28h | 2 | Flash device interface code assignment: <i>n</i> such that n + | 28: | 01 | x16 | | | | 1 specifies the bit field that represents the device width capabilities as described here: bit 0: x8 bit 1: x16 bit 2: x32 bit 3: x64 bits 4–7: – bits 8–15: – | 29: | 00 | | **Table 53: Device Geometry (Continued)** | Hex<br>Offset | Length | Description | Address | Hex<br>Code | ASCII Value<br>(DQ[7:0]) | |---------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|--------------------------| | 2Ah | 2 | n such that maximum number of bytes in write buffer | 2Ah | 0A | 1024 | | | | = 2 <sup>n</sup> | 2Bh | 00 | | | 2Ch | 1 | Number of erase block regions (x) within the device: x = 0 indicates no erase blocking; the device erases in bulk x specifies the number of device regions with one or more contiguous, same-size erase blocks Symmetrically blocked partitions have one blocking region | 2Ch | | See table<br>below | | 2Dh | 4 | Erase block region 1 information:<br>bits $0-15 = y$ , $y + 1 =$ number of identical-size erase<br>blocks<br>bits $16-31 = z$ , region erase block(s) size are z x 256<br>bytes | 2D:<br>30: | | See table<br>below | Note: 1. See the bit field table. **Table 54: Block Region Map Information** | | 256Mb | | 512Mb | | 1Gb | | |---------|--------|-----|--------|-----|--------|-----| | Address | Bottom | Тор | Bottom | Тор | Bottom | Тор | | 27: | 19 | | 1A | | 1B | | | 28: | 01 | | 01 | | 01 | | | 29: | 00 | | 00 | | 00 | | | 2A: | 0A | | 0A | | 0A | | | 2B: | 00 | | 00 | | 00 | | | 2C: | 01 | | 01 | | 01 | | | 2D: | 7F | | FF | | FF | | | 2E: | 00 | | 00 | | 01 | | | 2F: | 00 | | 00 | | 00 | | | 30: | 04 | | 04 | | 04 | | ### **Primary Micron-Specific Extended Query** #### **Table 55: Primary Micron-Specific Extended Query** | Hex Offset<br>P = 10Ah | Length | Description | Address Hex Code | | ASCII Value<br>(DQ[7:0]) | |--------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------|-----------------------------| | (P+0)h | 3 | Primary extended query table, unique ASCII | 10A: | 50 | Р | | (P+1)h | | string: PRI | 52 | R | | | (P+2)h | | | 10C: | 49 | I | | (P+3)h | 1 | Major version number, ASCII | 10D: | 31 | 1 | | (P+4)h | 1 | Minor version number, ASCII | 10E: | 34 | 4 | | (P+5)h<br>(P+6)h<br>(P+7)h<br>(P+8)h | 4 | Optional feature and command support (1 = yes; 0 = no) Bits 10–31 are reserved; undefined bits are 0 If bit 31 = 1, then another 31-bit field of optional | 10F: | E6 (Non-<br>MUX)<br>66 (A/D<br>MUX) | - | | | | features follows at the end of the bit 30 field | 110: | 07 | _ | | | | | 111: | 00 | _ | | | | | 112: | 00 | _ | | | | Bit 0: Chip erase supported | Bit ( | 0 = 0 | No | | | | Bit 1: Suspend erase supported | Bit 1 | 1 = 1 | Yes | | | | Bit 2: Suspend program supported | Bit 2 | 2 = 1 | Yes | | | | Bit 3: Legacy lock/unlock supported | Bit 3 | 3 = 0 | No | | | | Bit 4: Queued erase supported | Bit 4 | 1 = 0 | No | | | | Bit 5: Instant individual block locking supported | Bit 5 | 5 = 1 | Yes | | | | Bit 6: OTP bits supported | Bit 6 | 5 = 1 | Yes | | | | Bit 7: Page mode read supported | | 7 = 0<br>7 = 1 | No: A/D MUX<br>Yes: Non-MUX | | | | Bit 8: Synchronous read supported | Bit 8 | 3 = 1 | Yes | | | | Bit 9: Simultaneous operations supported | Bit 9 | 9 = 1 | Yes | | | | Bit 10: Reserved | Bit 1 | 0 = 0 | No | | | | Bit 30: CFI links to follow | Bit 3 | 0 = 0 | No | | | | Bit 31: another optional features field to follow. | Bit 31 = 0 | | No | | (P+9)h | 1 | Supported functions after suspend: read array, status, query Other supported options: Bits 1–7 reserved; undefined bits are 0 | 113: | 01 | - | | | | Bit 0: Program supported after erase suspend | | ) = 1 | Yes | | (P+A)h<br>(P+B)h | 2 | Block status register mask:<br>Bits 2 – 3 and 6 - 15 are reserved; undefined bits<br>are 0 | 114:<br>115: | 33 | - | | | | Bit 0: Block lock bit status register active | Bit ( | ) = 1 | Yes | | | | Bit 1: Block lock-down bit status active | Bit ' | 1 = 1 | Yes | #### **Table 55: Primary Micron-Specific Extended Query (Continued)** | Hex Offset<br>P = 10Ah | Length | Description | Address | Hex Code | ASCII Value<br>(DQ[7:0]) | |------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------|---------|----------|--------------------------| | (P+C)h | 1 | V <sub>CC</sub> logic supply highest performance program/<br>erase voltage<br>bits 0–3 BCD 100mV<br>Bits 4–7 BCD value in volts | 116: | 18 | 1.8V | | (P+D)h | 1 | V <sub>PP</sub> optimum program/erase voltage<br>Bits 0–3 BCD 100mV<br>Bits 4–7 hex value in volts | 117: | 90 | 9.0V | #### **Table 56: One Time Programmable (OTP) Space Information** | Hex Offset<br>P = 10Ah | Length | Description | Address | Hex<br>Code | ASCII Value<br>(DQ[7:0]) | |-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------|--------------------------| | (P+E)h | 1 | Number of OTP block fields in JEDEC ID space.<br>00h indicates that 256 OTP fields are available | 118: | 02 | 2 | | | | OTP Field 1: | 119: | 80 | 80h | | | | This field describes user-available OTP bytes. | 11A: | 00 | 00h | | | | Some are preprogrammed with device-unique serial numbers. Others are user-programmable | 1B: | 03 | 8 byte | | (P+F)h<br>(P+10)h<br>(P+11)h<br>(P+12)h | 4 | ial numbers. Others are user-programmable. Eits 0–15 point to the OTP lock byte (the first byte). The following bytes are factory preprogrammed and user-programmable: Eits 0–7 = lock/bytes JEDEC plane physical low address. Eits 8–15 = lock/bytes JEDEC plane physical high address. Eits 16–23 = n where 2 <sup>n</sup> equals factory-preprogrammed bytes. Eits 24–31 = n where 2 <sup>n</sup> equals user-programma- | 11C: | 03 | 8 byte | | (P+13)h | 4 | ble bytes. Protection Field 2: | 11D: | 89 | 89h | | (P+14)h | | Bits 0–31 point to the protection register physical | 11E: | 00 | 00h | | (P+15)h<br>(P+16)h | | lock word address in the JEDEC plane. The bytes that follow are factory or user-progam- | 11F: | 00 | 00h | | (F+10)11 | | mable. | 120: | 00 | 00h | | (P+17)h | 3 | Bits $32-39 = n$ where $n$ equals factory-program- | 121: | 00 | 0 | | (P+18)h | | med groups (low byte). | 122: | 00 | 0 | | (P+19)h | 19)h Bits 40–47 = n where n equals factory progmed groups (high byte). Bits 48–55 = n where 2n equals factory-promed bytes/groups. | | 123: | 00 | 0 | #### **Table 56: One Time Programmable (OTP) Space Information (Continued)** | Hex Offset<br>P = 10Ah | Length | Description | Address | Hex<br>Code | ASCII Value<br>(DQ[7:0]) | |------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------|---------|-------------|--------------------------| | (P+1A)h | 3 | Bits $56-63 = n$ where $n$ equals user-programmed | 124: | 10 | 16 | | (P+1B)h | | groups (low byte). | 125: | 00 | 0 | | (P+1C)h | | Bits 64–71 = n where $n$ equals user-programmed groups (high byte).<br>Bits 72–79 = n where $n$ equals user programmable bytes/groups. | 126: | 04 | 16 | #### **Table 57: Burst Read Informaton** | Hex Offset<br>P = 10Ah | Length | Description | Address | Hex<br>Code | ASCII Value<br>(DQ[7:0]) | |------------------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------------------------------|--------------------------------------| | (P+1D)h | 1 | Page mode read capability: Bits 7–0 = n where 2 <sup>n</sup> hex value represents the number of read page bytes. See offset 28h for device word width to determine page mode data output width. 00h indicates no read page buffer. | 127: | 05 (Non-<br>MUX)<br>00 (A/D<br>MUX) | 32 byte (Non-<br>MUX)<br>0 (A/D MUX) | | (P+1E)h | Number of synchronous mode read configuration fields that follow. 00h indicates no burst capability. | | 03 | 3 | | | (P+1F)h | 1 | Synchronous mode read capability configuration 1: Bits 3–7 = reserved. Bits 0–2 = n where 2 <sup>n+1</sup> hex value represents the maximum number of continuous synchronous reads when the device is configured for its maximum word width. A value of 07h indicates that the device is capable of continuous linear bursts that will output data until the internal burst counter reaches the end of the device's burstable address space. This fields's 3-bit value can be written directly to the RCR bits 0–2 if the device is configured for its maximum word width. See offset 28h for word width to determine the burst data output width. | 129: | 02 | 8 | | (P+20)h | 1 | Synchronous mode read capability configuration 2. | 12A: | 03 | 16 | | (P+21)h | 1 | Synchronous mode read capability configuration 3. | 12B: | 07 | Cont | #### **Table 58: Partition and Block Erase Region Information** | Hex Offset<br>P = 10Ah | | Description | | Add | ress | |------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|------| | Bottom | Тор | Optional Features and Commands | Length | Bottom | Тор | | (P+22)h | (P+22)h | Number of device hardware partition regions within the device: x = 0: A single hardware partition device (no fields follow). x specifies the number of device partition regions containing one or more contiguous erase block regions | 1 | 12C: | 12C: | #### **Table 59: Partition Region 1 Information: Top and Bottom Offset/Address** | Hex Offset<br>P = 10Ah | | Description | | Address | | |------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------| | Bottom | Тор | Optional Features and Commands | Length | Bottom | Тор | | (P+23)h | (P+23)h | Data size of this Partition Region information field: | 2 | 12D: | 12D: | | (P+24)h | (P+24)h | (number of addressable locations, including this field). | | 12E: | 12E: | | (P+25)h | (P+25)h | Number of identical partitions within the partition | 2 | 12F: | 12F: | | (P+26)h | (P+26)h | region. | | 130: | 130: | | (P+27)h | (P+27)h | Number of PROGRAM or ERASE operations allowed in a partition: Bits 0–3 = number of simultaneous PROGRAM operations. Bits 4–7 = number of simultaneous ERASE operations. | | 131: | 131: | | (P+28)h | (P+28)h | Simultaneous PROGRAM or ERASE operations allowed in other partitions while a partition in this region is in program mode: Bits 0–3 = number of simultaneous program operations. Bits 4–7 = number of simultaneous ERASE operations. | imultaneous PROGRAM or ERASE operations alowed in other partitions while a partition in this region is in program mode: Bits 0–3 = number of simultaneous program operations. | | 132: | | (P+29)h | (P+29)h | Simultaneous PROGRAM or ERASE operations allowed in other partitions while a partition in this region is in erase mode: Bits 0–3 = number of simultaneous PROGRAM operations. Bits 4–7 = number of simultaneous ERASE operations. | 1 | 133: | 133: | Table 59: Partition Region 1 Information: Top and Bottom Offset/Address (Continued) | Hex Offset<br>P = 10Ah | | Description | | Address | | | |------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|---------|------|--| | Bottom | Тор | Optional Features and Commands | Length | Bottom | Тор | | | (P+2A)h | (P+2A)h | Types of erase block regions in this partition region: x = 0: no erase blocking; the partition region erases in bulk. x = number of erase block regions with contiguous, same-size erase blocks. Symmetrically blocked partitions have one blocking region. Partition size = (type 1 blocks) x (type 1 block sizes) + (type 2 blocks) x (type 2 block sizes) ++ (type n blocks) x (type n block sizes). | 1 | 134: | 134: | | | (P+2B)h | (P+2B)h | Partition region 1 (erase block type 1) information: | 4 | 135: | 135: | | | (P+2C)h<br>(P+2D)h | (P+2C)h<br>(P+2D)h | Bits 0–15 = y, y+1 = number of identical-sized erase | | 136: | 136: | | | (P+2D)N<br>(P+2E)h | (P+2D)h<br>(P+2E)h | blocks in a partition. Bits 16–31 = z, where region erase block(s) size is z x | | 137: | 137: | | | (· · == <b>/</b> ·· | (* : ==,:: | 256 bytes. | | 138: | 138: | | | (P+2F)h | (P+2F)h | Partition 1 (erase block type 1): | 2 | 139: | 139: | | | (P+30)h | (P+30)h | Minimum block erase cycles x 1000 | | 13A: | 13A: | | | (P+31)h | (P+31)h | Partition 1 (erase block type 1) bits per cell; internal EDAC: Bits 0–3 = bits per cell in erase region Bit 4 = internal EDAC used (1 = yes, 0 = no) Bits 5–7 = reserved for future use | ts 0–3 = bits per cell in erase region<br>t 4 = internal EDAC used (1 = yes, 0 = no) | | | | | (P+32)h | (P+32)h | Partition 1 (erase block type 1) page mode and synchronous mode capabilities: Bits 0 = page mode host reads permitted (1 = yes, 0 = no) Bit 1 = synchronous host reads permitted (1 = yes, 0 = no) Bit 2 = synchronous host writes permitted (1 = yes, 0 = no) Bits 3-7 = reserved for future use | 1 | 13C: | 13C: | | | (P+33)h | (P+33)h | Partition 1 (Erase Block Type 1) programming region | 6 | 13D: | 13D: | | | (P+34)h | (P+34)h | information: Bits 0 - 7 = x, 2 <sup>x</sup> : programming region aligned size | | 13E: | 13E: | | | (P+35)h | (P+35)h | (bytes) | | 13F: | 13F: | | | (P+36)h | (P+36)h | Bits 8 - 14 = reserved for future use | | 140: | 140: | | | (P+37)h | (P+37)h | Bit 15 = legacy flash operation; ignore 0:7 | | 141: | 141: | | | (P+38)h | (P+38)h | Bit 16 - 23 = y: control mode valid size (bytes) Bit 24 - 31 = reserved for future use Bit 32 - 39 = z: control mode invalid size (bytes) Bit 40 - 46 = reserved for future use Bit 47 = legacy flash operation (ignore 23:16 and 39:32) | | 142: | 142: | | **Table 60: Partition and Erase Block Map Information** | | 256N | 256Mb | | 512Mb | | 1Gb | | |---------|----------------------|-------|----------------------|-------|----------------------|-----|--| | Address | Bottom | Тор | Bottom | Тор | Bottom | Тор | | | 12C: | 01 | | 01 | | 01 | | | | 12D: | 16 | | 16 | | 16 | | | | 12E: | 00 | | 00 | | 00 | | | | 12F: | 08 | | 08 | | 08 | | | | 130: | 00 | | 00 | | 00 | | | | 131: | 11 | | 11 | | 11 | | | | 132: | 00 | | 00 | | 00 | | | | 133: | 00 | | 00 | | 00 | | | | 134: | 01 | | 01 | | 01 | | | | 135: | OF | | 1F | | 3F | | | | 136: | 00 | | 00 | | 00 | | | | 137: | 00 | | 00 | | 00 | | | | 138: | 04 | | 04 | | 04 | | | | 139: | 64 | | 64 | | 64 | | | | 13A: | 00 | | 00 | | 00 | | | | 13B: | 12 | | 12 | | 12 | | | | 13C: | 02 MUX<br>03 Non-MUX | | 02 MUX<br>03 Non-MUX | | 02 MUX<br>03 Non-MUX | | | | 13D: | 0A | | 0A | | 0A | | | | 13E: | 00 | | 00 | | 00 | | | | 13F: | 10 | | 10 | | 10 | | | | 140: | 00 | | 00 | | 00 | | | | 141: | 10 | | 10 | | 10 | | | | 142: | 00 | | 00 | | 00 | | | ## **Flowcharts** **Figure 43: Word Program Procedure** | Bus<br>Operation | Command | Comments | |------------------|------------------|------------------------------------------------------------------------| | WRITE | PROGRAM<br>SETUP | Data = 0x41 Address = Location to program | | WRITE | DATA | Data = Data to program Address = Location to program | | READ | None | Status register data | | Idle | None | Check SR7 1 = Write state machine ready 0 = Write state machine busy | - Notes: 1. Repeat for subsequent word PROGRAM operations. - 2. Full status register check can be done after each program or after a sequence of PRO-**GRAM** operations. - 3. Write 0xFF after the last operation to set to the read array state. 102 Figure 44: Word Program Full Status Check Procedure #### Note: SR3 MUST be cleared before the write state machine will support further program attempts. | Bus<br>Operation | Command | Comments | |------------------|---------|-----------------------------------------------| | Idle | None | Check SR3 | | | | 1 = V <sub>PP</sub> error | | Idle | None | Check SR4 | | | | 1 = Data program error | | Idle | None | Check SR1 1 = Block locked; operation aborted | Note: 2. If an error is detected, clear the status register before continuing operations. Only the CLEAR STAUS REGISTER command clears the status register error bits. Figure 45: Program Suspend/Resume Procedure | Bus<br>Operation | Command | Comments | |------------------|-------------|----------------------------------------------------------------| | WRITE | PROGRAM | Data = B0h | | | SUSPEND | Address = Block to suspend | | WRITE | READ STATUS | Data = 70h | | | | Address = Same partition | | READ | | Status register data | | | | Address = Suspended block | | Standby | | Check SR7 | | | | 1 = Write state machine ready | | | | 0 = Write state machine busy | | Standby | | Check SR2 | | | | 1 = Program suspended | | | | 0 = Program completed | | WRITE | READ ARRAY | Data = FFh | | | | Address = Any address within the suspended partition | | READ | | Read array data from block other than the one being programmed | | )A/DITE | DDOCDANA. | | | WRITE | PROGRAM | Data = D0h | | | RESUME | Address = Suspended block | #### If the suspended partition was placed in read array mode: | WRITE | READ STATUS | Return partition to status mode: | |-------|-------------|----------------------------------| | | | Data = 70h | | | | Address = Same partition | **Figure 46: Buffer Programming Procedure** | Bus<br>Operation | Command | Comments | |-----------------------|--------------------------------|--------------------------------------------------------------| | WRITE | BUFFERED<br>PROGRAM<br>SETUP | Data = 0xE9<br>Addr = Colony base address | | WRITE | BUFFERED<br>PROGRAM<br>LOAD 1 | Data = word count -1 <sup>1</sup><br>Address = Block address | | WRITE <sup>2, 3</sup> | BUFFERED<br>PROGRAM<br>LOAD 2 | Data = Data to be programmed<br>Address = Word address | | WRITE <sup>4, 5</sup> | BUFFERED<br>PROGRAM<br>CONFIRM | Data = 0xD0<br>Address = Address within block | | READ | None | Status register Data<br>Address = Block address | - Notes: 1. D[8:0] is loaded as word count-1. - 2. Repeat BUFFERED PROGRAM LOAD 2 until the word count is achieved. (Load up to 512 words.) - 3. The command sequence aborts if the address of the BUFFERED PROGRAM LOAD 2 cycle is in a different block from the address of the BUFFERED PROGRAM SETUP cycle. - 4. The command sequence aborts if the address of the BUFFERED PROGRAM CONFIRM cycle is in a different block from the address of the BUFFERED PROGRAM SETUP cycle. Also, an abort will occur if the data of the BUFFERED PROGRAM CONFIRM cycle data is not 0xD0. - 5. The read mode changes to status read on the BUFFERED PROGRAM CONFIRM command. Figure 47: Buffered Enhanced Factory Programming (BEFP) Procedure | Bus<br>Operation | Action | Comments | | | |------------------|-----------------|------------------------------------------------------------|--|--| | Setup Phase | | | | | | WRITE | Unlock block | V <sub>PPH</sub> applied to V <sub>PP</sub> | | | | WRITE | BEFP setup | Data = 0x80 @ first word address <sup>1</sup> | | | | WRITE | BEFP confirm | Data = 0xD0 @ first word address | | | | READ | Status register | Data = Status register data<br>Adress = First word address | | | | Bus | | | | | |--------------------|-------------------------------------|------------------------------------------------------------------------------|--|--| | Operation | Action | Comments | | | | Standby | BEFP setup<br>done? | Check SR7: 0 = BEFP ready 1 = BEFP not ready | | | | Standby | Error condi-<br>tion check | If SR7 is set, check: SR3 set = V <sub>PP</sub> error SR1 set = Locked block | | | | <b>Program and</b> | Verify Phase | | | | | READ | Status register | Data = Status register data<br>Address = First word address | | | | Standby | Data stream ready? | Check SR0: 0 = Ready for data 1 = Not ready for data | | | | Standby | Initialize<br>count | X = 0 | | | | WRITE | Load buffer | Data = Data to program Address = First word address <sup>2</sup> | | | | Standby | Increment count | X = X + 1 | | | | Standby | Buffer full? | X = 512?<br>Yes = Read SR0<br>No = Load next data word | | | | READ | Status register | Data = Status register data Address = First word address | | | | Standby | Program<br>done? | Check SR0: 0 = Program done 1 = Program in progress | | | | Standby | Last data? | No = Fill buffer again<br>Yes = Exit | | | | WRITE | Exit program<br>and verify<br>phase | Data = 0xFFFF @ address not in current block | | | | Exit Phase | | | | | | READ | Status register | Data = Status register data Address = First word address | | | | Standby | Check exit sta-<br>tus | Check SR7: 0 = Exit not completed 1 = Exit completed | | | - Notes: 1. Repeat for subsequent blocks. - 2. After BEFP exit, a full status register check can determine if any program error occurred. - 3. See the Word Program Full Status Register Check Procedure flowchart. - 4. Write 0xFF to enter read array state. **Figure 48: Block Erase Procedure** | Bus<br>Operation | Command | Comments | | |------------------|----------------------|------------------------------------------------------------------------|--| | WRITE | BLOCK ERASE<br>SETUP | Data = 0x20<br>Address = Block to be erased | | | WRITE | ERASE CON-<br>FIRM | Data = 0xD0<br>Address = Block to be erased | | | READ | None | Status register data | | | Idle | None | Check SR7 1 = Write state machine ready 0 = Write state machine busy | | - Notes: 1. Repeat for subsequent block erasures. - 2. Full status register check can be done after each block erase or after a sequence of block erasures. - 3. Write 0xFF after the last operation to enter read array mode. **Figure 49: Block Erase Full Status Check Procedure** | Bus<br>Operation | Command | Comments | | |------------------|---------|----------------------------------------------------|--| | Idle | None | Check SR3 | | | | | 1 = V <sub>PP</sub> range error | | | Idle | None | Check SR[4, 5] | | | | | Both 1 = Command sequence error | | | Idle | None | Check SR5 | | | | | 1 = Block erase error | | | Idle | None | Check SR1 | | | | | 1 = Attempted erase of locked block; erase aborted | | - Notes: 1. Only the CLEAR STAUS REGISTER command clears the SR[1, 3, 4, 5]. - 2. If an error is detected, clear the status register before attempting an erase retry or other error recovery. Figure 50: Erase Suspend/Resume Procedure | Bus<br>Operation | Command | Comments | | |------------------|-------------|-------------------------------------------------------------|--| | WRITE | READ STATUS | Data = 0x70 | | | | | Address = Any partition address | | | WRITE | ERASE SUS- | Data = 0xB0 | | | | PEND | Address = Same partition address as above | | | READ | None | Status register data | | | | | Address = Same partition | | | Idle | None | Check SR7 | | | | | 1 = Write state machine ready | | | | | 0 = Write state machine busy | | | Idle | None | Check SR6 | | | | | 1 = Erase suspended | | | | | 0 = Erase completed | | | WRITE | Any READ or | Data = Command for desired operation | | | | PROGRAM | Address = Any address within the suspended partition | | | READ or | None | Read array or program data from/to block other than the one | | | WRITE | | being erased | | | WRITE | PROGRAM RE- | Data = 0xD0 | | | | SUME | Address = Any address | | If the suspended partition was placed in read array mode or a program loop: | WRITE | READ STATUS | Return partition to status mode: | | |-------|-------------|----------------------------------|--| | | REGISTER | Data = 0x70 | | | | | Address = Same partition | | **Figure 51: Block Lock Operations Procedure** | Bus<br>Operation | Command | Comments | | |-----------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | WRITE | LOCK SETUP | Data = 0x60 | | | WRITE | LOCK, UN-<br>LOCK, or<br>LOCK-DOWN<br>CONFIRM | Address = Block to lock/unlock/lock-down Data = 0x01 (BLOCK LOCK) Data = 0xD0 (BLOCK UNLOCK) Data = 0x2F (LOCK-DOWN BLOCK) Address = Block to lock/unlock/lock-down | | | WRITE (op-<br>tional) | READ DEVICE<br>ID | Data = 0x90<br>Address = Block address + offset 2 | | | READ (option-<br>al) | BLOCK LOCK<br>STATUS | Block lock status data Address = Block address + offset 2 | | | Idle | None | Confirm locking change on D[1, 0] | | | WRITE | READ ARRAY | Data = 0xFF Address = Block address | | **Figure 52: Protection Register Programming Procedure** | Bus<br>Operation | Command | Comments | |------------------|-----------------------|------------------------------------------------------------------------| | WRITE | PROGRAM PR<br>SETUP | Data = 0xC0<br>Address = First location to program | | WRITE | PROTECTION<br>PROGRAM | Data = Data to program Address = Location to program | | READ | None | Status register data | | Idle | None | Check SR7 1 = Write state machine ready 0 = Write state machine busy | Notes: - 1. PROGRAM PROTECTION REGISTER operation addresses must be within the protection register address space. Addresses outside this space will return an error. - 2. Repeat for subsequent PROGRAM operations. - 3. Full status register check can be done after each PROGRAM operation or after a sequence of PROGRAM operations. 4. Write 0xFF after the last operation to set to the read array state. Figure 53: Protection Register Programming Full Status Check Procedure | Bus<br>Operation | Command | Comments | |------------------|---------|----------------------------------------| | Idle | None | Check SR3 | | | | 1 = V <sub>PP</sub> error | | Idle | None | Check SR4 | | | | 1 = Programming error | | Idle | None | Check SR1 | | | | 1 = Register locked; operation aborted | - Notes: 1. Only the CLEAR STAUS REGISTER command clears SR[1, 3, 4]. - 2. If an error is detected, clear the status register before attempting a program retry or other error recovery. **Figure 54: Blank Check Procedure** | Bus<br>Operation | Command | Comments | |------------------|------------------------|------------------------------------------------------------------------| | WRITE | BLANK CHECK<br>SETUP | Data = 0xBC<br>Address = Block to be read | | WRITE | BLANK CHECK<br>CONFIRM | Data = 0xD0<br>Address = Block to be read | | READ | None | Status register data | | Idle | None | Check SR7 1 = Write state machine ready 0 = Write state machine busy | Notes: 1. Repeat for subsequent block blank check. 2. Full status register check should be read after blank check has been performed on each block. **Figure 55: Blank Check Full Status Check Procedure** | Bus<br>Operation | Command | Comments | |------------------|---------|-------------------------------------------| | Idle | None | Check SR[4, 5] 1 = Command sequence error | | Idle | None | Check SR5 1 = Blank check error | - Notes: 1. SR[1, 3] must be cleared before the write state machine will allow blank check to be performed. - 2. Only the CLEAR STAUS REGISTER command clears SR[1, 3, 4, 5]. - 3. If an error is detected, clear the status register before attempting a blank check retry or other error recovery. ### **AADM Mode** ### **AADM Feature Overview** The following is a list of general requirements for AADM mode. **Feature availability.** AADM mode is available in devices that are configured as A/D MUX. With this configuration, AADM mode is enabled by setting a specific volatile bit in the read configuration register. **High-address capture (A[MAX:16]).** When AADM mode is enabled, A[MAX:16] and A[15:0] are captured from the A/ DQ[15:0] balls. The selection of A[MAX:16] or A[15:0] is determined by the state of the OE# input, as A[MAX:16] is captured when OE# is at $V_{\rm II}$ . **READ and WRITE cycle support.** In AADM mode, both asynchronous and synchronous cycles are supported. **Customer requirements.** For AADM operation, the customer is required to ground A[MAX:16]. Other characteristics. For AADM, all other device characteristics (program time, erase time, $I_{CCS}$ , etc.) are the same as A/D MUX unless otherwise stated. ### **AADM Mode Enable (RCR[4] = 1)** Setting RCR[4] to its non-default state (1b) enables AADM mode. The default device configuration upon reset or power-up is A/D MUX mode. Upon setting RCR[4] = 1, the upper addresses, A[MAX:16] are latched. All 0s are latched by default. ### **Bus Cycles and Address Capture** + AADM bus operations have one or two address cycles. For two address cycles, the upper address (A[MAX:16]) must be issued first, followed by the lower address (A[15:0]). For bus operations with only one address cycle, only the lower address is issued. The upper address that applies is the one that was most recently latched on a previous bus cycle. For all READ cycles, sensing begins when the lower address is latched, regardless of whether there are one or two address cycles. In bus cycles, the external signal that distinguishes the upper address from the lower address is OE#. When OE# is at $V_{\rm IH}$ , a lower address is captured; when OE# is at $V_{\rm IL}$ , an upper address is captured. When the bus cycle has only one address cycle, the timing waveform is similar to A/D MUX mode. The lower address is latched when OE# is at $V_{\rm IH}$ , and data is subsequently outputted after the falling edge of OE#. When the device initially enters AADM mode, the upper address is internally latched as all 0s. ### **WAIT Behavior** The WAIT behavior in AADM mode functions the same as the legacy non-MUX WAIT behavior (A/D MUX WAIT behavior is unique). In other words, WAIT will always be driven whenever DQ[15:0] is driven, and WAIT will tri-state whenever DQ[15:0] tri-state. In asynchronous mode (RCR[15] = 1b), WAIT always indicates valid data when driven. In synchronous mode (RCR[15] = 0b), WAIT indicates valid data only after the latency count has lapsed and the data output data is truly valid. ### **Asynchronous READ and WRITE Cycles** For asynchronous READ and WRITE cycles, ADV# must be toggled HIGH-LOW-HIGH a minimum of one time and a maximum of two times during a bus cycle. If ADV# is toggled LOW twice during a bus cycle, OE# must be held LOW for the first ADV# rising edge and OE# must be held HIGH for the second ADV# rising edge. The first ADV# rising edge (with OE# LOW) captures A[MAX:16]. The second ADV# rising edge (with OE# HIGH) captures A[15:0]. Each bus cycle must toggle ADV# HIGH-LOW-HIGH at least one time in order to capture A[15:0]. For asynchronous reads, sensing begins when the lower address is latched. During asynchronous cycles, it is optional to capture A[MAX:16]. If these addresses are not captured, then the previously captured A[MAX:16] contents will be used. ### **Asynchronous READ Cycles** For AADM, note that asynchronous read access is from the rising edge of ADV# rather than the falling edge (tVHQV rather than tVLQV). **Table 61: AADM Asynchronous and Latching Timings** | Symbol | MIN (ns) | MAX (ns) | Notes | |-------------------|----------|----------|-------| | <sup>t</sup> GLQV | | 20 | | | <sup>t</sup> PHQV | | 150 | | | <sup>t</sup> ELQX | 0 | | | | <sup>t</sup> GLQX | 0 | | | | <sup>t</sup> EHQZ | | 9 | | | <sup>t</sup> GHQZ | | 9 | | | <sup>t</sup> OH | 0 | | | | <sup>t</sup> EHEL | 7 | | | | <sup>t</sup> ELTV | | 11 | | | <sup>t</sup> EHTZ | | 9 | | | <sup>t</sup> GLTV | | 7 | | | <sup>t</sup> GLTX | 0 | | | | <sup>t</sup> GHTZ | | 9 | | | <sup>t</sup> AVVH | 5 | | | | <sup>t</sup> ELVH | 9 | | | | <sup>t</sup> VLVH | 7 | | | | <sup>t</sup> VHVL | 7 | | | | <sup>t</sup> VHAX | 5 | | | | tVHGL | 3 | | | | <sup>t</sup> VHQV | | 96 | 1, 2 | | <sup>t</sup> VHQV | | 106 | 1, 2 | **Table 61: AADM Asynchronous and Latching Timings (Continued)** | Symbol | MIN (ns) | MAX (ns) | Notes | |-------------------|----------|----------|-------| | <sup>t</sup> PHVH | 30 | | | | <sup>t</sup> GHVH | 3 | | | | <sup>t</sup> GLVH | 3 | | | | <sup>t</sup> VHGH | 3 | | | Notes: 1. A READ cycle may be restarted prior to completing a pending READ operation, but this may occur only once before the sense operation is allowed to complete. 2. tVHQV applies to asynchronous read access time. Figure 56: AADM Asynchronous READ Cycle (Latching A[MAX:0]) Notes: 1. CE# need not be de-asserted at beginning of the cycle if OE# does not have output control. 2. Diagram shows WAIT as active LOW (RCR[10] = 0). Figure 57: AADM Asynchronous READ Cycle (Latching A[15:0] only) Notes: 1. Diagram shows WAIT as active LOW (RCR[10] = 0). 2. Without latching A[MAX:16] in the asynchronous READ cycle, the previously latched A[MAX:16] applies. ### **Asynchronous WRITE Cycles** **Table 62: AADM Asynchronous Write Timings** | Symbol | MIN (ns) | | |-------------------|----------|--| | <sup>t</sup> PHWL | 150 | | | <sup>t</sup> ELWL | 0 | | | tWLWH | 40 | | | <sup>t</sup> DVWH | 40 | | | <sup>t</sup> WHEH | 0 | | | <sup>t</sup> WHDX | 0 | | | <sup>t</sup> WHWL | 20 | | | tVPWH | 200 | | | <sup>t</sup> WVVL | 0 | | | <sup>t</sup> BHWH | 200 | | | <sup>t</sup> WHGL | 0 | | | <sup>t</sup> GHWL | 0 | | - Notes: 1. A READ cycle may be restarted prior to completing a pending READ operation, but this may occur only once before the sense operation is allowed to complete. - 2. tVHQV applies to asynchronous read access time. Figure 58: AADM Asynchronous WRITE Cycle (Latching A[MAX:0]) 1. CE# need not be de-asserted at beginning of cycle if OE# does not have output control. Figure 59: AADM Asynchronous WRITE Cycle (Latching A[15:0] only) Note: 1. Without latching A[MAX:16] in the WRITE cycle, the previously latched A[MAX:16] applies. ### **Synchronous READ and WRITE Cycles** Just as asynchronous bus cycles, synchronous bus cycles (RCR[15] = 0b) can have one or two address cycles. If the are two address cycles, the upper address must be latched first with OE# at $V_{\rm IL}$ followed by the lower address with OE# at $V_{\rm IH}$ . If there is only one address cycle, only the lower address will be latched and the previously latched upper address applies. For reads, sensing begins when the lower address is latched, but for synchronous reads, addresses are latched on a rising clock CLK instead of a rising ADV# edge. For synchronous bus cycles with two address cycles, it is not necessary to de-assert ADV# between the two address cycles. This allows both the upper and lower address to be latched in only two clock periods. ### **Synchronous READ Cycles** For synchronous READ operation, the specifications in the AADM Asynchronous and Latching Timings Table also apply. **Table 63: AADM Synchronous Timings** Notes 1 and 2 apply to entire table | Symbol | Target (104 MHz)<br>Min (ns) | Target (104 MHz)<br>Max (ns) | Notes | |--------------------------------------|------------------------------|------------------------------|-------| | <sup>t</sup> CLK | 9.6 | | | | <sup>t</sup> RISE/ <sup>t</sup> FALL | | 1.5 | 3 | | <sup>t</sup> AVCH | 3 | | | | tVLCH | 3 | | | | <sup>t</sup> ELCH | 3.5 | | | | <sup>t</sup> CHQV | | 7 | | | <sup>t</sup> CHQX | 1 | | | | <sup>t</sup> CHAX | 5 | | 4 | ### **Table 63: AADM Synchronous Timings (Continued)** Notes 1 and 2 apply to entire table | Symbol | Target (104 MHz)<br>Min (ns) | Target (104 MHz)<br>Max (ns) | Notes | |-------------------|------------------------------|------------------------------|-------| | <sup>t</sup> CHTV | | 7 | | | <sup>t</sup> CHVL | 2.5 | | | | <sup>t</sup> CHTX | 1 | | | | <sup>t</sup> CHVH | 2 | | | | <sup>t</sup> CHGL | 2.5 | | 6, 4 | | <sup>t</sup> VLVH | <sup>t</sup> CLK | 2 × <sup>t</sup> CLK | 5, 6 | | tVHCH | 3 | | | | <sup>t</sup> CHGH | 2 | | | | <sup>t</sup> GHCH | 2 | | | | <sup>t</sup> GLCH | 3 | | | ### Notes - 1. In synchronous burst READ cycles, the asynchronous OE# to ADV# setup and hold times must also be met (<sup>t</sup>GHVH and <sup>t</sup>VHGL) to signify that the address capture phase of the bus cycle is complete. - 2. A READ cycle may only be terminated (prior to the completion of sensing data) one time before a full bus cycle must be allowed to complete. - 3. Rise and fall time specified between $V_{IL}$ and $V_{IH}$ . - 4. To prevent A/D bus contention between the host and the memory device, OE# may only be asserted LOW after the host has satisfied the ADDR hold spec, <sup>†</sup>CHAX. - 5. The device must operate down to 9.6 MHz in synchronous burst mode. - 6. During the address capture phase of a read burst bus cycle, OE# timings relative to CLK shall be identical to those of ADV# relative to CLK. Figure 60: AADM Synchronous Burst READ Cycle (ADV# De-asserted Between Address Cycles) Notes: 1. CE# need not be de-asserted at beginning of cycle if OE# does not have output control. - 2. Diagram shows WAIT as active LOW (RCR[10] = 0) and asserted with data (RCR[8] = 0). - 3. For no-wrap bursts, end-of-wordline WAIT states could occur (not shown). Figure 61: AADM Synchronous Burst READ Cycle (ADV# Not De-asserted Between Address Cycles) Notes: 1. CE# need not be de-asserted at beginning of cycle if OE# does not have output control. - 2. Diagram shows WAIT as active LOW (RCR[10] = 0) and asserted with data (RCR[8] = 0). - 3. For no-wrap bursts, end-of-wordline WAIT states could occur (not shown). Figure 62: AADM Synchronous Burst READ Cycle (Latching A[15:0] only) Notes: - 1. Diagram shows WAIT as active LOW (RCR[10] = 0) and asserted with data (RCR[8] = 0). - 2. For no-wrap bursts, end-of-wordline WAIT states could occur (not shown). - 3. Without latching A[MAX:16] in the synchronous READ cycle, the previously latched A[MAX:16] applies. ### **Synchronous WRITE Cycles** For synchronous writes, only the address latching cycle(s) are synchronous. Synchronous address latching is depicted in the Synchronous READ Cycles. The actual WRITE operation (rising WE# edge) is asynchronous and is independent of CLK. Asynchronous writes are depicted in Asynchronous WRITE Cycles. ### **System Boot** Systems that use the AADM mode will boot from the bottom 128KB of device memory because A[MAX:16] are expected to be grounded in-system. The 128KB boot region is sufficient to perform required boot activities before setting RCR[4] to enable AADM mode. # 56-Ball MCP: 256Mb/512Mb Parallel NOR and 128Mb PSRAM Revision History ### **Revision History** Rev. B - 7/15 · Updated document status to "Production" Rev. A - 5/15 · Initial release 8000 S. Federal Way, P.O. Box 6, Boise, ID 83707-0006, Tel: 208-368-4000 www.micron.com/products/support Sales inquiries: 800-932-4992 Micron and the Micron logo are trademarks of Micron Technology, Inc. All other trademarks are the property of their respective owners. This data sheet contains minimum and maximum limits specified over the power supply and temperature range set forth herein. Although considered final, these specifications are subject to change, as further product development and data characterization sometimes occur.