# 3V, 256M-BIT [x 1/x 2/x 4] CMOS MXSMIO® (SERIAL MULTI I/O) FLASH MEMORY # Key Features - Protocol Support Single I/O, Dual I/O and Quad I/O - Supports DTR (Double Transfer Rate) Mode - Supports clock frequencies up to 133MHz - 4-Byte Address Mode permanent interface - Permanently fixed QE bit, QE=1 and 4 I/O mode is enabled # **Contents** | 1. FEATU | JRES | 5 | |----------------|---------------------------------------------------------------------|---------------| | 2. GENE | RAL DESCRIPTION | 6 | | | Table 1. Read performance Comparison | 6 | | 3. PIN C | ONFIGURATIONS | | | 4. PIN DI | ESCRIPTION | 7 | | 5. BLOC | K DIAGRAM | 8 | | | PROTECTION | | | | Table 2. Protected Area Sizes | | | | Table 3. 4K-bit Secured OTP Definition | | | 7. Memo | ry Organization | | | | Table 4. Memory Organization | | | 8. DEVIC | CE OPERATION | | | 8-1. | 256Mb Address Protocol | | | 8-2. | Quad Peripheral Interface (QPI) Read Mode | | | | MAND DESCRIPTION | | | | Table 5. Command Set | | | 9-1. | Write Enable (WREN) | | | 9-2. | Write Disable (WRDI) | | | 9-3. | Factory Mode Enable (FMEN) | | | 9-4. | Read Identification (RDID) | | | 9-5. | Release from Deep Power-down (RDP), Read Electronic Signature (RES) | | | 9-6. | Read Electronic Manufacturer ID & Device ID (REMS) | 27 | | 9-7. | QPI ID Read (QPIID) | 28 | | | Table 6. ID Definitions | 28 | | 9-8. | Read Status Register (RDSR) | 29 | | 9-9. | Read Configuration Register (RDCR) | 30 | | | Table 7. Status Register | | | | Table 8. Configuration Register | | | | Table 9. Output Driver Strength Table | | | | Table 10. Dummy Cycle and Frequency Table (MHz) | | | 9-10. | Write Status Register (WRSR) | | | 0.44 | Table 11. Protection Modes | | | 9-11. | | | | 9-12. | , , , , , , , , , , , , , , , , , , , , | | | 9-13. | , | | | 9-14.<br>9-15. | , | | | | 4 x I/O Read Mode (4READ) | | | 3- IU. | ▼ ^ I/O INEQUIVIOUE (HINE/ID) | <del>44</del> | | 9-17. | 4 x I/O Double Transfer Rate Read Mode (4DTRD) | 46 | |----------|-------------------------------------------------------------------------------|----| | 9-18. | Preamble Bit | 48 | | 9-19. | Burst Read | 52 | | 9-20. | Performance Enhance Mode - XIP (execute-in-place) | 53 | | 9-21. | Sector Erase (SE) | 56 | | 9-22. | Block Erase (BE32K) | 57 | | 9-23. | Block Erase (BE) | 58 | | 9-24. | Chip Erase (CE) | 59 | | 9-25. | Page Program (PP) | 60 | | 9-26. | 4 x I/O Page Program (4PP) | 61 | | 9-27. | Deep Power-down (DP) | 62 | | | Enter Secured OTP (ENSO) | | | 9-29. | Exit Secured OTP (EXSO) | 63 | | | Write Security Register (WRSCUR) | | | 9-31. | Read Security Register (RDSCUR) | 65 | | | Table 12. Security Register Definition | | | 9-32. | Write Protection Selection (WPSEL) | 67 | | 9-33. | Advanced Sector Protection | 69 | | | Table 13. Lock Register | 70 | | | Table 14. SPB Register | 71 | | | Table 15. DPB Register | 73 | | | Program/Erase Suspend/Resume | | | 9-35. | Erase Suspend | 75 | | 9-36. | Program Suspend | 75 | | | Write-Resume | | | | No Operation (NOP) | | | | Software Reset (Reset-Enable (RSTEN) and Reset (RST)) | | | | Read SFDP Mode (RDSFDP) | | | 10. RESE | Т | | | | Table 16. Reset Timing-(Power On) | | | | Table 17. Reset Timing-(Other Operation) | | | 11. POWE | ER-ON STATE | 81 | | 12. ELEC | TRICAL SPECIFICATIONS | 82 | | | Table 18. ABSOLUTE MAXIMUM RATINGS | 82 | | | Table 19. CAPACITANCE TA = 25°C, f = 1.0 MHz | 82 | | | Table 20. DC CHARACTERISTICS (Temperature = -40°C to 85°C, VCC = 2.7V - 3.6V) | 84 | | | Table 21. AC CHARACTERISTICS (Temperature = -40°C to 85°C, VCC = 2.7V - 3.6V) | 85 | | 13. OPERATING CONDITIONS | 87 | |------------------------------------------------------|----| | Table 22. Power-Up/Down Voltage and Timing | 89 | | 13-1. INITIAL DELIVERY STATE | 89 | | 14. ERASE AND PROGRAMMING PERFORMANCE | 90 | | 15. ERASE AND PROGRAMMING PERFORMANCE (Factory Mode) | 90 | | 16. DATA RETENTION | 91 | | 17. LATCH-UP CHARACTERISTICS | 91 | | 18. ORDERING INFORMATION | 92 | | 19. PART NAME DESCRIPTION | 93 | | 20. PACKAGE INFORMATION | 94 | | 20-1. 16-pin SOP (300mil) | 94 | | 20-2. 8-land WSON (8x6mm 3.4 x 4.3EP) | | | 21 REVISION HISTORY | 96 | # 3V 256M-BIT [x 1/x 2/x 4] CMOS MXSMIO® (SERIAL MULTI I/O) FLASH MEMORY #### 1. FEATURES #### **GENERAL** - Supports Serial Peripheral Interface -- Mode 0 and Mode 3 - Single Power Supply Operation - 2.7 to 3.6 volts for read, erase, and program operations - 268,435,456 x 1 bit structure or 134,217,728 x 2 bits (two I/O mode) structure or 67,108,864 x 4 bits (four I/O mode) structure - · Protocol Support - Single I/O, Dual I/O and Quad I/O - Latch-up protected to 100mA from -1V to Vcc +1V - Low Vcc write inhibit is from 1.5V to 2.5V - · Fast read for SPI mode - Supports clock frequencies up to 133MHz for all protocols - Supports Fast Read, 2READ, DREAD, 4READ, QREAD instructions - Supports DTR (Double Transfer Rate) Mode - Configurable dummy cycle number for fast read operation - Supports Performance Enhance Mode XIP (execute-in-place) - Quad Peripheral Interface (QPI) available - Equal 4K byte Sectors, or Equal Blocks with 32K byte or 64K byte each - Any Block can be erased individually - Permanently fixed QE bit (The Quad Enable bit), QE=1 and 4 I/O mode is enabled - · Programming: - 256byte page buffer - Quad Input/Output page program(4PP) to enhance program performance - Typical 100,000 erase/program cycles - 20 years data retention - · 4-Byte Address Mode permanent interface # **SOFTWARE FEATURES** - Input Data Format - 1-byte Command code - Advanced Security Features - Block lock protection The BP0-BP3 and T/B status bits define the size of the area to be protected against program and erase instructions - Individual sector protection function (Solid Protect) - Additional 4K bit secure OTP - Features unique identifier - Factory locked identifiable, and customer lockable - Command Reset - Program/Erase Suspend and Resume operation - Electronic Identification - JEDEC 1-byte manufacturer ID and 2-byte device ID - RES command for 1-byte Device ID - REMS command for 1-byte manufacturer ID and 1-byte device ID - Supports Serial Flash Discoverable Parameters (SFDP) mode #### HARDWARE FEATURES - SCLK Input - Serial clock input - SI/SIO0 - Serial Data Input or Serial Data Input/Output for 2 x I/O read mode and 4 x I/O read mode - SO/SIO1 - Serial Data Output or Serial Data Input/Output for 2 x I/O read mode and 4 x I/O read mode - SIO2 - Serial data Input & Output for 4 x I/O read mode - SIO3 - Serial data Input & Output for 4 x I/O read mode - RESET# - Hardware Reset pin - PACKAGE - 16-pin SOP (300mil) - 8-land WSON (8x6mm 3.4 x 4.3EP) - All devices are RoHS Compliant and Halogen-free #### 2. GENERAL DESCRIPTION MX25L25773G is 256Mb bits Serial NOR Flash memory, which is configured as 33,554,432 x 8 internally. When it is in two or four I/O mode, the structure becomes 134,217,728 bits x 2 or 67,108,864 bits x 4. MX25L25773G feature s a serial peripheral interface and software protocol allowing operation on a simple 3-wire bus while it is in single I/O mode. The three bus signals are a clock input (SCLK), a serial data input (SI), and a serial data output (SO). Serial access to the device is enabled by CS# input. When it is in two I/O read mode, the SI pin and SO pin become SIO0 pin and SIO1 pin for address/dummy bits input and data output. When it is in four I/O read mode, the SI pin and SO pin become SIO0 pin and SIO1 pin for address/dummy bits input and data output. The MX25L25773G MXSMIO<sup>®</sup> (Serial Multi I/O) provides sequential read operation on the whole chip. After program/erase command is issued, auto program/erase algorithms which program/erase and verify the specified page or sector/block locations will be executed. Program command is executed on byte basis, or page (256 bytes) basis, or word basis. Erase command is executed on 4K-byte sector, 32K-byte block, or 64K-byte block, or whole chip basis. To provide user with ease of interface, a status register is included to indicate the status of the chip. The status read command can be issued to detect completion status of a program or erase operation via WIP bit. Advanced security features enhance the protection and security functions, please refer to the security features section for more details. When the device is not in operation and CS# is high, it will remain in standby mode. The MX25L25773G utilizes Macronix's proprietary memory cell, which reliably stores memory contents even after 100,000 program and erase cycles. **Table 1. Read performance Comparison** | Numbers<br>of Dummy<br>Cycles | Fast Read<br>(MHz) | Dual Output<br>Fast Read<br>(MHz) | Quad Output<br>Fast Read<br>(MHz) | Dual IO<br>Fast Read<br>(MHz) | Quad IO<br>Fast Read<br>(MHz) | Quad I/O DT<br>Read<br>(MHz) | |-------------------------------|--------------------|-----------------------------------|-----------------------------------|-------------------------------|-------------------------------|------------------------------| | 4 | - | - | - | 80* | 54 | - | | 6 | - | - | - | - | 80* | 54* | | 8 | 120*/133R | 120*/133R | 120*/133R | 120/133R | 84/104R | 70/80R | | 10 | - | - | - | - | 120/133R | 84/100R | #### Notes: - 1. \* Default status. - 2. R mean VCC range = 3.0V-3.6V. ## 3. PIN CONFIGURATIONS #### 8-WSON (8x6mm) #### 16-PIN SOP (300mil) ## 4. PIN DESCRIPTION | SYMBOL | DESCRIPTION | |---------|------------------------------------------| | CS# | Chip Select | | | Serial Data Input (for 1 x I/O)/ Serial | | SI/SIO0 | Data Input & Output (for 2xI/O or 4xI/ | | | O read mode) | | | Serial Data Output (for 1 x I/O)/ Serial | | SO/SIO1 | Data Input & Output (for 2xI/O or 4xI/ | | | O read mode) | | SCLK | Clock Input | | SIO2 | Serial Data Input & Output (for 4xI/O | | 3102 | read mode) | | SIO3 | Serial Data Input & Output (for 4xI/O | | 0103 | read mode) | | RESET#* | Hardware Reset Pin Active low | | VCC | + 3V Power Supply | | GND | Ground | | NC | No Connection | Note\*: The pin of RESET# will remain internal pull up function while this pin is not physically connected in system configuration. However, the internal pull up function will be disabled if the system has physical connection to RESET# pin. # 5. BLOCK DIAGRAM #### 6. DATA PROTECTION During power transition, there may be some false system level signals which result in inadvertent erasure or programming. The device is designed to protect itself from these accidental write cycles. The state machine will be reset as standby mode automatically during power up. In addition, the control register architecture of the device constrains that the memory contents can only be changed after specific command sequences have completed successfully. In the following, there are several features to protect the system from the accidental write cycles during VCC power-up and power-down or from system noise. - Valid command length checking: The command length will be checked whether it is at byte base and completed on byte boundary. - Write Enable (WREN) command: WREN command is required to set the Write Enable Latch bit (WEL) before other commands to change data. - Deep Power Down Mode: By entering deep power down mode, the flash device also is under protected from writing all commands except Release from deep power down mode command (RDP) and Read Electronic Signature command (RES), and softreset command. - Advanced Security Features: there are some protection and security features which protect content from inadvertent write and hostile access. ## I. Block lock protection - The Software Protected Mode (SPM) use (BP3, BP2, BP1, BP0 and T/B) bits to allow part of memory to be protected as read only. The protected area definition is shown as "Table 2. Protected Area Sizes", the protected areas are more flexible which may protect various area by setting value of BP0-BP3 bits. **Table 2. Protected Area Sizes** Protected Area Sizes (T/B bit = 0) | | Statu | ıs bit | | Protect Level | |-----|-------|--------|-----|-----------------------------------------------------------------------| | BP3 | BP2 | BP1 | BP0 | 256Mb | | 0 | 0 | 0 | 0 | 0 (none) | | 0 | 0 | 0 | 1 | 1 (1 block, protected block 511 <sup>th</sup> ) | | 0 | 0 | 1 | 0 | 2 (2 blocks, protected block 510 <sup>th</sup> -511 <sup>th</sup> ) | | 0 | 0 | 1 | 1 | 3 (4 blocks, protected block 508 <sup>th</sup> -511 <sup>th</sup> ) | | 0 | 1 | 0 | 0 | 4 (8 blocks, protected block 504 <sup>th</sup> -511 <sup>th</sup> ) | | 0 | 1 | 0 | 1 | 5 (16 blocks, protected block 496 <sup>th</sup> -511 <sup>th</sup> ) | | 0 | 1 | 1 | 0 | 6 (32 blocks, protected block 480 <sup>th</sup> -511 <sup>th</sup> ) | | 0 | 1 | 1 | 1 | 7 (64 blocks, protected block 448 <sup>th</sup> -511 <sup>th</sup> ) | | 1 | 0 | 0 | 0 | 8 (128 blocks, protected block 384 <sup>th</sup> -511 <sup>th</sup> ) | | 1 | 0 | 0 | 1 | 9 (256 blocks, protected block 256 <sup>th</sup> -511 <sup>th</sup> ) | | 1 | 0 | 1 | 0 | 10 (512 blocks, protected all) | | 1 | 0 | 1 | 1 | 11 (512 blocks, protected all) | | 1 | 1 | 0 | 0 | 12 (512 blocks, protected all) | | 1 | 1 | 0 | 1 | 13 (512 blocks, protected all) | | 1 | 1 | 1 | 0 | 14 (512 blocks, protected all) | | 1 | 1 | 1 | 1 | 15 (512 blocks, protected all) | # Protected Area Sizes (T/B bit = 1) | | Statu | ıs bit | | Protect Level | |-----|-------|--------|-----|---------------------------------------------------------------------| | BP3 | BP2 | BP1 | BP0 | 256Mb | | 0 | 0 | 0 | 0 | 0 (none) | | 0 | 0 | 0 | 1 | 1 (1 block, protected block 0 <sup>th</sup> ) | | 0 | 0 | 1 | 0 | 2 (2 blocks, protected block 0 <sup>th</sup> -1 <sup>st</sup> ) | | 0 | 0 | 1 | 1 | 3 (4 blocks, protected block 0 <sup>th</sup> -3 <sup>rd</sup> ) | | 0 | 1 | 0 | 0 | 4 (8 blocks, protected block 0 <sup>th</sup> -7 <sup>th</sup> ) | | 0 | 1 | 0 | 1 | 5 (16 blocks, protected block 0 <sup>th</sup> -15 <sup>th</sup> ) | | 0 | 1 | 1 | 0 | 6 (32 blocks, protected block 0 <sup>th</sup> -31 <sup>st</sup> ) | | 0 | 1 | 1 | 1 | 7 (64 blocks, protected block 0 <sup>th</sup> -63 <sup>rd</sup> ) | | 1 | 0 | 0 | 0 | 8 (128 blocks, protected block 0 <sup>th</sup> -127 <sup>th</sup> ) | | 1 | 0 | 0 | 1 | 9 (256 blocks, protected block 0 <sup>th</sup> -255 <sup>th</sup> ) | | 1 | 0 | 1 | 0 | 10 (512 blocks, protected all) | | 1 | 0 | 1 | 1 | 11 (512 blocks, protected all) | | 1 | 1 | 0 | 0 | 12 (512 blocks, protected all) | | 1 | 1 | 0 | 1 | 13 (512 blocks, protected all) | | 1 | 1 | 1 | 0 | 14 (512 blocks, protected all) | | 1 | 1 | 1 | 1 | 15 (512 blocks, protected all) | - **II. Additional 4K-bit secured OTP** for unique identifier: to provide a 4K-bit one-time program area for setting a device unique serial number. This may be accomplished in the factory or by system customer. - Security register bit 0 indicates whether the secured OTP area is locked by factory or not. - The 4K-bit secure OTP is programmed by entering secure OTP mode (with Enter Security OTP command), and going through normal program procedure. Exiting secure OTP mode is done by writing Exit Security OTP command. - Customer may lock-down the customer lockable secured OTP by writing WRSCUR(write security register) command to set customer lock-down bit1 as "1". Please refer to "Table 12. Security Register Definition" for security register bit definition and "Table 3. 4K-bit Secured OTP Definition" for address range definition. - Note: Once lock-down whatever by factory or customer, it cannot be changed any more. While in 4K-bit secured OTP mode, array access is not allowed. **Table 3. 4K-bit Secured OTP Definition** | Address range Size | | Standard Factory Lock | Customer Lock | | |--------------------|----------|--------------------------------|------------------------|--| | xxx000-xxx00F | 128-bit | ESN (electrical serial number) | Determined by austemer | | | xxx010-xxx1FF | 3968-bit | N/A | Determined by customer | | # 7. Memory Organization **Table 4. Memory Organization** | | Block(64K-byte) | Block(32K-byte) | Sector | Address | s Range | | |---------------------------|------------------------------------------------|-----------------|--------|----------|----------|--------------------------| | | | | 8191 | 1FFF000h | 1FFFFFFh | : | | | | 1023 | ÷ | i | : | <b>\(\frac{1}{V}\)</b> | | | 511 | | 8184 | 1FF8000h | 1FF8FFFh | individual 16 sectors | | | 311 | | 8183 | 1FF7000h | 1FF7FFFh | lock/unlock unit:4K-byte | | | | 1022 | : | | ÷ | <b>^</b> | | | | | 8176 | 1FF0000h | 1FF0FFFh | | | | 510 | 1021 | 8175 | 1FEF000h | 1FEFFFFh | | | | | | : | : | ÷ | | | | | | 8168 | 1FE8000h | 1FE8FFFh | | | | | 1020 | 8167 | 1FE7000h | 1FE7FFFh | | | • | | | ••• | : | : | | | individual block | | | 8160 | 1FE0000h | 1FE0FFFh | | | lock/unlock unit:64K-byte | | | 8159 | 1FDF000h | 1FDFFFFh | | | | | 1019 | ••• | : | : | | | | 509 | | 8152 | 1FD8000h | 1FD8FFFh | | | | 509 | | 8151 | 1FD7000h | 1FD7FFFh | | | | | 1018 | : | : | : | | | | | | 8144 | 1FD0000h | 1FD0FFFh | | | | <u>. </u> | | | _ | | • | individual block lock/unlock unit:64K-byte | | | | 47 | 002F000h | 002FFFFh | | |---------------------------|----------|---|----|----------|-------------------------------------------------------------------------------------------------------|---| | | | 5 | | i | i | | | | 2 | | 40 | 0028000h | 0028FFFh | | | | _ | | 39 | 027000h | 0027FFFh | | | | | 4 | | : | :<br>0028FFFh | | | individual block | | | 32 | 0020000h | 0020FFFh | | | lock/unlock unit:64K-byte | | | 31 | 001F000h | 0h 0027FFFh : 00h 0020FFFh 00h 001FFFh : 00h 0018FFFh 00h 0017FFFh : 00h 0010FFFh : 00h 0000FFFFh : : | | | <b>A</b> | <b>A</b> | | 3 | | : | ÷ | | | 1 | | 24 | 0018000h | 0018FFFh | | | ! | 1 | 2 | 23 | 0017000h | 0017FFFh | | | | | | | | : | | | | | | 16 | 0010000h | 0010FFFh | | | | | | 15 | 000F000h | 000FFFFh | | | | | 1 | | : | : | | | | | | 8 | 0008000h | 0008FFFh | | | | 0 | | 7 | 0007000h | 0007FFFh | | | | | 0 | | :: | : | | | | | | 0 | 0000000h | 0000FFFh | | #### 8. DEVICE OPERATION - 1. Before a command is issued, status register should be checked to ensure device is ready for the intended operation. - 2. When an incorrect command is written to this device, it enters standby mode and stays in the standby mode until the next CS# falling edge. In standby mode, the device's SO pin should be High-Z.. - 3. When an correct command is written to this device, it enters active mode and stays in the active mode until next CS# rising edge. - 4. Input data is latched on the rising edge of Serial Clock (SCLK) and data shifts out on the falling edge of SCLK. The difference of Serial mode 0 and mode 3 is shown as "Figure 1. Serial Modes Supported". - 5. For the following instructions: RDID, RDSR, RDSCUR, READ, FAST\_READ, 2READ, DREAD, 4READ, QREAD, RDSFDP, RES, REMS, QPIID, RDDPB, RDSPB, RDLR, RDCR, the shifted-in instruction sequence is followed by a data-out sequence. After any bit of data being shifted out, the CS# can be high. For the following instructions: WREN, WRDI, WRSR, SE, BE32K, BE, CE, PP, 4PP, DP, ENSO, EXSO, WRSCUR, WPSEL, GBLK, GBULK, SUSPEND, RESUME, NOP, RSTEN, RST, EQIO, RSTQIO the CS# must go high exactly at the byte boundary; otherwise, the instruction will be rejected and not executed. - 6. While a Write Status Register, Program, or Erase operation is in progress, access to the memory array is ignored and will not affect the current operation of Write Status Register, Program, or Erase. Figure 1. Serial Modes Supported #### Note: CPOL indicates clock polarity of Serial master, CPOL=1 for SCLK high while idle, CPOL=0 for SCLK low while not transmitting. CPHA indicates clock phase. The combination of CPOL bit and CPHA bit decides which Serial mode is supported. Figure 2. Serial Input Timing (STR mode) Figure 3. Serial Input Timing (DTR mode) # Figure 4. Output Timing (STR mode) Figure 5. Output Timing (DTR mode) #### 8-1. 256Mb Address Protocol The original 24 bit address protocol of Serial NOR Flash can only access density size below 128Mb. For the memory device of 256Mb and above, the 32bit address is requested for the access to the higher memory size. The MX25L25745G provides a whole new 4-Byte address protocol, which is backward compatible to the legacy commands. All the command request for 4-Byte (32 bit) address cycle in this device. #### 8-2. Quad Peripheral Interface (QPI) Read Mode QPI protocol enables user to take full advantage of Quad I/O Serial NOR Flash by providing the Quad I/O interface in command cycles, address cycles and as well as data output cycles. #### **Enable QPI mode** By issuing EQIO (35h) command, the QPI mode is enabled. After QPI mode is enabled, the device enters quad mode (4-4-4). Figure 6. Enable QPI Sequence #### Reset QPI (RSTQIO) To reset the QPI mode, the RSTQIO (F5h) command is required. After the RSTQIO command is issued, the device returns from QPI mode (4 I/O interface in command cycles) to SPI mode (1 I/O interface in command cycles). #### Note: For EQIO and RSTQIO commands, CS# high width has to follow "From Write/Erase/Program to Read Status Register" tSHSL specification for next instruction, as defined in "Table 21. AC CHARACTERISTICS (Temperature = -40°C to 85°C, VCC = 2.7V - 3.6V)". Figure 7. Reset QPI Mode # 9. COMMAND DESCRIPTION ## **Table 5. Command Set** # **Read/Write Array Commands** | Command (byte) | READ<br>(normal read) | FAST READ<br>(fast read data) | 2READ<br>(2 x I/O read<br>command) | DREAD<br>(1I 2O read) | 4READ<br>(4 x I/O read<br>command) | QREAD<br>(1I 4O read) | 4DTRD (Quad<br>I/O DT Read) | |----------------|--------------------------------------------|--------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------------------------| | Mode | SPI | SPI | SPI | SPI | SPI/QPI | SPI | SPI/QPI | | Address Bytes | 4 | 4 | 4 | 4 | 4 | 4 | 4 | | 1st byte | 03 (hex) | 0B (hex) | BB (hex) | 3B (hex) | EB (hex) | 6B (hex) | ED (hex) | | 2nd byte | ADD1 | 3rd byte | ADD2 | 4th byte | ADD3 | 5th byte | ADD4 | 6th byte | | Dummy* | Dummy* | Dummy* | Dummy* | Dummy* | Dummy* | | Data Cycles | | | | | | | | | Action | n bytes read<br>out until CS#<br>goes high | n bytes read<br>out until CS#<br>goes high | n bytes read<br>out by 2 x I/O<br>until CS# goes<br>high | n bytes read<br>out by Dual<br>output until<br>CS# goes high | n bytes read<br>out by 4 x I/O<br>until CS# goes<br>high | n bytes read<br>out by Quad<br>output until<br>CS# goes high | n bytes read<br>out (Double<br>Transfer Rate)<br>by 4xl/O until<br>CS# goes high | | Command (byte) | PP<br>(page program) | 4PP<br>(quad page<br>program) | SE<br>(sector erase) | BE 32K<br>(block erase<br>32KB) | BE<br>(block erase<br>64KB) | CE<br>(chip erase) | |----------------|------------------------------|-----------------------------------------------|------------------------------|---------------------------------------|-----------------------------|---------------------| | Mode | SPI/QPI | SPI | SPI/QPI | SPI/QPI | SPI/QPI | SPI/QPI | | Address Bytes | 4 | 4 | 4 | 4 | 4 | 0 | | 1st byte | 02 (hex) | 38 (hex) | 20 (hex) | 52 (hex) | D8 (hex) | 60 or C7 (hex) | | 2nd byte | ADD1 | ADD1 | ADD1 | ADD1 | ADD1 | | | 3rd byte | ADD2 | ADD2 | ADD2 | ADD2 | ADD2 | | | 4th byte | ADD3 | ADD3 | ADD3 | ADD3 | ADD3 | | | 5th byte | ADD4 | ADD4 | ADD4 | ADD4 | ADD4 | | | Data Cycles | 1-256 | 1-256 | | | | | | Action | to program the selected page | quad input to<br>program the<br>selected page | to erase the selected sector | to erase the<br>selected 32K<br>block | to erase the selected block | to erase whole chip | <sup>\*</sup> Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. # **Register/Setting Commands** | register/sett | ing Command | S | | | | | | |-------------------|---------------------------------------------|-----------------------------------------------|-------------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------| | Command<br>(byte) | WREN (write enable) | WRDI<br>(write disable) | FMEN<br>(factory mode<br>enable) | RDSR<br>(read status<br>register) | RDCR<br>(read<br>configuration<br>register) | WRSR<br>(write status/<br>configuration<br>register) | WPSEL<br>(Write Protect<br>Selection) | | Mode | SPI/QPI | SPI/QPI | SPI/QPI | SPI/QPI | SPI/QPI | SPI/QPI | SPI | | 1st byte | 06 (hex) | 04 (hex) | 41 (hex) | 05 (hex) | 15 (hex) | 01 (hex) | 68 (hex) | | 2nd byte | | | | | | Values | | | 3rd byte | | | | | | Values | | | 4th byte | | | | | | | | | 5th byte | | | | | | | | | Data Cycles | | | | | | 1-2 | | | Action | sets the (WEL)<br>write enable<br>latch bit | resets the<br>(WEL) write<br>enable latch bit | enable factory<br>mode | to read out the<br>values of the<br>status register | to read out the<br>values of the<br>configuration<br>register | to write new<br>values of the<br>status/<br>configuration<br>register | to enter and<br>enable individal<br>block protect<br>mode | | Command<br>(byte) | EQIO<br>(Enable QPI) | RSTQIO<br>(Reset QPI) | PGM/ERS<br>Suspend<br>(Suspends<br>Program/<br>Erase) | PGM/ERS<br>Resume<br>(Resumes<br>Program/<br>Erase) | DP (Deep power down) | RDP (Release<br>from deep<br>power down) | SBL<br>(Set Burst<br>Length) | | Mode | SPI | QPI | SPI/QPI | SPI/QPI | SPI/QPI | SPI/QPI | SPI/QPI | | 1st byte | 35 (hex) | F5 (hex) | B0 (hex) | 30 (hex) | B9 (hex) | AB (hex) | C0 (hex) | | 2nd byte | | | | | | | | | 3rd byte | | | | | | | | | 4th byte | | | | | | | | | 5th byte | | | | | | | | | Data Cycles | | | | | | | | | Action | Entering the QPI mode | Exiting the QPI mode | | | enters deep<br>power down<br>mode | release from<br>deep power<br>down mode | to set Burst<br>length | # **ID/Security Commands** | Command<br>(byte) | RDID<br>(read identific-<br>ation) | RES<br>(read electronic<br>ID) | REMS<br>(read electronic<br>manufacturer &<br>device ID) | | RDSFDP | ENSO<br>(enter secured<br>OTP) | EXSO<br>(exit secured<br>OTP) | |-------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------|---------------------------------|-------------------------------|--------------------------------------------|-------------------------------------------| | Mode | SPI | SPI/QPI | SPI | QPI | SPI/QPI | SPI/QPI | SPI/QPI | | Address Bytes | 0 | 0 | 0 | 0 | 3 | 0 | 0 | | 1st byte | 9F (hex) | AB (hex) | 90 (hex) | AF (hex) | 5A (hex) | B1 (hex) | C1 (hex) | | 2nd byte | | x | x | | ADD1 | | | | 3rd byte | | x | x | | ADD2 | | | | 4th byte | | | ADD1 | | ADD3 | | | | 5th byte | | | | | Dummy (8) | | | | Action | outputs JEDEC<br>ID: 1-byte<br>Manufacturer<br>ID & 2-byte<br>Device ID | to read out<br>1-byte Device<br>ID | output the<br>Manufacturer<br>ID & Device ID<br>(Note 2) | ID in QPI<br>interface | Read SFDP<br>mode | to enter the<br>4K-bit secured<br>OTP mode | to exit the<br>4K-bit secured<br>OTP mode | | | DDOOLID | MESSIE | WEGE | 500DD | | 05114 | 0511114 | | Command (byte) | RDSCUR<br>(read security<br>register) | WRSCUR<br>(write security<br>register) | WRSPB<br>(SPB bit<br>program) | ESSPB<br>(all SPB bit<br>erase) | RDSPB<br>(read SPB<br>status) | GBLK<br>(gang block<br>lock) | GBULK<br>(gang block<br>unlock) | | Mode | SPI/QPI | SPI/QPI | SPI | SPI | SPI | SPI | SPI | | Address Bytes | 0 | 0 | 4 | 0 | 4 | 0 | 0 | | 1st byte | 2B (hex) | 2F (hex) | E3 (hex) | E4 (hex) | E2 (hex) | 7E (hex) | 98 (hex) | | 2nd byte | | | ADD1 | | ADD1 | | | | 3rd byte | | | ADD2 | | ADD2 | | | | 4th byte | | | ADD3 | | ADD3 | | | | 5th byte | | | ADD4 | | ADD4 | | | | Data Cycles | | | | | 1 | | | | Action | to read value<br>of security<br>register | to set the lock-<br>down bit as<br>"1" (once lock-<br>down, cannot<br>be updated) | | | | whole chip<br>write protect | whole chip<br>unprotect | | Command (byte) | WRLR<br>(write lock<br>register) | RDLR<br>(read lock<br>register) | WRDPB<br>(write DPB<br>register) | RDDPB<br>(read DPB<br>register) | |----------------|----------------------------------|---------------------------------|----------------------------------|---------------------------------| | Mode | SPI | SPI | SPI | SPI | | Address Bytes | 0 | 0 | 4 | 4 | | 1st byte | 2C (hex) | 2D (hex) | E1 (hex) | E0 (hex) | | 2nd byte | | | ADD1 | ADD1 | | 3rd byte | | | ADD2 | ADD2 | | 4th byte | | | ADD3 | ADD3 | | 5th byte | | | ADD4 | ADD4 | | Data Cycles | 2 | 2 | 1 | 1 | | Action | | | | | #### **Reset Commands** | Command (byte) | NOP<br>(No Operation) | RSTEN<br>(Reset Enable) | RST<br>(Reset<br>Memory) | |----------------|-----------------------|-------------------------|--------------------------| | Mode | SPI/QPI | SPI/QPI | SPI/QPI | | 1st byte | 00 (hex) | 66 (hex) | 99 (hex) | | 2nd byte | | | | | 3rd byte | | | | | 4th byte | | | | | 5th byte | | | | | Action | | | (Note 3) | - Note 1: It is not recommended to adopt any other code not in the command definition table, which will potentially enter the hidden mode. - Note 2: ADD=00H will output the manufacturer ID first and ADD=01H will output device ID first. - Note 3: The RSTEN command must be executed before executing the RST command. If any other command is issued in-between RSTEN and RST, the RST command will be ignored. - Note 4: The number in parentheses after "Dummy" stands for how many clock cycles it has. ## 9-1. Write Enable (WREN) The Write Enable (WREN) instruction sets the Write Enable Latch (WEL) bit. Instructions like PP, 4PP, SE, BE32K, BE, CE, and WRSR are intended to change the device content WEL bit should be set every time after the WREN instruction setting the WEL bit. The sequence of issuing WREN instruction is: CS# goes low→send WREN instruction code→ CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care in SPI mode. Figure 8. Write Enable (WREN) Sequence (SPI Mode) Figure 9. Write Enable (WREN) Sequence (QPI Mode) #### 9-2. Write Disable (WRDI) The Write Disable (WRDI) instruction resets the Write Enable Latch (WEL) bit. The sequence of issuing WRDI instruction is: CS# goes low→sending WRDI instruction code→CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care in SPI mode. The WEL bit is reset in the following situations: - Power-up - RESET# pin driven low - WRDI command completion - WRSR command completion - PP command completion - 4PP command completion - SE command completion - BE32K command completion - BE command completion - CE command completion - PGM/ERS Suspend command completion - Softreset command completion - WRSCUR command completion - WPSEL command completion - GBLK command completion - GBULK command completion - WRLR command completion - WRSPB command completion - WRDPB command completion - ESSPB command completion Figure 10. Write Disable (WRDI) Sequence (SPI Mode) Figure 11. Write Disable (WRDI) Sequence (QPI Mode) ## 9-3. Factory Mode Enable (FMEN) The Factory Mode Enable (FMEN) instruction enhances Program and Erase performance for increase factory production throughput. The FMEN instruction needs to be combined with the instructions which are intended to change the device content, like PP, 4PP, SE, BE32K, BE, and CE. The sequence of issuing FMEN instruction is: CS# goes low $\rightarrow$ send FMEN instruction code $\rightarrow$ CS# goes high. A valid factory mode operation need to included three sequences: WREN instruction $\rightarrow$ FMEN instruction $\rightarrow$ Program or Erase instruction. Suspend command is not acceptable under factory mode. The FMEN is reset by following situations - Power-up - Reset# pin driven low - PP command completion - 4PP command completion - SE command completion - BE32K command completion - BE command completion - CE command completion - Softreset command completion Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care in SPI mode. Figure 12. Factory Mode Enable (FMEN) Sequence (SPI Mode) Figure 13. Factory Mode Enable (FMEN) Sequence (QPI Mode) # 9-4. Read Identification (RDID) The RDID instruction is for reading the 1-byte manufacturer ID and the 2-byte Device Identification (Memory Type and Memory Density) that follows. The Macronix Manufacturer ID and Device ID are listed as *Table 6* ID Definitions. The sequence of issuing RDID instruction is: CS# goes low $\rightarrow$ send RDID instruction code $\rightarrow$ 24-bits ID data out on SO $\rightarrow$ to end RDID operation can drive CS# to high at any time during data out. While Program/Erase operation is in progress, it will not decode the RDID instruction, therefore there's no effect on the cycle of program/erase operation which is currently in progress. When CS# goes high, the device is at standby stage. Figure 14. Read Identification (RDID) Sequence (SPI mode only) #### 9-5. Release from Deep Power-down (RDP), Read Electronic Signature (RES) The Release from Deep Power-down (RDP) instruction is completed by driving Chip Select (CS#) High. When Chip Select (CS#) is driven High, the device is put in the Stand-by Power mode. If the device was not previously in the Deep Power-down mode, the transition to the Stand-by Power mode is immediate. If the device was previously in the Deep Power-down mode, though, the transition to the Stand-by Power mode is delayed by tRES1, and Chip Select (CS#) must remain High for at least tRES1(max), as specified in "Table 21. AC CHARACTERISTICS (Temperature = -40°C to 85°C, VCC = 2.7V - 3.6V)". Once in the Stand-by Power mode, the device waits to be selected, so that it can receive, decode and execute instructions. The RDP instruction is only for releasing from Deep Power Down Mode. Reset# pin goes low will release the Flash from deep power down mode. RES instruction is for reading out the old style of 8-bit Electronic Signature, whose values are shown as "Table 6. ID Definitions". This is not the same as RDID instruction. It is not recommended to use for new design. For new design, please use RDID instruction. The RDP and RES are allowed to execute in Deep Power-down mode, except if the device is in progress of program/erase/write cycle. In this case there's no effect on the current program/erase/write cycle in progress. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. The RES instruction is ended by CS# goes high after the ID been read out at least once. The ID outputs repeatedly if continuously send the additional clock cycles on SCLK while CS# is at low. If the device was not previously in Deep Power-down mode, the device transition to standby mode is immediate. If the device was previously in Deep Power-down mode, there's a delay of tRES2 to transit to standby mode, and CS# must remain to high at least tRES2(max). Once in the standby mode, the device waits to be selected, so it can be receive, decode, and execute instruction. Figure 15. Read Electronic Signature (RES) Sequence (SPI Mode) Figure 16. Read Electronic Signature (RES) Sequence (QPI Mode) Figure 17. Release from Deep Power-down (RDP) Sequence (SPI Mode) Figure 18. Release from Deep Power-down (RDP) Sequence (QPI Mode) #### 9-6. Read Electronic Manufacturer ID & Device ID (REMS) The REMS instruction returns both the JEDEC assigned manufacturer ID and the device ID. The Device ID values are listed in "Table 6. ID Definitions". The REMS instruction is initiated by driving the CS# pin low and sending the instruction code "90h" followed by two dummy bytes and one address byte (A7-A0). After which the manufacturer ID for Macronix (C2h) and the device ID are shifted out on the falling edge of SCLK with the most significant bit (MSB) first. If the address byte is 00h, the manufacturer ID will be output first, followed by the device ID. If the address byte is 01h, then the device ID will be output first, followed by the manufacturer ID. While CS# is low, the manufacturer and device IDs can be read continuously, alternating from one to the other. The instruction is completed by driving CS# high. CS# SCLK Mode 0 Command 2 Dummy Bytes SI 90h High-Z SO CS# **SCLK** ADD (1) SI Manufacturer ID Device ID SO **MSB** MSB MSB Figure 19. Read Electronic Manufacturer & Device ID (REMS) Sequence (SPI Mode only) Notes: (1) ADD=00H will output the manufacturer's ID first and ADD=01H will output device ID first. ## 9-7. QPI ID Read (QPIID) The QPIID Read instruction can be used to identify the Device ID and Manufacturer ID. The sequence of issuing the QPIID instruction is as follows: CS# goes low→send QPI ID instruction→Data out on SO→CS# goes high. Most significant bit (MSB) first. After the command cycle, the device will immediately output data on the falling edge of SCLK. The manufacturer ID, memory type, and device ID data byte will be output continuously, until the CS# goes high. **Table 6. ID Definitions** | Command Type | | MX25L25773G | | | | |--------------|------|-----------------|-------------|----------------|--| | RDID | 9Fh | Manufacturer ID | Memory Type | Memory Density | | | טוטא | 9511 | C2 | 20 | 19 | | | RES | ABh | Electronic ID | | | | | KES | ADII | 18 | | | | | REMS | 90h | Manufacturer ID | Device ID | | | | KEIVIS | 9011 | C2 | 18 | | | | QPIID | AFh | Manufacturer ID | Memory Type | Memory Density | | | QFIID | | C2 | 20 | 19 | | #### 9-8. Read Status Register (RDSR) The RDSR instruction is for reading Status Register Bits. The Read Status Register can be read at any time (even in program/erase/write status register condition). It is recommended to check the Write in Progress (WIP) bit before sending a new instruction when a program, erase, or write status register operation is in progress. The sequence of issuing RDSR instruction is: CS# goes low→ send RDSR instruction code→ Status Register data out on SO. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. Figure 20. Read Status Register (RDSR) Sequence (SPI Mode) Figure 21. Read Status Register (RDSR) Sequence (QPI Mode) ## 9-9. Read Configuration Register (RDCR) The RDCR instruction is for reading Configuration Register Bits. The Read Configuration Register can be read at any time (even in program/erase/write configuration register condition). It is recommended to check the Write in Progress (WIP) bit before sending a new instruction when a program, erase, or write configuration register operation is in progress. The sequence of issuing RDCR instruction is: CS# goes low $\rightarrow$ sending RDCR instruction code $\rightarrow$ Configuration Register data out on SO. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. Figure 22. Read Configuration Register (RDCR) Sequence (SPI Mode) Figure 23. Read Configuration Register (RDCR) Sequence (QPI Mode) For user to check if Program/Erase operation is finished or not, RDSR instruction flow are shown as follows: Figure 24. Program/Erase flow with read array data Figure 25. Program/Erase flow without read array data (read P\_FAIL/E\_FAIL flag) #### **Status Register** The definition of the status register bits is as below: **WIP bit.** The Write in Progress (WIP) bit, a volatile bit, indicates whether the device is busy in program/erase/write status register progress. When WIP bit sets to 1, which means the device is busy in program/erase/write status register progress. When WIP bit sets to 0, which means the device is not in progress of program/erase/write status register cycle. **WEL bit.** The Write Enable Latch (WEL) bit is a volatile bit that is set to "1" by the WREN instruction. WEL needs to be set to "1" before the device can accept program and erase instructions, otherwise the program and erase instructions are ignored. WEL automatically clears to "0" when a program or erase operation completes. To ensure that both WIP and WEL are "0" and the device is ready for the next program or erase operation, it is recommended that WIP be confirmed to be "0" before checking that WEL is also "0" (Please refer to "Figure 28. WRSR flow"). If a program or erase instruction is applied to a protected memory area, the instruction will be ignored and WEL will clear to "0". **BP3**, **BP2**, **BP1**, **BP0** bits. The Block Protect (BP3, BP2, BP1, BP0) bits, non-volatile bits, indicate the protected area (as defined in "Table 2. Protected Area Sizes") of the device to against the program/erase instruction without hardware protection mode being set. To write the Block Protect (BP3, BP2, BP1, BP0) bits requires the Write Status Register (WRSR) instruction to be executed. Those bits define the protected area of the memory to against Page Program (PP), Sector Erase (SE), Block Erase 32KB (BE32K), Block Erase (BE) and Chip Erase (CE) instructions (only if Block Protect bits (BP3:BP0) set to 0, the CE instruction can be executed). The BP3, BP2, BP1, BP0 bits are "0" as default. Which is unprotected. **QE bit.** The Quad Enable (QE) bit is permanently set to "1". When QE is "1", Quad mode is enabled and Quad mode commands are supported along with Single and Dual mode commands. Table 7. Status Register | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |----------|--------------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|--------------------------------------------|-----------------------------------------------------| | Reserved | QE<br>(Quad<br>Enable) | BP3<br>(level of<br>protected<br>block) | BP2<br>(level of<br>protected<br>block) | BP1<br>(level of<br>protected<br>block) | BP0<br>(level of<br>protected<br>block) | WEL<br>(write enable<br>latch) | WIP<br>(write in<br>progress bit) | | Reserved | 1=Quad<br>Enabled<br>0=not Quad<br>Enabled | (note 1) | (note 1) | (note 1) | (note 1) | 1=write<br>enable<br>0=not write<br>enable | 1=write<br>operation<br>0=not in write<br>operation | | Reserved | Non-volatile<br>bit | Non-volatile<br>bit | Non-volatile bit | Non-volatile<br>bit | Non-volatile<br>bit | volatile bit | volatile bit | Note 1: Please refer to the "Table 2. Protected Area Sizes". #### **Configuration Register** The Configuration Register is able to change the default status of Flash memory. Flash memory will be configured after the CR bit is set. #### **ODS** bit The output driver strength (ODS1, ODS0) bits are volatile bits, which indicate the output driver level (as defined in "Table 9. Output Driver Strength Table") of the device. The Output Driver Strength is defaulted as 30 Ohms when delivered from factory. To write the ODS bits requires the Write Status Register (WRSR) instruction to be executed. #### TB bit The Top/Bottom (TB) bit is a non-volatile OTP bit. The Top/Bottom (TB) bit is used to configure the Block Protect area by BP bit (BP3, BP2, BP1, BP0), starting from TOP or Bottom of the memory array. The TB bit is defaulted as "0", which means Top area protect. When it is set as "1", the protect area will change to Bottom area of the memory device. To write the TB bits requires the Write Status Register (WRSR) instruction to be executed. #### PBE bit The Preamble Bit Enable (PBE) bit is a volatile bit. It is used to enable or disable the preamble bit data pattern output on dummy cycles. The PBE bit is defaulted as "0", which means preamble bit is disabled. When it is set as "1", the preamble bit will be enabled, and inputted into dummy cycles. To write the PBE bits requires the Write Status Register (WRSR) instruction to be executed. **Table 8. Configuration Register** | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |--------------|--------------|----------|---------------|--------------|----------|----------------|----------------| | DC1 | DC0 | | PBE | TB | | ODS 1 | ODS 0 | | (Dummy | (Dummy | Reserved | (Preamble bit | (top/bottom | Reserved | (output driver | (output driver | | cycle 1) | cycle 0) | | Enable) | selected) | | strength) | strength) | | | | | | 0=Top area | | | | | | | | 0=Disable | protect | | | | | (Note 2) | (Note 2) | X | | 1=Bottom | X | (Note 1) | (Note 1) | | | | | 1=Enable | area protect | | | | | | | | | (Default=0) | | | | | volatile bit | volatile bit | Х | volatile bit | OTP | Х | volatile bit | volatile bit | Note 1: Please refer to "Table 9. Output Driver Strength Table" Note 2: Please refer to "Table 10. Dummy Cycle and Frequency Table (MHz)" **Table 9. Output Driver Strength Table** | ODS1 | ODS0 | Resistance (Ohm) | Note | |------|------|-------------------|--------------------| | 0 | 0 | 30 Ohms (Default) | | | 0 | 1 | 45 Ohms | Impedance at VCC/2 | | 1 | 0 | 90 Ohms | Impedance at VCC/2 | | 1 | 1 | 15 Ohms | | Table 10. Dummy Cycle and Frequency Table (MHz) (STR Mode) | DC[1:0] | Numbers of Dummy clock cycles | Fast Read | Dual Output Fast<br>Read | Quad Output Fast<br>Read | |--------------|-------------------------------|-----------|--------------------------|--------------------------| | 00 (default) | 8 | 120/133R | 120/133R | 120/133R | | 01 | 8 | 120/133R | 120/133R | 120/133R | | 10 | 8 | 120/133R | 120/133R | 120/133R | | 11 | 8 | 120/133R | 120/133R | 120/133R | | DC[1:0] | Numbers of Dummy clock cycles | Dual IO Fast Read | |--------------|-------------------------------|-------------------| | 00 (default) | 4 | 80 | | 01 | 8 | 120/133R | | 10 | 4 | 80 | | 11 | 8 | 120/133R | | DC[1:0] | Numbers of Dummy clock cycles | Quad IO Fast Read | |--------------|-------------------------------|-------------------| | 00 (default) | 6 | 80 | | 01 | 4 | 54 | | 10 | 8 | 84/104R | | 11 | 10 | 120/133R | # (DTR Mode) | DC[1:0] | Numbers of Dummy clock cycles | Quad IO DTR Read | |--------------|-------------------------------|------------------| | 00 (default) | 6 | 54 | | 01 | 6 | 54 | | 10 | 8 | 70/80R | | 11 | 10 | 84/100R | Note: "R" mean VCC range= 3.0V-3.6V. #### 9-10. Write Status Register (WRSR) The WRSR instruction is for changing the values of Status Register Bits and Configuration Register Bits. Before sending WRSR instruction, the Write Enable (WREN) instruction must be decoded and executed to set the Write Enable Latch (WEL) bit in advance. The WRSR instruction can change the value of Block Protect (BP3, BP2, BP1, BP0) bits to define the protected area of memory (as shown in "Table 2. Protected Area Sizes"), but has no effect on bit1(WEL) and bit0 (WIP) of the status register. The sequence of issuing WRSR instruction is: CS# goes low $\rightarrow$ send WRSR instruction code $\rightarrow$ Status Register data on SI $\rightarrow$ Configuration Register data on SI $\rightarrow$ CS# goes high. The CS# must go high exactly at the 8 bits or 16 bits data boundary; otherwise, the instruction will be rejected and not executed. The self-timed Write Status Register cycle time (tW) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be check out during the Write Status Register cycle is in progress. The WIP sets 1 during the tW timing, and sets 0 when Write Status Register Cycle is completed, and the Write Enable Latch (WEL) bit is reset. Figure 26. Write Status Register (WRSR) Sequence (SPI Mode) **Note:** The CS# must go high exactly at 8 bits or 16 bits data boundary to completed the write register command. Figure 27. Write Status Register (WRSR) Sequence (QPI Mode) # MX25L25773G ## **Software Protected Mode (SPM):** - The WREN instruction may set the WEL bit and can change the values of BP3, BP2, BP1, BP0. The protected area, which is defined by BP3, BP2, BP1, BP0 and T/B bit, is at software protected mode (SPM). **Table 11. Protection Modes** | Mode | Status register condition | Memory | |--------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------| | Software protection mode (SPM) | Status register can be written in (WEL bit is set to "1") and the BP0-BP3 bits can be changed | The protected area cannot be programmed or erased. | Note: As defined by the values in the Block Protect (BP3, BP2, BP1, BP0) bits of the Status Register, as shown in "Table 2. Protected Area Sizes". Figure 28. WRSR flow ### 9-11. Read Data Bytes (READ) The read instruction is for reading data out. The address is latched on rising edge of SCLK, and data shifts out on the falling edge of SCLK at a maximum frequency fR. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single READ instruction. The address counter rolls over to 0 when the highest address has been reached. The sequence of issuing READ instruction is: CS# goes low $\rightarrow$ sending READ instruction code $\rightarrow$ 4-byte address on SI $\rightarrow$ data out on SO $\rightarrow$ to end READ operation can use CS# to high at any time during data out. While Program/Erase/Write Status Register cycle is in progress, READ instruction is rejected without any impact on the Program/Erase/Write Status Register current cycle. Figure 29. Read Data Bytes (READ) Sequence (SPI Mode only) ### 9-12. Read Data Bytes at Higher Speed (FAST\_READ) The FAST\_READ instruction is for quickly reading data out. The address is latched on rising edge of SCLK, and data of each bit shifts out on the falling edge of SCLK at a maximum frequency fC. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single FAST\_READ instruction. The address counter rolls over to 0 when the highest address has been reached. The sequence of issuing FAST\_READ instruction is: CS# goes low $\rightarrow$ send FAST\_READ instruction code $\rightarrow$ 4-byte address on SI $\rightarrow$ 8 dummy cycles (default) $\rightarrow$ data out on SO $\rightarrow$ to end FAST\_READ operation can use CS# to high at any time during data out. While Program/Erase/Write Status Register cycle is in progress, FAST\_READ instruction is rejected without any impact on the Program/Erase/Write Status Register current cycle. Figure 30. Read at Higher Speed (FAST\_READ) Sequence (SPI Mode only) **Note:** Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. ### 9-13. Dual Output Read Mode (DREAD) The DREAD instruction enables double throughput of the Serial NOR Flash in read mode. The address is latched on rising edge of SCLK, and data of every two bits (interleave on 2 I/O pins) shift out on the falling edge of SCLK at a maximum frequency fT. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single DREAD instruction. The address counter rolls over to 0 when the highest address has been reached. Once writing DREAD instruction, the following data out will perform as 2-bit instead of previous 1-bit. The sequence of issuing DREAD instruction is: CS# goes low $\rightarrow$ send DREAD instruction $\rightarrow$ 4-byte address on SIO0 $\rightarrow$ 8 dummy cycles (default) on SIO0 $\rightarrow$ data out interleave on SIO1 & SIO0 $\rightarrow$ to end DREAD operation, user can use CS# to high at any time during data out. While Program/Erase/Write Status Register cycle is in progress, DREAD instruction is rejected without any impact on the Program/Erase/Write Status Register current cycle. Figure 31. Dual Read Mode Sequence (SPI Mode only) **Note:** Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. ### 9-14. 2 x I/O Read Mode (2READ) The 2READ instruction enables double throughput of the Serial NOR Flash in read mode. The address is latched on rising edge of SCLK, and data of every two bits (interleave on 2 I/O pins) shift out on the falling edge of SCLK at a maximum frequency fT. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single 2READ instruction. The address counter rolls over to 0 when the highest address has been reached. Once writing 2READ instruction, the following address/dummy/data out will perform as 2-bit instead of previous 1-bit. The sequence of issuing 2READ instruction is: CS# goes low $\rightarrow$ send 2READ instruction $\rightarrow$ 4-byte address interleave on SIO1 & SIO0 $\rightarrow$ 4 dummy cycles (default) on SIO1 & SIO0 $\rightarrow$ data out interleave on SIO1 & SIO0 $\rightarrow$ to end 2READ operation can use CS# to high at any time during data out. While Program/Erase/Write Status Register cycle is in progress, 2READ instruction is rejected without any impact on the Program/Erase/Write Status Register current cycle. Figure 32. 2 x I/O Read Mode Sequence (SPI Mode only) **Note:** Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. #### 9-15. Quad Read Mode (QREAD) The QREAD instruction enables quad throughput of the Serial NOR Flash in read mode. The address is latched on rising edge of SCLK, and data of every four bits (interleave on 4 I/O pins) shift out on the falling edge of SCLK at a maximum frequency fQ. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single QREAD instruction. The address counter rolls over to 0 when the highest address has been reached. Once writing QREAD instruction, the following data out will perform as 4-bit instead of previous 1-bit. The sequence of issuing QREAD instruction is: CS# goes low $\rightarrow$ send QREAD instruction $\rightarrow$ 4-byte address on SI $\rightarrow$ 8 dummy cycles $\rightarrow$ data out interleave on SIO3, SIO2, SIO1 & SIO0 $\rightarrow$ to end QREAD operation, user can use CS# to high at any time during data out. While Program/Erase/Write Status Register cycle is in progress, QREAD instruction is rejected without any impact on the Program/Erase/Write Status Register current cycle. Figure 33. Quad Read Mode Seguence (SPI Mode only) # MX25L25773G ### 9-16. 4 x I/O Read Mode (4READ) The 4READ instruction enables quad throughput of the the Serial NOR Flash in read mode. The address is latched on rising edge of SCLK, and data of every four bits (interleave on 4 I/O pins) shift out on the falling edge of SCLK at a maximum frequency fQ. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single 4READ instruction. The address counter rolls over to 0 when the highest address has been reached. Once writing 4READ instruction, the following address/dummy/data out will perform as 4-bit instead of previous 1-bit. **4 x I/O Read on SPI Mode (4READ)** The sequence of issuing 4READ instruction is: CS# goes low $\rightarrow$ send 4READ instruction $\rightarrow$ 4-byte address interleave on SIO3, SIO2, SIO1 & SIO0 $\rightarrow$ 6 dummy cycles (Default) $\rightarrow$ data out interleave on SIO3, SIO2, SIO1 & SIO0 $\rightarrow$ to end 4READ operation can use CS# to high at any time during data out. **4 x I/O Read on QPI Mode (4READ)** The 4READ instruction also support on QPI command mode. The sequence of issuing 4READ instruction QPI mode is: CS# goes low→ send 4READ instruction→ 4-byte address interleave on SIO3, SIO2, SIO1 & SIO0→ 6 dummy cycles (Default) →data out interleave on SIO3, SIO2, SIO1 & SIO0→ to end 4READ operation, user can use CS# to high at any time during data out. While Program/Erase/Write Status Register cycle is in progress, 4READ instruction is rejected without any impact on the Program/Erase/Write Status Register current cycle. Figure 34. 4 x I/O Read Mode Sequence (SPI Mode) #### Notes: - 1. Hi-impedance is inhibited for the two clock cycles. - 2. P7≠P3, P6≠P2, P5≠P1 & P4≠P0 (Toggling) is inhibited. - 3. Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. Figure 35. 4 x I/O Read Mode Sequence (QPI Mode) #### Notes: - 1. Hi-impedance is inhibited for the two clock cycles. - 2. P7≠P3, P6≠P2, P5≠P1 & P4≠P0 (Toggling) is inhibited. - 3. Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. # MX25L25773G ### 9-17. 4 x I/O Double Transfer Rate Read Mode (4DTRD) The 4DTRD instruction enables Double Transfer Rate throughput on quad I/O of the Serial NOR Flash in read mode. The address (interleave on 4 I/O pins) is latched on both rising and falling edge of SCLK, and data (interleave on 4 I/O pins) shift out on both rising and falling edge of SCLK. The 8-bit address can be latched-in at one clock, and 8-bit data can be read out at one clock, which means four bits at rising edge of clock, the other four bits at falling edge of clock. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single 4DTRD instruction. The address counter rolls over to 0 when the highest address has been reached. Once writing 4DTRD instruction, the following address/dummy/data out will perform as 8-bit instead of previous 1-bit. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care during SPI mode. While Program/Erase/Write Status Register cycle is in progress, 4DTRD instruction is rejected without any impact on the Program/Erase/Write Status Register current cycle. Figure 36. Fast Quad I/O DT Read (4DTRD) Sequence (SPI Mode) #### Notes: - 1. Hi-impedance is inhibited for this clock cycle. - 2. P7#P3, P6#P2, P5#P1 & P4#P0 (Toggling) will result in entering the performance enhance mode. - 3. Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. Figure 37. Fast Quad I/O DT Read (4DTRD) Sequence (QPI Mode) **Notes:** Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. ### 9-18. Preamble Bit The Preamble Bit data pattern supports system/memory controller to determine valid window of data output more easily and improve data capture reliability while the flash memory is running in high frequency. Preamble Bit data pattern can be enabled or disabled by setting the bit4 of Configuration register (Preamble bit Enable bit). Once the CR<4> is set, the preamble bit is inputted into dummy cycles. Enabling preamble bit will not affect the function of enhance mode bit. In Dummy cycles, performance enhance mode bit still operates with the same function. Preamble bit will output after performance enhance mode bit. The preamble bit is a fixed 8-bit data pattern (00110100). While dummy cycle number reaches 10, the complete 8 bits will start to output right after the performance enhance mode bit. While dummy cycle is not sufficient of 10 cycles, the rest of the preamble bits will be cut. For example, 8 dummy cycles will cause 6 preamble bits to output, and 6 dummy cycles will cause 4 preamble bits to output. Figure 38. SDR 1I/O (10DC) Figure 39. SDR 1I/O (8DC) # Figure 40. SDR 2I/O (10DC) # Figure 41. SDR 2I/O (8DC) # Figure 42. SDR 4I/O (10DC) # Figure 43. SDR 4I/O (8DC) ## Figure 44. DTR4IO (6DC) #### 9-19. Burst Read The Burst Read feature allows applications to fill a cache line with a fixed length of data without using multiple read commands. Burst Read is disabled by default at power-up or reset. Burst Read is enabled by setting the Burst Length. When the Burst Length is set, reads will wrap on the selected boundary (8/16/32/64-bytes) containing the initial target address. For example if an 8-byte Wrap Depth is selected, reads will wrap on the 8-byte-page-aligned boundary containing the initial read address. To set the Burst Length, drive CS# low $\rightarrow$ send SET BURST LENGTH instruction code (C0h) $\rightarrow$ send WRAP CODE $\rightarrow$ drive CS# high. Refer to the table below for valid 8-bit Wrap Codes and their corresponding Wrap Depth. | Data | Wrap Around | Wrap Depth | |------|-------------|------------| | 00h | Yes | 8-byte | | 01h | Yes | 16-byte | | 02h | Yes | 32-byte | | 03h | Yes | 64-byte | | 1xh | No | X | Once Burst Read is enabled, it will remain enabled until the device is power-cycled or reset. The SPI and QPI mode 4READ read command supports the wrap around feature after Burst Read is enabled. To change the wrap depth, resend the Burst Read instruction with the appropriate Wrap Code. To disable Burst Read, send the Burst Read instruction with Wrap Code 1xh. QPI and SPI "EBh" supports wrap around feature after wrap around is enabled. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care during SPI mode. Figure 45. Burst Read (SPI Mode) Figure 46. Burst Read (QPI Mode) Note: MSB=Most Significant Bit LSB=Least Significant Bit # MX25L25773G ### 9-20. Performance Enhance Mode - XIP (execute-in-place) The device could waive the command cycle bits if the two cycle bits after address cycle toggles. Performance enhance mode is supported in both SPI and QPI mode. In QPI mode, "EBh" "EDh" and SPI "EBh" "EDh" commands support enhance mode. The performance enhance mode is not supported in dual I/O mode. To enter performance-enhancing mode, P[7:4] must be toggling with P[3:0]; likewise P[7:0]=A5h, 5Ah, F0h or 0Fh can make this mode continue and skip the next 4READ instruction. To leave enhance mode, P[7:4] is no longer toggling with P[3:0]; likewise P[7:0]=FFh, 00h, AAh or 55h along with CS# is afterwards raised and then lowered. Issuing "FFh" data cycle can also exit enhance mode. The system then will leave performance enhance mode and return to normal operation. To conduct the Performance Enhance Mode Reset operation in SPI mode, 3FFh data cycle(10 clocks), should be issued in 1I/O sequence. In QPI Mode, FFFFFFFFh data cycle (10 clocks), in 4I/O should be issued. If the system controller is being Reset during operation, the flash device will return to the standard SPI operation. After entering enhance mode, following CS# go high, the device will stay in the read mode and treat CS# go low of the first clock as address instead of command cycle. This sequence of issuing 4READ instruction especially useful in random access: CS# goes low→send 4READ instruction→4-bytes address interleave on SIO3, SIO2, SIO1 & SIO0→performance enhance toggling bit P[7:0]→ 4 dummy cycles (Default) →data out until CS# goes high → CS# goes low (The following 4READ instruction is not allowed, hence 8 cycles of 4READ can be saved comparing to normal 4READ mode) →4-bytes random access address. Figure 47. 4 x I/O Read Performance Enhance Mode Sequence (SPI Mode) #### Notes: - 1. If not using performance enhance recommend to keep 1 or 0 in performance enhance indicator. - 2. Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. - 3. Reset the performance enhance mode, if P7=P3 or P6=P2 or P5=P1 or P4=P0, ex: AA, 00, FF. Figure 48. 4 x I/O Read Performance Enhance Mode Sequence (QPI Mode) ### Notes: - 1. Configuration Dummy cycle numbers will be different depending on the bit6 & bit 7 (DC0 & DC1) setting in configuration register. - 2. Reset the performance enhance mode, if P7=P3 or P6=P2 or P5=P1 or P4=P0, ex: AA, 00, FF. ### 9-21. Sector Erase (SE) The Sector Erase (SE) instruction is for erasing the data of the chosen sector to be "1". The instruction is used for any 4K-byte sector. A Write Enable (WREN) instruction must execute to set the Write Enable Latch (WEL) bit before sending the Sector Erase (SE). Any address of the sector (Please refer to "Table 4. Memory Organization") is a valid address for Sector Erase (SE) instruction. The CS# must go high exactly at the byte boundary (the least significant bit of the address byte been latched-in); otherwise, the instruction will be rejected and not executed. The sequence of issuing SE instruction is: CS# goes low $\rightarrow$ send SE instruction code $\rightarrow$ 4-byte address on SI $\rightarrow$ CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. The self-timed Sector Erase Cycle time (tSE) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while the Sector Erase cycle is in progress. The WIP sets 1 during the tSE timing, and clears when Sector Erase Cycle is completed, and the Write Enable Latch (WEL) bit is cleared. If the Block is protected by BP bits (WPSEL=0; Block Protect Mode) or SPB (WPSEL=1; Individual Sector Protect Mode), the Sector Erase (SE) instruction will not be executed on the block. Figure 49. Sector Erase (SE) Sequence (SPI Mode) Figure 50. Sector Erase (SE) Sequence (QPI Mode) ### 9-22. Block Erase (BE32K) The Block Erase (BE32K) instruction is for erasing the data of the chosen block to be "1". The instruction is used for 32K-byte block erase operation. A Write Enable (WREN) instruction must be executed to set the Write Enable Latch (WEL) bit before sending the Block Erase (BE32K). Any address of the block (Please refer to "Table 4. Memory Organization") is a valid address for Block Erase (BE32K) instruction. The CS# must go high exactly at the byte boundary (the least significant bit of address byte been latched-in); otherwise, the instruction will be rejected and not executed. Address bits [Am-A15] (Am is the most significant address) select the 32KB block address. The sequence of issuing BE32K instruction is: CS# goes low $\rightarrow$ send BE32K instruction code $\rightarrow$ 4-byte address on SI $\rightarrow$ CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care during SPI mode. The self-timed Block Erase Cycle time (tBE32K) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while during the Block Erase cycle is in progress. The WIP sets during the tBE32K timing, and clears when Block Erase Cycle is completed, and the Write Enable Latch (WEL) bit is cleared. If the Block is protected by BP bits (WPSEL=0; Block Protect Mode) or SPB (WPSEL=1; Individual Sector Protect Mode), the Block Erase (BE32K) instruction will not be executed on the block. Figure 51. Block Erase 32KB (BE32K) Sequence (SPI Mode) Figure 52. Block Erase 32KB (BE32K) Sequence (QPI Mode) ### 9-23. Block Erase (BE) The Block Erase (BE) instruction is for erasing the data of the chosen block to be "1". The instruction is used for 64K-byte block erase operation. A Write Enable (WREN) instruction must be executed to set the Write Enable Latch (WEL) bit before sending the Block Erase (BE). Any address of the block (Please refer to "Table 4. Memory Organization") is a valid address for Block Erase (BE) instruction. The CS# must go high exactly at the byte boundary (the least significant bit of address byte been latched-in); otherwise, the instruction will be rejected and not executed. The sequence of issuing BE instruction is: CS# goes low $\rightarrow$ send BE instruction code $\rightarrow$ 4-byte address on SI $\rightarrow$ CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. The self-timed Block Erase Cycle time (tBE) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while the Block Erase cycle is in progress. The WIP sets during the tBE timing, and clears when Block Erase Cycle is completed, and the Write Enable Latch (WEL) bit is reset. If the Block is protected by BP bits (WPSEL=0; Block Protect Mode) or SPB (WPSEL=1; Individual Sector Protect Mode), the Block Erase (BE) instruction will not be executed on the block. Figure 54. Block Erase (BE) Sequence (QPI Mode) ### 9-24. Chip Erase (CE) The Chip Erase (CE) instruction is for erasing the data of the whole chip to be "1". A Write Enable (WREN) instruction must be executed to set the Write Enable Latch (WEL) bit before sending the Chip Erase (CE). The CS# must go high exactly at the byte boundary, otherwise the instruction will be rejected and not executed. The sequence of issuing CE instruction is: CS# goes low→send CE instruction code→CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. The self-timed Chip Erase Cycle time (tCE) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while the Chip Erase cycle is in progress. The WIP sets during the tCE timing, and clears when Chip Erase Cycle is completed, and the Write Enable Latch (WEL) bit is cleared. When the chip is under "Block protect (BP) Mode" (WPSEL=0). The Chip Erase (CE) instruction will not be executed, if one (or more) sector is protected by BP3-BP0 bits. It will be only executed when BP3-BP0 all set to "0". When the chip is under "Individual Sector Protect Mode" (WPSEL=1). The Chip Erase (CE) instruction will be executed on unprotected block. The protected Block will be skipped. If one (or more) 4K byte sector was protected in top or bottom 64K byte block, the protected block will also skip the chip erase command. Figure 55. Chip Erase (CE) Sequence (SPI Mode) Figure 56. Chip Erase (CE) Sequence (QPI Mode) ## 9-25. Page Program (PP) The Page Program (PP) instruction is for programming memory bits to "0". One to 256 bytes can be sent to the device to be programmed. A Write Enable (WREN) instruction must be executed to set the Write Enable Latch (WEL) bit before sending the Page Program (PP). If more than 256 data bytes are sent to the device, only the last 256 data bytes will be accepted and the previous data bytes will be disregarded. The Page Program instruction requires that all the data bytes fall within the same 256-byte page. The low order address byte A[7:0] specifies the starting address within the selected page. Bytes that will cross a page boundary will wrap to the beginning of the selected page. The device can accept (256 minus A[7:0]) data bytes without wrapping. If 256 data bytes are going to be programmed, A[7:0] should be set to 0. The sequence of issuing PP instruction is: CS# goes low $\rightarrow$ send PP instruction code $\rightarrow$ 4-byte address on SI $\rightarrow$ at least 1-byte on data on SI $\rightarrow$ CS# goes high. The CS# must be kept to low during the whole Page Program cycle; The CS# must go high exactly at the byte boundary (the latest eighth bit of data being latched in), otherwise the instruction will be rejected and will not be executed. The self-timed Page Program Cycle time (tPP) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while the Page Program cycle is in progress. The WIP sets during the tPP timing, and clears when Page Program Cycle is completed, and the Write Enable Latch (WEL) bit is cleared. If the page is protected by BP bits (WPSEL=0; Block Protect Mode) or SPB (WPSEL=1; Individual Sector Protect Mode), the Page Program (PP) instruction will not be executed. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. Figure 57. Page Program (PP) Sequence (SPI Mode) Figure 58. Page Program (PP) Sequence (QPI Mode) ### 9-26. 4 x I/O Page Program (4PP) The Quad Page Program (4PP) instruction is for programming the memory to be "0". A Write Enable (WREN) instruction must be executed to set the Write Enable Latch (WEL) bit before sending the Quad Page Program (4PP). The Quad Page Programming takes four pins: SIO0, SIO1, SIO2, and SIO3 as address and data input, which can improve programmer performance and the effectiveness of application. The other function descriptions are as same as standard page program. The sequence of issuing 4PP instruction is: CS# goes low→ send 4PP instruction code→ 4-byte address on $SIO[3:0] \rightarrow at least 1-byte on data on <math>SIO[3:0] \rightarrow CS\#$ goes high. If the page is protected by BP bits (WPSEL=0; Block Protect Mode) or SPB (WPSEL=1; Individual Sector Protect Mode), the Quad Page Program (4PP) instruction will not be executed. Figure 59. 4 x I/O Page Program (4PP) Sequence (SPI Mode only) ### 9-27. Deep Power-down (DP) The Deep Power-down (DP) instruction places the device into a minimum power consumption state, Deep Power-down mode, in which the guiescent current is reduced from ISB1 to ISB2. The sequence of issuing DP instruction: CS# goes low— send DP instruction code— CS# goes high. The CS# must go high at the byte boundary (after exactly eighth bits of the instruction code have been latched-in); otherwise the instruction will not be executed. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. SIO[3:1] are "don't care". After CS# goes high there is a delay of tDP before the device transitions from Stand-by mode to Deep Power-down mode and before the current reduces from ISB1 to ISB2. Once in Deep Power-down mode, all instructions will be ignored except Release from Deep Power-down (RDP). The device exits Deep Power-down mode and returns to Stand-by mode if it receives a Release from Deep Power-down (RDP) instruction, power-cycle, or reset. Figure 61. Deep Power-down (DP) Sequence (QPI Mode) # MX25L25773G #### 9-28. Enter Secured OTP (ENSO) The ENSO instruction is for entering the additional 4K-bit secured OTP mode. While device is in 4K-bit secured OTPmode, main array access is not available. The additional 4K-bit secured OTP is independent from main array and may be used to store unique serial number for system identifier. After entering the Secured OTP mode, follow standard read or program procedure to read out the data or update data. The Secured OTP data cannot be updated again once it is lock-down. The sequence of issuing ENSO instruction is: CS# goes low $\rightarrow$ send ENSO instruction to enter Secured OTP mode $\rightarrow$ CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. Please note that after issuing ENSO command user can only access secure OTP region with standard read or program procedure. Furthermore, once security OTP is lock down, only read related commands are valid. ## 9-29. Exit Secured OTP (EXSO) The EXSO instruction is for exiting the additional 4K-bit secured OTP mode. The sequence of issuing EXSO instruction is: CS# goes low→ send EXSO instruction to exit Secured OTP mode→ CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. ## 9-30. Write Security Register (WRSCUR) The WRSCUR instruction is for changing the values of Security Register Bits. The WREN (Write Enable) instruction is required before issuing WRSCUR instruction. The WRSCUR instruction may change the values of bit1 (LDSO bit) for customer to lock-down the 4K-bit Secured OTP area. Once the LDSO bit is set to "1", the Secured OTP area cannot be updated any more. The sequence of issuing WRSCUR instruction is :CS# goes low $\rightarrow$ send WRSCUR instruction $\rightarrow$ CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. The CS# must go high exactly at the boundary; otherwise, the instruction will be rejected and not executed. Figure 62. Write Security Register (WRSCUR) Sequence (SPI Mode) Figure 63. Write Security Register (WRSCUR) Sequence (QPI Mode) ## 9-31. Read Security Register (RDSCUR) The RDSCUR instruction is for reading the value of Security Register bits. The Read Security Register can be read at any time (even in program/erase/write status register/write security register condition) and continuously. The sequence of issuing RDSCUR instruction is : CS# goes low $\rightarrow$ send RDSCUR instruction $\rightarrow$ Security Register data out on SO $\rightarrow$ CS# goes high. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. Figure 64. Read Security Register (RDSCUR) Sequence (SPI Mode) Figure 65. Read Security Register (RDSCUR) Sequence (QPI Mode) ## **Security Register** The definition of the Security Register bits is as below: Write Protection Selection bit. Please reference to "9-32. Write Protection Selection (WPSEL)". **Erase Fail Flag bit.** The Erase Fail bit indicates the status of last Erase operation. The bit will be set to "1" if the erase operation failed or the erase region is protected. It will be automatically cleared to "0" if the next erase operation succeeds. Please note that it does not interrupt or stop any operation in the flash memory. **Program Fail Flag bit.** The Program Fail bit indicates the status of last Program operation. The bit will be set to "1" if the program operation failed or the program region is protected. It will be automatically cleared to "0" if the next program operation succeeds. Please note that it does not interrupt or stop any operation in the flash memory. **Erase Suspend bit.** Erase Suspend Bit (ESB) indicates the status of Erase Suspend operation. Users may use ESB to identify the state of flash memory. After the flash memory is suspended by Erase Suspend command, ESB is set to "1". ESB is cleared to "0" after erase operation resumes. **Program Suspend bit.** Program Suspend Bit (PSB) indicates the status of Program Suspend operation. Users may use PSB to identify the state of flash memory. After the flash memory is suspended by Program Suspend command, PSB is set to "1". PSB is cleared to "0" after program operation resumes. **Secured OTP Indicator bit.** The Secured OTP indicator bit shows the secured OTP area is locked by factory or not. When it is "0", it indicates non-factory lock; "1" indicates factory-lock. **Lock-down Secured OTP (LDSO) bit.** By writing WRSCUR instruction, the LDSO bit may be set to "1" for customer lock-down purpose. However, once the bit is set to "1" (lock-down), the LDSO bit and the 4K-bit Secured OTP area cannot be updated any more. While it is in 4K-bit secured OTP mode, main array access is not allowed. Table 12. Security Register Definition | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-----------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------|--------------|---------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------| | WPSEL | E_FAIL | P_FAIL | Reserved | ESB<br>(Erase<br>Suspend bit) | PSB<br>(Program<br>Suspend bit) | LDSO<br>(indicate if<br>lock-down) | Secured OTP indicator bit | | 0=Block Lock (BP) protection mode 1=Individual Sector protection mode (default=0) | 0=normal<br>Erase<br>succeed<br>1=indicate<br>Erase failed<br>(default=0) | 0=normal Program succeed 1=indicate Program failed (default=0) | - | 0=Erase is not suspended 1= Erase suspended (default=0) | 0=Program is not suspended 1= Program suspended (default=0) | 0 = not lock-<br>down<br>1 = lock-down<br>(OTP, cannot<br>programmed/<br>erased then) | l lock l | | Non-volatile bit (OTP) | Volatile bit | Volatile bit | Volatile bit | Volatile bit | Volatile bit | Non-volatile bit (OTP) | Non-volatile bit (OTP) | ## 9-32. Write Protection Selection (WPSEL) There are two write protection methods provided on this device, (1) Block Protection (BP) mode or (2) Individual Sector Protection mode. The protection modes are mutually exclusive. The WPSEL bit selects which protection mode is enabled. If WPSEL=0 (factory default), BP mode is enabled and Individual Sector Protection mode is disabled. If WPSEL=1, Individual Sector Protection mode is enabled and BP mode is disabled. The WPSEL command is used to set WPSEL=1. A WREN command must be executed to set the WEL bit before sending the WPSEL command. Please note that the WPSEL bit is an OTP bit. Once WPSEL is set to "1", it cannot be programmed back to "0". ### When WPSEL = 0: Block Lock (BP) protection mode, The memory array is write protected by the BP3-BP0 bits. ### When WPSEL =1: Individual Sector protection mode, Blocks are individually protected by their own SPB or DPB. On power-up, all blocks are write protected by the Dynamic Protection Bits (DPB) by default. The Individual Sector Protection instructions WRLR, RDLR, WRSPB, ESSPB, WRDPB, RDDPB, GBLK, and GBULK are activated. The BP3 to BP0 bits of the Status Register are disabled and have no effect. The sequence of issuing WPSEL instruction is: CS# goes low $\rightarrow$ send WPSEL instruction to enable the Individual Sector Protect mode $\rightarrow$ CS# goes high. Figure 67. WPSEL Flow #### 9-33. Advanced Sector Protection Advanced Sector Protection can protect individual 4KB sectors in the bottom and top 64KB of memory and protect individual 64KB blocks in the rest of memory. There is one non-volatile Solid Protection Bit (SPB) and one volatile Dynamic Protection Bit (DPB) assigned to each 4KB sector at the bottom and top 64KB of memory and to each 64KB block in the rest of memory. A sector or block is write-protected from programming or erasing when its associated SPB or DPB is set to "1". Please refer to "9-33-5. Sector Protection States Summary Table" for the sector state with the protection status of DPB/SPB bits. The figure below helps describing an overview of these methods. The device is default to the Solid mode when shipped from factory. The detail algorithm of advanced sector protection is shown as follows: Solid Protection mode permits the SPB bits to be modified after power-on or a reset. The figure below is an overview of Advanced Sector Protection. Figure 68. Advanced Sector Protection Overview ## 9-33-1. Lock Register The Lock Register is a 16-bit one-time programmable register. Lock Register bit [6] is SPB Lock Down Bit (SPBLKDN) which is an unique bit assigned to control all SPB bit status. When SPBLKDN is 1, SPB can be changed. When it is locked as 0, all SPB can not be changed anymore, and SPBLKDN bit itself can not be altered anymore, either. The Lock Register is programmed using the WRLR (Write Lock Register) command. A WREN command must be executed to set the WEL bit before sending the WRLR command. Table 13. Lock Register | Bits | Field Name | Function | Type | Default<br>State | Description | |---------|------------|---------------|------|------------------|--------------------------------------| | 15 to 7 | RFU | Reserved | OTP | 1 | Reserved for Future Use | | 6 | SPBLKDN | SPB Lock Down | OTP | 1 | 1 = SPB changeable<br>0 = freeze SPB | | 5 to 0 | RFU | Reserved | OTP | 1 | Reserved for Future Use | Figure 69. Read Lock Register (RDLR) Sequence Figure 70. Write Lock Register (WRLR) Sequence # MX25L25773G #### 9-33-2. Solid Protection Bits The Solid Protection Bits (SPBs) are nonvolatile bits for enabling or disabling write-protection to sectors and blocks. The SPB bits have the same endurance as the Flash memory. An SPB is assigned to each 4KB sector in the bottom and top 64KB of memory and to each 64KB block in the remaining memory. The factory default state of the SPB bits is "0", which has the sector/block write-protection disabled. When an SPB is set to "1", the associated sector or block is write-protected. Program and erase operations on the sector or block will be inhibited. SPBs can be individually set to "1" by the WRSPB command. However, the SPBs cannot be individually cleared to "0". Issuing the ESSPB command clears all SPBs to "0". A WREN command must be executed to set the WEL bit before sending the WRSPB or ESSPB command. The RDSPB command reads the status of the SPB of a sector or block. The RDSPB command returns 00h if the SPB is "0", indicating write-protection is disabled. The RDSPB command returns FFh if the SPB is "1", indicating write-protection is enabled. **Note:** If SPBLKDN=0, commands to set or clear the SPB bits will be ignored. Table 14. SPB Register | Bit | Description | Bit Status | Default | Type | |--------|----------------------------|----------------------------------------------------------------|---------|--------------| | 7 to 0 | SPB (Solid Protection Bit) | 00h = Unprotect Sector / Block<br>FFh = Protect Sector / Block | 00h | Non-volatile | Figure 71. Read SPB Status (RDSPB) Sequence Figure 72. SPB Erase (ESSPB) Sequence Figure 73. SPB Program (WRSPB) Sequence #### 9-33-3. Dynamic Protection Bits The Dynamic Protection Bits (DPBs) are volatile bits for quickly and easily enabling or disabling write-protection to sectors and blocks. A DPB is assigned to each 4KB sector in the bottom and top 64KB of memory and to each 64KB block in the rest of the memory. The DBPs can enable write-protection on a sector or block regardless of the state of the corresponding SPB. However, the DPB bits can only unprotect sectors or blocks whose SPB bits are "0" (unprotected). When a DPB is "1", the associated sector or block will be write-protected, preventing any program or erase operation on the sector or block. All DPBs default to "1" after power-on or reset. When a DPB is cleared to "0", the associated sector or block will be unprotected if the corresponding SPB is also "0". DPB bits can be individually set to "1" or "0" by the WRDPB command. The DBP bits can also be globally cleared to "0" with the GBULK command or globally set to "1" with the GBLK command. A WREN command must be executed to set the WEL bit before sending the WRDPB, GBULK, or GBLK command. The RDDPB command reads the status of the DPB of a sector or block. The RDDPB command returns 00h if the DPB is "0", indicating write-protection is disabled. The RDDPB command returns FFh if the DPB is "1", indicating write-protection is enabled. Table 15. DPB Register | İ | Bit | Description | Bit Status | Default | Type | |---|--------|------------------------------|----------------------------------------------------------------|---------|----------| | | 7 to 0 | DPB (Dynamic Protection Bit) | 00h = Unprotect Sector / Block<br>FFh = Protect Sector / Block | FFh | Volatile | Figure 75. Write DPB Register (WRDPB) Sequence ### 9-33-4. Gang Block Lock/Unlock (GBLK/GBULK) These instructions are only effective if WPSEL=1. The GBLK and GBULK instructions provide a quick method to set or clear all DPB bits at once. The WREN (Write Enable) instruction is required before issuing the GBLK/GBULK instruction. The sequence of issuing GBLK/GBULK instruction is: CS# goes low $\rightarrow$ send GBLK/GBULK (7Eh/98h) instruction $\rightarrow$ CS# goes high. The CS# must go high exactly at the byte boundary, otherwise, the instruction will be rejected and not be executed. ### 9-33-5. Sector Protection States Summary Table | Protection | on Status | Sector/Block | |------------|-----------|------------------| | DPB | SPB | Protection State | | 0 | 0 | Unprotected | | 0 | 1 | Protected | | 1 | 0 | Protected | | 1 | 1 | Protected | #### 9-34. Program/Erase Suspend/Resume The device allow the interruption of Sector-Erase, Block-Erase or Page-Program operations and conduct other operations. After issue suspend command, the system can determine if the device has entered the Erase-Suspended mode through Bit2 (PSB) and Bit3 (ESB) of security register. (please refer to "Table 12. Security Register Definition") Both SPI (8 clocks) and QPI (2 clocks) command cycle can accept by this instruction. The SIO[3:1] are don't care when during SPI mode. ### 9-35. Erase Suspend Erase suspend allow the interruption of all erase operations. After the device has entered Erase-Suspended mode, the system can read any sector(s) or Block(s) except those being erased by the suspended erase operation. Reading the sector or Block being erase suspended is invalid. After erase suspend, WEL bit will be clear, only read related, resume and reset command can be accepted, including: 03h, 0Bh, 3Bh, 6Bh, BBh, EBh, 5Ah, C0h, 06h, 04h, 2Bh, 9Fh, AFh, 05h, ABh, 90h, B1h, C1h, B0h, 30h, 66h, 99h, 00h, 35h, F5h, 15h, 2Dh, E2h, E0h. If the system issues an Erase Suspend command after the sector erase operation has already begun, the device will not enter Erase-Suspended mode until tESL time has elapsed. Erase Suspend Bit (ESB) indicates the status of Erase Suspend operation. Users may use ESB to identify the state of flash memory. After the flash memory is suspended by Erase Suspend command, ESB is set to "1". ESB is cleared to "0" after erase operation resumes. #### 9-36. Program Suspend Program suspend allows the interruption of all program operations. After the device has entered Program-Suspended mode, the system can read any sector(s) or Block(s) except those being programmed by the suspended program operation. Reading the sector or Block being program suspended is invalid. After program suspend, WEL bit will be cleared, only read related, resume and reset command can be accepted, including: 03h, 08h, 38h, 68h, 88h, E8h, 5Ah, C0h, 06h, 04h, 28h, 9Fh, AFh, 05h, A8h, 90h, 81h, C1h, 80h, 30h, 66h, 99h, 00h, 35h, F5h, 15h, 2Dh, E2h, E0h. Program Suspend Bit (PSB) indicates the status of Program Suspend operation. Users may use PSB to identify the state of flash memory. After the flash memory is suspended by Program Suspend command, PSB is set to "1". PSB is cleared to "0" after program operation resumes. ## Figure 76. Suspend to Read Latency ### Figure 77. Resume to Read Latency ## Figure 78. Resume to Suspend Latency #### 9-37. Write-Resume The Write operation is being resumed when Write-Resume instruction issued. ESB or PSB (suspend status bit) in Status register will be changed back to "0". The operation of Write-Resume is as follows: CS# drives low $\rightarrow$ send write resume command cycle (30H) $\rightarrow$ drive CS# high. By polling Busy Bit in status register, the internal write operation status could be checked to be completed or not. The user may also wait the time lag of tSE, tBE, tPP for Sector-erase, Block-erase or Page-programming. WREN (command "06h") is not required to issue before resume. Resume to another suspend operation requires latency time of tPRS or tERS, as defined in "Table 21. AC CHARACTERISTICS (Temperature = -40°C to 85°C, VCC = 2.7V - 3.6V)". Please note that, if "performance enhance mode" is executed during suspend operation, the device can not be resumed. To restart the write command, disable the "performance enhance mode" is required. After the "performance enhance mode" is disabled, the write-resume command is effective. #### 9-38. No Operation (NOP) The "No Operation" command is only able to terminate the Reset Enable (RSTEN) command and will not affect any other command. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care during SPI mode. #### 9-39. Software Reset (Reset-Enable (RSTEN) and Reset (RST)) The Software Reset operation combines two instructions: Reset-Enable (RSTEN) command and Reset (RST) command. It returns the device to standby mode. All the volatile bits and settings will be cleared then, which makes the device return to the default status as power on. To execute Reset command (RST), the Reset-Enable (RSTEN) command must be executed first to perform the Reset operation. If there is any other command to interrupt after the Reset-Enable command, the Reset-Enable will be invalid. Both SPI (8 clocks) and QPI (2 clocks) command cycle can be accepted by this instruction. The SIO[3:1] are don't care when during SPI mode. If the Reset command is executed during program or erase operation, the operation will be disabled, the data under processing could be damaged or lost. The reset time is different depending on the last operation. For details, please refer to "Table 17. Reset Timing-(Other Operation)" for tREADY2. Figure 79. Software Reset Recovery Note: Refer to "Table 17. Reset Timing-(Other Operation)" for tREADY2 data. Figure 80. Reset Sequence (SPI mode) Figure 81. Reset Sequence (QPI mode) P/N: PM2898 #### 9-40. Read SFDP Mode (RDSFDP) 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. The sequence of issuing RDSFDP instruction is CS# goes low—send RDSFDP instruction (5Ah)—send 3 address bytes on SI pin—send 1 dummy byte on SI pin—read SFDP code on SO—to end RDSFDP operation can use CS# to high at any time during data out. SFDP is a JEDEC standard, JESD216B. For SFDP register values detail, please contact local Macronix sales channel for Application Note. Figure 82. Read Serial Flash Discoverable Parameter (RDSFDP) Sequence ### 10. RESET Driving the RESET# pin low for a period of tRLRH or longer will reset the device. After reset cycle, the device is at the following states: - Standby mode - All the volatile bits such as WEL/WIP/SRAM lock bit will return to the default status as power on. If the device is under programming or erasing, driving the RESET# pin low will also terminate the operation and data could be lost. During the resetting cycle, the SO data becomes high impedance and the current will be reduced to minimum. While Reset operation is during erase suspend, no matter what status the flash device is in, its Reset Recovery time should be referred to the Recovery time of the Erase activity in progress. Figure 83. RESET Timing Table 16. Reset Timing-(Power On) | Symbol | Parameter | Min. | Тур. | Max. | Unit | |---------|----------------------------|------|------|------|------| | tRHSL | Reset# high before CS# low | 10 | | | us | | tRS | Reset# setup time | 15 | | | ns | | tRH | Reset# hold time | 15 | | | ns | | tRLRH | Reset# low pulse width | 10 | | | us | | tREADY1 | Reset Recovery time | 35 | | | us | **Table 17. Reset Timing-(Other Operation)** | Symbol | Parameter | Min. | Тур. | Max. | Unit | |---------|---------------------------------------------------|------|------|------|------| | tRHSL | Reset# high before CS# low | 10 | | | us | | tRS | Reset# setup time | 15 | | | ns | | tRH | Reset# hold time | 15 | | | ns | | tRLRH | Reset# low pulse width | 10 | | | us | | | Reset Recovery time (During instruction decoding) | 40 | | | us | | | Reset Recovery time (for read operation) | 35 | | | us | | | Reset Recovery time (for program operation) | 310 | | | us | | tREADY2 | Reset Recovery time(for SE4KB operation) | 12 | | | ms | | | Reset Recovery time (for BE64KB/BE32KB operation) | 25 | | | ms | | | Reset Recovery time (for Chip Erase operation) | 100 | | | ms | | | Reset Recovery time (for WRSR operation) | 40 | | | ms | **Note:** For the Reset activity during Erase suspend, its tREADY2 timing should be referred to the Erase activity in progress. #### 11. POWER-ON STATE The device is at the following states after power-up: - Standby mode (please note it is not deep power-down mode) - Write Enable Latch (WEL) bit is reset The device must not be selected during power-up and power-down stage until the VCC reaches the following levels: - VCC minimum at power-up stage and then after a delay of tVSL - GND at power-down Please note that a pull-up resistor on CS# may ensure a safe and proper power-up/down level. An internal power-on reset (POR) circuit may protect the device from data corruption and inadvertent data change during power up state. When VCC is lower than VWI (POR threshold voltage value), the internal logic is reset and the flash device has no response to any command. For further protection on the device, if the VCC does not reach the VCC minimum level, the correct operation is not guaranteed. The write, erase, and program command should be sent after the below time delay: - tVSL after VCC reached VCC minimum level The device can accept read command after VCC reached VCC minimum and a time delay of tVSL. Please refer to the "Figure 91. Power-up Timing". #### Note: - To stabilize the VCC level, the VCC rail decoupled by a suitable capacitor close to package pins is recommended. (generally around 0.1uF) - At power-down stage, the VCC drops below VWI level, all operations are disable and device has no response to any command. The data corruption might occur during this stage if a write, program, erase cycle is in progress. #### 12. ELECTRICAL SPECIFICATIONS **Table 18. ABSOLUTE MAXIMUM RATINGS** | RATING | | VALUE | |-------------------------------|------------------|-------------------| | Ambient Operating Temperature | Industrial grade | -40°C to 85°C | | Storage Temperature | | -65°C to 150°C | | Applied Input Voltage | | -0.5V to VCC+0.5V | | Applied Output Voltage | | -0.5V to VCC+0.5V | | VCC to Ground Potential | | -0.5V to 4.0V | #### NOTICE: - 1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is stress rating only and functional operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended period may affect reliability. - 2. Specifications contained within the following tables are subject to change. - 3. During voltage transitions, all pins may overshoot to VCC+2.0V or -2.0V for period up to 20ns, and please refer to "Figure 84. Maximum Negative Overshoot Waveform" and "Figure 85. Maximum Positive Overshoot Waveform". Figure 84. Maximum Negative Overshoot Waveform Figure 85. Maximum Positive Overshoot Waveform Table 19. CAPACITANCE TA = 25°C, f = 1.0 MHz | Symbol | Parameter | Min. | Тур. | Max. | Unit | Conditions | |--------|--------------------|------|------|------|------|------------| | CIN | Input Capacitance | | | 8 | pF | VIN = 0V | | COUT | Output Capacitance | | | 10 | pF | VOUT = 0V | ### Figure 86. DATA INPUT TEST WAVEFORMS AND MEASUREMENT LEVEL Figure 87. OUTPUT LOADING Figure 88. SCLK TIMING DEFINITION Table 20. DC CHARACTERISTICS (Temperature = -40°C to 85°C, VCC = 2.7V - 3.6V) | Symbol | Parameter | Notes | Min. | Тур. | Max. | Units | Test Conditions | | | | | |--------|---------------------------------------------------------------|-------|---------|------|---------|-------|----------------------------------------------------------------|--|----|----|----| | ILI | Input Load Current | 1 | | | ±2 | uA | VCC = VCC Max,<br>VIN = VCC or GND | | | | | | ILO | Output Leakage Current | 1 | | | ±2 | uA | VCC = VCC Max,<br>VOUT = VCC or GND | | | | | | ISB1 | VCC Standby Current | 1 | | 15 | 100 | uA | VIN = VCC or GND,<br>CS# = VCC | | | | | | ISB2 | Deep Power-down<br>Current | | | 3 | 20 | uA | VIN = VCC or GND,<br>CS# = VCC | | | | | | | | | | 16 | 30 | mA | f=100MHz, (DTR 4 x I/O read)<br>SCLK=0.1VCC/0.9VCC,<br>SO=Open | | | | | | 1004 | VCC Read | | | 14 | 25 | mA | f=133MHz, (4 x I/O read)<br>SCLK=0.1VCC/0.9VCC,<br>SO=Open | | | | | | ICC1 | | 1 | | 12 | 20 | mA | f=104MHz, (4 x I/O read)<br>SCLK=0.1VCC/0.9VCC,<br>SO=Open | | | | | | | | | | | | | | | 12 | 15 | mA | | ICC2 | VCC Program Current (PP) | 1 | | 12 | 25 | mA | Program in Progress,<br>CS# = VCC | | | | | | ICC3 | VCC Write Status<br>Register (WRSR) Current | | | 10 | 12 | mA | Program status register in progress, CS#=VCC | | | | | | ICC4 | VCC Sector/Block (32K,<br>64K) Erase Current<br>(SE/BE/BE32K) | 1 | | 10 | 25 | mA | Erase in Progress, CS#=VCC | | | | | | ICC5 | VCC Chip Erase Current (CE) | 1 | | 14 | 25 | mA | Erase in Progress, CS#=VCC | | | | | | VIL | Input Low Voltage | | -0.5 | | 0.8 | V | | | | | | | VIH | Input High Voltage | | 0.7VCC | | VCC+0.4 | V | | | | | | | VOL | Output Low Voltage | | | | 0.2 | V | IOL = 100uA | | | | | | VOH | Output High Voltage | | VCC-0.2 | | | V | IOH = -100uA | | | | | ## Notes: - 1. Typical values at VCC = 3.3V, T = 25°C. These currents are valid for all product versions (package and speeds). - 2. Typical value is calculated by simulation. Table 21. AC CHARACTERISTICS (Temperature = -40°C to 85°C, VCC = 2.7V - 3.6V) | Symbol | Alt. | Parameter | | | Min. | Тур. | Max. | Unit | |--------------------------------|------|--------------------------------------|--------------------------------------------------|----------------------------|---------------------------------|--------------|-------|------| | fSCLK | fC | Clock Frequency for all comm | nands (except Rea | d) | D.C. | | 120 | MHz | | fRSCLK | fR | Clock Frequency for READ in | structions | | | | 50 | MHz | | (T00) 1/ | fT | Clock Frequency for 2READ/I | DREAD instructions | | Please refer to "Table 10. Dumm | | Dummy | MHz | | fTSCLK | fQ | Clock Frequency for 4READ/ | | | Cycle and Frequer | | | MHz | | | | | Others > 66MHz | | 45% x (1/fSCLK) | | | ns | | tCH <sup>(1)</sup> | tCLH | Clock High Time | (fSCLK/fTSCLK | = 00W1112 | 7 | | | ns | | | | | Normal Read (fR | SCLK) | 7 | | | ns | | (1) | | | Others | > 66MHz | 45% x (1/fSCLK) | | | ns | | tCL <sup>(1)</sup> | tCLL | Clock Low Time | (fSCLK/fTSCLK | = 001/11 12 | 7 | | | ns | | tCLCH <sup>(5)</sup> | | Clask Diss Time (neak to nea | Normal Read (fR | SCLK) | 0.1 | | - | V/ns | | tCHCL <sup>(5)</sup> | | Clock Rise Time (peak to pea | | | | | | + | | | 1000 | Clock Fall Time (peak to peak | <del></del> | | 0.1 | | | V/ns | | tSLCH | tCSS | CS# Active Setup Time (relati | | | 3 | | | ns | | tCHSL | | CS# Not Active Hold Time (re | lative to SCLK) | | 3 | | | ns | | tDVCH/<br>tDVCL | tDSU | Data In Setup Time | | | 2 | | | ns | | +CUDV/ | | | VCC: 2.7V - 3.6 | | 2 | | | ns | | tCHDX/<br>tCLDX <sup>(3)</sup> | tDH | Data In Hold Time | VCC: 3.0V - 3.6<br>(Loading: 15pF | | 1 | | | ns | | tCHSH | | CS# Active Hold Time (relative | <del></del> | | 3 | | | ns | | tSHCH | | CS# Not Active Setup Time (r | | | 3 | | | ns | | | | | From Read to ne | xt Read | 7 | | | ns | | tSHSL | tCSH | CS# Deselect Time | From Write/Erase/Program to Read Status Register | | 30 | | | ns | | tSHQZ <sup>(5)</sup> | tDIS | Output Disable Time | Trodd Clarac Progreter | | 1 | | 8 | ns | | | | Supur Diodois Time | | Loading: 30pF | | | 8 | ns | | | | | VCC: | Loading: 15pF | 1 | | 6 | ns | | | | Clock Low to Output Valid<br>Loading | 2.7V - 3.6V | Loading: 10pF | | | 5 | ns | | tCLQV <sup>(3)</sup> | tV | | | Loading: 15pF<br>ODS (0,0) | | | 5 | ns | | | | | 3.0V - 3.6V <sup>(9)</sup> | Loading: 10pF<br>ODS (0,0) | | | 4.5 | ns | | (2) | | | Loading: 30pF | 020 (0,0) | 1 | | | ns | | tCLQX <sup>(3)</sup> | tHO | Output Hold Time | Loading: 15pF/10 | )nF | 1 | | | ns | | tDP <sup>(5)</sup> | | CS# High to Deep Power-dov | <u> </u> | , P. | | | 10 | us | | tRES1 <sup>(5)</sup> | | CS# High to Standby Mode w | | Signature Read | | | 30 | us | | tRES2 <sup>(5)</sup> | | CS# High to Standby Mode w | | <del>-</del> | | | 30 | us | | tW | | Write Status/Configuration Re | | atare redu | | - | 40 | ms | | tWREAW | | Write Status/Corniguration Regi | <del> </del> | | | 40 | 1 40 | 1 | | | | · | 3161 | | | <del> </del> | 20 | ns | | tBP | | Byte-Program | | | | 15 | 30 | us | | tPP | | Page Program Cycle Time | | | | 0.25 | 0.75 | ms | | tSE | | Sector Erase Cycle Time | | | | 30 | 400 | ms | | tBE32 | | Block Erase (32KB) Cycle Tin | | | | 180 | 1000 | ms | | tBE | | Block Erase (64KB) Cycle Tin | ne | | | 380 | 2000 | ms | | tCE | | Chip Erase Cycle Time | | | | 110 | 210 | S | | tESL <sup>(6)</sup> | | Erase Suspend Latency | | | | | 25 | us | | tPSL <sup>(6)</sup> | | Program Suspend Latency | | | | | 25 | us | | tPRS <sup>(7)</sup> | | Latency between Program Re | | | 0.3 | 100 | | us | | tERS <sup>(8)</sup> | | Latency between Erase Resu | | | 0.3 | 400 | | us | | tQVD <sup>(3)</sup> | | Data Output Valid Time Differ | ence among all SI | O pins | | | 600 | ps | #### Notes: - 1. tCH + tCL must be greater than or equal to 1/Frequency. - 2. Typical values given for TA=25°C. Not 100% tested. - 3. Not 100% tested. - 4. Test condition is shown as "Figure 86. DATA INPUT TEST WAVEFORMS AND MEASUREMENT LEVEL" and "Figure 87. OUTPUT LOADING". - 5. The value guaranteed by characterization, not 100% tested in production. - 6. Latency time is required to complete Erase/Program Suspend operation until WIP bit is "0". - 7. For tPRS, minimum timing must be observed before issuing the next program suspend command. However, a period equal to or longer than the typical timing is required in order for the program operation to make progress. - 8. For tERS, minimum timing must be observed before issuing the next erase suspend command. However, a period equal to or longer than the typical timing is required in order for the erase operation to make progress. - 9. For tCLQV, please note that the output driver strength (ODS1, ODS0) bits must be configured correctly according to "Table 9. Output Driver Strength Table". #### 13. OPERATING CONDITIONS #### At Device Power-Up and Power-Down AC timing illustrated in *Figure 89* and *Figure 90* are for the supply voltages and the control signals at device power-up and power-down. If the timing in the figures is ignored, the device will not operate correctly. During power-up and power-down, CS# needs to follow the voltage applied on VCC to keep the device not to be selected. The CS# can be driven low when VCC reach Vcc(min.) and wait a period of tVSL. Figure 89. AC Timing at Device Power-Up | S | Symbol | Parameter | Notes | Min. | Max. | Unit | |---|--------|---------------|-------|------|--------|------| | | tVR | VCC Rise Time | 1 | | 500000 | us/V | ## Notes: - 1. Sampled, not 100% tested. - 2. For AC spec tCHSL, tSLCH, tDVCH, tCHDX, tSHSL, tCHSH, tSHCH, tCHCL, tCLCH in the figure, please refer to "Table 21. AC CHARACTERISTICS (Temperature = -40°C to 85°C, VCC = 2.7V 3.6V)". ## Figure 90. Power-Down Sequence During power-down, CS# needs to follow the voltage drop on VCC to avoid mis-operation. Figure 91. Power-up Timing ## Figure 92. Power Up/Down and Voltage Drop When powering down the device, VCC must drop below $V_{PWD}$ for at least tPWD to ensure the device will initialize correctly during power up. Please refer to "Figure 92. Power Up/Down and Voltage Drop" and "Table 22. Power-Up/Down Voltage and Timing" below for more details. Table 22. Power-Up/Down Voltage and Timing | Symbol | Parameter | Min. | Max. | Unit | |-----------|-------------------------------------------------------------------------------------|------|--------|------| | tVSL | VCC(min.) to device operation | 3000 | | us | | VWI | Write Inhibit Voltage | 1.5 | 2.5 | V | | $V_{PWD}$ | VCC voltage needed to below V <sub>PWD</sub> for ensuring initialization will occur | | 0.9 | V | | tPWD | The minimum duration for ensuring initialization will occur | 300 | | us | | tVR | VCC Rise Time | | 500000 | us/V | | VCC | VCC Power Supply | 2.7 | 3.6 | V | Note: These parameters are characterized only. #### 13-1. INITIAL DELIVERY STATE The device is delivered with the memory array erased: all bits are set to 1 (each byte contains FFh). The Status Register contains 40h (all Status Register bits are 0 except QE bit: QE=1). #### 14. ERASE AND PROGRAMMING PERFORMANCE | Parameter | Min. | Typ. (1) | Max. (2) | Unit | |----------------------------------------------|------|----------|----------|--------| | Write Status Register Cycle Time | | | 40 | ms | | Sector Erase Cycle Time (4KB) | | 30 | 400 | ms | | Block Erase Cycle Time (32KB) | | 0.18 | 1 | S | | Block Erase Cycle Time (64KB) | | 0.38 | 2 | S | | Chip Erase Cycle Time | | 110 | 210 | S | | Byte Program Time (via page program command) | | 15 | 30 | us | | Page Program Time | | 0.25 | 0.75 | ms | | Erase/Program Cycle | | 100,000 | | cycles | #### Note: - 1. Typical program and erase time assumes the following conditions: 25°C, 3.3V, and all zero pattern. - 2. Under worst conditions of 2.7V, highest operation temperature, post program/erase cycling. - 3. System-level overhead is the time required to execute the first-bus-cycle sequence for the programming command. ## 15. ERASE AND PROGRAMMING PERFORMANCE (Factory Mode) | Parameter | Min. | Тур. | Max. | Unit | |-------------------------------|------|------|------|--------| | Sector Erase Cycle Time (4KB) | | 18 | | ms | | Block Erase Cycle Time (32KB) | | 100 | | ms | | Block Erase Cycle Time (64KB) | | 200 | | ms | | Chip Erase Cycle Time | | 80 | | S | | Page Program Time | | 0.16 | | ms | | Erase/Program Cycle | | | 50 | cycles | #### **Notice:** - 1. Factory Mode must be operated in 20°C to 45°C and VCC 3.0V-3.6V. - 2. In Factory mode, the Erase/Program operation should not exceed 50 cycles, and "ERASE AND PROGRAMMING PERFORMANCE" 100k cycles will not be affected. - 3. During factory mode, Suspend command (B0h) cannot be executed. ## **16. DATA RETENTION** | Parameter | Condition | Min. | Max. | Unit | |----------------|-----------|------|------|-------| | Data retention | 55°C | 20 | | years | ## 17. LATCH-UP CHARACTERISTICS | | Min. | Max. | |----------------------------------------------------------------------------|---------------|------------| | Input Voltage with respect to GND on all power pins | | 1.5 VCCmax | | Input Current on all non-power pins | -100mA | +100mA | | Test conditions: VCC = VCCmax, one pin at a time (compliant to JEDEC JESD? | 78 standard). | | ## 18. ORDERING INFORMATION Please contact Macronix regional sales for the latest product selection and available form factors. | PART NO. | TEMPERATURE | PACKAGE | Remark | |--------------------|---------------|-----------------------------|----------------------| | MX25L25773GMI-08G | -40°C to 85°C | 16-SOP (300mil) | Support Factory Mode | | MX25L25773GZ4I-08G | -40°C to 85°C | 8-WSON (8x6mm 3.4 x 4.3 EP) | Support Factory Mode | ### 19. PART NAME DESCRIPTION ## 20. PACKAGE INFORMATION ## 20-1. 16-pin SOP (300mil) Doc. Title: Package Outline for SOP 16L (300MIL) Dimensions (inch dimensions are derived from the original mm dimensions) | SY<br>UNIT | MBOL | Α | <b>A</b> 1 | A2 | b | С | D | E | E1 | е | L | L1 | S | θ | |------------|------|-------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----| | | Min. | | 0.10 | 2.25 | 0.31 | 0.20 | 10.10 | 10.10 | 7.42 | | 0.40 | 1.31 | 0.51 | 0° | | mm | Nom. | | 0.20 | 2.35 | 0.41 | 0.25 | 10.30 | 10.30 | 7.52 | 1.27 | 0.84 | 1.44 | 0.64 | 5° | | | Max. | 2.65 | 0.30 | 2.45 | 0.51 | 0.30 | 10.50 | 10.50 | 7.60 | | 1.27 | 1.57 | 0.77 | 8° | | | Min. | | 0.004 | 0.089 | 0.012 | 0.008 | 0.397 | 0.397 | 0.292 | | 0.016 | 0.052 | 0.020 | 0° | | | Nom. | | 0.008 | 0.093 | 0.016 | 0.010 | 0.405 | 0.405 | 0.296 | 0.050 | 0.033 | 0.057 | 0.025 | 5° | | | Max. | 0.104 | 0.012 | 0.096 | 0.020 | 0.012 | 0.413 | 0.413 | 0.299 | | 0.050 | 0.062 | 0.030 | 8° | ### 20-2. 8-land WSON (8x6mm 3.4 x 4.3EP) Doc. Title: Package Outline for WSON 8L (8x6x0.8MM, LEAD PITCH 1.27MM, E.P. 3.4x4.3MM) Note: This package has an exposed metal pad underneath the package. It is recommended to leave the metal pad floating or to connect it to the same ground as the GND pin of the package. Do not connect the metal pad to any other voltage or signal line on the PCB. Avoid placing vias or traces underneath the metal pad. Connection of this metal pad to any other voltage or signal line can result in shorts and/or electrical malfunction of the device. ### Dimensions (inch dimensions are derived from the original mm dimensions) | UNIT | MBOL | Α | A1 | A2 | b | D | D1 | E | E1 | L | е | у | |------|------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|-------| | | Min. | 0.70 | _ | | 0.35 | 7.90 | 3.35 | 5.90 | 4.25 | 0.45 | | 0.00 | | mm | Nom. | - | _ | 0,20 | 0.40 | 8.00 | 3.40 | 6.00 | 4.30 | 0.50 | 1,27 | _ | | | Max. | 0.80 | 0.05 | - | 0.48 | 8.10 | 3.45 | 6.10 | 4.35 | 0.55 | - | 0.05 | | | MIn. | 0.028 | | | 0.014 | 0.311 | 0.132 | 0.232 | 0.167 | 0.018 | | 0.00 | | Inch | Nom. | | | 0.008 | 0.016 | 0.315 | 0.134 | 0.236 | 0.169 | 0.020 | 0.05 | | | | Max. | 0.032 | 0.002 | | 0.019 | 0.319 | 0.136 | 0.240 | 0.171 | 0.022 | | 0.002 | ## **21. REVISION HISTORY** | Revision | Descriptions | Page | |---------------|------------------------------------------------------------------|--------| | July 30, 2020 | | | | 0.00 | 1. Initial Release. | All | | | | | | December 31, | , 2020 | | | 1.0 | 1. Changed the version as 1.0 to align with the product status. | All | | | 2. Corrected "Read Electronic Signature (RES) Sequence" figures. | P25-26 | | | 3. Description modification. | P57 | Except for customized products which has been expressly identified in the applicable agreement, Macronix's products are designed, developed, and/or manufactured for ordinary business, industrial, personal, and/or household applications only, and not for use in any applications which may, directly or indirectly, cause death, personal injury, or severe property damages. In the event Macronix products are used in contradicted to their target usage above, the buyer shall take any and all actions to ensure said Macronix's product qualified for its actual use in accordance with the applicable laws and regulations; and Macronix as well as it's suppliers and/or distributors shall be released from any and all liability arisen therefrom. Copyright© Macronix International Co., Ltd. 2020. All rights reserved, including the trademarks and tradename thereof, such as Macronix, MXIC, MXIC Logo, MX Logo, Integrated Solutions Provider, Nbit, Macronix NBit, HybridNVM, HybridFlash, HybridXFlash, XtraROM, KH Logo, BE-SONOS, KSMC, Kingtech, MXSMIO, Macronix vEE, RichBook, Rich TV, OctaBus, FitCAM, ArmorFlash, LybraFlash. The names and brands of third party referred thereto (if any) are for identification purposes only. For the contact and order information, please visit Macronix's Web site at: http://www.macronix.com # **Mouser Electronics** **Authorized Distributor** Click to View Pricing, Inventory, Delivery & Lifecycle Information: # Macronix: MX25L25773GZ4I-08G-T MX25L25773GZ4I-08G-TR