**Esses winbond** ### 1.8V 512M-BIT SERIAL FLASH MEMORY WITH DUAL/QUAD SPI & RPMC #### **Table of Contents** | 1. | GENE | ERAL DE | SCRIPTIONS | 5 | |----|-------|---------|----------------------------------------------------------------------------------|----| | 2. | FEAT | URES | | 5 | | 3. | PACK | AGE TY | PES AND PIN CONFIGURATIONS | 6 | | | 3.1 | Pad C | onfiguration WSON 8x6-mm | 6 | | | 3.2 | Pad D | escription WSON 8x6-mm | 6 | | 4. | PIN D | ESCRIP | TIONS | 7 | | | 4.1 | Chip S | Select (/CS) | 7 | | | 4.2 | Serial | Data Input, Output and IOs (DI, DO and IO0, IO1, IO2, IO3) | 7 | | | 4.3 | Serial | Clock (CLK) | 7 | | 5. | BLOC | K DIAGI | RAM | 8 | | 6. | FUNC | CTIONAL | DESCRIPTIONS | 9 | | | 6.1 | SPI Or | perations | 9 | | | | 6.1.1 | Standard SPI Instructions | | | | | 6.1.2 | Dual SPI Instructions | 9 | | | | 6.1.3 | Quad SPI Instructions | 10 | | | | 6.1.4 | 3-Byte / 4-Byte Address Modes | 10 | | | | 6.1.5 | Software Reset | 10 | | | 6.2 | RPMC | OPERATIONS | 11 | | | | 6.2.1 | RPMC Initialization | | | | | 6.2.2 | RPMC Operation Flow | | | | | 6.2.3 | Operations Allowed / Disallowed During RPMC Operation | | | | | 6.2.4 | RPMC Status Register Definition | | | | 6.3 | | Protection | | | 7. | STAT | US AND | CONFIGURATION REGISTERS | 16 | | | 7.1 | Status | Registers | | | | | 7.1.1 | Erase/Write In Progress (BUSY) - Status Only | | | | | 7.1.2 | Write Enable Latch (WEL) - Status Only | 16 | | | | 7.1.3 | Block Protect Bits (BP3, BP2, BP1, BP0) - Volatile/Non-Volatile Writable | | | | | 7.1.4 | Top/Bottom Block Protect (TB) - Volatile/Non-Volatile Writable | 17 | | | | 7.1.5 | Complement Protect (CMP) - Volatile/Non-Volatile Writable | 17 | | | | 7.1.6 | Status Register Protect (SRP1, SRP0) - Volatile/Non-Volatile Writable | 17 | | | | 7.1.7 | Erase/Program Suspend Status (SUS) - Status Only | 18 | | | | 7.1.8 | Security Register Lock Bits (LB3, LB2, LB1) - Volatile/Non-Volatile OTP Writable | 18 | | | | 7.1.9 | Quad Enable (QE) - Volatile/Non-Volatile Writable | 18 | | | | 7.1.10 | Current Address Mode (ADS) - Status Only | 19 | | | | 7.1.11 | Power-Up Address Mode (ADP) - Non-Volatile Writable | 19 | | | | 7.1.12 | Write Protect Selection (WPS) - Volatile/Non-Volatile Writable | 19 | | | - winbond | |------------|----------------------------------------------------| | <br>7 1 13 | Output Driver Strength (DRV1_DRV0) = Volatile/Non- | | | 7.1.13 | Output Driver Strength (DRV1, DRV0) - Volatile/Non-Volatile Writable | 20 | |-----|--------|-----------------------------------------------------------------------------------|----| | | 7.1.14 | Reserved Bits - Non Functional | 20 | | | 7.1.15 | W25R512NW/W74M51NW Status Register Memory Protection (WPS = 0, CMP = 0) | 21 | | | 7.1.16 | W25R512NW/W74M51NW Status Register Memory Protection (WPS = 0, CMP = 1) | 22 | | | 7.1.17 | W25R512NW/W74M51NW Individual Block Memory Protection (WPS=1) | 23 | | 7.2 | Exten | ded Address Register - Volatile Writable Only | 24 | | 7.3 | INSTE | RUCTIONS | 25 | | 7.4 | Device | e ID and Instruction Set Tables | 25 | | | 7.4.1 | Manufacturer and Device Identification | | | | 7.4.2 | Instruction Set Table 1 (Standard/Dual/Quad SPI, 3-Byte & 4-Byte Address Mode)(1) | 26 | | | 7.4.3 | Instruction Set Table 2 (Dual/Quad SPI Instructions,3-Byte Address Mode) | 27 | | | 7.4.4 | Instruction Set Table 3 (Standard SPI, 4-Byte Address Mode) <sup>(1)</sup> | 28 | | | 7.4.5 | Instruction Set Table 4 (Dual/Quad SPI Instructions, 4-Byte Address Mode) | 29 | | | 7.4.6 | Instruction Set Table 2-1 (RPMC Input Instruction, OP1) <sup>(1)</sup> | 31 | | | 7.4.7 | Instruction Set Table 2-2 (RPMC Output Instruction, OP2)(1) | 31 | | 7.5 | Instru | ction Descriptions | 32 | | | 7.5.1 | Write Enable (06h) | | | | 7.5.2 | Write Enable for Volatile Status Register (50h) | | | | 7.5.3 | Write Disable (04h) | | | | 7.5.4 | Read Status Register-1 (05h), Status Register-2 (35h) & Status Register-3 (15h) | 33 | | | 7.5.5 | Write Status Register-1 (01h), Status Register-2 (31h) & Status Register-3 (11h) | | | | 7.5.6 | Read Extended Address Register (C8h) | | | | 7.5.7 | Write Extended Address Register (C5h) | 37 | | | 7.5.8 | Enter 4-Byte Address Mode (B7h) | 38 | | | 7.5.9 | Exit 4-Byte Address Mode (E9h) | 38 | | | 7.5.10 | Read Data (03h) | 39 | | | 7.5.11 | Read Data with 4-Byte Address (13h) | 40 | | | 7.5.12 | Fast Read (0Bh) | 41 | | | 7.5.13 | Fast Read with 4-Byte Address (0Ch) | 42 | | | 7.5.14 | Fast Read Dual Output (3Bh) | 43 | | | 7.5.15 | Fast Read Dual Output with 4-Byte Address (3Ch) | 44 | | | 7.5.16 | Fast Read Quad Output (6Bh) | 45 | | | 7.5.17 | Fast Read Quad Output with 4-Byte Address (6Ch) | 46 | | | 7.5.18 | Fast Read Dual I/O (BBh) | 47 | | | 7.5.19 | Fast Read Dual I/O with 4-Byte Address (BCh) | 48 | | | 7.5.20 | Fast Read Quad I/O (EBh) | 50 | | | 7.5.21 | Fast Read Quad I/O with 4-Byte Address (ECh) | 51 | | | 7.5.22 | Set Burst with Wrap (77h) | 54 | | | 7.5.23 | 33 3 4 (3 ) | | | | 7.5.24 | Quad Input Page Program (32h) | 56 | | | 7.5.25 | Sector Erase (20h) | 57 | | | 7.5.26 | 32KB Block Erase (52h) | 58 | | | | | winbond see | | |-----|------|----------|-------------------------------------------------------|-----| | | | 7.5.27 | 64KB Block Erase (D8h) | 59 | | | | 7.5.28 | Chip Erase (C7h / 60h) | 60 | | | | 7.5.29 | Erase / Program Suspend (75h) | 61 | | | | 7.5.30 | Erase / Program Resume (7Ah) | 62 | | | | 7.5.31 | Power-down (B9h) | 63 | | | | 7.5.32 | Release Power-down / Device ID (ABh) | 64 | | | | 7.5.33 | Read Manufacturer / Device ID (90h) | 65 | | | | 7.5.34 | Read Manufacturer / Device ID Dual I/O (92h) | 66 | | | | 7.5.35 | Read Manufacturer / Device ID Quad I/O (94h) | 67 | | | | 7.5.36 | Read Unique ID Number (4Bh) | 68 | | | | 7.5.37 | Read JEDEC ID (9Fh) | 69 | | | | 7.5.38 | Read SFDP Register (5Ah) | 70 | | | | 7.5.39 | Erase Security Registers (44h) | 71 | | | | 7.5.40 | Program Security Registers (42h) | 72 | | | | 7.5.41 | Read Security Registers (48h) | | | | | 7.5.42 | Individual Block/Sector Lock (36h) | | | | | 7.5.43 | Individual Block/Sector Unlock (39h) | | | | | 7.5.44 | Read Block/Sector Lock (3Dh) | | | | | 7.5.45 | Global Block/Sector Lock (7Eh) | | | | | 7.5.46 | Global Block/Sector Unlock (98h) | | | | | 7.5.47 | Enable Reset (66h) and Reset Device (99h) | | | | | 7.5.48 | Write Root Key Register (9Bh + 00h) | | | | | 7.5.49 | Update HMAC Key (9Bh + 01h) | | | | | 7.5.50 | Increment Monotonic counters (9Bh + 02h) | | | | | 7.5.51 | Request Monotonic counters (9Bh + 03h) | | | | | 7.5.52 | Reserved RPMCCommands (9Bh + 04h~FFh) | | | | | 7.5.53 | Read RPMCStatus / Data (96h) | | | 8. | ELEC | TRICAL | CHARACTERISTICS | 85 | | | 8.1 | Absolu | te Maximum Ratings (1)(2) | 85 | | | 8.2 | Operat | ing Ranges | 85 | | | 8.3 | Power- | -up Timing and Write Inhibit Threshold <sup>(1)</sup> | 86 | | | 8.4 | | ectrical Characteristics | | | | 8.5 | | asurement Conditions <sup>(1)</sup> | | | | | | | | | | 8.6 | | ectrical Characteristics(6) | | | | 8.7 | | Output Timing | | | | 8.8 | Serial I | Input Timing | 91 | | 9. | PACK | AGE SP | ECIFICATIONS | 92 | | | 9.1 | 8-Pad | WSON 8x6-mm (Package Code E) | 92 | | | 9.2 | 16-Pin | SOIC 300-mil (Package Code F) | 93 | | 10. | | | IFORMATION | | | | | | Part Numbers and Top Side Marking | | | | IV.I | vallu F | all muliibels and ton one maining | 9:) | | | | W | inl | bo | nd | | |----|------------------|---|-----|----|----|----| | 11 | REVISION AISTORY | | | | | 96 | #### 1. GENERAL DESCRIPTIONS The W25R512NW/W74M51NW (512M-bit) Serial Flash memory provides a storage solution for systems with limited space, pins and power. The W25R/74M series offers flexibility and performance well beyond ordinary Serial Flash devices. They are ideal for code shadowing to RAM, executing code directly from Dual/Quad SPI (XIP) and storing voice, text and data. All devices are offered in space-saving packages. The W25R512NW/W74M51NW support the standard Serial Peripheral Interface (SPI), Dual/Quad I/O SPI: Serial Clock, Chip Select, Serial Data I/O0 (DI), I/O1 (DO), I/O2, and I/O3. SPI clock frequencies of up to 133MHz are supported allowing equivalent clock rates of 266MHz (133MHz x 2) for Dual I/O and 532MHz (133MHz x 4) for Quad I/O when using the Fast Read Dual/Quad I/O instructions. These transfer rates can outperform standard Asynchronous 8 and 16-bit Parallel Flash memories. The device supports JEDEC standard manufacturer and device ID and SFDP Register, a 64-bit Unique Serial Number and three 256-bytes Security Registers. The W25R/74M series is also equipped with an enhanced authentication security feature by Replay Protection Monotonic Counter (RPMC). It provides a high level secured communication between the flash device and the controller to reduce the system vulnerabilities to hardware attacks. #### 2. FEATURES #### New Family of SpiFlash Memories - W25R512NW/W74M51NW: 512M-bit / 64M-byte - Standard SPI: CLK, /CS, DI, DO - Dual SPI: CLK, /CS, IO<sub>0</sub>, IO<sub>1</sub> - Quad SPI: CLK, /CS, IO<sub>0</sub>, IO<sub>1</sub>, IO<sub>2</sub>, IO<sub>3</sub> - 3 or 4-Byte Addressing Mode - Software Reset #### Highest Performance Serial Flash - 133MHz Standard/Dual/Quad SPI clocks - 266/532MHz equivalent Dual/Quad SPI - 60MB/S continuous data transfer rate - More than 100,000 erase/program cycles - More than 20-year data retention #### • Low Power, Wide Temperature Range - Single 1.7 to 1.95V supply - -40°C to +85°C operating range #### Flexible Architecture with 4KB sectors - Uniform Sector/Block Erase (4K/32K/64K-Byte) - Program 1 to 256 byte per programmable page - Erase/Program Suspend & Resume #### Advanced Security Features - Power Supply Lock-Down and OTP protection - Top/Bottom, Complement array protection - Individual Block/Sector array protection - 64-Bit Unique ID for each device - Discoverable Parameters (SFDP) Register - 3X256-Bytes Security Registers with OTP locks - Replay Protection Monotonic Counter (RPMC) - Volatile & Non-volatile Status Register Bits #### • Space Efficient Packaging - 8-pad WSON 8x6-mm - Contact Winbond for other options #### 3. PACKAGE TYPES AND PIN CONFIGURATIONS #### 3.1 Pad Configuration WSON 8x6-mm Figure 1a. W25R512NW/W74M51NW Pad Assignments, 8-pad WSON 8x6-mm (Package Code E) #### 3.2 Pad Description WSON 8x6-mm | PIN NO. | PIN NAME | I/O | FUNCTION | |---------|----------|-----|------------------------------------| | 1 | /CS | I | Chip Select Input | | 2 | IO1 | I/O | Data Input Output 1 <sup>(1)</sup> | | 3 | IO2 | I/O | Data Input Output 2 <sup>(2)</sup> | | 4 | GND | | Ground | | 5 | IO0 | I/O | Data Input Output 0 <sup>(1)</sup> | | 6 | CLK | I | Serial Clock Input | | 7 | IO3 | I/O | Data Input Output 3 <sup>(2)</sup> | | 8 | VCC | | Power Supply | #### Notes: 1. IO0 and IO1 are used for Standard and Dual SPI instructions 2. IO0 - IO3 are used for Quad SPI instructions. #### 4. PIN DESCRIPTIONS #### 4.1 Chip Select (/CS) The SPI Chip Select (/CS) pin enables and disables device operation. When /CS is high the device is deselected and the Serial Data Output (DO, or IO0, IO1, IO2, IO3) pins are at high impedance. When deselected, the devices power consumption will be at standby levels unless an internal erase, program or write status register cycle is in progress. When /CS is brought low the device will be selected, power consumption will increase to active levels and instructions can be written to and data read from the device. After power-up, /CS must transition from high to low before a new instruction will be accepted. The /CS input must track the VCC supply level at power-up (see "Write Protection" and Figure 58). If needed a pull-up resister on the /CS pin can be used to accomplish this. #### 4.2 Serial Data Input, Output and IOs (DI, DO and IO0, IO1, IO2, IO3) The W25R512NW/W74M51NW supports standard SPI, Dual SPI, Quad SPI operation. Standard SPI instructions use the unidirectional DI (input) pin to serially write instructions, addresses or data to the device on the rising edge of the Serial Clock (CLK) input pin. Standard SPI also uses the unidirectional DO (output) to read data or status from the device on the falling edge of CLK. Dual/Quad SPI instructions use the bidirectional IO pins to serially write instructions, addresses or data to the device on the rising edge of CLK and read data or status from the device on the falling edge of CLK #### 4.3 Serial Clock (CLK) The SPI Serial Clock Input (CLK) pin provides the timing for serial input and output operations. ("See SPI Operations") # **Esses winbond se** #### 5. BLOCK DIAGRAM Figure 2. W25R512NW/W74M51NW Serial Flash Memory Block Diagram #### 6. FUNCTIONAL DESCRIPTIONS #### 6.1 SPI Operations Figure 3. W25R512NW/W74M51NW Serial Flash Memory Operation Diagram #### 6.1.1 Standard SPI Instructions The W25R512NW/W74M51NW is accessed through an SPI compatible bus consisting of four signals: Serial Clock (CLK), Chip Select (/CS), Serial Data Input (DI) and Serial Data Output (DO). Standard SPI instructions use the DI input pin to serially write instructions, addresses or data to the device on the rising edge of CLK. The DO output pin is used to read data or status from the device on the falling edge of CLK. SPI bus operation Mode 0 (0,0) and 3 (1,1) are supported. The primary difference between Mode 0 and Mode 3 concerns the normal state of the CLK signal when the SPI bus master is in standby and data is not being transferred to the Serial Flash. For Mode 0, the CLK signal is normally low on the falling and rising edges of /CS. For Mode 3, the CLK signal is normally high on the falling and rising edges of /CS. #### 6.1.2 Dual SPI Instructions The W25R512NW/W74M51NW supports Dual SPI operation when using instructions such as "Fast Read Dual Output (3Bh)" and "Fast Read Dual I/O (BBh)". These instructions allow data to be transferred to or from the device at two to three times the rate of ordinary Serial Flash devices. The Dual SPI Read instructions are ideal for quickly downloading code to RAM upon power-up (code-shadowing) or for executing non-speed-critical code directly from the SPI bus (XIP). When using Dual SPI instructions, the DI and DO pins become bidirectional I/O pins: IOO and IO1. #### 6.1.3 Quad SPI Instructions The W25R512NW/W74M51NW can be reset to the initial power-on state by a software Reset sequence. This sequence must include two consecutive commands: Enable Reset (66h) & Reset (99h). If the command sequence is successfully accepted, the device will take approximately 30uS (trst) to reset. No command will be accepted during the reset period. #### 6.1.4 3-Byte / 4-Byte Address Modes The W25R512NW/W74M51NW provides two Address Modes that can be used to specify any byte of data in the memory array. The 3-Byte Address Mode is backward compatible to older generations of serial flash memory that only support up to 128M-bit data. To address the 256M-bit or more data in 3-Byte Address Mode, Extended Address Register must be used in addition to the 3-Byte addresses. 4-Byte Address Mode is designed to support Serial Flash Memory devices from 256M-bit to 32G-bit. The extended Address Register is not necessary when the 4-Byte Address Mode is enabled. Upon power up, the W25R512NW/W74M51NW can operate in either 3-Byte Address Mode or 4-Byte Address Mode, depending on the Non-Volatile Status Register Bit ADP (S17) setting. If ADP=0, the device will operate in 3-Byte Address Mode; if ADP=1, the device will operate in 4-Byte Address Mode. The factory default value for ADP is 0. To switch between the 3-Byte or 4-Byte Address Modes, "Enter 4-Byte Mode (B7h)" or "Exit 4-Byte Mode (E9h)" instructions must be used. The current address mode is indicated by the Status Register Bit ADS (S16). #### 6.1.5 Software Reset The W25R512NW/W74M51NW can be reset to the initial power-on state by a software Reset sequence. This sequence must include two consecutive instructions: Enable Reset (66h) & Reset (99h). If the instruction sequence is successfully accepted, the device will take approximately 30µS (trst) to reset. No instruction will be accepted during the reset period.). - 10 - Publication Release Date: June 14, 2022 - Revision C1 #### 6.2 RPMC OPERATIONS To prevent hardware vulnerability attack, RPMC provides a building block towards providing Confidentiality and Integrity of read/write flash memory data. The W25R512NW/W74M51NW is equipped with four 32-bit Monotonic counters and can be addressed individually by the 8-bit Counter\_Address. These Monotonic counters are used by the SPI flash controllers to ensure the physical authenticity of the attached flash devices. RPMC operation is based on the HMAC-SHA-256 cryptographic algorithm. HMAC-SHA-256 is a type of keyed hash algorithm that is constructed from the SHA-256 hash function and used as a Hash-based Message Authentication Code (HMAC). The HMAC process mixes a secret key with the message data, hashes the result with the hash function, mixes that hash value with the secret key again, and then applies the hash function a second time. The output hash is 256 bits in length. An HMAC can be used to determine whether a message sent over an insecure channel has been tampered with, provided that the sender and receiver share a secret key. The sender computes the hash value for the original data and sends both the original data and hash value as a single message. The receiver recalculates the hash value on the received message and checks that the computed HMAC matches the transmitted HMAC. Any change to the data or the hash value results in a mismatch, because knowledge of the secret key is required to change the message and reproduce the correct hash value. Therefore, if the original and computed hash values match, the message is authenticated. #### 6.2.1 RPMC Initialization RPMC operation is initialized in an OEM manufacturing environment by issuing the "Write Root Key Register" command. When this command is successfully received and executed, a 256-bit Root Key will be written into the flash device permanently, and the corresponding Monotonic counters will also be initialized to 0. After the initialization procedure, the Root Key value can no longer be altered or accessed externally through the SPI interface. The initialized Monotonic counters is ready to accept the authenticated RPMC commands. Figure 3a. W25R512NW/W74M51NW RPMC Initialization Flow Diagram #### 6.2.2 RPMC Operation Flow Once the root key and the Monotonic counters have been initialized, every time after the device is powered on, prior to any RPMC operations, the external SPI flash controller must update the HMAC Key register in the W25R512NW/W74M51NW. After initializing the HMAC key register, there are two different RPMC operations can be performed. "Increment Monotonic counters" is used to increase the Monotonic counters value by 1. "Request Monotonic counters" is used to read out the existing Monotonic counters data. Figure 3b. W25R512NW/W74M51NW RPMC Operation Flow Diagram #### 6.2.3 Operations Allowed / Disallowed During RPMC Operation The RPMC operation is independent to the other SPI flash operations. The RPMC input command OP1 (9Bh) will initial internal operations after the authenticated command is accepted by the device. During the internal operation period, the BUSY bit in the RPMC Status Register (bit 0) will be set to 1. The RPMC internal operation cannot be suspended and can only be interrupted by the Device Reset command (99h). While the RPMC internal operation is going on, other SPI flash commands can be issued and executed. Please refer to the table below for details. | Operations | Device Behavior | | | |------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Suspend/Resume | Only main flash memory Program/Erase operations can be suspended and resumed later. RPMC operations cannot be suspended. | | | | Read/Program/Erase<br>main memory array | All memory Read/Program/Erase commands are accepted while a RPMC operation is on-going. | | | | Read/Write SPI flash<br>Status Registers | The SPI flash Status Register-1&2 can be read out or written to during any internal RPMC operations. | | | | RPMC OP1 command | The RPMC input command OP1 will be ignored while a RPMC operation is on-going. This command can be accepted and executed while a main memory Program/Erase operation is on-going. | | | | Read RPMC<br>Status/Data<br>OP2 command | The RPMC Status Register can be read out while a RPMC operation is ongoing and this is the way to check if the RPMC operation has finished or not. If the BUSY bit of RPMC Status Register is set as 1, the RPMC data output following the Status Register is not reliable. During the SPI flash internal Program/Erase operations, this command can still be used to check the RPMC status or read out RPMC data. | | | | Device Reset | The software reset sequence can be issued any time during SPI flash or RPMC internal operations. All volatile settings will be reset and data corruption may happen if there's an on-going Program/Erase operation. | | | #### 6.2.4 RPMC Status Register Definition During the RPMC operations, an 8-bit Status Register is used to indicate various states of the command execution and device status. A "Read RPMC Status" command can be issued during any RPMC operation to check the Status Register. | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------------------|----------------|--------------------------------------------------------------------|-------------------------|----------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------|-------| | Successful<br>Completion | Not<br>Defined | Fatal Error<br>(Pgm/Erase<br>Fail or no<br>valid counter<br>found) | Counter_AddressMismatch | HMAC Key<br>Reg<br>Uninitialized | Signature Mismatch or Counter Address out of range or Write_Mode out of range | Root Keys Overwrite or Root Keys length mismatch or TruncatedSig Mismatch | BUSY | | RPMC Status<br>Register[7:0] | Applicable<br>CmdType(s) | Description | | | |------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0000000 | | Power On State (Read RPMC Status is issued directly after power-up). | | | | 10000000 | 00, 01, 02, 03 | This status must be set on successful completion (no errors) of OP1 command (9Bh). | | | | 0xxxxxx1 | 00, 01, 02, 03,<br>04-FF | This bit must be set to 1, when device is busy executing OP1 command (9Bh). It is reset to 0 when the command execution is done. | | | | 0xxxxx1x | 00, 01 | This bit is set only when the correct payload size is received. For CmdType = 00, this bit must be set on Root Key Register Overwrite or Counter Address out of range or Truncated Signature mis-match error. For CmdType = 01, this bit is set when the corresponding Monotonic counters is uninitialized. | | | | 0xxxx1xx | 00, 01, 02, 03 | This bit must be set on Signature Mismatch, Counter Address out of range when correct payload size is received; or CmdType is out of range; or incorrect payload size is received. | | | | 0xxx1xxx | 02, 03 | This bit must be set on HMAC Key Register (or Monotonic counters) uninitialized on previous OP1 command when correct payload size is received. | | | | 0xx1xxxx | 02 | This bit must be set on Counter_AddressMismatch on previous increment when correct payload size is received. | | | | 0x1xxxxx | | Fatal Error, e.g. program fail, no valid counter found after initialization. | | | | Current value | | Status register will naturally not be updated until first 8 bits of OP1 (9Bh) is received. However it is expected that the correct error type is reflected for any OP1 operation that exceeds a minimum of 16 clocks with active chip-select. | | | - 14 - #### 6.3 Write Protection Applications that use non-volatile memory must take into consideration the possibility of noise and other adverse system conditions that may compromise data integrity. To address this concern, the W25R512NW/W74M51NW provides several means to protect the data from inadvertent writes. - Device resets when VCC is below threshold. - Time delay write disable after Power-up - Write enable/disable instructions and automatic write disable after erase or program - Software write protection using Status Registers - Additional Individual Block/Sector Locks for array protection - Write Protection using Power-down instruction - Lock Down write protection for Status Register until the next power-up - One Time Program (OTP) write protection for array and Security Registers using Status Register\* - \* Note: This feature is available upon special flow. Please contact Winbond for details. Upon power-up or at power-down, the W25R512NW/W74M51NW will maintain a reset condition while VCC is below the threshold value of VwI, (See Power-up Timing and Voltage Levels and Figure 43). While reset, all operations are disabled and no instructions are recognized. During power-up and after the VCC voltage exceeds VwI, all program and erase related instructions are further disabled for a time delay of tPUW. This includes the Write Enable, Page Program, Sector Erase, Block Erase, Chip Erase and the Write Status Register instructions. Note that the chip select pin (/CS) must track the VCC supply level at power-up until the VCC-min level and tVSL time delay is reached. After power-up the device is automatically placed in a write-disabled state with the Status Register Write Enable Latch (WEL) set to a 0. A Write Enable instruction must be issued before a Page Program, Sector Erase, Block Erase, Chip Erase or Write Status Register instruction will be accepted. After completing a program, erase or write instruction the Write Enable Latch (WEL) is automatically cleared to a write-disabled state of 0. Software controlled write protection is facilitated using the Write Status Register instruction and setting the Status Register Protect (SRP0, SRP1) and Block Protect (CMP, TB, BP[3:0]) bits. These settings allow a portion or the entire memory array to be configured as read only. Used in conjunction with the Write Protect (/WP) pin, changes to the Status Register can be enabled or disabled under hardware control. See Status Register section for further information. Additionally, the Power-down instruction offers an extra level of write protection as all instructions are ignored except for the Release Power-down instruction. The W25R512NW/W74M51NW also provides another Write Protect method using the Individual Block Locks. Each 64KB block (except the top and bottom blocks, total of 510 blocks) and each 4KB sector within the top/bottom blocks (total of 32 sectors) are equipped with an Individual Block Lock bit. When the lock bit is 0, the corresponding sector or block can be erased or programmed; when the lock bit is set to 1, Erase or Program commands issued to the corresponding sector or block will be ignored. When the device is powered on, all Individual Block Lock bits will be 1, so the entire memory array is protected from Erase/Program. An "Individual Block Unlock (39h)" instruction must be issued to unlock any specific sector or block. The WPS bit in Status Register-3 is used to decide which Write Protect scheme should be used. When WPS=0 (factory default), the device will only utilize CMP, TB, BP[3:0] bits to protect specific areas of the array; when WPS=1, the device will utilize the Individual Block Locks for write protection. #### 7. STATUS AND CONFIGURATION REGISTERS Three Status and Configuration Registers are provided for W25R512NW/W74M51NW. The Read Status Register-1/2/3 instructions can be used to provide status on the availability of the flash memory array, whether the device is write enabled or disabled, the state of write protection, Quad SPI setting, Security Register lock status, Erase/Program Suspend status, output driver strength, power-up and current Address Mode. The Write Status Register instruction can be used to configure the device write protection features, Quad SPI setting, Security Register OTP locks, output driver strength and power-up Address Mode. Write access to the Status Register is controlled by the state of the non-volatile Status Register Protect bits (SRP0, SRP1), the Write Enable instruction. #### 7.1 Status Registers Figure 4a. Status Register-1 #### 7.1.1 Erase/Write In Progress (BUSY) - Status Only BUSY is a read only bit in the status register (S0) that is set to a 1 state when the device is executing a Page Program, Quad Page Program, Sector Erase, Block Erase, Chip Erase, Write Status Register or Erase/Program Security Register instruction. During this time the device will ignore further instructions except for the Read Status Register and Erase/Program Suspend instruction (see tW, tPP, tSE, tBE, and tCE in AC Characteristics). When the program, erase or write status/security register instruction has completed, the BUSY bit will be cleared to a 0 state indicating the device is ready for further instructions. #### 7.1.2 Write Enable Latch (WEL) – Status Only Write Enable Latch (WEL) is a read only bit in the status register (S1) that is set to 1 after executing a Write Enable Instruction. The WEL status bit is cleared to 0 when the device is write disabled. A write disable state occurs upon power-up or after any of the following instructions: Write Disable, Page Program, Quad Page Program, Sector Erase, Block Erase, Chip Erase, Write Status Register, Erase Security Register and Program Security Register. #### 7.1.3 Block Protect Bits (BP3, BP2, BP1, BP0) - Volatile/Non-Volatile Writable The Block Protect Bits (BP3, BP2, BP1, BP0) are non-volatile read/write bits in the status register (S5, S4, S3, and S2) that provide Write Protection control and status. Block Protect bits can be set using the Write Status Register Instruction (see tw in AC characteristics). All, none or a portion of the memory array can be protected from Program and Erase instructions (see Status Register Memory Protection table). The factory default setting for the Block Protection Bits is 0, none of the array protected. #### 7.1.4 Top/Bottom Block Protect (TB) – Volatile/Non-Volatile Writable The non-volatile Top/Bottom bit (TB) controls if the Block Protect Bits (BP3, BP2, BP1, BP0) protect from the Top (TB=0) or the Bottom (TB=1) of the array as shown in the Status Register Memory Protection table. The factory default setting is TB=0. The TB bit can be set with the Write Status Register Instruction depending on the state of the SRP0, SRP1 and WEL bits. #### 7.1.5 Complement Protect (CMP) - Volatile/Non-Volatile Writable The Complement Protect bit (CMP) is a non-volatile read/write bit in the status register (S14). It is used in conjunction with TB, BP3, BP2, BP1 and BP0 bits to provide more flexibility for the array protection. Once CMP is set to 1, previous array protection set by TB, BP3, BP2, BP1 and BP0 will be reversed. For instance, when CMP=0, a top 64KB block can be protected while the rest of the array is not; when CMP=1, the top 64KB block will become unprotected while the rest of the array become read-only. Please refer to the Status Register Memory Protection table for details. The default setting is CMP=0. #### 7.1.6 Status Register Protect (SRP1, SRP0) - Volatile/Non-Volatile Writable The Status Register Protect bits (SRP1 and SRP0) are non-volatile read/write bits in the status register (S8 and S7). The SRP bits control the method of write protection: software protection, power supply lock-down or one time programmable (OTP) protection. | SRP1 | SRP0 | Status<br>Register | Description | |------|------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------| | 0 | х | | The Status register can be written to after a Write Enable instruction, WEL=1. [Factory Default] | | 1 | 0 | Power Supply<br>Lock-Down | Status Register is protected and cannot be written to again until the next power-down, power-up cycle. <sup>(1)</sup> | | 1 | 1 | One Time<br>Program <sup>(2)</sup> | Status Register is permanently protected and cannot be written to. | - 1. When SRP1, SRP0 = (1, 0), a power-down, power-up cycle will change SRP1, SRP0 to (0, 0) state. - 2. This feature is available upon special flow. Please contact Winbond for details. Figure 4b. Status Register-2 #### 7.1.7 Erase/Program Suspend Status (SUS) - Status Only The Suspend Status bit is a read only bit in the status register (S15) that is set to 1 after executing a Erase/Program Suspend (75h) instruction. The SUS status bit is cleared to 0 by Erase/Program Resume (7Ah) instruction as well as a power-down, power-up cycle. #### 7.1.8 Security Register Lock Bits (LB3, LB2, LB1) - Non-Volatile OTP Writable The Security Register Lock Bits (LB3, LB2, LB1) are non-volatile One Time Program (OTP) bits in Status Register (S13, S12, S11) that provide the write protect control and status to the Security Registers. The default state of LB3-1 is 0, Security Registers are unlocked. LB3-1 can be set to 1 individually using the Write Status Register instruction. LB3-1 are One Time Programmable (OTP), once it's set to 1, the corresponding 256-Byte Security Register will become read-only permanently. #### 7.1.9 Quad Enable (QE) – Volatile/Non-Volatile Writable The Quad Enable (QE) bit is set to 1 by default in the factory, therefore the device supports Standard/Dual SPI as well as Quad SPI after power on. This bit cannot be reset to 0 Figure 4c. Status Register-3 #### 7.1.10 Current Address Mode (ADS) - Status Only The Current Address Mode bit is a read only bit in the Status Register-3 that indicates which address mode the device is currently operating in. When ADS=0, the device is in the 3-Byte Address Mode, when ADS=1, the device is in the 4-Byte Address Mode. #### 7.1.11 Power-Up Address Mode (ADP) - Non-Volatile Writable The ADP bit is a non-volatile bit that determines the initial address mode when the device is powered on or reset. This bit is only used during the power on or device reset initialization period, and it is only writable by the non-volatile Write Status sequence (06h + 11h). When ADP=0 (factory default), the device will power up into 3-Byte Address Mode, the Extended Address Register must be used to access memory regions beyond 128Mb. When ADP=1, the device will power up into 4-Byte Address Mode directly. #### 7.1.12 Write Protect Selection (WPS) - Volatile/Non-Volatile Writable The WPS bit is used to select which Write Protect scheme should be used. When WPS=0, the device will use the combination of CMP, TB, BP[3:0] bits to protect a specific area of the memory array. When WPS=1, the device will utilize the Individual Block Locks to protect any individual sector or blocks. The default value for all Individual Block Lock bits is 1 upon device power on or after reset. #### 7.1.13 Output Driver Strength (DRV1, DRV0) - Volatile/Non-Volatile Writable The DRV1 & DRV0 bits are used to determine the output driver strength for the Read operations. | DRV1, DRV0 | Driver Strength | | | |------------|-----------------|--|--| | 0, 0 | 100% | | | | 0, 1 | 75% (default) | | | | 1, 0 | 50% | | | | 1, 1 | 25% | | | #### 7.1.14 Reserved Bits - Non Functional There are a few reserved Status Register bits that may be read out as a "0" or "1". It is recommended to ignore the values of those bits. During a "Write Status Register" instruction, the Reserved Bits can be written as "0", but there will not be any effects. - 20 - #### 7.1.15 W25R512NW/W74M51NW Status Register Memory Protection (WPS = 0, CMP = 0) | STATUS REGISTER <sup>(1)</sup> | | | | | 512M-BIT / 64M-BYTE MEMORY PROTECTION <sup>(2)</sup> | | | | |--------------------------------|-----|-----|-----|-----|------------------------------------------------------|------------------------|-------------------|-------------------| | ТВ | ВР3 | BP2 | BP1 | BP0 | PROTECTED<br>BLOCK(S) | PROTECTED<br>ADDRESSES | PROTECTED DENSITY | PROTECTED PORTION | | 0 | 0 | 0 | 0 | 0 | NONE | NONE | NONE | NONE | | 0 | 0 | 0 | 0 | 1 | 1023 | 03FF0000h - 03FFFFFFh | 64KB | Upper 1/1024 | | 0 | 0 | 0 | 1 | 0 | 1022 thru 1023 | 03FE0000h - 03FFFFFFh | 128KB | Upper 1/512 | | 0 | 0 | 0 | 1 | 1 | 1020 thru 1023 | 03FC0000h - 03FFFFFFh | 256KB | Upper 1/256 | | 0 | 0 | 1 | 0 | 0 | 1016 thru 1023 | 03F80000h - 03FFFFFFh | 512KB | Upper 1/128 | | 0 | 0 | 1 | 0 | 1 | 1008 thru 1023 | 03F00000h - 03FFFFFFh | 1MB | Upper 1/64 | | 0 | 0 | 1 | 1 | 0 | 992 thru 1023 | 03E00000h - 03FFFFFFh | 2MB | Upper 1/32 | | 0 | 0 | 1 | 1 | 1 | 960 thru 1023 | 03C00000h - 03FFFFFFh | 4MB | Upper 1/16 | | 0 | 1 | 0 | 0 | 0 | 896 thru 1023 | 03800000h - 03FFFFFh | 8MB | Upper 1/8 | | 0 | 1 | 0 | 0 | 1 | 768 thru 1023 | 03000000h - 03FFFFFFh | 16MB | Upper 1/4 | | 0 | 1 | 0 | 1 | 0 | 512 thru 1023 | 02000000h - 03FFFFFh | 32MB | Upper 1/2 | | 0 | 1 | 0 | 1 | 1 | 0 thru 1023 | 00000000h - 03FFFFFh | 64MB | ALL | | 0 | 1 | 1 | 0 | 0 | 0 thru 1023 | 00000000h - 03FFFFFh | 64MB | ALL | | 0 | 1 | 1 | 0 | 1 | 0 thru 1023 | 00000000h - 03FFFFFh | 64MB | ALL | | 0 | 1 | 1 | 1 | 0 | 0 thru 1023 | 00000000h - 03FFFFFh | 64MB | ALL | | 0 | 1 | 1 | 1 | 1 | 0 thru 1023 | 00000000h - 03FFFFFh | 64MB | ALL | | 1 | 0 | 0 | 0 | 0 | NONE | NONE | NONE | NONE | | 1 | 0 | 0 | 0 | 1 | 0 | 00000000h - 0000FFFFh | 64KB | Lower 1/1024 | | 1 | 0 | 0 | 1 | 0 | 0 thru 1 | 00000000h - 0001FFFFh | 128KB | Lower 1/512 | | 1 | 0 | 0 | 1 | 1 | 0 thru 3 | 00000000h - 0003FFFFh | 256KB | Lower 1/256 | | 1 | 0 | 1 | 0 | 0 | 0 thru 7 | 00000000h - 0007FFFFh | 512KB | Lower 1/128 | | 1 | 0 | 1 | 0 | 1 | 0 thru 15 | 00000000h - 000FFFFh | 1MB | Lower 1/64 | | 1 | 0 | 1 | 1 | 0 | 0 thru 31 | 00000000h - 001FFFFh | 2MB | Lower 1/32 | | 1 | 0 | 1 | 1 | 1 | 0 thru 63 | 00000000h - 003FFFFFh | 4MB | Lower 1/16 | | 1 | 1 | 0 | 0 | 0 | 0 thru 127 | 00000000h - 007FFFFh | 8MB | Lower 1/8 | | 1 | 1 | 0 | 0 | 1 | 0 thru 255 | 00000000h - 00FFFFFh | 16MB | Lower 1/4 | | 1 | 1 | 0 | 1 | 0 | 0 thru 511 | 00000000h - 01FFFFFh | 32MB | Lower 1/2 | | 1 | 1 | 0 | 1 | 1 | 0 thru 1023 | 00000000h - 03FFFFFh | 64MB | ALL | | 1 | 1 | 1 | 0 | Х | 0 thru 1023 | 00000000h - 03FFFFFh | 64MB | ALL | | 1 | 1 | 1 | 1 | Х | 0 thru 1023 | 00000000h - 03FFFFFh | 64MB | ALL | - X = don't care - 2. If any Erase or Program command specifies a memory region that contains protected data portion, this command will be ignored. #### 7.1.16 W25R512NW/W74M51NW Status Register Memory Protection (WPS = 0, CMP = 1) | STATUS REGISTER <sup>(1)</sup> | | | | | 512M-BIT / 64M-BYTE MEMORY PROTECTION <sup>(2)</sup> | | | | | | | |--------------------------------|-----|-----|-----|-----|------------------------------------------------------|--------------------------|-------------------|-------------------|--|--|--| | ТВ | BP3 | BP2 | BP1 | BP0 | PROTECTED<br>BLOCK(S) | PROTECTED<br>ADDRESSES | PROTECTED DENSITY | PROTECTED PORTION | | | | | 0 | 0 | 0 | 0 | 0 | ALL | ALL 00000000h - 03FFFFFh | | ALL | | | | | 0 | 0 | 0 | 0 | 1 | 0 thru 1022 | 00000000h - 03FEFFFFh | 65,472KB | Lower 1023/1024 | | | | | 0 | 0 | 0 | 1 | 0 | 0 thru 1021 | 00000000h - 03FDFFFFh | 65,408KB | Lower 511/512 | | | | | 0 | 0 | 0 | 1 | 1 | 0 thru 1019 | 00000000h - 03FBFFFFh | 65,280KB | Lower 255/256 | | | | | 0 | 0 | 1 | 0 | 0 | 0 thru 1015 | 00000000h - 03F7FFFh | 65,024KB | Lower 127/128 | | | | | 0 | 0 | 1 | 0 | 1 | 0 thru 1007 | 00000000h - 03EFFFFFh | 63MB | Lower 63/64 | | | | | 0 | 0 | 1 | 1 | 0 | 0 thru 991 | 00000000h - 03DFFFFFh | 62MB | Lower 31/32 | | | | | 0 | 0 | 1 | 1 | 1 | 0 thru 959 | 00000000h - 03BFFFFFh | 60MB | Lower 15/16 | | | | | 0 | 1 | 0 | 0 | 0 | 0 thru 895 | 00000000h - 037FFFFh | 56MB | Lower 7/8 | | | | | 0 | 1 | 0 | 0 | 1 | 0 thru 767 | 00000000h - 02FFFFFh | 48MB | Lower 3/4 | | | | | 0 | 1 | 0 | 1 | 0 | 0 thru 511 | 00000000h - 01FFFFFh | 32MB | Lower 1/2 | | | | | 0 | 1 | 0 | 1 | 1 | NONE | NONE NONE NO | | NONE | | | | | 0 | 1 | 1 | 0 | 0 | NONE | NONE | NONE | NONE | | | | | 0 | 1 | 1 | 0 | 1 | NONE | NONE | NONE | NONE | | | | | 0 | 1 | 1 | 1 | 0 | NONE | NONE | NONE | NONE | | | | | 0 | 1 | 1 | 1 | 1 | NONE | NONE | NONE | NONE | | | | | 1 | 0 | 0 | 0 | 1 | 1 thru 1023 | 00010000h - 03FFFFFFh | 65,472KB | Upper 1023/1024 | | | | | 1 | 0 | 0 | 1 | 0 | 2 thru 1023 | 00020000h - 03FFFFFFh | 65,408KB | Upper 511/512 | | | | | 1 | 0 | 0 | 1 | 1 | 4 thru 1023 | 00040000h - 03FFFFFh | 65,280KB | Upper 255/256 | | | | | 1 | 0 | 1 | 0 | 0 | 8 thru 1023 | 00080000h - 03FFFFFh | 65,024KB | Upper 127/128 | | | | | 1 | 0 | 1 | 0 | 1 | 16 thru 1023 | 00100000h - 03FFFFFh | 63MB | Upper 63/64 | | | | | 1 | 0 | 1 | 1 | 0 | 32 thru 1023 | 00200000h - 03FFFFFh | 62MB | Upper 31/32 | | | | | 1 | 0 | 1 | 1 | 1 | 64 thru 1023 | 00400000h - 03FFFFFh | 60MB | Upper 15/16 | | | | | 1 | 1 | 0 | 0 | 0 | 128 thru 1023 | 00800000h - 03FFFFFh | 56MB | Upper 7/8 | | | | | 1 | 1 | 0 | 0 | 1 | 256 thru 1023 | 01000000h - 03FFFFFFh | 48MB | Upper 3/4 | | | | | 1 | 1 | 0 | 1 | 0 | 512 thru 1023 | 02000000h - 03FFFFFh | 32MB | Upper 1/2 | | | | | 1 | 1 | 0 | 1 | 1 | NONE | NONE | NONE | NONE | | | | | 1 | 1 | 1 | 0 | Х | NONE | NONE | NONE | NONE | | | | | 1 | 1 | 1 | 1 | Х | NONE | NONE | NONE | NONE | | | | - 1. X = don't care - 2. If any Erase or Program command specifies a memory region that contains protected data portion, this command will be ignored. #### 7.1.17 W25R512NW/W74M51NW Individual Block Memory Protection (WPS=1) Figure 4d. Individual Block/Sector Locks - 1. Individual Block/Sector protection is only valid when WPS=1. - 2. All individual block/sector lock bits are set to 1 by default after power up, all memory array is protected. #### 7.2 Extended Address Register - Volatile Writable Only Figure 4e. Extended Address Register In addition to the Status Registers, W25R512NW/W74M51NW provides a volatile Extended Address Register which consists of the 4th byte of memory address. The Extended Address Register is accessible by Read Extended Address Register (C8h) and Write Extended Address Register (C5h) instructions. The Extended Address Register is used only when the device is operating in the 3-Byte Address Mode (ADS=0). The separate 128Mb memory array ranges (or regions) of 00000000h-00FFFFFh, 01000000h-01FFFFFh, 02000000h-02FFFFFh and 03000000h- 03FFFFFh are accessible depending on the setting of Extended Address Register A25 and A24 bits as shown on the table below. | A25, A24 | Memory Array Address Range | |----------|----------------------------| | 0, 0 | 00000000h – 00FFFFFh | | 0, 1 | 01000000h – 01FFFFFh | | 1, 0 | 02000000h – 02FFFFFh | | 1, 1 | 03000000h – 03FFFFFh | Any command with dedicated 4-byte address input will use the 4th Address Byte (A31-A24) input and not the Extended Address Register. If the device powers up with ADP bit set to 1, or an "Enter 4-Byte Address Mode (B7h)" instruction is issued, the device will require 4-Byte address input for all address related instructions, and the Extended Address Register setting will be ignored. The 4th Byte Address input will not alter the content of Extended Address Register. Upon power up, hardware reset, or after the execution of a Software Reset, the Extended Address Register values will be cleared to 0. #### 7.3 INSTRUCTIONS The Standard/Dual/Quad SPI instruction set of the W25R512NW/W74M51NW consists of 48 basic instructions that are fully controlled through the SPI bus (see Instruction Set Table1-3). Instructions are initiated with the falling edge of Chip Select (/CS). The first byte of data clocked into the DI input provides the instruction code. Data on the DI input is sampled on the rising edge of clock with most significant bit (MSB) first. Instructions vary in length from a single byte to several bytes and may be followed by address bytes, data bytes, dummy bytes (don't care), and in some cases, a combination. Instructions are completed with the rising edge of edge /CS. Clock relative timing diagrams for each instruction are included in Figures 5 through 57. All read instructions can be completed after any clocked bit. However, all instructions that Write, Program or Erase must complete on a byte boundary (/CS driven high after a full 8-bits have been clocked) otherwise the instruction will be ignored. This feature further protects the device from inadvertent writes. Additionally, while the memory is being programmed or erased, or when the Status Register is being written, all instructions except for Read Status Register will be ignored until the program or erase cycle has completed. #### 7.4 Device ID and Instruction Set Tables #### 7.4.1 Manufacturer and Device Identification | MANUFACTURER ID | (MF7 - MF0) | | |----------------------|--------------------|--------------| | Winbond Serial Flash | EFh | | | | | | | Device ID | (ID7 - ID0) | (ID15 - ID0) | | Instruction | ABh, 90h, 92h, 94h | 9Fh | | W25R512NW/W74M51NW | 19h | 6020h | #### 7.4.2 Instruction Set Table 1 (Standard/Dual/Quad SPI, 3-Byte & 4-Byte Address Mode)<sup>(1)</sup> | Data Input Output | Byte 1 | Byte 2 | Byte 3 | Byte 4 | Byte 5 | Byte 6 | Byte 7 | |------------------------------------------|---------|--------------------------|------------|-----------|--------------------------|----------------------|----------------------| | Number of Clock <sub>(1-1-1)</sub> | 8 | 8 | 8 | 8 | 8 | 8 | 8 | | Write Enable | 06h | | | • | | | | | Volatile SR Write Enable | 50h | | | | | | | | Write Disable | 04h | | | | | | | | Set Read Parameters | C0h | P7-P0 | | | | | | | Release Power-down / ID | ABh | Dummy | Dummy | Dummy | (ID7-ID0) <sup>(2)</sup> | | | | Manufacturer/Device ID | 90h | Dummy | Dummy | 00h | (MF7-MF0) | (ID7-ID0) | | | JEDEC ID | 9Fh | (MF7-MF0) | (ID15-ID8) | (ID7-ID0) | | ( -/ | | | Read Unique ID | 4Bh | Dummy | Dummy | Dummy | Dummy | (UID63-0) | | | Read Data | 03h | A23-A16 | A15-A8 | A7-A0 | (D7-D0) | , | | | Read Data with 4-Byte Address | 13h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | (D7-D0) | | | Fast Read | 0Bh | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0) | | | Fast Read with 4-Byte Address | 0Ch | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0) | | Page Program | 02h | A23-A16 | A15-A8 | A7-A0 | D7-D0 | D7-D0 <sup>(3)</sup> | · | | Page Program with 4-Byte Address | 12h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | D7-D0 | D7-D0 <sup>(3)</sup> | | Sector Erase (4KB) | 20h | A23-A16 | A15-A8 | A7-A0 | | | | | Sector Erase (4KB) with 4-Byte Address | 21h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Block Erase (32KB) | 52h | A23-A16 | A15-A8 | A7-A0 | | | | | Block Erase (64KB) | D8h | A23-A16 | A15-A8 | A7-A0 | | | | | Block Erase (64KB) with 4-Byte Address | DCh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Chip Erase | C7h/60h | | | | | | | | Read Status Register-1 | 05h | (S7-S0) <sup>(2)</sup> | | | | | | | Write Status Register-1 <sup>(4)</sup> | 01h | (S7-S0) <sup>(4)</sup> | | | | | | | Read Status Register-2 | 35h | (S15-S8) <sup>(2)</sup> | | | | | | | Write Status Register-2 | 31h | (S15-S8) | | | | | | | Read Status Register-3 | 15h | (S23-S16) <sup>(2)</sup> | | | | | | | Write Status Register-3 | 11h | (S23-S16) | | | | | | | Read Extended Addr. Reg. | C8h | (EA7-EA0) <sup>(2)</sup> | | | | | | | Write Extended Addr. Reg. | C5h | (EA7-EA0) | | | | | | | Read SFDP Register | 5Ah | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0) | | | Erase Security Register <sup>(5)</sup> | 44h | A23-A16 | A15-A8 | A7-A0 | | 1 | | | Program Security Register <sup>(5)</sup> | 42h | A23-A16 | A15-A8 | A7-A0 | D7-D0 | D7-D0 <sup>(3)</sup> | | | Read Security Register <sup>(5)</sup> | 48h | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0) | | | Global Block Lock | 7Eh | | | | | | | | Global Block Unlock | 98h | | | T | T | T | | | Read Block Lock | 3Dh | A23-A16 | A15-A8 | A7-A0 | (L7-L0) | | | | Individual Block Lock | 36h | A23-A16 | A15-A8 | A7-A0 | | | | | Individual Block Unlock | 39h | A23-A16 | A15-A8 | A7-A0 | | | | | Erase / Program Suspend | 75h | | | | | | | | Erase / Program Resume | 7Ah | | | | | | | | Power-down | B9h | | | | | | | | Enter 4-Byte Address Mode | B7h | | | | | | | | Exit 4-Byte Address Mode | E9h | | | | | | | | Enable Reset | 66h | | | | | | | | Reset Device | 99h | | | | | | | - 26 - #### 7.4.3 Instruction Set Table 2 (Dual/Quad SPI Instructions,3-Byte Address Mode) | | | | | | * | | | | | | |-------------------------------------------|--------|---------|---------|--------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------| | Data Input Output | Byte 1 | Byte 2 | Byte 3 | Byte 4 | Byte 5 | Byte 6 | Byte 7 | Byte 8 | Byte 9 | Byte 10 | | Number of Clock <sub>(1-1-2)</sub> | 8 | 8 | 8 | 8 | 4 | 4 | 4 | 4 | 4 | 4 | | Fast Read Dual Output | 3Bh | A23-A16 | A15-A8 | A7-A0 | Dummy | Dummy | (D7-D0) <sup>(7)</sup> | ••• | | | | Fast Read Dual Output with 4-Byte Address | 3Ch | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | Dummy | (D7-D0) <sup>(7)</sup> | | | | Number of Clock(1-2-2) | 8 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | | Mftr./Device ID Dual I/O | 92h | A23-A16 | A15-A8 | 0 | Dummy <sup>(11)</sup> | (MF7-MF0) | (ID7-ID0) | | | | | Fast Read Dual I/O | BBh | A23-A16 | A15-A8 | A7-A0 | Dummy <sup>(11)</sup> | (D7-D0) | | | | | | Fast Read Dual I/O<br>with 4-Byte Address | BCh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy <sup>(11)</sup> | (D7-D0) | | | | | Number of Clock(1-1-4) | 8 | 8 | 8 | 8 | 2 | 2 | 2 | 2 | 2 | 2 | | Quad Input Page<br>Program | 32h | A23-A16 | A15-A8 | A7-A0 | (D7-D0) <sup>(9)</sup> | (D7-D0) <sup>(3)</sup> | | | | | | Quad Page Program with 4-Byte Address | 34h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | D7-D0 | | | | | | Fast Read Quad Output | 6Bh | A23-A16 | A15-A8 | A7-A0 | Dummy | Dummy | Dummy | Dummy | (D7-D0) <sup>(9)</sup> | | | Number of Clock(1-1-4) | 8 | 8 | 8 | 8 | 8 | 2 | 2 | 2 | 2 | 2 | | Fast Read Quad Output with 4-Byte Address | 6Ch | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | Dummy | Dummy | Dummy | (D7-D0) <sup>(9)</sup> | | Number of Clock(1-4-4) | 8 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | | Mftr./Device ID Quad I/O | 94h | A23-A16 | A15-A8 | 0 | Dummy <sup>(11)</sup> | Dummy | Dummy | (MF7-MF0) | (ID7-ID0) | | | Fast Read Quad I/O | EBh | A23-A16 | A15-A8 | A7-A0 | Dummy <sup>(11)</sup> | Dummy | Dummy | (D7-D0) | | | | Fast Read Quad I/O<br>with 4-Byte Address | ECh | A31-A24 | A23-A16 | A15-A8 | A7-A0f | Dummy <sup>(11)</sup> | Dummy | Dummy | (D7-D0) | | | Set Burst with Wrap | 77h | Dummy | Dummy | Dummy | W7-W0 | | | | | | #### 7.4.4 Instruction Set Table 3 (Standard SPI, 4-Byte Address Mode)<sup>(1)</sup> | Data Input Output | Byte 1 | Byte 2 | Byte 3 | Byte 4 | Byte 5 | Byte 6 | Byte 7 | |------------------------------------------|---------|--------------------------|------------|-----------|--------------------------|-----------|----------------------| | Number of Clock <sub>(1-1-1)</sub> | 8 | 8 | 8 | 8 | 8 | 8 | 8 | | Write Enable | 06h | | | | | | • | | Volatile SR Write Enable | 50h | | | | | | | | Write Disable | 04h | | | | | | | | Set Read Parameters | C0h | P7-P0 | | | | | | | Release Power-down / ID | ABh | Dummy | Dummy | Dummy | (ID7-ID0) <sup>(2)</sup> | | | | Manufacturer/Device ID | 90h | Dummy | Dummy | 00h | (MF7-MF0) | (ID7-ID0) | | | JEDEC ID | 9Fh | (MF7-MF0) | (ID15-ID8) | (ID7-ID0) | | | - | | Read Unique ID | 4Bh | Dummy | Dummy | Dummy | Dummy | Dummy | (UID63-0) | | Read Data | 03h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | (D7-D0) | | | Read Data with 4-Byte Address | 13h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | (D7-D0) | | | Fast Read | 0Bh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0) | | Fast Read with 4-Byte Address | 0Ch | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0) | | Page Program | 02h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | D7-D0 | D7-D0 <sup>(3)</sup> | | Page Program with 4-Byte Address | 12h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | D7-D0 | D7-D0 <sup>(3)</sup> | | Sector Erase (4KB) | 20h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Sector Erase (4KB) with 4-Byte Address | 21h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Block Erase (32KB) | 52h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Block Erase (64KB) | D8h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Block Erase (64KB) with 4-Byte Address | DCh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Chip Erase | C7h/60h | | | | | | | | Read Status Register-1 | 05h | (S7-S0) <sup>(2)</sup> | | | | | | | Write Status Register-1 <sup>(4)</sup> | 01h | (S7-S0) <sup>(4)</sup> | | | | | | | Read Status Register-2 | 35h | (S15-S8) <sup>(2)</sup> | | | | | | | Write Status Register-2 | 31h | (S15-S8) | | | | | | | Read Status Register-3 | 15h | (S23-S16) <sup>(2)</sup> | | | | | | | Write Status Register-3 | 11h | (S23-S16) | | | | | | | Read Extended Addr. Reg. | C8h | (EA7-EA0) <sup>(2)</sup> | | | | | | | Write Extended Addr. Reg. | C5h | (EA7-EA0) | | | | | | | Read SFDP Register | 5Ah | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0) | | | Erase Security Register <sup>(5)</sup> | 44h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Program Security Register <sup>(5)</sup> | 42h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | D7-D0 | D7-D0 <sup>(3)</sup> | | Read Security Register <sup>(5)</sup> | 48h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0) | | Global Block Lock | 7Eh | | | | | | | | Global Block Unlock | 98h | | | | | | | | Read Block Lock | 3Dh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | (L7-L0) | | | Individual Block Lock | 36h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Individual Block Unlock | 39h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | | | | Erase / Program Suspend | 75h | | | | | | | | Erase / Program Resume | 7Ah | | | | | | | | Power-down | B9h | | | | | | | | Enter 4-Byte Address Mode | B7h | | | | | | | | Exit 4-Byte Address Mode | E9h | | | | | | | | Enable Reset | 66h | | | | | | | | Reset Device | 99h | | | | | | | - 28 - #### 7.4.5 Instruction Set Table 4 (Dual/Quad SPI Instructions, 4-Byte Address Mode) | Data Input Output | Byte 1 | Byte 2 | Byte 3 | Byte 4 | Byte 5 | Byte 6 | Byte 7 | Byte 8 | Byte9 | |----------------------------------------------|--------|---------|---------|--------|--------|------------------------|-------------------------|------------------------|-----------| | Number of Clock <sub>(1-1-2)</sub> | 8 | 8 | 8 | 8 | 8 | 8 | 4 | 4 | | | Fast Read Dual Output | 3Bh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0,) <sup>(7)</sup> | | | | Fast Read Dual Output<br>with 4-Byte Address | 3Ch | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | (D7-D0,) <sup>(7)</sup> | | | | Number of Clock(1-2-2) | 8 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | | | Mftr./Device ID Dual I/O | 92h | A31-A24 | A23-A16 | A15-A8 | 00 | Dummy <sup>(11)</sup> | (MF7-MF0) | (ID7-ID0) | | | Fast Read Dual I/O | BBh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy <sup>(11)</sup> | (D7-D0) | | | | Fast Read Dual I/O<br>with 4-Byte Address | BCh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy <sup>(11)</sup> | (D7-D0) | | | | Number of Clock(1-1-4) | 8 | 8 | 8 | 8 | 8 | 4 | 4 | 4 | | | Quad Input Page Program | 32h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | (D7-D0) <sup>(9)</sup> | (D7-D0) <sup>(3)</sup> | | | | Quad Page Program<br>with 4-Byte Address | 34h | A31-A24 | A23-A16 | A15-A8 | A7-A0 | D7-D0 | D7-D0 | D7-D0 | D7-D0 | | Fast Read Quad Output | 6Bh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | Dummy | (D7-D0) <sup>(9)</sup> | | | Fast Read Quad Output<br>with 4-Byte Address | 6Ch | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy | Dummy | (D7-D0) <sup>(9)</sup> | | | Number of Clock(1-4-4) | 8 | 2 | 2 | 2 | 2 | 2 | 4 | 2 | 2 | | Mftr./Device ID Quad I/O | 94h | A31-A24 | A23-A16 | A15-A8 | 00 | Dummy <sup>(11)</sup> | Dummy | (MF7-MF0) | (ID7-ID0) | | Fast Read Quad I/O | EBh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy <sup>(11)</sup> | Dummy | (D7-D0) | | | Fast Read Quad I/O<br>with 4-Byte Address | ECh | A31-A24 | A23-A16 | A15-A8 | A7-A0 | Dummy <sup>(11)</sup> | Dummy | (D7-D0) | | | Set Burst with Wrap | 77h | Dummy | Dummy | Dummy | Dummy | W7-W0 | | | | #### **Notes:** - 1. Data bytes are shifted with Most Significant Bit first. Byte fields with data in parenthesis "()" indicate data output from the device on either 1, 2 or 4 IO pins. - 2. The Status Register contents and Device ID will repeat continuously until /CS terminates the instruction. - 3. At least one byte of data input is required for Page Program, Quad Page Program and Program Security Registers, up to 256 bytes of data input. If more than 256 bytes of data are sent to the device, the addressing will wrap to the beginning of the page and overwrite previously sent data. - 4. Write Status Register-1 (01h) can also be used to program Status Register-1&2, see section 8.2.5. - 5. Security Register Address: ``` Security Register 1: A23-16 = 00h; A15-8 = 10h; A7-0 = byte address Security Register 2: A23-16 = 00h; A15-8 = 20h; A7-0 = byte address Security Register 3: A23-16 = 00h; A15-8 = 30h; A7-0 = byte address ``` 6. Dual SPI address input format: ``` IO0 = A22, A20, A18, A16, A14, A12, A10, A8 A6, A4, A2, A0, M6, M4, M2, M0 IO1 = A23, A21, A19, A17, A15, A13, A11, A9 A7, A5, A3, A1, M7, M5, M3, M1 ``` 7. Dual SPI data output format: ``` IO0 = (D6, D4, D2, D0) IO1 = (D7, D5, D3, D1) ``` 8. Quad SPI address input format: ``` IO0 = A20, A16, A12, A8, A4, A0, M4, M0 IO1 = A21, A17, A13, A9, A5, A1, M5, M1 IO2 = A22, A18, A14, A10, A6, A2, M6, M2 IO3 = A23, A19, A15, A11, A7, A3, M7, M3 ``` 9. Quad SPI data input/output format: ``` IO0 = (D4, D0, .....) IO1 = (D5, D1, .....) IO2 = (D6, D2, .....) IO3 = (D7, D3, .....) ``` 10. Fast Read Quad I/O data output format: ``` IO0 = (x, x, x, x, D4, D0, D4, D0) IO1 = (x, x, x, x, D5, D1, D5, D1) IO2 = (x, x, x, x, D6, D2, D6, D2) IO3 = (x, x, x, x, D7, D3, D7, D3) ``` 11. The first dummy is M7-M0 should be set to Fxh Set Burst with Wrap input format: ``` IO0 = x, x, x, x, x, x, W4, x IO1 = x, x, x, x, x, x, W5, x IO2 = x, x, x, x, x, x, W6, x IO3 = x, x, x, x, x, x, x ``` #### 7.4.6 Instruction Set Table 2-1 (RPMC Input Instruction, OP1)(1) | INSTRUCTION NAME | BYTE 0 | BYTE 1<br>(CmdType) | BYTE 2 | BYTE 3 <sup>(2)</sup> | | | | |--------------------------------|--------|---------------------|-------------------|-----------------------|---------------------------------|--------------------------------------|--| | Write<br>Root Key Register | 9Bh | 00h | CounterAddr[7:0] | Reserved[7:0] | Byte 4 - 35<br>RootKey[255:0] | Byte 36 - 63<br>TruncatedSign[223:0] | | | Update 9Bh | | 01h | CounterAddr[7:0] | Reserved[7:0] | Byte 4 - 7<br>KeyData[31:0] | Byte 8 - 39<br>Signature[255:0] | | | Increment<br>Monotonic Counter | 9Bh | 02h | CounterAddr[7:0] | Reserved[7:0] | Byte 4 - 7<br>CounterData[31:0] | Byte 8 - 39<br>Signature[255:0] | | | Request<br>Monotonic Counter | 9Bh | 03h | CounterAd dr[7:0] | Reserved[7:0] | Byte 4 - 15<br>Tag[95:0] | Byte 16 - 47<br>Signature[255:0] | | | Reserved Commands | 9Bh | 04h ~ FFh | Reserved | | | | | #### 7.4.7 Instruction Set Table 2-2 (RPMC Output Instruction, OP2)(1) | INSTRUCTION NAME | BYTE 0 | BYTE 1 | BYTE 2 | BYTE 3 - 14 | BYTE 15 - 18 | BYTE 19 - 50 | |----------------------------------------------|--------|--------|--------------------|-------------|---------------------|--------------------| | Read RPMC<br>Status / Data <sup>(3)(4)</sup> | 96h | dummy | (RPMC Status[7:0]) | (Tag[95:0]) | (CounterData[31:0]) | (Signature[255:0]) | #### Notes (For Instruction Set Table 2-1/2): - 1. All RPMC instructions are in Standard SPI format. Each Input/Output Byte requires 8 clocks. - 2. The Reserved[7:0] field for RPMC OP1 must be all 0s (00000000'b). - 3. The controller may terminate the Read RPMC Status/Data instruction at any time without going through the entire data output sequence. - 4. When BUSY=1, from Byte-3 and beyond, the device will output the RPMC\_Status[7:0] value continuously until /CS terminates the instruction. The device will not output Tag, CounterData & Signature fields when BUSY=1. Once BUSY becomes 0, another OP2 command must be issued to read out the correct Tag, CounterData & Signature fields. #### 7.5 Instruction Descriptions #### 7.5.1 Write Enable (06h) The Write Enable instruction (Figure 6) sets the Write Enable Latch (WEL) bit in the Status Register to a 1. The WEL bit must be set prior to every Page Program, Quad Page Program, Sector Erase, Block Erase, Chip Erase, Write Status Register and Erase/Program Security Registers instruction. The Write Enable instruction is entered by driving /CS low, shifting the instruction code "06h" into the Data Input (DI) pin on the rising edge of CLK, and then driving /CS high. Figure 6. Write Enable Instruction #### 7.5.2 Write Enable for Volatile Status Register (50h) The non-volatile Status Register bits described in section 7.1 can also be written to as volatile bits. This gives more flexibility to change the system configuration and memory protection schemes quickly without waiting for the typical non-volatile bit write cycles or affecting the endurance of the Status Register non-volatile bits. To write the volatile values into the Status Register bits, the Write Enable for Volatile Status Register (50h) instruction must be issued prior to a Write Status Register (01h) instruction. Write Enable for Volatile Status Register instruction (Figure 7) will not set the Write Enable Latch (WEL) bit, it is only valid for the Write Status Register instruction to change the volatile Status Register bit values. Figure 7. Write Enable for Volatile Status Register Instruction - Revision C1 #### 7.5.3 Write Disable (04h) The Write Disable instruction (Figure 8) resets the Write Enable Latch (WEL) bit in the Status Register to a 0. The Write Disable instruction is entered by driving /CS low, shifting the instruction code "04h" into the DI pin and then driving /CS high. Note that the WEL bit is automatically reset after Power-up and upon completion of the Write Status Register, Erase/Program Security Registers, Page Program, Quad Page Program, Sector Erase, Block Erase, Chip Erase and Reset instructions. Figure 8. Write Disable Instruction #### 7.5.4 Read Status Register-1 (05h), Status Register-2 (35h) & Status Register-3 (15h) The Read Status Register instructions allow the 8-bit Status Registers to be read. The instruction is entered by driving /CS low and shifting the instruction code "05h" for Status Register-1, "35h" for Status Register-2 or "15h" for Status Register-3 into the DI pin on the rising edge of CLK. The status register bits are then shifted out on the DO pin at the falling edge of CLK with most significant bit (MSB) first as shown in Figure 9. Refer to section 7.1 for Status Register descriptions. The Read Status Register instruction may be used at any time, even while a Program, Erase or Write Status Register cycle is in progress. This allows the BUSY status bit to be checked to determine when the cycle is complete and if the device can accept another instruction. The Status Register can be read continuously, as shown in Figure 8. The instruction is completed by driving /CS high. Figure 9. Read Status Register Instruction #### 7.5.5 Write Status Register-1 (01h), Status Register-2 (31h) & Status Register-3 (11h) The Write Status Register instruction allows the Status Registers to be written. The writable Status Register bits include: SRP0, SEC, TB, BP[2:0] in Status Register-1; CMP, LB[3:1], QE, SRP1 in Status Register-2; DRV1, DRV0, WPS & ADP in Status Register-3. All other Status Register bit locations are read-only and will not be affected by the Write Status Register instruction. LB[3:1] are non-volatile OTP bits, once it is set to 1, it cannot be cleared to 0. To write non-volatile Status Register bits, a standard Write Enable (06h) instruction must previously have been executed for the device to accept the Write Status Register instruction (Status Register bit WEL must equal 1). Once write enabled, the instruction is entered by driving /CS low, sending the instruction code "01h/31h/11h", and then writing the status register data byte as illustrated in Figure 10a & 10b. To write volatile Status Register bits, a Write Enable for Volatile Status Register (50h) instruction must have been executed prior to the Write Status Register instruction (Status Register bit WEL remains 0). However, SRP1 and LB[3:1] cannot be changed from "1" to "0" because of the OTP protection for these bits. Upon power off or the execution of a Software Reset, the volatile Status Register bit values will be lost, and the non-volatile Status Register bit values will be restored. During non-volatile Status Register write operation (06h combined with 01h/31h/11h), after /CS is driven high, the self-timed Write Status Register cycle will commence for a time duration of tw (See AC Characteristics). While the Write Status Register cycle is in progress, the Read Status Register instruction may still be accessed to check the status of the BUSY bit. The BUSY bit is a 1 during the Write Status Register cycle and a 0 when the cycle is finished and ready to accept other instructions again. After the Write Status Register cycle has finished, the Write Enable Latch (WEL) bit in the Status Register will be cleared to 0. During volatile Status Register write operation (50h combined with 01h/31h/11h), after /CS is driven high, the Status Register bits will be refreshed to the new values within the time period of tshsl2 (See AC Characteristics). BUSY bit will remain 0 during the Status Register bit refresh period. Refer to section 7.1 for Status Register descriptions. Figure 10a. Write Status Register-1/2/3 Instruction ## massa winbond sassa The W25R512NW/W74M51NW is also backward compatible to Winbond's previous generations of serial flash memories, in which the Status Register-1&2 can be written using a single "Write Status Register-1 (01h)" command. To complete the Write Status Register-1&2 instruction, the /CS pin must be driven high after the sixteenth bit of data that is clocked in as shown in Figure 10b. If /CS is driven high after the eighth clock, the Write Status Register-1 (01h) instruction will only program the Status Register-1, the Status Register-2 will not be affected (Previous generations will clear CMP and QE bits). Figure 10b. Write Status Register-1/2 Instruction ### 7.5.6 Read Extended Address Register (C8h) When the device is in the 3-Byte Address Mode, the Extended Address Register is used as the 4<sup>th</sup> address byte A[31:24] to access memory regions beyond 128Mb. The Read Extended Address Register instruction is entered by driving /CS low and shifting the instruction code "C8h" into the DI pin on the rising edge of CLK. The Extended Address Register bits are then shifted out on the DO pin at the falling edge of CLK with most significant bit (MSB) first as shown in Figure 10. When the device is in the 4-Byte Address Mode, the Extended Address Register is not used. Figure 10a. Read Extended Address Register Instruction ### 7.5.7 Write Extended Address Register (C5h) The Extended Address Register is a volatile register that stores the 4<sup>th</sup> byte address (A31-A24) when the device is operating in the 3-Byte Address Mode (ADS=0). To write the Extended Address Register bits, a Write Enable (06h) instruction must previously have been executed for the device to accept the Write Extended Address Register instruction (Status Register bit WEL must equal 1). Once write enabled, the instruction is entered by driving /CS low, sending the instruction code "C5h", and then writing the Extended Address Register data byte as illustrated in Figure 11. Upon power up or the execution of a Software Reset, the Extended Address Register bit values will be cleared to 0. The Extended Address Register is only effective when the device is in the 3-Byte Address Mode. When the device operates in the 4-Byte Address Mode (ADS=1), any command with address input of A31-A24 will replace the Extended Address Register values. It is recommended to check and update the Extended Address Register if necessary when the device is switched from 4-Byte to 3-Byte Address Mode. Figure 11a. Write Extended Address Register Instruction #### 7.5.8 Enter 4-Byte Address Mode (B7h) The Enter 4-Byte Address Mode instruction (Figure 12) will allow 32-bit address (A31-A0) to be used to access the memory array beyond 128Mb. The Enter 4-Byte Address Mode instruction is entered by driving /CS low, shifting the instruction code "B7h" into the DI pin and then driving /CS high. Figure 12. Enter 4-Byte Address Mode instruction #### 7.5.9 Exit 4-Byte Address Mode (E9h) In order to be backward compatible, the Exit 4-Byte Address Mode instruction (Figure 13) will only allow 24-bit address (A23-A0) to be used to access the memory array up to 128Mb. The Extended Address Register must be used to access the memory array beyond 128Mb. The Exit 4-Byte Address Mode instruction is entered by driving /CS low, shifting the instruction code "E9h" into the DI pin and then driving /CS high. Figure 13. Exit 4-Byte Address Mode instruction #### 7.5.10 Read Data (03h) The Read Data instruction allows one or more data bytes to be sequentially read from the memory. The instruction is initiated by driving the /CS pin low and then shifting the instruction code "03h" followed by a 24-bit address (A23-A0) or a 32-bit address (A31-A0) into the DI pin. The code and address bits are latched on the rising edge of the CLK pin. After the address is received, the data byte of the addressed memory location will be shifted out on the DO pin at the falling edge of CLK with most significant bit (MSB) first. The address is automatically incremented to the next higher address after each byte of data is shifted out allowing for a continuous stream of data. This means that the entire memory can be accessed with a single instruction as long as the clock continues. The instruction is completed by driving /CS high. The Read Data instruction sequence is shown in Figure 14. If a Read Data instruction is issued while an Erase, Program or Write cycle is in process (BUSY=1) the instruction is ignored and will not have any effects on the current cycle. The Read Data instruction allows clock rates from D.C. to a maximum of fr (see AC Electrical Characteristics). Figure 14. Read Data Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode ### 7.5.11 Read Data with 4-Byte Address (13h) The Read Data with 4-Byte Address instruction is similar to the Read Data (03h) instruction. Instead of 24-bit address, 32-bit address is needed following the instruction code 13h. No matter the device is operating in 3-Byte Address Mode or 4-byte Address Mode, the Read Data with 4-Byte Address instruction will always require 32-bit address to access the entire 512Mb memory. The Read Data with 4-Byte Address instruction sequence is shown in Figure 15. If this instruction is issued while an Erase, Program or Write cycle is in process (BUSY=1) the instruction is ignored and will not have any effects on the current cycle. The Read Data with 4-Byte Address instruction allows clock rates from D.C. to a maximum of fR (see AC Electrical Characteristics). Figure 15. Read Data with 4-Byte Address Instruction #### 7.5.12 Fast Read (0Bh) The Fast Read instruction is similar to the Read Data instruction except that it can operate at the highest possible frequency of FR (see AC Electrical Characteristics). This is accomplished by adding eight "dummy" clocks after the 24/32-bit address as shown in Figure 16. The dummy clocks allow the devices internal circuits additional time for setting up the initial address. During the dummy clocks the data value on the DO pin is a "don't care". Figure 16a. Fast Read Instruction ## 7.5.13 Fast Read with 4-Byte Address (0Ch) The Fast Read with 4-Byte Address instruction is similar to the Fast Read instruction except that it requires 32-bit address instead of 24-bit address. No matter the device is operating in 3-Byte Address Mode or 4-byte Address Mode, the Read Data with 4-Byte Address instruction will always require 32-bit address to access the entire 512Mb memory. Figure 17. Fast Read with 4-Byte Address Instruction #### 7.5.14 Fast Read Dual Output (3Bh) The Fast Read Dual Output (3Bh) instruction is similar to the standard Fast Read (0Bh) instruction except that data is output on two pins; $IO_0$ and $IO_1$ . This allows data to be transferred at twice the rate of standard SPI devices. The Fast Read Dual Output instruction is ideal for quickly downloading code from Flash to RAM upon power-up or for applications that cache code-segments to RAM for execution. Similar to the Fast Read instruction, the Fast Read Dual Output instruction can operate at the highest possible frequency of FR (see AC Electrical Characteristics). This is accomplished by adding eight "dummy" clocks after the 24/32-bit address as shown in Figure 18. The dummy clocks allow the device's internal circuits additional time for setting up the initial address. The input data during the dummy clocks is "don't care". However, the $IO_0$ pin should be high-impedance prior to the falling edge of the first data out clock. Figure 18. Fast Read Dual Output Instruction ### 7.5.15 Fast Read Dual Output with 4-Byte Address (3Ch) The Fast Read Dual Output with 4-Byte Address instruction is similar to the Fast Read Dual Output instruction except that it requires 32-bit address instead of 24-bit address. No matter the device is operating in 3-Byte Address Mode or 4-byte Address Mode, the Fast Read Dual Output with 4-Byte Address instruction will always require 32-bit address to access the entire 512Mb memory. Figure 19. Fast Read Dual Output with 4-Byte Address Instruction #### 7.5.16 Fast Read Quad Output (6Bh) The Fast Read Quad Output (6Bh) instruction is similar to the Fast Read Dual Output (3Bh) instruction except that data is output on four pins, IO<sub>0</sub>, IO<sub>1</sub>, IO<sub>2</sub>, and IO<sub>3</sub>. The Quad Enable (QE) bit in Status Register-2 must be set to 1 before the device will accept the Fast Read Quad Output Instruction. The Fast Read Quad Output Instruction allows data to be transferred at four times the rate of standard SPI devices. The Fast Read Quad Output instruction can operate at the highest possible frequency of FR (see AC Electrical Characteristics). This is accomplished by adding eight "dummy" clocks after the 24/32-bit address as shown in Figure 20. The dummy clocks allow the device's internal circuits additional time for setting up the initial address. The input data during the dummy clocks is "don't care". However, the IO pins should be high-impedance prior to the falling edge of the first data out clock. Figure 20. Fast Read Quad Output Instruction ### 7.5.17 Fast Read Quad Output with 4-Byte Address (6Ch) The Fast Read Quad Output with 4-Byte Address instruction is similar to the Fast Read Quad Output instruction except that it requires 32-bit address instead of 24-bit address. No matter the device is operating in 3-Byte Address Mode or 4-byte Address Mode, the Fast Read Quad Output with 4-Byte Address instruction will always require 32-bit address to access the entire 512Mb memory. Figure 21. Fast Read Quad Output with 4-Byte Address Instruction #### 7.5.18 Fast Read Dual I/O (BBh) The Fast Read Dual I/O (BBh) instruction allows for improved random access while maintaining two IO pins, $IO_0$ and $IO_1$ . It is similar to the Fast Read Dual Output (3Bh) instruction but with the capability to input the Address bits (A23/A31-0) two bits per clock. This reduced instruction overhead may allow for code execution (XIP) directly from the Dual SPI in some applications. Figure 22a. Fast Read Dual I/O Instruction (Initial instruction or previous M5-4 ≠ 10) 32-Bit Address is required when the device is operating in 4-Byte Address Mode # **Esses winbond sesses** #### 7.5.19 Fast Read Dual I/O with 4-Byte Address (BCh) The Fast Read Dual I/O with 4-Byte Address instruction is similar to the Fast Read Dual I/O instruction except that it requires 32-bit address instead of 24-bit address. No matter the device is operating in 3-Byte Address Mode or 4-byte Address Mode, the Fast Read Dual I/O with 4-Byte Address instruction will always require 32-bit address to access the entire 512Mb memory. Figure 23a. Fast Read Dual I/O with 4-Byte Address Instruction (Initial instruction or previous M5-4 $\neq$ 10) - 48 - # sees winbond s Figure 23b. Fast Read Dual I/O with 4-Byte Address Instruction (Previous instruction set M5-4 = 10) #### 7.5.20 Fast Read Quad I/O (EBh) The Fast Read Quad I/O (EBh) instruction is similar to the Fast Read Dual I/O (BBh) instruction except that address and data bits are input and output through four pins IO<sub>0</sub>, IO<sub>1</sub>, IO<sub>2</sub> and IO<sub>3</sub> and four Dummy clocks are required prior to the data output. The Quad I/O dramatically reduces instruction overhead allowing faster random access for code execution (XIP) directly from the Quad SPI. The Quad Enable bit (QE) of Status Register-2 must be set to enable the Fast Read Quad I/O Instruction. Figure 24a. Fast Read Quad I/O Instruction (Initial instruction or previous M5-4≠10) 32-Bit Address is required when the device is operating in 4-Byte Address Mode #### Fast Read Quad I/O with "8/16/32/64-Byte Wrap Around" The Fast Read Quad I/O instruction can also be used to access a specific portion within a page by issuing a "Set Burst with Wrap" (77h) command prior to EBh. The "Set Burst with Wrap" (77h) command can either enable or disable the "Wrap Around" feature for the following EBh commands. When "Wrap Around" is enabled, the data being accessed can be limited to either an 8, 16, 32 or 64-byte section of a 256-byte page. The output data starts at the initial address specified in the instruction, once it reaches the ending boundary of the 8/16/32/64-byte section, the output will wrap around to the beginning boundary automatically until /CS is pulled high to terminate the command. The Burst with Wrap feature allows applications that use cache to quickly fetch a critical address and then fill the cache afterwards within a fixed length (8/16/32/64-byte) of data without issuing multiple read commands. The "Set Burst with Wrap" instruction allows three "Wrap Bits", W6-4 to be set. The W4 bit is used to enable or disable the "Wrap Around" operation while W6-5 are used to specify the length of the wrap around section within a page. Refer to section 8.2.24 for detail descriptions. - Revision C1 #### 7.5.21 Fast Read Quad I/O with 4-Byte Address (ECh) The Fast Read Quad I/O with 4-Byte Address instruction is similar to the Fast Read Dual I/O instruction except that it requires 32-bit address instead of 24-bit address. No matter the device is operating in 3-Byte Address Mode or 4-byte Address Mode, the Fast Read Quad I/O with 4-Byte Address instruction will always require 32-bit address to access the entire 512Mb memory. #### Fast Read Quad I/O with 4-Byte Address Configurable "Dummy Clocks" and "Wrap Length" The number of "dummy clocks" and "wrap length" of the "Fast Read Quad I/O with4-Byte Address (ECh)" instruction in SPI mode are configurable. In standard SPI mode and before executing the Fast Read Quad I/O instruction, the number of "dummy clocks" can be configured by the "Set Read Parameters (C0h)" instruction. Depending on the Read Parameter Bits P[6:4] setting, the number of dummy clocks can be configured as either 6, 8, 10, 12, 14, or 16. The default number of dummy clocks upon power up or after a Reset instruction is 6. The Fast Read Quad I/O with 4-Byte Address instruction can also be used to access a specific portion within a page by issuing a "Set Burst with Wrap" (77h) command prior to ECh. The "Set Burst with Wrap" (77h) command can either enable or disable the "Wrap Around" feature for the following ECh commands. When "Wrap Around" is enabled, the data being accessed can be limited to either an 8, 16, 32 or 64-byte section of a 256-byte page. The output data starts at the initial address specified in the instruction, once it reaches the ending boundary of the 8/16/32/64-byte section, the output will wrap around to the beginning boundary automatically until /CS is pulled high to terminate the command. The Burst with Wrap feature allows applications that use cache to quickly fetch a critical address and then fill the cache afterwards within a fixed length (8/16/32/64-byte) of data without issuing multiple read commands. The "Set Burst with Wrap" instruction allows three "Wrap Bits", W6-4 to be set. The W4 bit is used to enable or disable the "Wrap Around" operation while W6-5 are used to specify the length of the wrap around section within a page. Refer to Section 8.2.25 for detail descriptions. Figure 28a. Fast Read Quad I/O w/ 4-Byte Addr. (Initial instruction or previous M5-4±10, SPI Mode only) ## sees winbond sees Figure 25a. Fast Read Quad I/O with 4-Byte Address Instruction (Initial instruction or previous M5-4≠10) ## rese winbond sees Figure 25b. Fast Read Quad I/O with 4-Byte Address Instruction (Previous instruction set M5-4 = 10) #### Fast Read Quad I/O with "8/16/32/64-Byte Wrap Around" The Fast Read Quad I/O instruction can also be used to access a specific portion within a page by issuing a "Set Burst with Wrap" (77h) command prior to ECh. The "Set Burst with Wrap" (77h) command can either enable or disable the "Wrap Around" feature for the following ECh commands. When "Wrap Around" is enabled, the data being accessed can be limited to either an 8, 16, 32 or 64-byte section of a 256-byte page. The output data starts at the initial address specified in the instruction, once it reaches the ending boundary of the 8/16/32/64-byte section, the output will wrap around to the beginning boundary automatically until /CS is pulled high to terminate the command. The Burst with Wrap feature allows applications that use cache to quickly fetch a critical address and then fill the cache afterwards within a fixed length (8/16/32/64-byte) of data without issuing multiple read commands. The "Set Burst with Wrap" instruction allows three "Wrap Bits", W6-4 to be set. The W4 bit is used to enable or disable the "Wrap Around" operation while W6-5 are used to specify the length of the wrap around section within a page. Refer to section 8.2.24 for detail descriptions. ### 7.5.22 Set Burst with Wrap (77h) The Set Burst with Wrap (77h) instruction is used in conjunction with "Fast Read Quad I/O" and "Word Read Quad I/O" instructions to access a fixed length of 8/16/32/64-byte section within a 256-byte page. Certain applications can benefit from this feature and improve the overall system code execution performance. Similar to a Quad I/O instruction, the Set Burst with Wrap instruction is initiated by driving the /CS pin low and then shifting the instruction code "77h" followed by 24/32 dummy bits and 8 "Wrap Bits", W7-0. The instruction sequence is shown in Figure 28. Wrap bit W7 and the lower nibble W3-0 are not used. | W6, W5 | W4 = 0 | | W4 =1 (DEFAULT) | | | |--------|-------------|-------------|-----------------|-------------|--| | | Wrap Around | Wrap Length | Wrap Around | Wrap Length | | | 0 0 | Yes | 8-byte | No | N/A | | | 0 1 | Yes | 16-byte | No | N/A | | | 1 0 | Yes | 32-byte | No | N/A | | | 1 1 | Yes | 64-byte | No | N/A | | Once W6-4 is set by a Set Burst with Wrap instruction, all the following "Fast Read Quad I/O" and "Word Read Quad I/O" instructions will use the W6-4 setting to access the 8/16/32/64-byte section within any page. To exit the "Wrap Around" function and return to normal read operation, another Set Burst with Wrap instruction should be issued to set W4 = 1. The default value of W4 upon power on or after a software reset is 1. Figure 28. Set Burst with Wrap Instruction 32-Bit dummy bits are required when the device is operating in 4-Byte Address Mode #### 7.5.23 Page Program (02h) The Page Program instruction allows from one byte to 256 bytes (a page) of data to be programmed at previously erased (FFh) memory locations. A Write Enable instruction must be executed before the device will accept the Page Program Instruction (Status Register bit WEL= 1). The instruction is initiated by driving the /CS pin low then shifting the instruction code "02h" followed by a 24/32-bit address (A23/A31-A0) and at least one data byte, into the DI pin. The /CS pin must be held low for the entire length of the instruction while data is being sent to the device. The Page Program instruction sequence is shown in Figure 29. If an entire 256 byte page is to be programmed, the last address byte (the 8 least significant address bits) should be set to 0. If the last address byte is not zero, and the number of clocks exceeds the remaining page length, the addressing will wrap to the beginning of the page. In some cases, less than 256 bytes (a partial page) can be programmed without having any effect on other bytes within the same page. One condition to perform a partial page program is that the number of clocks cannot exceed the remaining page length. If more than 256 bytes are sent to the device the addressing will wrap to the beginning of the page and overwrite previously sent data. As with the write and erase instructions, the /CS pin must be driven high after the eighth bit of the last byte has been latched. If this is not done the Page Program instruction will not be executed. After /CS is driven high, the self-timed Page Program instruction will commence for a time duration of tpp (See AC Characteristics). While the Page Program cycle is in progress, the Read Status Register instruction may still be accessed for checking the status of the BUSY bit. The BUSY bit is a 1 during the Page Program cycle and becomes a 0 when the cycle is finished and the device is ready to accept other instructions again. After the Page Program cycle has finished the Write Enable Latch (WEL) bit in the Status Register is cleared to 0. The Page Program instruction will not be executed if the addressed page is protected by the Block Protect (CMP, TB, BP3, BP2, BP1, and BP0) bits or the Individual Block/Sector Locks. Figure 29a. Page Program Instruction #### 7.5.24 Quad Input Page Program (32h) The Quad Page Program instruction allows up to 256 bytes of data to be programmed at previously erased (FFh) memory locations using four pins: IO<sub>0</sub>, IO<sub>1</sub>, IO<sub>2</sub>, and IO<sub>3</sub>. The Quad Page Program can improve performance for PROM Programmer and applications that have slow clock speeds <5MHz. Systems with faster clock speed will not realize much benefit for the Quad Page Program instruction since the inherent page program time is much greater than the time it take to clock-in the data. To use Quad Page Program the Quad Enable (QE) bit in Status Register-2 must be set to 1. A Write Enable instruction must be executed before the device will accept the Quad Page Program instruction (Status Register-1, WEL=1). The instruction is initiated by driving the /CS pin low then shifting the instruction code "32h" followed by a 24/32-bit address (A23/A31-A0) and at least one data byte, into the IO pins. The /CS pin must be held low for the entire length of the instruction while data is being sent to the device. All other functions of Quad Page Program are identical to standard Page Program. The Quad Page Program instruction sequence is shown in Figure 30. Figure 30. Quad Input Page Program Instruction #### 7.5.25 Sector Erase (20h) The Sector Erase instruction sets all memory within a specified sector (4K-bytes) to the erased state of all 1s (FFh). A Write Enable instruction must be executed before the device will accept the Sector Erase Instruction (Status Register bit WEL must equal 1). The instruction is initiated by driving the /CS pin low and shifting the instruction code "20h" followed a 24/32-bit sector address (A23/A31-A0). The Sector Erase instruction sequence is shown in Figure 31a & 31b. The /CS pin must be driven high after the eighth bit of the last byte has been latched. If this is not done the Sector Erase instruction will not be executed. After /CS is driven high, the self-timed Sector Erase instruction will commence for a time duration of tse (See AC Characteristics). While the Sector Erase cycle is in progress, the Read Status Register instruction may still be accessed for checking the status of the BUSY bit. The BUSY bit is a 1 during the Sector Erase cycle and becomes a 0 when the cycle is finished and the device is ready to accept other instructions again. After the Sector Erase cycle has finished the Write Enable Latch (WEL) bit in the Status Register is cleared to 0. The Sector Erase instruction will not be executed if the addressed page is protected by the Block Protect (CMP, TB, BP3, BP2, BP1, and BP0) bits or the Individual Block/Sector Locks. Figure 31a. Sector Erase Instruction #### 7.5.26 32KB Block Erase (52h) The Block Erase instruction sets all memory within a specified block (32K-bytes) to the erased state of all 1s (FFh). A Write Enable instruction must be executed before the device will accept the Block Erase Instruction (Status Register bit WEL must equal 1). The instruction is initiated by driving the /CS pin low and shifting the instruction code "52h" followed a 24/32-bit block address (A23/A31-A0). The Block Erase instruction sequence is shown in Figure 32a & 32b. The /CS pin must be driven high after the eighth bit of the last byte has been latched. If this is not done the Block Erase instruction will not be executed. After /CS is driven high, the self-timed Block Erase instruction will commence for a time duration of tBE1 (See AC Characteristics). While the Block Erase cycle is in progress, the Read Status Register instruction may still be accessed for checking the status of the BUSY bit. The BUSY bit is a 1 during the Block Erase cycle and becomes a 0 when the cycle is finished and the device is ready to accept other instructions again. After the Block Erase cycle has finished the Write Enable Latch (WEL) bit in the Status Register is cleared to 0. The Block Erase instruction will not be executed if the addressed page is protected by the Block Protect (CMP, TB, BP3, BP2, BP1, and BP0) bits or the Individual Block/Sector Locks. Figure 32a. 32KB Block Erase Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode - 58 - #### 7.5.27 64KB Block Erase (D8h) The Block Erase instruction sets all memory within a specified block (64K-bytes) to the erased state of all 1s (FFh). A Write Enable instruction must be executed before the device will accept the Block Erase Instruction (Status Register bit WEL must equal 1). The instruction is initiated by driving the /CS pin low and shifting the instruction code "D8h" followed a 24/32-bit block address (A23/A31-A0). The Block Erase instruction sequence is shown in Figure 33a & 33b. The /CS pin must be driven high after the eighth bit of the last byte has been latched. If this is not done the Block Erase instruction will not be executed. After /CS is driven high, the self-timed Block Erase instruction will commence for a time duration of tbe (See AC Characteristics). While the Block Erase cycle is in progress, the Read Status Register instruction may still be accessed for checking the status of the BUSY bit. The BUSY bit is a 1 during the Block Erase cycle and becomes a 0 when the cycle is finished and the device is ready to accept other instructions again. After the Block Erase cycle has finished the Write Enable Latch (WEL) bit in the Status Register is cleared to 0. The Block Erase instruction will not be executed if the addressed page is protected by the Block Protect (CMP, TB, BP3, BP2, BP1, and BP0) bits or the Individual Block/Sector Locks. Figure 33a. 64KB Block Erase Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode ### 7.5.28 Chip Erase (C7h / 60h) The Chip Erase instruction sets all memory within the device to the erased state of all 1s (FFh). A Write Enable instruction must be executed before the device will accept the Chip Erase Instruction (Status Register bit WEL must equal 1). The instruction is initiated by driving the /CS pin low and shifting the instruction code "C7h" or "60h". The Chip Erase instruction sequence is shown in Figure 34. The /CS pin must be driven high after the eighth bit has been latched. If this is not done the Chip Erase instruction will not be executed. After /CS is driven high, the self-timed Chip Erase instruction will commence for a time duration of tce (See AC Characteristics). While the Chip Erase cycle is in progress, the Read Status Register instruction may still be accessed to check the status of the BUSY bit. The BUSY bit is a 1 during the Chip Erase cycle and becomes a 0 when finished and the device is ready to accept other instructions again. After the Chip Erase cycle has finished the Write Enable Latch (WEL) bit in the Status Register is cleared to 0. The Chip Erase instruction will not be executed if any memory region is protected by the Block Protect (CMP, TB, BP3, BP2, BP1, and BP0) bits or the Individual Block/Sector Locks. Figure 34. Chip Erase Instruction ### 7.5.29 Erase / Program Suspend (75h) The Erase/Program Suspend instruction "75h", allows the system to interrupt a Sector or Block Erase operation or a Page Program operation and then read from or program/erase data to, any other sectors or blocks. The Erase/Program Suspend instruction sequence is shown in Figure 35a & 35b. The Write Status Register instruction (01h) and Erase instructions (20h, 52h, D8h, C7h, 60h, 44h) are not allowed during Erase Suspend. Erase Suspend is valid only during the Sector or Block erase operation. If written during the Chip Erase operation, the Erase Suspend instruction is ignored. The Write Status Register instruction (01h) and Program instructions (02h, 32h, 42h) are not allowed during Program Suspend. Program Suspend is valid only during the Page Program or Quad Page Program operation. The Erase/Program Suspend instruction "75h" will be accepted by the device only if the SUS bit in the Status Register equals to 0 and the BUSY bit equals to 1 while a Sector or Block Erase or a Page Program operation is on-going. If the SUS bit equals to 1 or the BUSY bit equals to 0, the Suspend instruction will be ignored by the device. A maximum of time of "tsus" (See AC Characteristics) is required to suspend the erase or program operation. The BUSY bit in the Status Register will be cleared from 1 to 0 within "tsus" and the SUS bit in the Status Register will be set from 0 to 1 immediately after Erase/Program Suspend. For a previously resumed Erase/Program operation, it is also required that the Suspend instruction "75h" is not issued earlier than a minimum of time of "tsus" following the preceding Resume instruction "7Ah". Unexpected power off during the Erase/Program suspend state will reset the device and release the suspend state. SUS bit in the Status Register will also reset to 0. The data within the page, sector or block that was being suspended may become corrupted. It is recommended for the user to implement system design techniques against the accidental power interruption and preserve data integrity during erase/program suspend state. Figure 35a. Erase/Program Suspend Instruction ### 7.5.30 Erase / Program Resume (7Ah) The Erase/Program Resume instruction "7Ah" must be written to resume the Sector or Block Erase operation or the Page Program operation after an Erase/Program Suspend. The Resume instruction "7Ah" will be accepted by the device only if the SUS bit in the Status Register equals to 1 and the BUSY bit equals to 0. After issued the SUS bit will be cleared from 1 to 0 immediately, the BUSY bit will be set from 0 to 1 within 200ns and the Sector or Block will complete the erase operation or the page will complete the program operation. If the SUS bit equals to 0 or the BUSY bit equals to 1, the Resume instruction "7Ah" will be ignored by the device. The Erase/Program Resume instruction sequence is shown in Figure 36a & 36b. Resume instruction is ignored if the previous Erase/Program Suspend operation was interrupted by unexpected power off. It is also required that a subsequent Erase/Program Suspend instruction not to be issued with in a minimum of time of "tsus" following a previous Resume instruction. Figure 36a. Erase/Program Resume Instruction - 62 - — Revision C1 #### 7.5.31 Power-down (B9h) Although the standby current during normal operation is relatively low, standby current can be further reduced with the Power-down instruction. The lower power consumption makes the Power-down instruction especially useful for battery powered applications (See ICC1 and ICC2 in AC Characteristics). The instruction is initiated by driving the /CS pin low and shifting the instruction code "B9h" as shown in Figure 37a & 37b. The /CS pin must be driven high after the eighth bit has been latched. If this is not done the Power-down instruction will not be executed. After /CS is driven high, the power-down state will entered within the time duration of tDP (See AC Characteristics). While in the power-down state only the Release Power-down / Device ID (ABh) instruction, which restores the device to normal operation, will be recognized. All other instructions are ignored. This includes the Read Status Register instruction, which is always available during normal operation. Ignoring all but one instruction makes the Power Down state a useful condition for securing maximum write protection. The device always powers-up in the normal operation with the standby current of ICC1. Figure 37a. Deep Power-down Instruction #### 7.5.32 Release Power-down / Device ID (ABh) The Release from Power-down / Device ID instruction is a multi-purpose instruction. It can be used to release the device from the power-down state, or obtain the devices electronic identification (ID) number. To release the device from the power-down state, the instruction is issued by driving the /CS pin low, shifting the instruction code "ABh" and driving /CS high as shown in Figure 38a & 38b. Release from power-down will take the time duration of tRES1 (See AC Characteristics) before the device will resume normal operation and other instructions are accepted. The /CS pin must remain high during the tRES1 time duration. When used only to obtain the Device ID while not in the power-down state, the instruction is initiated by driving the /CS pin low and shifting the instruction code "ABh" followed by 3-dummy bytes. The Device ID bits are then shifted out on the falling edge of CLK with most significant bit (MSB) first. The Device ID values for the W25R512NW/W74M51NW is listed in Manufacturer and Device Identification table. The Device ID can be read continuously. The instruction is completed by driving /CS high. When used to release the device from the power-down state and obtain the Device ID, the instruction is the same as previously described, and shown in Figure 38c & 38d, except that after /CS is driven high it must remain high for a time duration of tRES2 (See AC Characteristics). After this time duration the device will resume normal operation and other instructions will be accepted. If the Release from Power-down / Device ID instruction is issued while an Erase, Program or Write cycle is in process (when BUSY equals 1) the instruction is ignored and will not have any effects on the current cycle. Figure 38a. Release Power-down Instruction Figure 38c. Release Power-down / Device ID Instruction #### 7.5.33 Read Manufacturer / Device ID (90h) The Read Manufacturer/Device ID instruction is an alternative to the Release from Power-down / Device ID instruction that provides both the JEDEC assigned manufacturer ID and the specific device ID. The Read Manufacturer/Device ID instruction is very similar to the Release from Power-down / Device ID instruction. The instruction is initiated by driving the /CS pin low and shifting the instruction code "90h" followed by a 24-bit address (A23-A0) of 000000h. After which, the Manufacturer ID for Winbond (EFh) and the Device ID are shifted out on the falling edge of CLK with most significant bit (MSB) first as shown in Figure 39. The Device ID values for the W25R512NW/W74M51NW are listed in Manufacturer and Device Identification table. The instruction is completed by driving /CS high. Figure 39. Read Manufacturer / Device ID Instruction #### 7.5.34 Read Manufacturer / Device ID Dual I/O (92h) The Read Manufacturer / Device ID Dual I/O instruction is an alternative to the Read Manufacturer / Device ID instruction that provides both the JEDEC assigned manufacturer ID and the specific device ID at 2x speed. The Read Manufacturer / Device ID Dual I/O instruction is similar to the Fast Read Dual I/O instruction. The instruction is initiated by driving the /CS pin low and shifting the instruction code "92h" followed by a 24/32-bit address (A23/A31-A0) of 000000h, but with the capability to input the Address bits two bits per clock. After which, the Manufacturer ID for Winbond (EFh) and the Device ID are shifted out 2 bits per clock on the falling edge of CLK with most significant bits (MSB) first as shown in Figure 40. The Device ID values for the W25R512NW/W74M51NW are listed in Manufacturer and Device Identification table. The Manufacturer and Device IDs can be read continuously, alternating from one to the other. The instruction is completed by driving /CS high. Figure 40. Read Manufacturer / Device ID Dual I/O Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode #### Note: The "Continuous Read Mode" bits M(7-0) must be set to Fxh to be compatible with Fast Read Dual I/O instruction. #### 7.5.35 Read Manufacturer / Device ID Quad I/O (94h) The Read Manufacturer / Device ID Quad I/O instruction is an alternative to the Read Manufacturer / Device ID instruction that provides both the JEDEC assigned manufacturer ID and the specific device ID at 4x speed. The Read Manufacturer / Device ID Quad I/O instruction is similar to the Fast Read Quad I/O instruction. The instruction is initiated by driving the /CS pin low and shifting the instruction code "94h" followed by a four clock dummy cycles and then a 24/32-bit address (A23/A31-A0) of 000000h, but with the capability to input the Address bits four bits per clock. After which, the Manufacturer ID for Winbond (EFh) and the Device ID are shifted out four bits per clock on the falling edge of CLK with most significant bit (MSB) first as shown in Figure 41. The Device ID values for the W25R512NW/W74M51NW are listed in Manufacturer and Device Identification table. The Manufacturer and Device IDs can be read continuously, alternating from one to the other. The instruction is completed by driving /CS high. Figure 41. Read Manufacturer / Device ID Quad I/O Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode #### Note: The "Continuous Read Mode" bits M(7-0) must be set to Fxh to be compatible with Fast Read Quad I/O instruction. #### 7.5.36 Read Unique ID Number (4Bh) The Read Unique ID Number instruction accesses a factory-set read-only 64-bit number that is unique to each W25R512NW/W74M51NW device. The ID number can be used in conjunction with user software methods to help prevent copying or cloning of a system. The Read Unique ID instruction is initiated by driving the /CS pin low and shifting the instruction code "4Bh" followed by a four bytes of dummy clocks. After which, the 64-bit ID is shifted out on the falling edge of CLK as shown in Figure 42. Figure 42. Read Unique ID Number Instruction 5 Dummy Bytes are required when the device is operating in 4-Byte Address Mode ## 7.5.37 Read JEDEC ID (9Fh) For compatibility reasons, the W25R512NW/W74M51NW provides several instructions to electronically determine the identity of the device. The Read JEDEC ID instruction is compatible with the JEDEC standard for SPI compatible serial memories that was adopted in 2003. The instruction is initiated by driving the /CS pin low and shifting the instruction code "9Fh". The JEDEC assigned Manufacturer ID byte for Winbond (EFh) and two Device ID bytes, Memory Type (ID15-ID8) and Capacity (ID7-ID0) are then shifted out on the falling edge of CLK with most significant bit (MSB) first as shown in Figure 43a & 43b. For memory type and capacity values refer to Manufacturer and Device Identification table. Figure 43a. Read JEDEC ID Instruction ### 7.5.38 Read SFDP Register (5Ah) The W25R512NW/W74M51NW features a 256-Byte Serial Flash Discoverable Parameter (SFDP) register that contains information about device configurations, available instructions and other features. The SFDP parameters are stored in one or more Parameter Identification (PID) tables. Currently only one PID table is specified, but more may be added in the future. The Read SFDP Register instruction is compatible with the SFDP standard initially established in 2010 for PC and other applications, as well as the JEDEC standard JESD216 that is published in 2011. Most Winbond SpiFlash Memories shipped after June 2011 (date code 1124 and beyond) support the SFDP feature as specified in the applicable datasheet. The Read SFDP instruction is initiated by driving the /CS pin low and shifting the instruction code "5Ah" followed by a 24-bit address (A23-A0)<sup>(1)</sup> into the DI pin. Eight "dummy" clocks are also required before the SFDP register contents are shifted out on the falling edge of the 40<sup>th</sup> CLK with most significant bit (MSB) first as shown in Figure 44. For SFDP register values and descriptions, please refer to the Winbond Application Note for SFDP Definition Table. Note: 1. A23-A8 = 0; A7-A0 are used to define the starting byte address for the 256-Byte SFDP Register. Figure 44. Read SFDP Register Instruction Sequence Diagram Only 24-Bit Address is required when the device is operating in either 3-Byte or 4-Byte Address Mode #### 7.5.39 Erase Security Registers (44h) The W25R512NW/W74M51NW offers three 256-byte Security Registers which can be erased and programmed individually. These registers may be used by the system manufacturers to store security and other important information separately from the main memory array. The Erase Security Register instruction is similar to the Sector Erase instruction. A Write Enable instruction must be executed before the device will accept the Erase Security Register Instruction (Status Register bit WEL must equal 1). The instruction is initiated by driving the /CS pin low and shifting the instruction code "44h" followed by a 24/32-bit address (A23/A31-A0) to erase one of the three security registers. | ADDRESS | {A23/A31}-16 | A15-12 | A11-8 | A7-0 | |----------------------|--------------|--------|-------|------------| | Security Register #1 | 00h | 0001 | 0000 | Don't Care | | Security Register #2 | 00h | 0010 | 0000 | Don't Care | | Security Register #3 | 00h | 0011 | 0000 | Don't Care | The Erase Security Register instruction sequence is shown in Figure 45. The /CS pin must be driven high after the eighth bit of the last byte has been latched. If this is not done the instruction will not be executed. After /CS is driven high, the self-timed Erase Security Register operation will commence for a time duration of tse (See AC Characteristics). While the Erase Security Register cycle is in progress, the Read Status Register instruction may still be accessed for checking the status of the BUSY bit. The BUSY bit is a 1 during the erase cycle and becomes a 0 when the cycle is finished and the device is ready to accept other instructions again. After the Erase Security Register cycle has finished the Write Enable Latch (WEL) bit in the Status Register is cleared to 0. The Security Register Lock Bits (LB3-1) in the Status Register-2 can be used to OTP protect the security registers. Once a lock bit is set to 1, the corresponding security register will be permanently locked, Erase Security Register instruction to that register will be ignored (Refer to section 7.1.8 for detail descriptions). Figure 45. Erase Security Registers Instruction ### 7.5.40 Program Security Registers (42h) The Program Security Register instruction is similar to the Page Program instruction. It allows from one byte to 256 bytes of security register data to be programmed at previously erased (FFh) memory locations. A Write Enable instruction must be executed before the device will accept the Program Security Register Instruction (Status Register bit WEL= 1). The instruction is initiated by driving the /CS pin low then shifting the instruction code "42h" followed by a 24/32-bit address (A23/A31-A0) and at least one data byte, into the DI pin. The /CS pin must be held low for the entire length of the instruction while data is being sent to the device. | ADDRESS | {A23/A31}-16 | A15-12 | A11-8 | A7-0 | |----------------------|--------------|--------|-------|--------------| | Security Register #1 | 00h | 0001 | 0000 | Byte Address | | Security Register #2 | 00h | 0010 | 0000 | Byte Address | | Security Register #3 | 00h | 0011 | 0000 | Byte Address | The Program Security Register instruction sequence is shown in Figure 46. The Security Register Lock Bits (LB3-1) in the Status Register-2 can be used to OTP protect the security registers. Once a lock bit is set to 1, the corresponding security register will be permanently locked, Program Security Register instruction to that register will be ignored (See 7.1.8, 8.2.25 for detail descriptions). Figure 46. Program Security Registers Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode ### 7.5.41 Read Security Registers (48h) The Read Security Register instruction is similar to the Fast Read instruction and allows one or more data bytes to be sequentially read from one of the four security registers. The instruction is initiated by driving the /CS pin low and then shifting the instruction code "48h" followed by a 24/32-bit address (A23/A31-A0) and eight "dummy" clocks into the DI pin. The code and address bits are latched on the rising edge of the CLK pin. After the address is received, the data byte of the addressed memory location will be shifted out on the DO pin at the falling edge of CLK with most significant bit (MSB) first. The byte address is automatically incremented to the next byte address after each byte of data is shifted out. Once the byte address reaches the last byte of the register (byte address FFh), it will reset to address 00h, the first byte of the register, and continue to increment. The instruction is completed by driving /CS high. The Read Security Register instruction sequence is shown in Figure 47. If a Read Security Register instruction is issued while an Erase, Program or Write cycle is in process (BUSY=1) the instruction is ignored and will not have any effects on the current cycle. The Read Security Register instruction allows clock rates from D.C. to a maximum of FR (see AC Electrical Characteristics). | ADDRESS | {A23/A31}-16 | A15-12 | A11-8 | A7-0 | |----------------------|--------------|--------|-------|--------------| | Security Register #1 | 00h | 0001 | 0000 | Byte Address | | Security Register #2 | 00h | 0010 | 0000 | Byte Address | | Security Register #3 | 00h | 0011 | 0000 | Byte Address | Figure 47. Read Security Registers Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode ### 7.5.1 Set Read Parameters (C0h) "Set Read Parameters (C0h)" instruction is used to accommodate a wide range of applications with different needs for either maximum read frequency or minimum data access latency. This is accomplished by setting the number of dummy clocks and wrap length configurations for set of selected instructions. Set Read Parameters (C0h) instruction writes to the Read Parameter Register (P[7:0]). P[6:4] bits is the dummy clocks configuration, while P[1:0] bits is the wrap length configuration for QPI\* mode only. In SPI mode, SPI Set Read Parameters (C0h)" instruction writes to 'Dummy Clocks' P[6:4] bits only, while it will ignore 'Wrap Length' P[1:0] bits input as they are don't care in SPI mode. The Set Read Parameters instruction sequence is shown in Figure 54. Set Read Parameters instruction (SPI) is used to configure the number of dummy cycles through P[6:4] Read Parameter bits for the following SPI, instructions: - Standard SPI mode: Fast Read Quad I/O (EBh/ECh) instruction The dummy clocks for various Fast Read instructions in SPI mode are fixed, except for "Fast Read Quad I/O (EBh/ECh)" instructions. Please refer to the Instruction Tables 1-4 and 7-8 for details. "Wrap Length" for the SPI "Fast Read Quad I/O (EBh/ECh)" instruction is set by W6-4 bit with the "Set Burst with Wrap (77h)" instruction. The Wrap bits (Set Burst with Wrap '77h') as well as Read Parameter bits P[7:0] setting will remain unchanged when the device is switched from Standard SPI mode to QPI mode or vice versa. It is very important that the required dummy cycles and wrap length are set properly before executing the SPI (EBh/ECh), QPI (0Bh, EBh, 0Ch) instructions. The default Parameter Read "Dummy Clocks" and "Wrap Length" settings for selected SPI and QPI read instructions after power up or reset are defined on the tables below. After power up or reset, Read Parameter bits are reset to 00h. Detailed Read Parameter bits configuration are also shown below. | | SPI-EB/EC<br>P6 P5 P4 | | DUMMY<br>CLOCKS | MAXIMUM*<br>READ FREQ. | | |---|-----------------------|---|-----------------|------------------------|--| | 0 | 0 | 0 | 2 | 33MHz | | | 0 | 0 | 1 | 4 | 50MHz | | | 0 | 1 | 0 | 6 (Def) | 104MHz | | | 0 | 1 | 1 | 8 | 133MHz | | | 1 | 0 | 0 | 10 | 133MHz | | | 1 | 0 | 1 | 12 | 133MHz | | | 1 | 1 | 0 | 14 | 133MHz | | | 1 | 1 | 1 | 16 | 133MHz | | Note: 4-byte alignment Read address from "00" Figure 54. Set Read Parameters Instruction (SPI Mode Left/QPI Mode Right) ### 7.5.2 Individual Block/Sector Lock (36h) The Individual Block/Sector Lock provides an alternative way to protect the memory array from adverse Erase/Program. In order to use the Individual Block/Sector Locks, the WPS bit in Status Register-3 must be set to 1. If WPS=0, the write protection will be determined by the combination of CMP, TB, BP[3:0] bits in the Status Registers. The Individual Block/Sector Lock bits are volatile bits. The default values after device power up or after a Reset are 1, so the entire memory array is being protected. To lock a specific block or sector as illustrated in Figure 4d, an Individual Block/Sector Lock command must be issued by driving /CS low, shifting the instruction code "36h" into the Data Input (DI) pin on the rising edge of CLK, followed by a 24/32-bit address and then driving /CS high. Figure 52a. Individual Block/Sector Lock Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode ### 7.5.3 Individual Block/Sector Unlock (39h) The Individual Block/Sector Lock provides an alternative way to protect the memory array from adverse Erase/Program. In order to use the Individual Block/Sector Locks, the WPS bit in Status Register-3 must be set to 1. If WPS=0, the write protection will be determined by the combination of CMP, TB, BP[3:0] bits in the Status Registers. The Individual Block/Sector Lock bits are volatile bits. The default values after device power up or after a Reset are 1, so the entire memory array is being protected. To unlock a specific block or sector as illustrated in Figure 4d, an Individual Block/Sector Unlock command must be issued by driving /CS low, shifting the instruction code "39h" into the Data Input (DI) pin on the rising edge of CLK, followed by a 24/32-bit address and then driving /CS high. Figure 53a. Individual Block Unlock Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode ### 7.5.4 Read Block/Sector Lock (3Dh) The Individual Block/Sector Lock provides an alternative way to protect the memory array from adverse Erase/Program. In order to use the Individual Block/Sector Locks, the WPS bit in Status Register-3 must be set to 1. If WPS=0, the write protection will be determined by the combination of CMP, TB, BP[3:0] bits in the Status Registers. The Individual Block/Sector Lock bits are volatile bits. The default values after device power up or after a Reset are 1, so the entire memory array is being protected. To read out the lock bit value of a specific block or sector as illustrated in Figure 4d, a Read Block/Sector Lock command must be issued by driving /CS low, shifting the instruction code "3Dh" into the Data Input (DI) pin on the rising edge of CLK, followed by a 24/32-bit address. The Block/Sector Lock bit value will be shifted out on the DO pin at the falling edge of CLK with most significant bit (MSB) first as shown in Figure 54. If the least significant bit (LSB) is 1, the corresponding block/sector is locked; if LSB=0, the corresponding block/sector is unlocked, Erase/Program operation can be performed. Figure 54a. Read Block Lock Instruction 32-Bit Address is required when the device is operating in 4-Byte Address Mode #### 7.5.5 Global Block/Sector Lock (7Eh) All Block/Sector Lock bits can be set to 1 by the Global Block/Sector Lock instruction. The command must be issued by driving /CS low, shifting the instruction code "7Eh" into the Data Input (DI) pin on the rising edge of CLK, and then driving /CS high. Figure 55. Global Block Lock Instruction ### 7.5.6 Global Block/Sector Unlock (98h) All Block/Sector Lock bits can be set to 0 by the Global Block/Sector Unlock instruction. The command must be issued by driving /CS low, shifting the instruction code "98h" into the Data Input (DI) pin on the rising edge of CLK, and then driving /CS high. Figure 56. Global Block Unlock Instruction ### 7.5.7 Enable Reset (66h) and Reset Device (99h) Because of the small package and the limitation on the number of pins, the W25R512NW/W74M51NW provide a software Reset instruction instead of a dedicated RESET pin. Once the Reset instruction is accepted, any on-going internal operations will be terminated and the device will return to its default power-on state and lose all the current volatile settings, such as Volatile Status Register bits, Write Enable Latch (WEL) status, Program/Erase Suspend status, Read parameter setting (P7-P0), and Wrap Bit setting (W6-W4). To avoid accidental reset, both instructions must be issued in sequence. Any other commands other than "Reset (99h)" after the "Enable Reset (66h)" command will disable the "Reset Enable" state. A new sequence of "Enable Reset (66h)" and "Reset (99h)" is needed to reset the device. Once the Reset command is accepted by the device, the device will take approximately tRST=30us to reset. During this period, no command will be accepted. Data corruption may happen if there is an on-going or suspended internal Erase or Program operation when Reset command sequence is accepted by the device. It is recommended to check the BUSY bit and the SUS bit in Status Register before issuing the Reset command sequence. Figure 57a. Enable Reset and Reset Instruction Sequence ### 7.5.8 Write Root Key Register (9Bh + 00h) This command is used by the SPI Flash Controller to initialize the Root Key Register corresponding to the received Counter Address with the received Root Key. It is expected to be used in an OEM manufacturing environment when the SPI Flash Controller and SPI Flash are powered together for the first time. After the command is issued on the interface the SPI Flash device must ensure that the received transaction is error free. This includes checking following conditions: - Payload size is correct. (including OP1 is 64 bytes) - Counter Address falls within the range of supported counters. - The Root Key Register corresponding to the requested Counter Address was previously uninitialized. [Root\_Key\_Reg\_Init\_State[Counter\_Address] = 0xFFh] - Truncated signature field is the same as least significant 224 bits of HMAC-SHA-256 based signature computed based on received input parameters. If the received transaction is error free SPI Flash device successfully executes the command and posts "successful completion" in the RPMC Status Register. This command must be executed to ensure that power cycling in the middle of command execution is properly handled. This requires that the internal state tracking the root key register initialization is written as the last operation of the command execution. (Root Key Reg Init State[Counter Address] = 0] Root Key Register Write with root key is = 256'hFF...FF is used as a temporary key. When this request is received error-free Root\_Key\_Reg\_Init\_State[Counter\_Address] is not affected. Instead only the corresponding Monotonic counters is initialized to 0 if previously uninitialized. This state is tracked as separate state using MC\_Init\_State[Counter\_Address]. This state is used to leave the Monotonic counters at the current value when an error free Root Key Register Write operation is received. (Both 256'hFF..FF and non 256'hFF..FF) Once this command is successfully executed with a non 256'hFF..FF Root Key, the device will not accept the "Write Root Key Register" command any more, and the Root Key value cannot be read out by any instructions. Figure 43. Write Root Key Register Instruction ### 7.5.9 Update HMAC Key (9Bh + 01h) This command is used by the SPI Flash Controller to update the HMAC-Key register corresponding to the received Counter Address with a new HMAC key calculated based on received input. This command must be issued once only on every power cycle event on the interface. This allows the HMAC key storage to be implemented using volatile memory. Status register busy indication is expected to indicate busy for double the amount of Read\_Counter\_Polling\_Delay specified in SFDP table since this command performs two distinct HMAC-SHA-256 computations. After the command is issued on the interface the SPI Flash device must ensure that the received transaction is error free. This includes checking following conditions: - Payload size is correct. (including OP1 = 40 bytes) - Counter Address falls within the range of supported counters. - The Monotonic counters corresponding to the requested Counter Address was previously initialized. - Signature matches the HMAC-SHA-256 based signature computed based on received input parameters. This command performs two HMAC-SHA-256 operations. If the received transaction is error free, the SPI Flash device successfully executes the command and posts "successful completion" in the RPMC Status Register. If the received transaction has errors, the SPI Flash device does not execute the transaction and posts the corresponding error in the RPMC Status Register. Figure 44. Update HMAC Key Register Instruction ### 7.5.10 Increment Monotonic counters (9Bh + 02h) This command is used by the SPI Flash Controller to increment the Monotonic counters by 1 inside the SPI Flash Device. After the command is issued on the interface the SPI Flash device must ensure that the received transaction is error free. This includes checking following conditions: - Payload size is correct. (including OP1 = 40 bytes) - Counter Address falls within the range of supported counters. - The Monotonic counters corresponding to the requested Counter Address was previously initialized. - The HMAC Key Register corresponding to the requested Counter Address was previously initialized. - The requested Signature matches the HMAC-SHA-256 based signature computed based on received input parameters. - The received Counter Addressmatches the current value of the counter read from the SPI Flash. If the received transaction is error free, the SPI Flash device successfully executes the command and posts "successful completion" in the RPMC Status Register. The increment counter implementation should make sure that the counter increment operation is performed in a power glitch aware manner. Figure 45. Increment Monotonic counters Instruction ### 7.5.11 Request Monotonic counters (9Bh + 03h) This command is used by the SPI Flash Controller to request the Monotonic counters value inside the SPI Flash Device. After the command is issued on the interface the SPI Flash device must ensure that the received transaction is error free. This includes checking following conditions: - Payload size is correct. (including OP1 = 48 bytes) - Counter Address falls within the range of supported counters. - The Monotonic counters corresponding to the requested Counter Address was previously initialized. - The HMAC Key Register corresponding to the requested Counter Address was previously initialized. - The requested Signature matches the HMAC-SHA-256 based signature computed based on received input parameters. If the received transaction is error free, the SPI Flash device successfully executes the command and posts "successful completion" in the RPMC Status Register. In response to this command, the SPI flash reads the Monotonic counters addressed by counter address. It calculates HMAC-SHA-256 signatures the second time, based on following parameters. - HMAC Message[127:0] = Tag [95:0], Counter Data Read[31:0] - HMAC Key[255:0] = HMAC\_Key\_Register[Counter\_Address][255:0] Figure 46. Request Monotonic counters Instruction ### 7.5.12 Reserved RPMCCommands (9Bh + 04h~FFh) If the SPI Flash Controller issues any of the reserved command-types, the SPI Flash Device must return Error status in the RPMC Status Register. It asserts bit 2 to indicate that a reserved command-type was issued. ### 7.5.13 Read RPMCStatus / Data (96h) This command is used by the SPI Flash Controller to read the RPMC status from any previously issued OP1 command. In addition, if previous OP1 command is Request Monotonic counters and if SPI Flash returns successful completion (BUSY=0) in the RPMC Status Register, then it must also return valid values in the Tag, Counter\_Addressand Signature field. If there're other error flags, the values returned in Tag, Counter and Signature field are invalid. The controller may abort the read prematurely prior to completely reading the entire payload. This may occur when the controller wants to simply read the RPMC status or when it observes an error being returned in the RPMC status field. The controller may also continue reading past the defined payload size of 49 bytes. Since this is an error condition, the SPI Flash may return any data past the defined payload size. The controller must ignore the data. Figure 47a. Read RPMC Data Instruction (BUSY=0) When BUSY=1, from Byte-3 and beyond, the device will output the RPMC Status[7:0] value continuously until /CS terminates the instruction. The device will not output Tag, CounterData & Signature fields when BUSY=1. Once BUSY becomes 0, another OP2 command must be issued to read out the correct Tag, CounterData & Signature fields. Figure 47b. Read RPMC Data Instruction (BUSY=1) ### 8. ELECTRICAL CHARACTERISTICS ### 8.1 Absolute Maximum Ratings (1)(2) | PARAMETERS | SYMBOL | CONDITIONS | RANGE | UNIT | |------------------------------------|---------------------|---------------------------------------|----------------------|------| | Supply Voltage | VCC | | -0.6 to 2.5V | V | | Voltage Applied to Any Pin | Vio | Relative to Ground | -0.6 to VCC+0.4 | V | | Transient Voltage on any Pin | VIOT | <20nS Transient<br>Relative to Ground | –2.0V to<br>VCC+2.0V | V | | Storage Temperature | Tstg | | -65 to +150 | °C | | Lead Temperature | TLEAD (3) | | See Note (3) | °C | | Electrostatic Discharge<br>Voltage | VESD <sup>(2)</sup> | Human Body<br>Model | -2000 to +2000 | V | #### Notes # 8.2 Operating Ranges | PARAMETER | SYMBOL | CONDITIONS | SPEC | | UNIT | | |-----------------------------------|---------|--------------------------------|------|------|----------|--| | PARAMETER | STWIDOL | CONDITIONS | MIN | MAX | UNIT | | | Supply Voltage <sup>(1)</sup> | VCC | $F_R = 133MHz$ , $f_R = 84MHz$ | 1.7 | 1.95 | <b>V</b> | | | Ambient Temperature,<br>Operating | TA | Industrial | -40 | +85 | °C | | #### Note: <sup>1.</sup> This device has been designed and tested for the specified operation ranges. Proper operation outside of these levels is not guaranteed. Exposure to absolute maximum ratings may affect device reliability. Exposure beyond absolute maximum ratings may cause permanent damage. <sup>2.</sup>JEDEC Std JESD22-A114A (C1=100pF, R1=1500 ohms, R2=500 ohms). <sup>3.</sup>Compliant with JEDEC Standard J-STD-20C for small body Sn-Pb or Pb-free (Green) assembly and the European directive on restrictions on hazardous substances (RoHS) 2002/95/EU. <sup>1.</sup>VCC voltage during Read can operate across the min and max range but should not exceed ±10% of the programming (erase/write) voltage. # 8.3 Power-up Timing and Write Inhibit Threshold(1) | PARAMETER | SYMBOL | SPEC | UNIT | | |-------------------------------------|----------|------|------|------| | PARAIMETER | STIVIDOL | MIN | MAX | UNII | | VCC (min) to /CS Low | tvsL | 20 | | μs | | Time Delay Before Write Instruction | tpuw | 5 | | ms | #### Note: 1. These parameters are characterized only. Figure 58. Power-up Timing and Voltage Levels Figure 58b. Power-up, Power-Down Requirement ### 8.4 DC Electrical Characteristics | DADAMETED | SYMPOL CONDITIONS | | | SPEC | | | | |-----------------------------------------------------------------------------------|-------------------|------------------------------------|-----------|------|-----------|------|--| | PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNIT | | | Input Capacitance | CIN | VIN = 0V | | | 12 | pF | | | Output Capacitance | Cout | Vout = 0V | | | 16 | pF | | | Input Leakage | ILI | | | | ±4 | μA | | | I/O Leakage | ILO | | | | ±4 | μA | | | Standby Current | Icc1 | /CS = VCC,<br>VIN = GND or VCC | | 30 | 250 | μA | | | Power-down Current | Icc2 | /CS = VCC,<br>VIN = GND or VCC | | 1 | 40 | μA | | | Current Read Data /<br>Dual /Quad 50MHz <sup>(2)</sup> | Icc3 | C = 0.1 VCC / 0.9 VCC<br>DO = Open | | | 20 | mA | | | Current Read Data /<br>Dual /Quad 104MHz <sup>(2)</sup> | Icc3 | C = 0.1 VCC / 0.9 VCC<br>DO = Open | | | 25 | mA | | | Current Read Data /<br>Dual Output Read/Quad<br>Output Read 133MHz <sup>(2)</sup> | Icc3 | C = 0.1 VCC / 0.9 VCC<br>DO = Open | | | 30 | mA | | | Current Write Status<br>Register | ICC4 | /CS = VCC | | 15 | 25 | mA | | | Current Page Program | Icc5 | /CS = VCC | | 15 | 25 | mA | | | Current Sector/Block<br>Erase | Icc6 | /CS = VCC | | 15 | 25 | mA | | | Current Chip Erase | Icc7 | /CS = VCC | | 15 | 25 | mA | | | RPMC OP1 Write Only | Icc8 | /CS = VCC | | 15 | 25 | mA | | | RPMC OP1 &<br>Array Read | Icc9 | C = 0.1 VCC / 0.9 VCC<br>DO = Open | | 19 | 40 | mA | | | RPMC OP1 &<br>Array Program/Erase | Icc10 | /CS = VCC | | 35 | 45 | mA | | | RPMC OP2 Read Only | Icc11 | C = 0.1 VCC / 0.9 VCC | | | 30 | mA | | | RPMC OP2 &<br>Array Program/Erase | Icc12 | C = 0.1 VCC / 0.9 VCC | | 30 | 45 | mA | | | Input Low Voltage | VIL | | | | VCC x 0.3 | V | | | Input High Voltage | VIH | | VCC x 0.7 | | VCC + 0.4 | V | | | Output Low Voltage | VoL | IOL = 100 μA | | | 0.2 | V | | | Output High Voltage | Voн | IOH = -100 μA | VCC - 0.2 | | | V | | #### Notes: - 1. Tested on sample basis and specified through design and characterization data. TA = 25° C, VCC = 3.0V. - 2. Checker Board Pattern. ### 8.5 AC Measurement Conditions(1) | PARAMETER | CVMDOL | SF | LINUT | | |----------------------------------|--------|--------------------|------------------|------| | PARAMETER | SYMBOL | MIN | MAX | UNIT | | Load Capacitance | CL | | 30 | pF | | Input Rise and Fall Times | TR, TF | | 5 <sup>(2)</sup> | ns | | Input Pulse Voltages | VIN | 0.1 VCC to 0.9 VCC | | V | | Input Timing Reference Voltages | IN | 0.5 VCC to 0.5 VCC | | V | | Output Timing Reference Voltages | Оит | 0.5 VCC to 0.5 VCC | | V | #### Note: - 1. Output Hi-Z is defined as the point where data out is no longer driven. - 2. Rise/Fall Time measured at 30% to 70%Vcc of Input Signals. Figure 59. AC Measurement I/O Waveform # 8.6 AC Electrical Characteristics(6) | DESCRIPTION | CVMDOL | A1.T | | SPEC | | UNIT | |-----------------------------------------------------|------------------------------|-----------------|-----------|------|-----|------| | DESCRIPTION | SYMBOL | ALT | MIN | TYP | MAX | UNII | | Clock frequency for RPMC instructions | FR | f <sub>C2</sub> | D.C. | | 80 | MHz | | Clock frequency except for & 03h/13h instructions | F <sub>R</sub> (6) | f <sub>C1</sub> | D.C. | | 133 | MHz | | Clock frequency for Read Data instruction (03h/13h) | fR | | D.C. | | 84 | MHz | | Clock High, Low Time | tCLH,<br>tCLL <sup>(1)</sup> | | 45%<br>PC | | | ns | | Clock Rise Time peak to peak | tCLCH <sup>(2)</sup> | | 0.1 | | | V/ns | | Clock Fall Time peak to peak | tCHCL <sup>(2)</sup> | | 0.1 | | | V/ns | | /CS Active Setup Time relative to CLK | tslch | tcss | 5 | | | ns | | /CS Not Active Hold Time relative to CLK | tCHSL | | 5 | | | ns | | Data In Setup Time | tDVCH | tDSU | 1.75 | | | ns | | Data In Hold Time | tCHDX | tDH | 2 | | | ns | | /CS Active Hold Time relative to CLK | tchsh | | 3 | | | ns | | /CS Not Active Setup Time relative to CLK | tshch | | 3 | | | ns | | /CS Deselect Time | tshsl | tcsH | 50 | | | ns | | Output Disable Time | tshqz(2) | tDIS | | | 10 | ns | | Clock Low to Output Valid | tCLQV | tv | | | 6 | ns | | Output Hold Time | tCLQX | tHO | 1 | | | ns | Continued - next page | AC F | lectrical | Characteristics | (cont'd) | |------|-----------|-----------------|----------| | | | | | | | | ALT | | | | | |------------------------------------------------------|----------------------|-----|-----|-----|-------|------| | DESCRIPTION | SYMBOL | | MIN | TYP | MAX | UNIT | | /CS High to Power-down Mode | tDP <sup>(2)</sup> | | | | 3 | μs | | /CS High to Standby Mode without ID Read | tRES1 <sup>(2)</sup> | | | | 3 | μs | | /CS High to Standby Mode with ID Read | tRES2 <sup>(2)</sup> | | | | 1.8 | μs | | /CS High to next Instruction after Suspend | tsus <sup>(2)</sup> | | | | 20 | μs | | /CS High to next Instruction after Reset | tRST <sup>(2)</sup> | | | | 30 | μs | | RPMC Write Root Key Register | tKEY | | | 170 | 250 | μs | | RPMC Update HMAC Key Register | tHMAC | | | 50 | 75 | μs | | RPMC Increment Monotonic Counter | tinc1 | | | 80 | 200 | μs | | RPMC Increment Monotonic Counter (Counter Switching) | tinc2 | | | 75 | 250 | ms | | RPMC Request Monotonic Counter | treQ | | | 80 | 120 | μs | | Write Status Register Time | tw | | | 1 | 30 | ms | | Page Program Time | tPP | | | 0.7 | 3.5 | ms | | Sector Erase Time (4KB) | tse | | | 60 | 200 | ms | | Block Erase Time (32KB) | tBE₁ | | | 170 | 800 | ms | | Block Erase Time (64KB) | tBE <sub>2</sub> | | | 220 | 2,000 | ms | | Chip Erase Time | tce | | | 120 | 400 | s | #### Notes: - 1. Clock high + Clock low must be less than or equal to Pc. Pc = 1/fc(max.) - 2. Value guaranteed by design and/or characterization, not 100% tested in production. - 3. Only applicable as a constraint for a Write Status Register instruction when SRP=1 - 5.It's possible to reset the device with shorter tRESET (as short as a few hundred ns), a 1us minimum is recommended to ensure reliable operation. - 6.4-bytes address alignment for read: read address start from A1,A0=0,0 # 8.7 Serial Output Timing ## 8.8 Serial Input Timing ### 9. PACKAGE SPECIFICATIONS ### 9.1 8-Pad WSON 8x6-mm (Package Code E) | Cumbal | | Millimeters | | Inches | | | |--------|------|-------------|-------|--------|-----------|-------| | Symbol | Min | Nom | Max | Min | Nom | Max | | Α | 0.70 | 0.75 | 0.80 | 0.028 | 0.030 | 0.031 | | A1 | 0.00 | 0.02 | 0.05 | 0.000 | 0.001 | 0.002 | | b | 0.35 | 0.40 | 0.48 | 0.014 | 0.016 | 0.019 | | С | | 0.20 REF | | | 0.008 REF | | | D | 7.90 | 8.00 | 8.10 | 0.311 | 0.315 | 0.319 | | D2 | 3.35 | 3.40 | 3.45 | 0.132 | 0.134 | 0.136 | | E | 5.90 | 6.00 | 6.10 | 0.232 | 0.236 | 0.240 | | E2 | 4.25 | 4.30 | 4.35 | 0.167 | 0.169 | 0.171 | | е | | 1.27 | | | 0.050 | | | L | 0.45 | 0.50 | 0.55 | 0.018 | 0.020 | 0.022 | | У | 0.00 | | 0.050 | 0.000 | | 0.002 | Note:The metal pad area on the bottom center of the package is not connected to any internal electrical signals. It can be left floating or connected to the device ground (GND pin). Avoid placement of exposed # 9.2 16-Pin SOIC 300-mil (Package Code F) | Symbol | Millimeters | | | Inches | | | |--------|-------------|-------|-------|-----------|-------|-------| | | Min | Nom | Max | Min | Nom | Max | | Α | 2.36 | 2.49 | 2.64 | 0.093 | 0.098 | 0.104 | | A1 | 0.10 | | 0.30 | 0.004 | | 0.012 | | A2 | | 2.31 | | | 0.091 | | | b | 0.33 | 0.41 | 0.51 | 0.013 | 0.016 | 0.020 | | С | 0.18 | 0.23 | 0.28 | 0.007 | 0.009 | 0.011 | | D | 10.08 | 10.31 | 10.49 | 0.397 | 0.406 | 0.413 | | E | 10.01 | 10.31 | 10.64 | 0.394 | 0.406 | 0.419 | | E1 | 7.39 | 7.49 | 7.59 | 0.291 | 0.295 | 0.299 | | е | 1.27 BSC | | | 0.050 BSC | | | | L | 0.38 | 0.81 | 1.27 | 0.015 | 0.032 | 0.050 | | у | | | 0.076 | | | 0.003 | | θ | 0° | | 8° | 0° | | 8° | ### 10. ORDERING INFORMATION ### Notes: - 1. The "W" prefix and the Temperature designator "I" are not included on the part marking. - 2. Standard bulk shipments are in Tube (shape E). Please specify alternate packing method, such as Tape and Reel (shape T) or Tray (shape S), when placing orders. - 3. For shipments with OTP enabled feature, please contact Winbond. # 10.1 Valid Part Numbers and Top Side Marking The following table provides the valid part numbers for the W25R512NW/W74M51NW SpiFlash Memory. Please contact Winbond for specific availability by density and package type. Winbond SpiFlash memories use a 12-digit Product Number for ordering. However, due to limited space, the Top Side Marking on all packages uses an abbreviated 10-digit number. | PACKAGE TYPE | DENSITY | PRODUCT NUMBER | TOP SIDE MARKING | |--------------------------|----------|----------------|------------------| | <b>E</b><br>WSON-8 8x6mm | 512M-bit | W25R512NWEIQ | 25R512NWEQ | | PACKAGE TYPE | DENSITY | PRODUCT NUMBER | TOP SIDE MARKING | |--------------------------|----------|----------------|------------------| | <b>E</b><br>WSON-8 8x6mm | 512M-bit | W74M51NWZEIQ | 74M51NWEIQ | ### 11. REVISION AISTORY | VERSION | DATE | PAGE | DESCRIPTION | |---------|-------------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | А | 08/17/2020<br>~<br>03/26/2021 | 87<br>95-96<br>88<br>90<br>91<br>95 | New Create Preliminary Updated power-up timing Added W74M part no Updated ICC1-3 Updated BBh/BCh frequency Updated t(typ.) Updated Ordering information | | В | 09/30/2021 | 90,91 | Removed Preliminary Updated BB/BC clock read and note 6 | | C1 | 06/14/2022 | 89<br>90 | Added Note. 2 for AC measurement condition Updated tDVCH, tCHDX, tCLQV, tCLQX | ### **Trademarks** Winbond and SpiFlash are trademarks of Winbond Electronics Corporation. All other marks are the property of their respective owner. ### **Important Notice** Winbond products are not designed, intended, authorized or warranted for use as components in systems or equipment intended for surgical implantation, atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, or for other applications intended to support or sustain life. Furthermore, Winbond products are not intended for applications wherein failure of Winbond products could result or lead to a situation wherein personal injury, death or severe property or environmental damage could occur. Winbond customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Winbond for any damages resulting from such improper use or sales. Information in this document is provided solely in connection with Winbond products. Winbond reserves the right to make changes, corrections, modifications or improvements to this document and the products and services described herein at any time, without notice. Please note that all data and specifications are subject to change without notice. All the trademarks of products and companies mentioned in this datasheet belong to their respective owners.