# XT25F128F-W # Quad IO Serial NOR Flash Datasheet \* Information furnished is believed to be accurate and reliable. However, XTX Technology Inc. assumes no responsibility for the consequences of use of such information or for any infringement of patents of other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent rights of XTX Technology Inc. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied. XTX Technology Inc. products are not authorized for use as critical components in life support devices or systems without express written approval of XTX Technology Inc. The XTX logo is a registered trademark of XTX Technology Inc. All other names are the property of their respective own. # **Serial NOR Flash Memory** # 3.3V Multi I/O with 4KB, 32KB & 64KB Sector/Block Erase #### ■ 128M -bit Serial Flash - 16, 384K-byte - 256 bytes per programmable page #### ■ Standard, Dual, Quad SPI, DTR - Standard SPI: SCLK, CS#, SI, SO, WP#, HOLD#/RESET# - Dual SPI: SCLK, CS#, IOO, IO1, WP#, HOLD#/RESET# - Quad SPI: SCLK, CS#, IO0, IO1, IO2, IO3 - SPI DTR(Double Transfer Rate) Read #### ■ Flexible Architecture - Sector of 4K-bytes - Block of 32/64k-bytes #### Advanced Security Features - 3\*1024-Bytes Security Registers With OTP Lock - Support 128 bits Unique ID #### ■ Software/Hardware Write Protection - Write protect all/portion of memory via software - Enable/Disable protection with WP# Pin - Top or Bottom, Sector or Block selection ## ■ Continuous Read With 8/16/32/64-byte Wrap ## **■** Erase/Program Suspend/Resume ## Package Options - See 1.1 Available Ordering OPN - All Pb-free packages are compliant RoHS, Halogen-Free and REACH. #### Temperature Range & Moisture Sensitivity Level • Industrial Level Temperature. (-40 $^{\circ}$ C to +85 $^{\circ}$ C), MSL3 #### Power Consumption - 8mA typical read current under 80MHz - 0.5uA typical Deep Power-Down current #### ■ Single Power Supply Voltage 2.7~3.6V #### ■ Endurance and Data Retention - Minimum 100,000 Program/Erase Cycle - 20-year Data Retention typical #### ■ High Speed Clock Frequency - 133MHz for fast read with 30PF load - Dual I/O Data transfer up to 266Mbits/s - Quad I/O Data transfer up to 532Mbits/s - DTR Quad I/O Data transfer up to 832Mbits/s #### ■ Program/Erase Speed Page Program time: 0.4ms typical • Sector Erase time: 40ms typical Block Erase time: 0.15/0.25s typical Chip Erase time: 30s typical # **CONTENTS** | 1. | GENERAL DESCRIPTION | 4 | | | | | | |------|--------------------------------------------|--------------------|--|--|--|--|--| | 1.1. | . Available Ordering OPN | 4 | | | | | | | 1.2. | . Connection Diagram | 4 | | | | | | | 1.3. | . Pin Description | 5 | | | | | | | 1.4. | . Block Diagram | 5 | | | | | | | 1.5. | . Memory Description | Nemory Description | | | | | | | 2. | DEVICE OPERATION | 7 | | | | | | | 2.1. | . SPI Mode | 7 | | | | | | | 2.2. | . DTR Read | 7 | | | | | | | 2.3. | . Hold Function | 7 | | | | | | | 2.4. | . RESET Function | 8 | | | | | | | 2.5. | . The Reset Signaling Protocol (JEDEC 252) | 9 | | | | | | | 3. | STATUS REGISTER | 10 | | | | | | | 4. | DATA PROTECTION | 13 | | | | | | | 5. | COMMANDS DESCRIPTION | 16 | | | | | | | 5.1. | . Register Access | 19 | | | | | | | 5.2. | . Array access | 25 | | | | | | | 5.3. | . Device Operations | 41 | | | | | | | | . One-Time Programmable (OTP) Operations | | | | | | | | 5.5. | . Advanced Data Protection | 50 | | | | | | | 6. | ELECTRICAL CHARACTERISTICS | 52 | | | | | | | 6.1. | . Power-on Timing | 52 | | | | | | | 6.2. | . Initial Delivery State | 52 | | | | | | | 6.3. | . Absolute Maximum Ratings | 53 | | | | | | | 6.4. | . Capacitance Measurement Condition | 53 | | | | | | | 6.5. | . DC Characteristics | 54 | | | | | | | 6.6. | . AC Characteristics | 55 | | | | | | | 7. | ORDERING INFORMATION | 58 | | | | | | | 8. | PACKAGE INFORMATION | 59 | | | | | | | 8.1. | . Package SOP8 208mil | 59 | | | | | | | 8.2. | . Package WSON8 6x5mm | 60 | | | | | | | a | DEVISION HISTORY | 61 | | | | | | # 1. GENERAL DESCRIPTION The XT25F128F-W (128M-bit) Serial flash supports standard Serial Peripheral Interface (SPI), Dual/Quad SPI: Serial Clock, Chip Select, Serial Data I/O0 (SI), I/O1 (SO), I/O2 (WP#), and I/O3 (HOLD#/RESET#). # 1.1. Available Ordering OPN | OPN | Package Type | Package Carrier | |------------------|--------------|-----------------| | XT25F128FSSIGU-W | SOP8 208mil | Tube | | XT25F128FWOIGT-W | WSON8 6x5mm | Tape & Reel | | XT25F128FWOIGA-W | WSON8 6x5mm | Tray | # 1.2. Connection Diagram Rev 0.6 Feb/26/2022 Page 4 # 1.3. Pin Description | Pin Name | I/O | Description | |--------------------|-----|-------------------------------------------| | CS# | I | Chip Select Input | | SO (IO1) | I/O | Data Output (Data Input Output 1) | | WP# (IO2) | I/O | Write Protect Input (Data Input Output 2) | | VSS | | Ground | | SI (IO0) | I/O | Data Input (Data Input Output 0) | | SCLK | I | Serial Clock Input | | HOLD#/RESET# (IO3) | I/O | Hold or Reset Input (Data Input Output 3) | | vcc | | Power Supply | #### Notes: - 1. IOO and IO1 are used for Standard and Dual SPI instructions - 2. IOO IO3 are used for Quad SPI instructions, WP# & HOLD# (or RESET#) functions are only available for Standard/Dual SPI. # 1.4. Block Diagram # 1.5. Memory Description # **Uniform Block Sector Architecture** | Block(64K-byte) | Block(32K-byte) | Sector(4K-byte) | Address | Range | |-----------------|-----------------|-----------------|---------|---------| | | | 4095 | FFF000H | FFFFFFH | | | 511 | | | | | | | 4088 | FF8000H | FF8FFFH | | 255 | | 4087 | FF7000H | FF7FFFH | | | 510 | | | | | | | 4080 | FF0000H | FFOFFFH | | | | 4079 | FEF000H | FEFFFFH | | | 509 | | | | | 25.4 | | 4072 | FE8000H | FE8FFFH | | 254 | | 4071 | FE7000H | FE7FFFH | | | 508 | | | | | | | 4064 | FE0000H | FEOFFFH | | | | | | | | | | | | | | | | | | | | | | 31 | 01F000H | 01FFFFH | | | 3 | | | | | 1 | | 24 | 018000H | 018FFFH | | 1 | | 23 | 017000H | 017FFFH | | | 2 | | | | | | | 16 | 010000H | 010FFFH | | | | 15 | 00F000H | 00FFFFH | | | 1 | | | | | 0 | | 8 | 008000Н | 008FFFH | | U | | 7 | 007000H | 007FFFH | | | 0 | | | | | | | 0 | 000000Н | 000FFFH | # 2. DEVICE OPERATION ## 2.1. SPI Mode #### **Standard SPI** The device features a serial peripheral interface on 4 signals bus: Serial Clock (SCLK), Chip Select (CS#), Serial Data Input (SI) and Serial Data Output (SO). Both SPI bus mode 0 and 3 are supported. Input data is latched on the rising edge of SCLK and data shifts out on the falling edge of SCLK. #### **Dual SPI** The device supports Dual SPI operation when using the "Dual Output Fast Read" and "Dual I/O Fast Read" (3BH and BBH) commands. These commands allow data to be transferred to or from the device at two times the rate of the standard SPI. When using the Dual SPI command the SI and SO pins become bidirectional I/O pins: IOO and IO1. #### **Quad SPI** The device supports Quad SPI operation when using the "Quad Output Fast Read", "Quad I/O Fast Read", "DTR Fast Read Quad I/O" (6BH, EBH, EDH) commands. These commands allow data to be transferred to or from the device at four times the rate of the standard SPI. When using the Quad SPI command the SI and SO pins become bidirectional I/O pins: IOO and IO1, and WP# and HOLD#/RESET# pins become IO2 and IO3. Quad SPI commands require the non-volatile Quad Enable bit (QE) in Status Register to be set. ### 2.2. DTR Read To effectively improve the read operation throughput without increasing the serial clock frequency, the device introduces multiple DTR (Double Transfer Rate) Read instructions that support Standard/Dual/Quad SPI mode. The byte-long instruction code is still latched into the device on the rising edge of the serial clock similar to all other SPI instructions. Once a DTR instruction code is accepted by the device, the address input and data output will be latched on both rising and falling edges of the serial clock. #### 2.3. Hold Function The HOLD# signal goes low to stop any serial communications with the device, but doesn't stop the opertion of write status register, programming, or erasing in progress. The operation of Hold, need CS# keep low, and starts on falling edge of the HOLD# signal, with SCLK signal being low (if SCLK is not being low, Hold operation will not start until SCLK being low). The Hold condition ends on rising edge of HOLD# signal with SCLK being low (If SCLK is not being low, Hold operation will not end until SCLK being low). The SO is high impedance, both SI and SCLK don't care during the Hold operation, if CS# drives high during Hold operation, it will reset the internal logic of the device. To re-start communication with chip, the HOLD# must be at high and then CS# must be at low. # 2.4. RESET Function The RESET# pin allows the device to be reset by the control. The pin 7 can be configured as a RESET# pin depending on the status register setting, which need QE=0 and HOLD/RST=1. The RESET# pin goes low for a period of tRLRH or longer will reset the flash. After reset cycle, the flash is at the following states: - Standby mode. - All the volatile bits will return to the default status as power on. | Symbol | Parameter | Min | Тур | Max | Unit. | |--------|-----------------------------|-----|-----|-----|-------| | tRLRH | Reset Pulse Width | 1 | | | us | | tRHSL | Reset High Time Before Read | 50 | | | us | | tRB | Reset Recovery Time | | | 12 | ms | # 2.5. The Reset Signaling Protocol (JEDEC 252) The protocol consists of two phases: reset request, and completion (a device internal reset). #### **Reset Request** - 1. CS# is driven active low to select the SPI slave $^{\text{Note 1}}$ . - 2. Clock (SCK) remains stable in either a high or low state Note 2. - 3. SI / IOO is driven low by the bus master, simultaneously with CS# going active low Note 3. - 4. CS# is driven inactive Note 4. Repeat the steps 1-4 each time alternating the state of SI<sup>Note 5</sup>. #### Note: - 1. This powers up the SPI slave. - 2. This prevents any confusion with a command, as no command bits are transferred (clocked). - 3. No SPI bus slave drives SI during CS# low before a transition of SCK, i.e., slave streaming output active is not allowed until after the first edge of SCK. - 4. The slave captures the state of SI on the rising edge of CS#. - 5. SI is low on the first CS#, high on the second, low on the third, high on the fourth. #### **Reset Completion** After the fourth CS# pulse, the slave triggers its internal reset. #### **Timing Diagram and Timing Parameters** #### **Reset Signaling Protocol** # 3. STATUS REGISTER #### Status Register-1 | <b>S7</b> | S6 | <b>S</b> 5 | <b>S4</b> | S3 | S2 | <b>S1</b> | S0 | |--------------------------------------|----------------------|----------------------|----------------------|----------------------|----------------------|-----------------------|----------------------------| | SRP0 | BP4 | BP3 | BP2 | BP1 | BP0 | WEL | WIP | | Status<br>Register<br>Protection Bit | Block<br>Protect Bit | Block<br>Protect Bit | Block<br>Protect Bit | Block<br>Protect Bit | Block<br>Protect Bit | Write Enable<br>Latch | Erase/Write In<br>Progress | | Non-volatile | Non-volatile | Non-volatile | Non-volatile | Non-volatile | Non-volatile | Volatile<br>Read Only | Volatile<br>Read Only | #### Status Register-2 | S15 | S14 | S13 | S12 | S11 | S10 | <b>S9</b> | <b>S8</b> | |------------------------|---------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------|--------------|--------------------------------------| | SUS1 | CMP | LB3 | LB2 | LB1 | SUS2 | QE | SRP1 | | Erase<br>Suspend | Complement<br>Protect Bit | Security<br>Register Lock<br>Bit | Security<br>Register Lock<br>Bit | Security<br>Register Lock<br>Bit | Program<br>Suspend | Quad Enable | Status<br>Register<br>Protection Bit | | Volatile,<br>Read Only | Non-volatile | Non-volatile<br>Writable<br>(OTP) | Non-volatile<br>Writable<br>(OTP) | Non-volatile<br>Writable<br>(OTP) | Volatile<br>Read Only | Non-volatile | Non-volatile | #### **Status Register-3** | S23 | S22 | S21 | S20 | S19 | S18 | S17 | <b>S16</b> | |--------------------------------|------------------------------|------------------------------|----------|----------|----------------------------------|---------------------------------|---------------------------------| | Hold/RST | DRV1 | DRV0 | Reserved | Reserved | WPS | DC1 | DC0 | | HOLD# or<br>RESET#<br>Function | Output<br>Driver<br>Strength | Output<br>Driver<br>Strength | Reserved | Reserved | Write<br>Protection<br>Selection | Dummy<br>Configuration<br>Bit 1 | Dummy<br>Configuration<br>Bit 0 | | Non-volatile | Non-volatile | Non-volatile | Reserved | Reserved | Non-volatile | Non-volatile<br>Writable | Non-volatile<br>Writable | ## **HOLD/RST** The HOLD/RST bit is used to determine whether HOLD# or RESET# function should be implemented on the hardware pin for 8-pin packages. When HOLD/RST=0, the pin acts as HOLD#, When the HOLD/RST=1, the pin acts as RESET#. However, the HOLD# or RESET# function are only available when QE=0, If QE=1, The HOLD# and RESET# functions are disabled, the pin acts as dedicated data I/O pin. # DRV1, DRV0 The Output Driver Strength (DRV1 & DRV0) bits are used to determine the output driver strength for the Read operations. | DRV1 | DRV0 | Driver Strength | |------|------|-----------------| | 0 | 0 | 25% | | 0 | 1 | 50% | | 1 | 0 | 75% (Default) | | 1 | 1 | 100% | #### **WPS** 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, BP (4: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. #### DC1, DC0 The Dummy Configuration Bits (DC1, DC0) select the mode and number of Dummy cycles between the end of address and the start of read data output for command BBH, EBH and EDH under SPI mode. Dummy cycles provide additional latency that is needed to complete the initial read access of the flash array before data can be returned to the host system. Some read commands require additional latency cycles as the SCLK frequency is increased. **Latency Code and DTR Mode Frequency Table** | DC0 | Dual I/O Fast Read<br>BBH | Quad I/O Fast Read<br>EBH | |-------------|---------------------------|---------------------------| | 0 (Default) | 4 Dummy (104MHz) | 6 Dummy (104MHz) | | 1 | 8 Dummy (133MHz) Note 1 | 10 Dummy (133MHz) Note 1 | | DC1 | DTR Fast Read Quad I/O<br>EDH | | |-------------|-------------------------------|--| | 0 (Default) | 8 Dummy (104MHz) | | | 1 | 6 Dummy (84MHz) | | Note 1: The SCLK frequency for BBH and EBH is 133MHz under 3.0-3.6V power supply. #### SUS1, SUS2 The SUS1 and SUS2 bits are read only bits in the status register (S15 and S10) that are set to 1 after executing an Program/Erase Suspend (75H) command (The Erase Suspend will set the SUS1 to 1, and the Program Suspend will set the SUS2 to 1). The SUS1 and SUS2 bits are cleared to 0 by Program/Erase Resume (7AH) command, software reset (66H+99H) command as well as a power-down, power-up cycle. #### **CMP** The CMP bit is a non-volatile Read/Write bit in the Status Register (S14). It is used in conjunction the BP4-BP0 bits to provide more flexibility for the array protection. Please see the Status register Memory Protection table for details. The default setting is CMP=0. #### LB1, LB2, LB3 The LB1, LB12, LB3 bits are non-volatile One Time Program (OTP) bits in Status Register (S11-S13) that provide the write protect control and status to the Security Registers. The default state of LB1-LB3 are 0, the security registers are unlocked. The LB1-LB3 bits can be set to 1 individually using the Write Register instruction. The LB1-LB3 bits are One Time Programmable, once its set to 1, the Security Registers will become read-only permanently. #### QE The Quad Enable (QE) bit is a non-volatile Read/Write bit in the Status Register that allows Quad operation. When the QE bit is set to 0 (Default) the WP# pin and HOLD#/RESET# pin are enable. When the QE pin is set to 1, the Quad IO2 and IO3 pins are enabled. #### SRP1, SRP0 The Status Register Protect (SRP1 and SRP0) bits are non-volatile Read/Write bits in the status register. The SRP bits control the type of write protection: software protection, hardware protection, power supply lock-down or one-time programmable protection. | SRP1 | SRP0 | WP# | Status Register | Description | |------|------|-----|------------------------|---------------------------------------------------------------------------------------------------------------| | 0 | 0 | Х | Software Protected | The Status Register can be written to after a Write Enable command, WEL=1. (Default) | | 0 | 1 | 0 | Hardware Protected | WP#=0, the Status Register locked and cannot be written to. | | 0 | 1 | 1 | Hardware Unprotected | WP#=1, the Status Register is unlocked and can be written to after a Write Enable command, WEL=1. | | 1 | 0 | Х | Power Supply Lock-Down | Status Register is protected and cannot be written to again until the next Power-Down, Power-Up cycle. Note 1 | | 1 | 1 | Х | One-Time Program | Status Register is protected and cannot be written to. Note 2 | #### Note: - 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 on special order. Please contact XTX for details. #### BP4, BP3, BP2, BP1, BP0 The Block Protect (BP4, BP3, BP2, BP1, BP0) bits are non-volatile. They define the size of the area to be software protected against Program and Erase commands. These bits are written with the Write Status Register (WRSR) command. When the Block Protect (BP4, BP3, BP2, BP1, BP0) bits are set to 1, the relevant memory area (as defined in Table1) becomes protected against Page Program (PP), Sector Erase (SE) and Block Erase (BE) commands. The Block Protect(BP4, BP3, BP2, BP1, BP0) bits can be written provided that the Hardware Protected mode has not been set. The Chip Erase (CE) command is executed if the Block Protect (BP2, BP1, BP0) bits are 0 and CMP=0 or the Block Protect (BP2, BP1, BP0) bits are 1 and CMP=1. #### WEL The Write Enable Latch (WEL) bit indicates the status of the internal Write Enable Latch. When set to 1 the internal Write Enable Latch is set, when set to 0 the internal Write Enable Latch is reset and no Write Status Register, Program or Erase command is accepted. #### **WIP** The Write In Progress (WIP) bit indicates whether the memory is busy in program/erase/write status register progress. When WIP bit sets to 1, means the device is busy in program/erase/write status register progress, when WIP bit sets 0, means the device is not in program/erase/write status register progress. # 4. DATA PROTECTION The device provide the following data protection methods: - Write Enable (WREN) command: The WREN command sets the Write Enable Latch bit (WEL). The WEL bit will return to reset by the following situation: - Power-Up / Software Reset (66H+99H) - Write Disable (WRDI) - Write Status Register (WRSR) - Page Program (PP) - Sector Erase (SE) / Block Erase (BE) / Chip Erase (CE) - Erase Security Register / Program Security Register - Software Protection Mode: The Block Protect (BP4, BP3, BP2, BP1, BP0) bits, WPS bit and CMP bit define the section of the memory array that can be read but cannot be changed. - Hardware Protection Mode: WP# goes low to prevent writing status register. - Deep Power-Down Mode: In Deep Power-Down Mode, all commands are ignored except the Release from Deep Power-Down Mode command (ABH) and software reset (66H+99H). Table 1.0 XT25F128F-W Protected area size (WPS=0, CMP=0) | Status Register Content | | | | | Memory Content | | | | | | |-------------------------|-----|-----|-----|-----|----------------------------------|--------------------------|-------|--------------|--|--| | BP4 | BP3 | BP2 | BP1 | BP0 | Blocks | Blocks Addresses Density | | Portion | | | | Х | Х | 0 | 0 | 0 | NONE | NONE | NONE | NONE | | | | 0 | 0 | 0 | 0 | 1 | 252 to 255 FC0000H-FFFFFFH 256KB | | 256KB | Upper 1/64 | | | | 0 | 0 | 0 | 1 | 0 | 248 to 255 | F80000H-FFFFFFH | 512KB | Upper 1/32 | | | | 0 | 0 | 0 | 1 | 1 | 240 to 255 | F00000H-FFFFFFH | 1MB | Upper 1/16 | | | | 0 | 0 | 1 | 0 | 0 | 224 to 255 | E00000H-FFFFFFH | 2MB | Upper 1/8 | | | | 0 | 0 | 1 | 0 | 1 | 192 to 255 | C00000H-FFFFFFH | 4MB | Upper 1/4 | | | | 0 | 0 | 1 | 1 | 0 | 128 to 255 | 800000H-FFFFFFH | 8MB | Upper 1/2 | | | | 0 | 1 | 0 | 0 | 1 | 0 to 3 | 000000H-03FFFFH | 256KB | Lower 1/64 | | | | 0 | 1 | 0 | 1 | 0 | 0 to 7 | 000000H-07FFFFH | 512KB | Lower 1/32 | | | | 0 | 1 | 0 | 1 | 1 | 0 to 15 | 000000H-0FFFFFH | 1MB | Lower 1/16 | | | | 0 | 1 | 1 | 0 | 0 | 0 to 31 | 000000H-1FFFFFH | 2MB | Lower 1/8 | | | | 0 | 1 | 1 | 0 | 1 | 0 to 63 | 000000H-3FFFFFH | 4MB | Lower 1/4 | | | | 0 | 1 | 1 | 1 | 0 | 0 to 127 | 000000H-7FFFFFH | 8MB | Lower 1/2 | | | | Х | Х | 1 | 1 | 1 | 0 to 255 | 000000H-FFFFFFH | 16MB | ALL | | | | 1 | 0 | 0 | 0 | 1 | 255 | FFF000H-FFFFFFH | 4KB | Top Block | | | | 1 | 0 | 0 | 1 | 0 | 255 | FFE000H-FFFFFFH | 8KB | Top Block | | | | 1 | 0 | 0 | 1 | 1 | 255 | FFC000H-FFFFFFH | 16KB | Top Block | | | | 1 | 0 | 1 | 0 | Χ | 255 | FF8000H-FFFFFFH | 32KB | Top Block | | | | 1 | 0 | 1 | 1 | 0 | 255 | FF8000H-FFFFFFH | 32KB | Top Block | | | | 1 | 1 | 0 | 0 | 1 | 0 | 000000H-000FFFH | 4KB | Bottom Block | | | | 1 | 1 | 0 | 1 | 0 | 0 | 000000H-001FFFH | 8KB | Bottom Block | | | | 1 | 1 | 0 | 1 | 1 | 0 | 000000H-003FFFH | 16KB | Bottom Block | | | | 1 | 1 | 1 | 0 | Х | 0 | 000000H-007FFFH | 32KB | Bottom Block | | | | 1 | 1 | 1 | 1 | 0 | 0 | 000000H-007FFFH | 32KB | Bottom Block | | | # Table1.1 XT25F128F-W Protected area size (WPS=0, CMP=1) | | Status F | Register | Content | : | Memory Content | | | | | | |-----|----------|----------|---------|-----|----------------|------------------|---------|-------------|--|--| | BP4 | BP3 | BP2 | BP1 | BP0 | Blocks | Blocks Addresses | | Portion | | | | Х | Х | 0 | 0 | 0 | 0 to 255 | 000000H-FFFFFFH | ALL | ALL | | | | 0 | 0 | 0 | 0 | 1 | 0 to 251 | 000000H-FBFFFFH | 16128KB | Lower 63/64 | | | | 0 | 0 | 0 | 1 | 0 | 0 to 247 | 000000H-F7FFFFH | 15872KB | Lower 31/32 | | | | 0 | 0 | 0 | 1 | 1 | 0 to 239 | 000000H-EFFFFFH | 15MB | Lower 15/16 | | | | 0 | 0 | 1 | 0 | 0 | 0 to 223 | 000000H-DFFFFFH | 14MB | Lower 7/8 | | | | 0 | 0 | 1 | 0 | 1 | 0 to 191 | 000000H-BFFFFFH | 12MB | Lower 3/4 | | | | 0 | 0 | 1 | 1 | 0 | 0 to 127 | 000000H-7FFFFH | 8MB | Lower 1/2 | | | | 0 | 1 | 0 | 0 | 1 | 4 to 255 | 040000H-FFFFFFH | 16128KB | Upper 63/64 | | | | 0 | 1 | 0 | 1 | 0 | 8 to 255 | 080000H-FFFFFFH | 15872KB | Upper 31/32 | | | | 0 | 1 | 0 | 1 | 1 | 16 to 255 | 100000H-FFFFFFH | 15MB | Upper 15/16 | | | | 0 | 1 | 1 | 0 | 0 | 32 to 255 | 200000H-FFFFFFH | 14MB | Upper 7/8 | | | | 0 | 1 | 1 | 0 | 1 | 64 to 255 | 400000H-FFFFFFH | 12MB | Upper 3/4 | | | | 0 | 1 | 1 | 1 | 0 | 128 to 255 | 800000H-FFFFFFH | 8MB | Upper 1/2 | | | | Х | Х | 1 | 1 | 1 | NONE | NONE | NONE | NONE | | | | 1 | 0 | 0 | 0 | 1 | 0 to 255 | 000000H-FFEFFFH | 16380KB | L-4095/4096 | | | | 1 | 0 | 0 | 1 | 0 | 0 to 255 | 000000H-FFDFFFH | 16376KB | L-2047/2048 | | | | 1 | 0 | 0 | 1 | 1 | 0 to 255 | 000000H-FFBFFFH | 16368KB | L-1023/1024 | | | | 1 | 0 | 1 | 0 | Х | 0 to 255 | 000000H-FF7FFFH | 16352KB | L-511/512 | | | | 1 | 0 | 1 | 1 | 0 | 0 to 255 | 000000H-FF7FFFH | 16352KB | L-511/512 | | | | 1 | 1 | 0 | 0 | 1 | 0 to 255 | 001000H-FFFFFFH | 16380KB | U-4095/4096 | | | | 1 | 1 | 0 | 1 | 0 | 0 to 255 | 002000H-FFFFFFH | 16376KB | U-2047/2048 | | | | 1 | 1 | 0 | 1 | 1 | 0 to 255 | 004000H-FFFFFFH | 16368KB | U-1023/1024 | | | | 1 | 1 | 1 | 0 | Х | 0 to 255 | 008000H-FFFFFFH | 16352KB | U-511/512 | | | | 1 | 1 | 1 | 1 | 0 | 0 to 255 | 008000H-FFFFFFH | 16352KB | U-511/512 | | | #### Table1.2 XT25F128F-W Individual Block Protection (WPS=1) | Block | Sector | Addre | Individual Block Lock Operation | | |-------|--------|---------|---------------------------------|---------------------------| | | 4095 | FFF000H | FFFFFFH | The Top/Bottom block | | 255 | | | | is protected by sector. | | | 4080 | FF0000H | FFOFFFH | Other 254 Blocks are | | | | | | protected by block | | | | | | Block Lock: | | | | | | 36H+Address | | | | | | Block Unlock: 39H+Address | | 2 | | | | Read Block Lock: | | 1 | | | | 3DH+Address | | 1 | | | | Global Block Lock: 7EH | | | 15 | 00F000Н | 00FFFFH | Global Block Unlock: | | 0 | | | | 98H | | | 0 | 000000Н | 000FFFH | | # 5. COMMANDS DESCRIPTION All commands, addresses and data are shifted in and out of the device, beginning with the most significant bit on the first rising edge of SCLK after CS# is driven low. Then, the one-byte command code must be shifted in to the device, most significant bit first on SI, each bit being latched on the rising edges of SCLK. See Table 2, every command sequence starts with a one-byte command code. Depending on the command, this might be followed by address bytes, or by data bytes, or by both or none. CS# must be driven high after the last bit of the command sequence has been shifted in. For the command of Read, Fast Read, Read Status Register or Release from Deep Power-Down, and Read Device ID, the shifted-in command sequence is followed by a data-out sequence. CS# can be driven high after any bit of the data-out sequence is being shifted out. For the command of Page Program, Sector Erase, Block Erase, Chip Erase, Write Status Register, Write Enable or Write Disable command, CS# must be driven high exactly at the byte boundary, otherwise the command is rejected, and is not executed. That is CS# must be driven high when the number of clock pulses after CS# being driven low is an exact multiple of eight. For Page Program, if at any time the input byte is not a full byte, nothing will happen and WEL will not be reset. **Table 2 Commands** | <b>Command Name</b> | Command | SPI | | Ad | dress Byte | | | Dummy | Data | |-------------------------------------------|---------|-----|-------------------|-------|------------|-------|-------|------------------------|--------| | | Code | | Total<br>ADD Byte | Byte1 | Byte2 | Byte3 | Byte4 | Cycle | Byte | | Register Access | | | | | | | | | | | Read Status Register_1 | 05H | ٧ | 0 | | | | | 0 | 1 to ∞ | | Read Status Register_2 | 35H | ٧ | 0 | | | | | 0 | 1 to ∞ | | Read Status Register_3 | 15H | ٧ | 0 | | | | | 0 | 1 to ∞ | | Write Status Register_1 | 01H | ٧ | 0 | | | | | 0 | 1 or 2 | | Write Status Register_2 | 31H | ٧ | 0 | | | | | 0 | 1 | | Write Status Register_3 | 11H | ٧ | 0 | | | | | 0 | 1 | | Manufacturer/Device<br>ID | 90H | ٧ | 3 | 00 | 00 | 00 | | 0 | 1 to ∞ | | Read Serial Flash Discoverable Parameters | 5AH | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 8 | 1 to ∞ | | Read Unique ID | 4BH | ٧ | 0 | | | | | 32 <sup>Note1</sup> | 1 to ∞ | | Read Identification | 9FH | ٧ | 0 | | | | | 0 | 1 to ∞ | | Array access | | | | | | | | | l | | Read Data | 03H | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 0 | 1 to ∞ | | Fast Read | OBH | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 8 | 1 to ∞ | | Dual Output Fast Read | 3BH | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 8 | 1 to ∞ | | Dual I/O Fast Read | ВВН | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 4/8 <sup>Note2/3</sup> | 1 to ∞ | | Quad Output Fast Read | 6BH | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 8 | 1 to ∞ | | V V V V V V V | 3 3 3 3 3 3 0 0 0 0 0 | ADD1 ADD1 ADD1 ADD1 ADD1 ADD1 ADD1 ADD1 | ADD2 ADD2 ADD2 ADD2 ADD2 ADD2 ADD2 ADD2 | ADD3 ADD3 ADD3 ADD3 ADD3 ADD3 ADD3 ADD3 | 6 8/6 <sup>Note2/3</sup> 0 0 0 0 0 0 0 | 1 to ∞ 1 to ∞ 1 to ∞ 1 to ∞ 1 to ∞ 1 to ∞ 0 0 0 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | V V V V V V | 3<br>3<br>3<br>3<br>3<br>0 | ADD1 ADD1 ADD1 ADD1 ADD1 | ADD2 ADD2 ADD2 ADD2 ADD2 | ADD3 ADD3 ADD3 ADD3 ADD3 | 8/6 <sup>Note2/3</sup> 0 0 0 0 0 0 | 1 to ∞ 1 to 256 1 to 256 0 0 0 | | \frac{1}{V} \qquad \qquad \frac{1}{V} \qquad \qqqq | 3<br>3<br>3<br>3<br>0 | ADD1 ADD1 ADD1 ADD1 | ADD2 ADD2 ADD2 ADD2 | ADD3 ADD3 ADD3 ADD3 | 0<br>0<br>0<br>0<br>0 | 1 to 256 1 to 256 0 0 0 | | V V V V V | 3<br>3<br>3<br>0 | ADD1 ADD1 ADD1 | ADD2 ADD2 ADD2 | ADD3 ADD3 ADD3 | 0 0 0 0 | 256<br>1 to<br>256<br>0<br>0<br>0 | | V V V V V | 3<br>3<br>3<br>0 | ADD1 | ADD2 | ADD3 | 0 0 0 | 256<br>0<br>0<br>0<br>0 | | V V V V | 3<br>3<br>0 | ADD1 | ADD2 | ADD3 | 0 0 | 0 0 | | V V | 0 0 | | | | 0 | 0 | | V V | 0 0 | ADD1 | ADD2 | ADD3 | 0 | 0 | | V | 0 0 | | | | | | | ٧ | 0 | | | | 0 | 0 | | ٧ | 0 | | | | 0 | 0 | | | | | | | | | | ٧ | n | | | | 0 | 0 | | 1 | | | | | 0 | 0 | | ٧ | 0 | | | | 0 | 0 | | ٧ | 0 | | | | 0 | 0 | | ٧ | 0 | | | | 0 | 0 | | ٧ | 0 | | | | 0 | 0 | | ٧ | 0 | | | | 6 | 0 | | ٧ | 0 | | | | 0 | 0 | | ٧ | 0 | | | | 0 | 0 | | ٧ | 0 | | | | 24 | 0 | | erations | | | | | | | | ٧ | 3 | ADD1 | ADD2 | ADD3 | 0 | 0 | | ٧ | 3 | ADD1 | ADD2 | ADD3 | 0 | 1 to<br>256 | | ٧ | 3 | ADD1 | ADD2 | ADD3 | 8 | 1 to ∞ | | | v v v v v v v v v v v v v v v v v v v | v 0 0 v 0 0 v 0 v 0 v 0 v 0 v 0 v 0 v 0 | √ 0 √ 0 erations √ √ 3 ADD1 √ 3 ADD1 √ 3 ADD1 | √ 0 √ 0 erations √ 3 ADD1 ADD2 √ 3 ADD1 ADD2 √ 3 ADD1 ADD2 √ 3 ADD1 ADD2 | √ 0 √ 0 erations √ 3 ADD1 ADD2 ADD3 √ 3 ADD1 ADD2 ADD3 √ 3 ADD1 ADD2 ADD3 √ 3 ADD1 ADD2 ADD3 | √ 0 √ 0 24 erations √ 3 ADD1 ADD2 ADD3 0 √ 3 ADD1 ADD2 ADD3 0 | | 7EH | ٧ | 0 | | | | | 0 | 0 | |-----|-------------------|-------------------------|---------------------------|-----------------------------|---------------------------------------|-------------------------------------------------|-----|-----------------------------------------------------------------| | 98H | ٧ | 0 | | | | | 0 | 0 | | 36H | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 0 | 0 | | 39H | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 0 | 0 | | 3DH | ٧ | 3 | ADD1 | ADD2 | ADD3 | | 0 | 1 | | | 98H<br>36H<br>39H | 98H V<br>36H V<br>39H V | 98H V 0 36H V 3 39H V 3 | 98H V 0 3 ADD1 39H V 3 ADD1 | 98H V 0 3 ADD1 ADD2 39H V 3 ADD1 ADD2 | 98H V 0 3 ADD1 ADD2 ADD3 39H V 3 ADD1 ADD2 ADD3 | 98H | 98H V 0 0 0 0 36H V 3 ADD1 ADD2 ADD3 0 39H V 3 ADD1 ADD2 ADD3 0 | #### Note: - 1.For Read Unique ID(4BH), 32 Dummy includes 24bit Address - 2.M7-0 is counted for Dummy clocks. - 3. The number of Dummy clocks is configurable by Status Register DC bits. # **Table of ID Definitions:** # XT25F128F-W | Operation Code | MID7-MID0 | ID15-ID8 | ID7-ID0 | |----------------|-----------|----------|---------| | 9FH | OB | 40 | 18 | | 90H | OB | | 17 | | ABH | | | 17 | # **5.1.** Register Access # 5.1.1. Read Status Register (05H or 35H or 15H) The Read Status Register (RDSR) command is for reading the Status Register. The Status Register can be read at any time, even while a Program, Erase or Write Status Register cycle is in progress. When one of these cycles is in progress, it is recommended to check the Write In Progress (WIP) bit before sending a new command to the device. It is also possible to read the Status Register continuously. For command code "05H", the SO will output Status Register bits S7~S0. For the command code "35H", the SO will output Status Register bits S15~S8. For the command code "15H", the SO will output Status Register bits S23~S16. Figure 1. Read Status Register Sequence Diagram #### 5.1.2. Write Status Register (01H or 31H or 11H) The Write Status Register (WRSR) command allows new values to be written to the Status Register. Before it can be accepted, a Write Enable (WREN) command must previously have been executed. After the Write Enable (WREN) command has been decoded and executed, the device sets the Write Enable Latch (WEL). The Write Status Register (WRSR) command has no effect on the volatile bits of the Status Register. CS# must be driven high after the eighth bit or sixteenth bit of the data byte has been latched in. If not, the Write Status Register (WRSR) command is not executed. As soon as CS# is driven high, the self-timed Write Status Register cycle (whose duration is tW) is initiated. While the Write Status Register cycle is in progress, the Status Register may still be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Write Status Register cycle, and is 0 when it is completed. When the cycle is completed, the Write Enable Latch (WEL) is reset. The Write Status Register (WRSR) command allows the user to change the values of the Block Protect (BP4, BP3, BP2, BP1, BP0) bits, to define the size of the area that is to be treated as read-only, as defined in Table 1.0 & 1.1. The Write Status Register (WRSR) command also allows the user to set or reset the Status Register Protect (SRP) bit in accordance with the Write Protect (WP#) signal. The Status Register Protect (SRP) bit and Write Protect (WP#) signal allow the device to be put in the Hardware Protected Mode. The Write Status Register (WRSR) command is not executed once the Hardware Protected Mode is entered. For command code "01H", the SI will input Status Register bits S7~S0, S15~S8. For the command code "31H", the SI will input Status Register bits S23~S16. CS O 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 SCLK Command Status Register in O1H/31H/11H O1H/31H/11H O1H/31H/11H Figh-Z SO High-Z Figure 2. Write Status Register Sequence Diagram ## 5.1.3. Read Manufacture ID/ Device ID (90H) The Read Manufacturer/Device ID command is an alternative to the Release from Deep Power-Down and Read Device ID command that provides both the JEDEC assigned Manufacturer ID and the specific Device ID. The command is initiated by driving the CS# pin low and shifting the command code "90H" followed by a 24-bit address (A23-A0) of 000000H. After which, the Manufacturer ID and the Device ID are shifted out on the falling edge of SCLK with most significant bit (MSB) first is shown in Figure 3. If the 24-bit address is initially set to 000001H, the Device ID will be read first. Rev 0.6 Feb/26/2022 Page 21 #### 5.1.4. Read SFDP(5AH) The Serial Flash Discoverable Parameter (SFDP) standard provides a consistent method of describing the functional and feature capabilities of serial flash devices in a standard set of internal parameter tables. These parameter tables can be interrogated by host system software to enable adjustments needed to accommodate divergent features from multiple vendors. The concept is similar to the one found in the Introduction of JEDEC Standard, JESD68 on CFI. SFDP is a standard of JEDEC Standard No.216. Note: For SFDP Table, please contact XTX. **Note**: A23-A8 = 0, A7-A0 is the starting byte address for 256-byte SFDP Register. ## 5.1.5. Read Unique ID(4BH) The Read Unique ID command accesses a factory-set read-only 128bit number that is unique to each device. The Unique ID can be used in conjunction with user software methods to help prevent copying or cloning of a system. The Read Unique ID command sequence: CS# goes low $\rightarrow$ Sending Read Unique ID command $\rightarrow$ 4 Dummy bytes $\rightarrow$ 128bit Unique ID Out $\rightarrow$ CS# goes high. The command sequence is show below. #### 5.1.6. Read Identification (9FH) The Read Identification (RDID) command allows the 8-bit manufacturer identification to be read, followed by two bytes of device identification. The device identification indicates the memory type in the first byte, and the memory capacity of the device in the second byte. Any Read Identification (RDID) command while an Erase or Program cycle is in progress will not be decoded, and has no effect on the cycle that is in progress. The Read Identification (RDID) command should not be issued while the device is in Deep Power-Down Mode. The device is first selected by driving CS# to low. Then, the 8-bit command code for the command is shifted in. This is followed by the 24-bit manufacture identification and device identification, stored in the memory, being shifted out on Serial Data Output, each bit being shifted out during the falling edge of Serial Clock. The command sequence is shown in Figure 6. The Read Identification (RDID) command is terminated by driving CS# to high at any time during data output. When CS# is driven high, the device is put in the Standby Mode. Once in the Standby Mode, the device waits to be selected, so that it can receive, decode and execute commands. # 5.2. Array Access ## 5.2.1. Normal Read (03H) The Read Data Bytes (READ) command is followed by a 3-byte address (A23-A0), each bit being latched-in during the rising edge of SCLK. Then the memory content, at that address, is shifted out on SO, each bit being shifted out, at a Max frequency fR, during the falling edge of SCLK. The first byte addressed can be at any location. The address is automatically incremented to the next address after each byte of data is shifted out. The whole memory can, therefore, be read with a single Read Data Bytes (READ) command. Any Read Data Bytes (READ) command, while an Erase, Program or Write cycle is in progress, is rejected without having any effects on the cycle that is in progress. Rev 0.6 Feb/26/2022 Page 25 # 5.2.2. Fast Read (0BH) The Read Data Bytes at Higher Speed (Fast Read) command is for quickly reading data out. It is followed by a 3-byte address (A23-A0) and a Dummy byte, each bit being latched-in during the rising edge of SCLK. Then the memory content, at that address, is shifted out on SO, each bit being shifted out, at a Max frequency fC, during the falling edge of SCLK. The first byte addressed can be at any location. The address is automatically incremented to the next address after each byte of data is shifted out. Figure 8. Read Data By test Higher Speed Sequence Diagram ## 5.2.3. Dual Output Fast Read (3BH) The Dual Output Fast Read command is followed by 3-byte address (A23-A0) and a Dummy byte, each bit being latched in during the rising edge of SCLK, then the memory contents are shifted out 2-bit per clock cycle from SI and SO. The command sequence is shown in the following figure. The first byte addressed can be at any location. The address is automatically incremented to the next address after each byte of data is shifted out. # 5.2.4. Dual I/O Fast Read(BBH) The Dual I/O Fast Read command is similar to the Dual Output Fast Read command but with the capability to input the 3-byte address (A23-0) and a "Continuous Read Mode" byte 2-bit per clock by SI and SO, each bit being latched in during the rising edge of SCLK, then the memory contents are shifted out 2-bit per clock cycle from SI and SO. The command sequence is shown in the following figure. The first byte addressed can be at any location. The address is automatically incremented to the next address after each byte of data is shifted out. The number of Dummy clocks for "Dual I/O Fast Read" (BBH) can be set by the Dummy Code Bit 0 (DC0) in status register. When the DC0 bit is set to 0, which is default, the number of Dummy clock cycles is 4. When the DC0 bit is set to 1, the Dummy clock cycles is 8. #### \* The number of dummy clocks (M7-M0 included) can be set by DC0 bit #### Dual I/O Fast Read with "Continuous Read Mode" The Dual I/O Fast Read command can further reduce command overhead through setting the "Continuous Read Mode" bits (M7-0) after the input 3-byte address (A23-A0). If the "Continuous Read Mode" bits (M5-4) =(1,0), then the next Dual I/O Fast Read command (after CS# is raised and then lowered) does not require the BBH command code. The command sequence is shown in figure below. If the "Continuous Read Mode" bits (M5-4) do not equal (1,0), the next command requires the first BBH command code, thus returning to normal operation. A "Continuous Read Mode" Reset command can be used to reset (M5-4) before issuing normal command. Figure 10a. Dual I/O Fast Read Sequence Diagram (M5-4=(1,0)) <sup>\*</sup> The number of dummy clocks (M7-M0 included) can be set by DC0 bit # 5.2.5. Quad Output Fast Read(6BH) The Quad Output Fast Read command is followed by 3-byte address (A23-A0) and a Dummy byte, each bit being latched in during the rising edge of SCLK, then the memory contents are shifted out 4-bit per clock cycle from IO3, IO2, IO1 and IO0. The command sequence is shown in the figure below. The first byte addressed can be at any location. The address is automatically incremented to the next address after each byte of data is shifted out. #### 5.2.6. Quad I/O Fast Read(EBH) The Quad I/O Fast Read command is similar to the Dual I/O Fast Read command but with the capability to input the 3-byte address (A23-0) and a "Continuous Read Mode" byte and 4 Dummy clocks 4-bit per clock by IOO, IO1, IO3, IO4, each bit being latched in during the rising edge of SCLK, then the memory contents are shifted out 4-bit per clock cycle from IO0, IO1, IO2, IO3. The command sequence is shown in the figure below. The first byte addressed can be at any location. The address is automatically incremented to the next address after each byte of data is shifted out. The Quad Enable bit (QE) of Status Register (S9) must be set to 1 to enable for the Quad I/O Fast read command. The number of Dummy clocks for "Quad I/O Fast Read" (EBH) can be set by the Dummy Configuration Bit 0 (DC0) in status register. When the DC0 bit is set to 0, which is default, the number of Dummy clock cycles is 6. When the DC0 bit is set to 1, the Dummy clock cycles is 10. # \* The number of dummy clocks can be set by DC0 bit #### Quad I/O Fast Read with "Continuous Read Mode" The Quad I/O Fast Read command can further reduce command overhead through setting the "Continuous Read Mode" bits (M7-0) after the input 3-byte address (A23-A0). If the "Continuous Read Mode" bits (M5-4) =(1, 0), then the next Quad I/O Fast Read command (after CS# is raised and then lowered) does not require the EBH command code. The command sequence is shown in Figure 12a. If the "Continuous Read Mode" (M5-4) do not equal (1, 0), the next command requires the first EBH command code, thus returning to normal operation. A "Continuous Read Mode" Reset command can be used to reset (M5-4) before issuing normal command. Rev 0.6 Feb/26/2022 Page 30 # Quad I/O Fast Read with "8/16/32/64-Byte Wrap Around" in Standard SPI mode The Quad I/O Fast Read command can be used to access a specific portion within a page by issuing "Set Burst with Wrap" (77H) commands 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/64-byte section of a 256-byte page. The output data starts at the initial address specified in the command, once it reaches the ending boundary of the 8/16/32/64-byte section, the output will wrap around 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. # 5.2.7. DTR Fast Read(0DH) The DTR Fast Read instruction is similar to the Fast Read instruction except that the 24-bit address input and the data output require DTR (Double Transfer Rate) operation. This is accomplished by adding six Dummy clocks after a 3-byte address (A23-A0) as shown in the figure below. 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 13. DTR Fast Read Instruction(SPI Mode) CS# SCLK ODH Command Co Rev 0.6 Feb/26/2022 Page 32 ## 5.2.8. DTR Fast Read Dual I/O (BDH) The DTR Fast Read Dual I/O (BDH) instruction allows for improved random access while maintaining two IO pins, IOO and IO1. It is similar to the Dual I/O Fast Read (BBH) instruction but with the capability to input a 3-byte address (A23-AO) two bits per clock. This reduced instruction overhead may allow for code execution (XIP) directly from the Dual SPI in some applications. #### DTR Fast Read Dual I/O with "Continuous Read Mode" The DTR Fast Read Dual I/O instruction can further reduce instruction overhead through setting the "Continuous Read Mode" bits (M7-0) after a 3-byte address (A23-A0), as shown in "BBH" command description. The upper nibble of the (M7-4) controls the length of the next Fast Read Dual I/O instruction through the inclusion or exclusion of the first byte instruction code. The lower nibble bits of the (M3-0) are don't care ("x"). However, the IO pins should be high-impedance for 4 Dummy clocks prior to the falling edge of the first data out clock. If the "Continuous Read Mode" bits M5-4 = (1, 0), then the next Fast Read Dual I/O instruction (after /CS is raised and then lowered) does not require the BDH instruction code, as shown in the figure below. This reduces the instruction sequence by eight clocks and allows the Read address to be immediately entered after /CS is asserted low. If the "Continuous Read Mode" bits M5-4 do not equal to (1,0), the next instruction (after /CS is raised and then lowered) requires the first byte instruction code, thus returning to normal operation. It is recommended to input FFFFh/FFFFFh on IOO for the next instruction (16/20 clocks), to ensure M4 = 1 and return the device to normal operation. CS# SCLK Command C Figure 14. DTR Fast Read Dual I/O(Initial instruction or previous M5-4≠10, SPI Mode only) ## 5.2.9. DTR Fast Read Quad I/O (EDH) The DTR Fast Read Quad I/O (EDH) instruction is similar to the Quad I/O Fast Read(EBH) instruction except that address and data bits are input and output through four pins IOO, IO1, IO2 and IO3 and several Dummy clocks(including M7-M0) are required in SPI mode 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 must be set to enable the DTR Fast Read Quad I/O Instruction. The number of Dummy clocks for "DTR Fast Read Quad I/O" (EDH) can be set by the Dummy Code Bit1(DC1) in status register. When the DC1 bit is set to 0, which is default, the number of Dummy clock cycles is 8. When the DC1 bit is set to 1, the Dummy clock cycles is 6. #### DTR Fast Read Quad I/O with "Continuous Read Mode" The DTR Fast Read Quad I/O instruction can further reduce instruction overhead through setting the "Continuous Read Mode" bits (M7-0) after the input Address bits (A23-0), as shown in "EBH" command description. The upper nibble of the (M7-4) controls the length of the next DTR Fast Read Quad I/O instruction through the inclusion or exclusion of the first byte instruction code. The lower nibble bits of the (M3-0) are don't care ("x"). However, the IO pins should be high-impedance prior to the falling edge of the first data out clock. If the "Continuous Read Mode" bits M5-4 = (1,0), then the next DTR Fast Read Quad I/O instruction (after /CS is raised and then lowered) does not require the EBH instruction code. This reduces the instruction sequence by eight clocks and allows the Read address to be immediately entered after /CS is asserted low. If the "Continuous Read Mode" bits M5-4 do not equal to (1,0), the next instruction (after /CS is raised and then lowered) requires the first byte instruction code, thus returning to normal operation. It is recommended to input FFh/3FFh on IOO for the next instruction (8/10 clocks), to ensure M4 = 1 and return the device to normal operation. Rev 0.6 Feb/26/2022 Page 34 Figure 15a. DTR Fast Read Quad I/O (Previous instruction set M5-4=10, SPI Mode) #### DTR Fast Read Quad I/O with "8/16/32/64-Byte Wrap Around" in Standard SPI mode The DTR 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 EDH. The "Set Burst with Wrap" (77H) command can either enable or disable the "Wrap Around" feature for the following EDH 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. #### 5.2.10. Page Program(02H) The Page Program (PP) command is for programming the memory. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit before sending the Page Program command. The Page Program (PP) command is entered by driving CS# Low, followed by the command code, three address bytes and at least one data byte on SI. If the 8 least significant address bits (A7-A0) are not all zero, all transmitted data that goes beyond the end of the current page are programmed from the start address of the same page (from the address whose 8 least significant bits (A7-A0) are all zero). CS# must be driven low for the entire duration of the sequence. The Page Program command sequence: CS# goes low →Sending Page Program command → 3-byte address on SI → At least 1 byte data on SI →CS# goes high. The command sequence is shown in Figure 16. If more than 256 bytes are sent to the device, previously latched data are discarded and the last 256 data bytes are guaranteed to be programmed correctly within the same page. If less than 256 data bytes are sent to device, they are correctly programmed at the requested addresses without having any effects on the other bytes of the same page. CS# must be driven high after the eighth bit of the last data byte has been latched in; otherwise the Page Program (PP) command is not executed. As soon as CS# is driven high, the self-timed Page Program cycle (whose duration is tPP) is initiated. While the Page Program cycle is in progress, the Status Register may be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Page Program cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. A Page Program (PP) command applied to a page which is protected by the Block Protect (BP4, BP3, BP2, BP1, BP0) is not executed. ### 5.2.11. Quad Page Program(32H) The Quad Page Program command is for programming the memory using four pins: IO0, IO1, IO2, and IO3. To use Quad Page Program, the Quad Enable bit in status register Bit9 must be set (QE=1). A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit before sending the Page Program command. The Quad Page Program command is entered by driving CS# Low, followed by the command code (32H), three address bytes and at least one data byte on IO pins. The command sequence is shown in the figure below. If the 8 least significant address bits (A7-A0) are not all zero, all transmitted data that goes beyond the end of the current page are programmed from the start address of the same page (from the address whose 8 least significant bits (A7-A0) are all zero). If more than 256 bytes are sent to the device, previously latched data are discarded and the last 256 data bytes are guaranteed to be programmed correctly within the same page. If less than 256 data bytes are sent to device, they are correctly programmed at the requested addresses without having any effects on the other bytes of the same page. CS# must be driven high after the eighth bit of the last data byte has been latched in; otherwise the Quad Page Program command will not be executed. As soon as CS# is driven high, the self-timed Quad Page Program cycle (whose duration is tPP) is initiated. While the Quad Page Program cycle is in progress, the Status Register can be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Quad Page Program cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. A Quad Page Program command applied to a page which is protected by the Block Protect (BP4, BP3, BP2, BP1, BP0) will not be executed. ### 5.2.12. Sector Erase(20H) The Sector Erase (SE) command is for erasing all the data of the chosen sector. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit before sending the Sector Erase command. The Sector Erase (SE) command is entered by driving CS# low, followed by the command code, and 3-address byte on SI. Any address inside the sector is a valid address for the Sector Erase (SE) command. The Sector Erase command sequence: CS# goes low→ Sending Sector Erase command→ 3-byte address on SI→ CS# goes high. The command sequence is shown in Figure 18. CS# must be driven high after the eighth bit of the last address byte has been latched in; otherwise the Sector Erase (SE) command will not be executed. As soon as CS# is driven high, the self-timed Sector Erase cycle (whose duration is tSE) is initiated. While the Sector Erase cycle is in progress, the Status Register can be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Sector Erase cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. A Sector Erase (SE) command applied to a sector which is protected by the Block Protect (BP4, BP3, BP2, BP1, BP0) bit (see Table1.0&1.1) will not be executed. **Note:** Power disruption during erase operation will cause incomplete erase, thus it is recommended to perform a re-erase once power resume. #### 5.2.13. 32K Block Erase(52H) The 32KB Block Erase (BE) command is for erasing all the data of the chosen block. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit before sending the 32KB Block Erase command. The 32KB Block Erase (BE) command is entered by driving CS# low, followed by the command code, and three address bytes on SI, driving CS# high. Any address inside the block is a valid address for the 32KB Block Erase (BE) command. The 32KB Block Erase command sequence: CS# goes low→ Sending 32KB Block Erase command→ 3-byte address on SI→CS# goes high. The command sequence is shown in Figure 19. CS# must be driven high after the eighth bit of the last address byte has been latched in; otherwise the 32KB Block Erase (BE) command will not be executed. As soon as CS# is driven high, the self-timed Block Erase cycle (whose duration is tBE) is initiated. While the Block Erase cycle is in progress, the Status Register can be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Block Erase cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. A 32KB Block Erase (BE) command applied to a block which is protected by the Block Protect (BP4, BP3, BP2, BP1, BP0) bits (see Table1.0 & 1.1) will not be executed. **Note:** Power disruption during erase operation will cause incomplete erase, thus it is recommended to perform a re-erase once power resume. ### 5.2.14. 64K Block Erase(D8H) The 64KB Block Erase (BE) command is for erasing all the data of the chosen block. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit, before sending the 64KB Block Erase command. The 64KB Block Erase (BE) command is entered by driving CS# low, followed by the command code, and three address bytes on SI, driving CS# high. Any address inside the block is a valid address for the 64KB Block Erase (BE) command. The 64KB Block Erase command sequence: CS# goes low →Sending 64KB Block Erase command → 3-byte address on SI→CS# goes high. The command sequence is shown in Figure 20. CS# must be driven high after the eighth bit of the last address byte has been latched in; otherwise the 64KB Block Erase (BE) command will not be executed. As soon as CS# is driven high, the self-timed Block Erase cycle (whose duration is tBE) is initiated. While the Block Erase cycle is in progress, the Status Register can be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Block Erase cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. A 64KB Block Erase (BE) command applied to a block which is protected by the Block Protect (BP4, BP3, BP2, BP1, BP0) bits (see Table1.0 & 1.1) will not be executed. **Note**: Power disruption during erase operation will cause incomplete erase, thus it is recommended to perform a re-erase once power resume. #### 5.2.15. Chip Erase(60H or C7H) The Chip Erase (CE) command is for erasing all the data of the chip. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit, before sending the Chip Erase command .The Chip Erase (CE) command is entered by driving CS# Low, followed by the command code on Serial Data Input (SI). The Chip Erase command sequence: CS# goes low→ Sending Chip Erase command→CS# goes high. The command sequence is shown in Figure 21. CS# must be driven high after the eighth bit of the command code has been latch in, otherwise the Chip Erase command will not be executed. As soon as CS# is driven high, the self-timed Chip Erase cycle (whose duration is tCE) is initiated. While the Chip Erase cycle is in progress, the Status Register can be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Chip Erase cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. The Chip Erase (CE) command is executed if the Block Protect (BP4, BP3,BP2, BP1, BP0) bits are all 0. The Chip Erase (CE) command is ignored if one or more sectors are protected. **Note:** Power disruption during erase operation will cause incomplete erase, thus it is recommended to perform a re-erase once power resume. ### 5.3. Device Operations ### **5.3.1.** Enable Reset (66H) and Reset (99H) If the Reset command is accepted, any on-going internal operation 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 status (WEL), Read Parameter setting (P7-P0) and Wrap Bit Setting (W6-W4). The "Reset (99H)" command sequence as follow: CS# goes low $\rightarrow$ Sending Enable Reset command $\rightarrow$ CS# goes high $\rightarrow$ CS# goes low $\rightarrow$ Sending Reset command $\rightarrow$ CS# goes high. Once the Reset command is accepted by the device, the device will take approximately tRST\_R to reset. During this period, no command will be accepted. Data corruption may happen if there is an on-going 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. The Enable Reset (66H) command must be issued prior to a Reset(99H) command and any other commands can't be inserted between them. Otherwise, Enable Reset (66H) command will be cleared. Figure 22. Enable Reset and Reset command Sequence Diagram #### 5.3.2. Write Enable(06H) The Write Enable (WREN) command is for setting the Write Enable Latch (WEL) bit. The Write Enable Latch (WEL) bit must be set prior to every Page Program (PP), Sector Erase (SE), Block Erase (BE), Chip Erase (CE), Erase Security Register, Program Security Register and Write Status Register (WRSR) command. The Write Enable (WREN) command sequence: CS# goes low → Sending the Write Enable command → CS# goes high. ### 5.3.3. Write Enable for Volatile Status Register (50H) The non-volatile Status Register bits 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. The Write Enable for Volatile Status Register command must be issued prior to a Write Status Register command and any other commands can't be inserted between them. Otherwise, Write Enable for Volatile Status Register will be cleared. The Write Enable for Volatile Status Register command will not set the Write Enable Latch bit, it is only valid for the Write Status Register command to change the volatile Status Register bit values. Figure 24. Write Enable for Volatile Status Register Sequence Diagram #### 5.3.4. Write Disable(04H) The Write Disable command is for resetting the Write Enable Latch (WEL) bit. The Write Disable command sequence: CS# goes low $\rightarrow$ Sending the Write Disable command $\rightarrow$ CS# goes high. The WEL bit is reset by following condition: Power-up and upon completion of the Write Status Register, Page Program, Sector Erase, Block Erase and Chip Erase commands. CS# **SCLK** Command 04H High-Z SO Figure 25. Write Disable Sequence Diagram ### 5.3.5. Program Erase Suspend(75H) The Program/Erase Suspend command "75H", allows the system to interrupt a page program or sector/block erase operation and then read data from any other sector or block. The Write Status Register command (01H/31H/11H) and Erase/Program Security Registers command (44H,42H) and Erase commands (20H, 52H, D8H, C7H, 60H) and Page Program command (02H / 32H) are not allowed during Program suspend. The Write Status Register command (01H/31H/11H) and Erase Security Registers command (44H) and Erase commands (20H, 52H, D8H, C7H, 60H) are not allowed during Erase suspend. Program/Erase Suspend is valid only during the page program or sector/block erase operation. A maximum of time of "tSUS" (See AC Characteristics) is required to suspend the program/erase operation. The Program/Erase Suspend command will be accepted by the device only if the SUS bit in the Status Register equal to 0 and WIP bit equal to 1 while a Page Program or a Sector or Block Erase operation is on-going. If the SUS bit equal to 1 or WIP bit equal to 0, the Suspend command will be ignored by the device. The WIP bit will be cleared form 1 to 0 within "tSUS" and the SUS bit will be set from 0 to 1 immediately after Program/Erase Suspend. A power-off during the suspend period will reset the device and release the suspend state. The command sequence is show in Figure 26. Figure 26. Program/Erase Suspend Sequence Diagram Feb/26/2022 Rev 0.6 Page 43 ### 5.3.6. Program Erase Resume (7AH) The Program/Erase Resume command must be written to resume the program or sector/block erase operation after a Program/Erase Suspend command. The Program/Erase command will be accepted by the device only if the SUS bit equal to 1 and the WIP bit equal to 0. After issued the SUS bit in the status register will be cleared from 1 to 0 immediately, the WIP 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. The Program/Erase Resume command will be ignored unless a Program/Erase Suspend is active. The command sequence is show in Figure 27. Figure 27. Program/Erase Resume Sequence Diagram ### 5.3.7. Set Burst With Wrap(77H) The Set Burst with Wrap command is used in conjunction with "Quad I/O Fast Read (EBH)" and "Quad Read under DTR (EDH)" commands to access a fixed length of 8/16/32/64-byte section within a 256-byte page in standard SPI mode. The Set Burst with Wrap command sequence: CS# goes low →Send Set Burst with Wrap command →Send 24 Dummy bits →Send 8 bits "Wrap bits"→CS# goes high | W6,W5 | W | 1=0 | W4=1(Default) | | | |--------|-------------|-------------|---------------|-------------|--| | WO, W3 | 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 | | If the W6-W4 bits are set by the Set Burst with Wrap command, all the following "Quad I/O Fast Read (EBH)" and "Quad Read under DTR (EDH)" command will use the W6-W4 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 command should be issued to set W4=1. ### 5.3.8. Deep Power Down(B9H) Executing the Deep Power-Down (DP) command is the only way to put the device in the lowest power consumption mode (the Deep Power-Down Mode). It can also be used as an extra software protection mechanism, since in this mode, the device ignores all Write, Program and Erase commands. Driving CS# high deselects the device, and puts the device in the Standby Mode (if there is no internal cycle currently in progress). But the Standby Mode is different from the Deep Power-Down Mode. The Deep Power-Down Mode can only be entered by executing the Deep Power-Down (DP) command. Once the flash memory has entered the Deep Power-Down Mode, all commands are ignored except the Release from Deep Power-Down and Read Device ID (RDI) command software reset (66H+99H). This command releases the flash memory from the Deep Power-Down Mode. The Deep Power-Down Mode automatically stops at Power-Off, and the device always Power-Up in the Standby Mode. The Deep Power-Down (DP) command is entered by driving CS# low, followed by the command code on SI, driving CS# high. The Deep Power-Down command sequence: CS# goes low→Sending Deep Power-Down command→CS# goes high. The command sequence is shown in Figure 29. CS# must be driven high after the eighth bit of the command code has been latched in; otherwise the Deep Power-Down (DP) command will not be executed. As soon as CS# is driven high, it requires a time duration of tDP before the supply current is reduced to ICC2 and the Deep Power-Down Mode is entered. Any input of Deep Power-Down (DP) command, while an Erase, Program or Write cycle is in progress, is rejected without having any effects on the cycle that is in progress. Figure 29. Deep Power-Down Sequence Diagram ### 5.3.9. Release From Deep Power Down(ABH) The Release from Deep Power-Down and Read Device ID command is a multi-purpose command. It can be used to release the device from Deep Power-Down Mode or obtain the devices electronic identification (ID) number. To release the device from Deep Power-Down Mode, the command is issued by driving the CS# pin low, shifting the instruction code "ABH" and driving CS# high as shown in Figure 30. Release from Deep Power-Down Mode will take the time duration of tRES1 (See AC Characteristics) before the device resume to normal state and other command are accepted. The CS# pin must remain high during the tRES1 time duration. When the command is used only to obtain the Device ID while the flash memory is not in Deep Power-Down Mode, the command 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 SCLK with most significant bit (MSB) first as shown in Figure 30a. The Device ID value is listed in Manufacturer and Device Identification table. The Device ID can be read continuously. The command is completed by driving CS# high. When the command is used to release the device from Deep Power-Down Mode and obtain the Device ID, the command is the same as previously described, and shown in Figure 30a., 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 to normal mode and other command will be accepted. If the Release from Deep Power-Down and Read Device ID command is issued while an Erase, Program or Write cycle is in process (when WIP equal 1) the command will be ignored and will not affect the current cycle. SCLK SCLK Command Deep Power-Down Mode Figure 30a. Release Power-Down/Read Device ID Sequence Diagram CS SCLK O 1 2 3 4 5 6 7 8 9 10 11 Command ABH ## 5.4. One-Time Programmable (OTP) Operations ### 5.4.1. Read Security Register(48H) The Read Security Registers command is similar to Fast Read command. The command is followed by a 3-byte address (A23-A0) and a dummy byte, each bit being latched-in during the rising edge of SCLK. Then the memory content, at that address, is shifted out on SO, each bit being shifted out, at a Max frequency fC, during the falling edge of SCLK. The first byte addressed can be at any location. The address is automatically incremented to the next address after each byte of data is shifted out. Once the A9-A0 address reaches the last byte of the register (Byte 3FFH), it will reset to 000H, the command is completed by driving CS# high. | Address | A23-A16 | A15-A12 | A11-A10 | A9-A0 | |-----------------------|----------|---------|---------|--------------| | Security Registers #1 | 0000000b | 0001b | 00b | Byte Address | | Security Registers #2 | 0000000b | 0010b | 00b | Byte Address | | Security Registers #3 | 0000000b | 0011b | 00b | Byte Address | ### 5.4.2. Program Security Register(42H) The Program Security Registers command is similar to the Page Program command. It allows from 1 to 256 bytes data to be programmed at once in the total 3x1024-byte Security Registers. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit before sending the Program Security Registers command. The Program Security Registers command is entered by driving CS# Low, followed by the command code (42H), three address bytes and at least one data byte on SI. As soon as CS# is driven high, the self-timed Program Security Registers cycle (whose duration is tPP) is initiated. While the Program Security Registers cycle is in progress, the Status Register may be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Program Security Registers cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. If the Security Registers Lock Bit (LB1,LB2,LB3) is set to 1, the corresponding Security Registers (#1, #2, #3) will be permanently locked. Program Security Registers command will be ignored. | Address | A23-A16 | A15-A12 | A11-A10 | A9-A0 | |-----------------------|----------|---------|---------|--------------| | Security Registers #1 | 0000000b | 0001b | 00b | Byte Address | | Security Registers #2 | 0000000b | 0010b | 00b | Byte Address | | Security Registers #3 | 0000000b | 0011b | 00b | Byte Address | ### 5.4.3. Erase Security Register(44H) The device provides 3x1024-byte Security Registers which only erased each 1024-byte at once. 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 Registers command is similar to Sector/Block Erase command. A Write Enable (WREN) command must previously have been executed to set the Write Enable Latch (WEL) bit. The Erase Security Registers command sequence: CS# goes low → Sending Erase Security Registers Command → Sending 24-bit Address → CS# goes high. The command sequence is shown in Figure 33. CS# must be driven high after the eighth bit of the command code has been latched in, otherwise the Erase Security Registers command is not executed. As soon as CS# is driven high, the self-timed Erase Security Registers cycle (whose duration is tSE) is initiated. While the Erase Security Registers cycle is in progress, the Status Register may be read to check the value of the Write In Progress (WIP) bit. The Write In Progress (WIP) bit is 1 during the self-timed Erase Security Registers cycle, and is 0 when it is completed. At some unspecified time before the cycle is completed, the Write Enable Latch (WEL) bit is reset. The Security Registers Lock Bit (LB1,LB2,LB3) in the Status Register can be used to OTP protect the corresponding security registers (#1, #2, #3). Once the LB bit is set to 1, the corresponding Security Registers will be permanently locked; the Erase Security Registers command will be ignored. | Address | A23-A16 | A15-A12 | A11-A10 | A9-A0 | |-----------------------|----------|---------|---------|------------| | Security Registers #1 | 0000000b | 0001b | 00b | Don't Care | | Security Registers #2 | 0000000b | 0010b | 00b | Don't Care | | Security Registers #3 | 0000000b | 0011b | 00b | Don't Care | ### 5.5. Advanced Data Protection ### 5.5.1. Global Block/Sector Lock (7EH) or Unlock (98H) All Block/Sector Lock bits can be set to 1 by the Global Block/Sector Lock command, or can set to 0 by the Global Block/Sector Unlock command. The Global Block/Sector Lock command (7EH) sequence: CS# goes low $\rightarrow$ SI: Sending Global Block/Sector Lock command $\rightarrow$ CS# goes high. The command sequence is shown in Figure 34. The Global Block/Sector Unlock command (98H) sequence: CS# goes low $\rightarrow$ SI: Sending Global Block/Sector Unlock command $\rightarrow$ CS# goes high. The command sequence is shown in Figure 34a. CS# SCLK Command TEH SO High-Z Figure 34. The Global Block/Sector Lock Sequence Diagram Figure 34a. The Global Block/Sector Unlock Sequence Diagram ### 5.5.2. Individual Block/Sector Lock (36H)/Unlock (39H)/Read (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, BP (4:0) bits in the Status Register. 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. The individual Block/Sector Lock command (36H) sequence: CS# goes low $\rightarrow$ SI: Sending individual Block/Sector Lock command $\rightarrow$ SI: Sending 24bits individual Block/Sector Lock Address $\rightarrow$ CS# goes high. The command sequence is shown in Figure 35. The individual Block/Sector Unlock command (39H) sequence: CS# goes low $\rightarrow$ SI: Sending individual Block/Sector Unlock command $\rightarrow$ SI: Sending 24bits individual Block/Sector Lock Address $\rightarrow$ CS# goes high. The command sequence is shown in Figure 35a. The Read individual Block/Sector lock command (3DH) sequence: CS# goes low $\rightarrow$ SI: Sending Read individual Block/Sector Lock command $\rightarrow$ SI: Sending 24bits individual Block/Sector Lock Address $\rightarrow$ SO: The Block/Sector Lock Bit will out $\rightarrow$ CS# goes high. If the least significant bit(LSB) is1, the corresponding block/sector is locked, if the LSB is 0, the corresponding block/sector is unlocked, Erase/Program operation can be performed. The command sequence is shown in Figure 35b. Figure35a. Individual Block/Sector Unlock command Sequence Diagram Figure 35b. Read Individual Block/Sector lock command Sequence Diagram ### 6. ELECTRICAL CHARACTERISTICS ## 6.1. Power-on Timing **Power-Up Timing and Write Inhibit Threshold** | Symbol | Parameter | Min | Max | Unit | |------------------|-----------------------|-----|-----|------| | t <sub>VSL</sub> | VCC(min) To CS# Low | 100 | | us | | $V_{WI}$ | Write Inhibit Voltage | 1.5 | 2.5 | V | ## **6.2.** Initial Delivery State The device is delivered with the memory array erased: all bits are set to 1(each byte contains FFH). All Status Register bits except S22 bits are 0, S22 bit is 1. ## 6.3. Absolute Maximum Ratings | Parameter | Value | Unit | |-------------------------------|-------------|---------------| | Ambient Operating Temperature | -40 to 85 | ${\mathbb C}$ | | Storage Temperature | -65 to 150 | $^{\circ}$ | | Output Short Circuit Current | 200 | mA | | Applied Input/Output Voltage | -0.5 to 4.0 | V | | VCC | -0.5 to 4.0 | V | ### Input Test Waveform and Measurement Level #### **Maximum Negative Overshoot Waveform** #### Maximum Positive Overshoot Waveform ## 6.4. Capacitance Measurement Condition | Symbol | Parameter | Min | Тур | Max | Unit | Conditions | | | |--------|---------------------------------|------------------|--------|-----|------|------------|----|---------| | CIN | Input Capacitance | | | | pF | VIN=0V | | | | COUT | Output Capacitance | 8 | | 8 | | 8 | pF | VOUT=0V | | CL | Load Capacitance | 30 | | | pF | | | | | | Input Rise And Fall time | | | 5 | ns | | | | | | Input Pulse Voltage | 0.1VCC to 0.8VCC | | VCC | V | | | | | | Input Timing Reference Voltage | 0.2VCC to 0.7VCC | | | V | | | | | | Output Timing Reference Voltage | | 0.5VCC | | V | | | | ### **Absolute Maximum Ratings Diagram** Note: Input pulse rise and fall time are <5ns ### 6.5. DC Characteristics (T=-40°C~85°C,VCC=2.7~3.6V) | Symbol | Parameter | Test Condition | Min. | Тур | Max. | Unit | |--------|-----------------------------|-----------------------------------------------------|---------|-----|---------|------| | ILI | Input Leakage Current | | | | ±2 | μΑ | | ILO | Output Leakage Current | | | | ±2 | μΑ | | ICC1 | Standby Current | CS#=VCC<br>VIN=VCC or VSS | | 14 | 50 | μА | | ICC2 | Deep Power-Down Current | CS#=VCC<br>VIN=VCC or VSS | | 0.5 | 5 | μΑ | | ICC3 | Operating Current(Read) | CLK=0.1VCC/0.9VCC at<br>133MHz,Q=Open(*1,*2,*4 I/O) | | 12 | 20 | mA | | | | CLK=0.1VCC/0.9VCC at<br>80MHz, Q=Open(*1,*2,*4 I/O) | | 8 | 13 | mA | | ICC4 | Operating Current(PP) | CS#=VCC | | 15 | 25 | mA | | ICC5 | Operating Current(WRSR) | CS#=VCC | | 15 | 25 | mA | | ICC6 | Operating Current(SE/BE/CE) | CS#=VCC | | 15 | 25 | mA | | VIL | Input Low Voltage | | -0.5 | | 0.25VCC | V | | VIH | Input High Voltage | | 0.7VCC | | VCC+0.4 | V | | VOL | Output Low Voltage | IOL=100uA | | | 0.2 | V | | VOH | Output High Voltage | IOH=-100uA | VCC-0.2 | | | V | ### Note: - 1. Typical values given for T=25°C, VCC=3.3V. - 2. Value guaranteed by design and/or characterization, not 100% tested in production. ### 6.6. AC Characteristics (T=-40°C~85°C,VCC=2.7~3.6V, CL=30pF) | Symbol | Parameter | Min. | Тур. | Max. | Unit | |---------------------|---------------------------------------------------------------------------------------------|--------|------|------|------| | fC <sup>Note3</sup> | Serial Clock Frequency For: all commands except Read (03H) and DTR on 3.0-3.6V power supply | | | 133 | MHz | | fC1 Note3 | Serial Clock Frequency For: all commands except Read (03H) and DTR on 2.7-3.0V power supply | | | 104 | MHz | | fC2 Note3 | Serial Clock Frequency For DTR Read | | | 104 | MHz | | fC3 Note3 | Serial Clock Frequency For: Quad I/O Fast Read (EBH) under continuous read mode | | | 80 | MHz | | fR Note3 | Serial Clock Frequency For: Read (03H) | | | 80 | MHz | | tCLH Note2 | Serial Clock High Time | 45% PC | | | ns | | tCLL Note2 | Serial Clock Low Time | 45% PC | | | ns | | tCLCH | Serial Clock Rise Time(Slew Rate) | 0.2 | | | V/ns | | tCHCL | Serial Clock Fall Time(Slew Rate) | 0.2 | | | V/ns | | tSLCH | CS# Active Setup Time | 5 | | | ns | | tCHSH | CS# Active Hold Time | 5 | | | ns | | tSHCH | CS# Not Active Setup Time | 5 | | | ns | | tCHSL | CS# Not Active Hold Time | 5 | | | ns | | tSHSL | CS# High Time (read/write) | 20 | | | ns | | tSHQZ | Output Disable Time | | | 6 | ns | | tCLQX | Output Hold Time | 1.2 | | | ns | | tCLQV | Clock Low To Output Valid | | | 5.5 | ns | | tDVCH | Data In Setup Time | 2 | | | ns | | tCHDX | Data In Hold Time | 2 | | | ns | | tHLCH | Hold# Low Setup Time(relative to Clock) | 5 | | | ns | | tHHCH | Hold# High Setup Time(relative to Clock) | 5 | | | ns | | tCHHL | Hold# High Hold Time(relative to Clock) | 5 | | | ns | | tCHHH | Hold# Low Hold Time(relative to Clock) | 5 | | | ns | | tHLQZ | Hold# Low To High-Z Output | | | 7.5 | ns | | tHHQX | Hold# High To Low-Z Output | | | 9 | ns | | tWHSL | Write Protect Setup Time Before CS# Low | 20 | | | ns | | tSHWL | Write Protect Hold Time After CS# High | 100 | | | ns | | tDP | CS# High To Deep Power-Down Mode | | | 3 | μs | | tRES1 | CS# High To Standby Mode Without Electronic Signature Read | | | 20 | μs | | tRES2 | CS# High To Standby Mode With Electronic Signature Read | | | 20 | μs | | tRST_R | CS# High To Next Command After Reset (from read) | | | 30 | μs | | tRST_P | CS# High To Next Command After Reset (from program) | | | 30 | μs | | tRST_E | CS# High To Next Command After Reset (from erase) | | | 12 | ms | | tSUS | CS# High To Next Command After Suspend | | | 20 | μs | | tRS | Latency Between Resume And Next Suspend | 500 | | | μs | | tW | Write Status Register Cycle Time | | 1 | 20 | ms | | tBP | Byte Programming Time (First Byte) | | 25 | 50 | us | | tBP | Byte Programming Time (After First Byte) | | 2.5 | 5 | us | | tPP | Page Programming Time | | 0.4 | 2 | ms | | tSE | Sector Erase Time | 40 | 800 | ms | |------|-----------------------------|------|-----|----| | tBE1 | Block Erase Time(32K Bytes) | 0.15 | 1.2 | S | | tBE2 | Block Erase Time(64K Bytes) | 0.25 | 1.6 | S | | tCE | Chip Erase Time | 30 | 100 | S | ### Note: - 1. Clock high or Clock low must be more than or equal to 45%PC. PC=1/fC(MAX). - 2. Typical values given for T=25°C, VCC=3.3V. Value guaranteed by design and/or characterization, not 100% tested in production. - 3. Serial Clock Frequency for Read Commands: ### **Read Performance** | Unit:<br>MHz | 03H | ОВН | ЗВН | BBH<br>DC0=0<br>(Default) | BBH<br>DC0=1 | 6ВН | EBH<br>DC0=0<br>(Default) | EBH<br>DC0=1 | 0DH | BDH | EDH<br>DC1=0<br>(Default) | EDH<br>DC1=1 | |---------------|-----|-----|-----|---------------------------|--------------|-----|---------------------------|--------------|-----|-----|---------------------------|--------------| | 2.7V-<br>3.0V | 80 | 104 | 104 | 104 | 104 | 104 | 104 | 104 | 104 | 104 | 104 | 94 | | 3.0V-<br>3.6V | 80 | 133 | 133 | 104 | 133 | 133 | 104 | 133 | 104 | 104 | 104 | 84 | ### Resume to Suspend Timing Diagram ### 7. ORDERING INFORMATION The ordering part number is formed by a valid combination of the following # **8. PACKAGE INFORMATION** # 8.1. Package SOP8 208mil | CVAADOL | | MILLIMETER | | |-----------|------|------------|------| | SYMBOL | MIN | NOM | MAX | | Α | 1.75 | 1.95 | 2.15 | | A1 | 0.05 | 0.15 | 0.25 | | A2 | 1.70 | 1.80 | 1.90 | | А3 | 0.75 | 0.80 | 0.85 | | b | 0.33 | _ | 0.51 | | b1 | 0.30 | _ | 0.48 | | С | 0.17 | _ | 0.25 | | <b>c1</b> | 0.15 | 0.20 | 0.23 | | D | 5.13 | 5.23 | 5.33 | | E | 7.70 | 7.90 | 8.10 | | E1 | 5.18 | 5.28 | 5.38 | | е | | 1.27 BSC | | | L | 0.50 | 0.65 | 0.80 | | L1 | | 1.31 REF | | | θ | 0° | _ | 8° | ## 8.2. Package WSON8 6x5mm | SYMBOL | MILLIMETER | | | |-----------|------------|----------|------| | | MIN | NOM | MAX | | Α | 0.70 | 0.75 | 0.80 | | A1 | 0.00 | 0.02 | 0.05 | | b | 0.35 | 0.40 | 0.45 | | <b>b1</b> | | 0.25 REF | | | С | 0.18 | 0.20 | 0.25 | | D | 5.90 | 6.00 | 6.10 | | Nd | | 3.81 BSC | | | e | | 1.27 BSC | | | E | 4.90 | 5.00 | 5.10 | | D2 | 3.30 | 3.40 | 3.50 | | E2 | 3.90 | 4.00 | 4.10 | | L | 0.55 | 0.60 | 0.65 | | h | 0.30 | 0.35 | 0.40 | ## 9. REVISION HISTORY | Revision | Description | Date | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------| | 0.0 | Preliminary version | Jun 12, 2020 | | 0.1 | Updated SFDP | Jan 28, 2020 | | 0.2 | Update POD of SOP8 208mil, WSON8 6x5mm, WSON8 8x6mm | Mar 29, 2021 | | 0.3 | Update to reserve SFDP Table Read Frequency for DTR changed from 133MHz to 104MHz | Apr 29, 2021 | | 0.4 | tSE max 200ms -> 800ms<br>Add Absolute Maximum Ratings Diagram | Jul 1, 2021 | | 0.5 | Update to add internal version "-W" and deleted package WSON8 8x6mm and 105° C OPN | Feb 10, 2022 | | 0.6 | Idpd typ 1uA->0.5uA Istb typ 15uA->14uA VIL max 0.3VCC->0.25VCC tSE typ 25ms->40ms tHLQZ max 6ns->7.5ns tHHQX max 6ns->9ns tRS min 100us->500us EBH under continuous read mode: 80MHz | Feb 26, 2022 |