# MX25L12835E HIGH PERFORMANCE SERIAL FLASH SPECIFICATION # **Contents** | 1. FEATURES | | |----------------------------------------------------------------------------|----| | 2. GENERAL DESCRIPTION | 6 | | Table 1. Additional Features | 6 | | 3. PIN CONFIGURATION | 7 | | 4. PIN DESCRIPTION | 7 | | 5. BLOCK DIAGRAM | 8 | | 6. DATA PROTECTION | 9 | | Table 2. Protected Area Sizes | 10 | | Table 3. 4K-bit Secured OTP Definition | 10 | | 7. MEMORY ORGANIZATION | 11 | | Table 4. Memory Organization for MX25L12835E | 11 | | 8. DEVICE OPERATION | 12 | | 9. HOLD FEATURE | 13 | | 10. COMMAND DESCRIPTION | 14 | | Table 5. Command Sets | 14 | | 10-1. Write Enable (WREN) | 17 | | 10-2. Write Disable (WRDI) | 18 | | 10-3. Read Identification (RDID) | 19 | | 10-4. Read Status Register (RDSR) | 20 | | 10-5. Write Status Register (WRSR) | 22 | | Table 6. Protection Modes | 23 | | 10-6. Read Data Bytes (READ) | | | 10-7. Read Data Bytes at Higher Speed (FAST_READ) | | | 10-8. Dual Read Mode (DREAD) | | | 10-9. 2 x I/O Read Mode (2READ) | | | 10-10. Quad Read Mode (QREAD) | | | 10-11. 4 x I/O Read Mode (4READ) | | | 10-12. Performance Enhance Mode | | | 10-13. Performance Enhance Mode Reset (FFh) | | | 10-14. Burst Read | | | 10-15. Sector Erase (SE) | | | 10-16. Block Erase (BE) | | | 10-17. Block Erase (BE32K) | | | 10-18. Chip Erase (CE) | | | 10-19. Page Program (PP) | | | 10-20. 4 x I/O Page Program (4PP) | | | 10-21. Continuously program mode (CP mode) | | | 10-22. Deep Power-down (DP) | | | 10-23. Release from Deep Power-down (RDP), Read Electronic Signature (RES) | | | 10-24. Read Electronic Manufacturer ID & Device ID (REMS), (REMS4) | | | Table 7. ID Definitions | | | 10-26. Enter Secured OTP (ENSO) | | | 10-20. Enter Secured OTP (ENSO) | | | 10-28. Read Security Register (RDSCUR) | | # MX25L12835E | Table 8. Security Register Definition | 52 | |----------------------------------------------------------------------------------|--------------| | 10-29. Write Security Register (WRSCUR) | 53 | | 10-30. Write Protection Selection (WPSEL) | | | 10-31. Single Block Lock/Unlock Protection (SBLK/SBULK) | 57 | | 10-32. Read Block Lock Status (RDBLOCK) | 60 | | 10-33. Gang Block Lock/Unlock (GBLK/GBULK) | 61 | | 10-34. Clear SR Fail Flags (CLSR) | | | 10-35. Enable SO to Output RY/BY# (ESRY) | 62 | | 10-36. Disable SO to Output RY/BY# (DSRY) | 62 | | 10-37. No Operation (NOP) | | | 10-38. Software Reset (Reset-Enable (RSTEN) and Reset (RST)) | | | 11. POWER-ON STATE | | | 12. ELECTRICAL SPECIFICATIONS | | | 12-1. ABSOLUTE MAXIMUM RATINGS | 65 | | 12-2. CAPACITANCE TA = 25°C, f = 1.0 MHz | | | Table 9. DC CHARACTERISTICS (Temperature = -40°C to 85°C for Industrial grade, V | ′CC = 2.7V ~ | | 3.6V) | | | Table 10. AC CHARACTERISTICS (Temperature = -40°C to 85°C for Industrial grade, | | | 3.6V) | | | 13. TIMING ANALYSIS | 70 | | 13-1. RESET | | | Table 11. Reset Timing | | | Table 12. Power-Up Timing | | | 13-2. INITIAL DELIVERY STATE | | | 14. OPERATING CONDITIONS | | | 15. ERASE AND PROGRAMMING PERFORMANCE | | | 16. DATA RETENTION | | | 17. LATCH-UP CHARACTERISTICS | 76 | | 18. ORDERING INFORMATION | 77 | | 19. PART NAME DESCRIPTION | 78 | | 20. PACKAGE INFORMATION | 79 | | | | ## 128M-BIT [x 1/x 2/x 4] CMOS MXSMIO™ (SERIAL MULTI I/O) FLASH MEMORY ## 1. FEATURES #### **GENERAL** - Serial Peripheral Interface compatible -- Mode 0 and Mode 3 - 134,217,728 x 1 bit structure or 67,108,864 x 2 bits (two I/O mode) structure or 33,554,432 x 4 bits (four I/O mode) structure - · 4096 Equal Sectors with 4K bytes each - Any Sector can be erased individually - · 512 Equal Blocks with 32K bytes each - Any Block can be erased individually - · 256 Equal Blocks with 64K bytes each - Any Block can be erased individually - · Power Supply Operation - 2.7 to 3.6 volt for read, erase, and program operations - Latch-up protected to 100mA from -1V to Vcc +1V #### **PERFORMANCE** · High Performance VCC = 2.7~3.6V - Normal read - 50MHz - Fast read - 1 I/O: 104MHz with 8 dummy cycles - 2 I/O: 70MHz with 4 dummy cycles for 2READ instruction; 70MHz with 8 dummy cycles for DREAD instruction - 4 I/O: 70MHz with 6 dummy cycles for 4READ instruction; 70Mhz with 8 dummy cycles for QREAD instruction - Fast program time: 1.4ms(typ.) and 5ms(max.)/page (256-byte per page) - Byte program time: 9us (typical) - 8/16/32/64 byte Wrap-Around Burst Read Mode - Continuously Program mode (automatically increase address under word program mode) - Fast erase time: 60ms (typ.)/sector (4K-byte per sector); 0.7s(typ.) /block (64K-byte per block); 80s(typ.) / chip - Low Power Consumption - Low active read current: 19mA(max.) at 104MHz, 15mA(max.) at 66MHz and 10mA(max.) at 33MHz - Low active programming current: 25mA (max.) - Low active erase current: 25mA (max.) - Low standby current: 100uA (max.) - Deep power down current: 40uA (max.) - · Typical 100,000 erase/program cycles - · 20 years data retention ## **SOFTWARE FEATURES** - Input Data Format - 1-byte Command code - · Advanced Security Features - BP0-BP3 block group protect - Flexible individual block protect when OTP WPSEL=1 - Additional 4K bits secured OTP for unique identifier - · Auto Erase and Auto Program Algorithms - Automatically erases and verifies data at selected sector - Automatically programs and verifies data at selected page by an internal algorithm that automatically times the program pulse width (Any page to be programmed should have page in the erased state first.) - Status Register Feature - Electronic Identification - JEDEC 1-byte Manufacturer ID and 2-byte Device ID - RES command for 1-byte Device ID - The REMS, REMS2, REMS4 commands for 1-byte Manufacturer ID and 1-byte Device ID #### HARDWARE FEATURES - SCLK Input - Serial clock input - SI/SIO0 - Serial Data Input or Serial Data Input/Output for 2 x I/O mode and 4 x I/O mode - SO/SIO1 - Serial Data Output or Serial Data Input/Output for 2 x I/O mode and 4 x I/O mode - WP#/SIO2 - Hardware write protection or serial data Input/Output for 4 x I/O mode - HOLD#/SIO3 - To pause the device without deselecting the device or serial data Input/Output for 4 x I/O mode - RESET# - Hardware Reset Pin - PACKAGE - 16-pin SOP (300mil) - 8-WSON (8 x 6mm) - All devices are RoHS Compliant ## 2. GENERAL DESCRIPTION MX25L12835E is 134,217,728 bits serial Flash memory, which is configured as 16,777,216 x 8 internally. When it is in two or four I/O mode, the structure becomes 67,108,864 bits x 2 or 33,554,432 bits x 4. The MX25L12835E features a serial peripheral interface and software protocol allowing operation on a simple 3-wire bus. 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. MX25L12835E, $MXSMIO^{TM}$ (Serial Multi I/O) flash memory, provides sequential read operation on whole chip and multi-I/O features. When it is in dual I/O 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 quad I/O mode, the SI pin, SO pin, WP# pin and HOLD# pin become SIO0 pin, SIO1 pin, SIO2 pin and SIO3 pin for address/dummy bits input and data Input/Output. 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 for Continuously Program mode, and erase command is executed on sector (4K-byte), block (32K-byte/64K-byte), 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. When the device is not in operation and CS# is high, it is put in standby mode and draws less than 100uA DC current. The MX25L12835E utilizes Macronix's proprietary memory cell, which reliably stores memory contents even after 100,000 program and erase cycles. **Table 1. Additional Features** | Additional Features | | d Security | Read Performance | | | | | | |---------------------|--------------------------------------------------------------|--------------------------|-------------------------|------------------------|------------------------|-----------------------|-----------------------|--| | Part<br>Name | Flexible or<br>Individual block<br>(or sector)<br>protection | 4K-bit<br>secured<br>OTP | 1 I/O Read<br>(104 MHz) | 2 I/O Read<br>(70 MHz) | 4 I/O Read<br>(70 MHz) | Dual Read<br>(70 MHz) | Quad Read<br>(70 MHz) | | | MX25L12835E | V | ٧ | V | V | V | V | V | | | Additional Features | Identifier | | | | | | | | |---------------------|---------------------------------------|-------------|-------------------------|-------------------------|---------------------------|--|--|--| | Part<br>Name | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | REMS2 (command: EF hex) | REMS4 (command: DF hex) | RDID<br>(command: 9F hex) | | | | | MX25L12835E | 17 (hex) | C2 17 (hex) | C2 17 (hex) | C2 17 (hex) | C2 20 18 (hex) | | | | ## 3. PIN CONFIGURATION ## 16-PIN SOP (300mil) ## 8-WSON (8x6mm) ## 4. PIN DESCRIPTION | SYMBOL | DESCRIPTION | |----------------|-------------------------------------------------------------------------------------------------| | CS# | Chip Select | | SI/SIO0 | Serial Data Input (for 1xI/O)/ Serial Data Input & Output (for 2xI/O or 4xI/O mode) | | SO/SIO1 | Serial Data Output (for 1xI/O)/Serial Data Input & Output (for 2xI/O or 4xI/O mode) | | SCLK | Clock Input | | WP#/SIO2 | Write protection: connect to GND or Serial Data Input & Output (for 4xI/O mode) | | HOLD#/<br>SIO3 | To pause the device without deselecting the device or Serial data Input/Output for 4 x I/O mode | | RESET# | Hardware Reset Pin | | VCC | + 3.3V Power Supply | | GND | Ground | | NC | No Connection | **Note:** The RESET# pin function is only available on 16-SOP package. ## 5. BLOCK DIAGRAM #### 6. DATA PROTECTION MX25L12835E is designed to offer protection against accidental erasure or programming caused by spurious system level signals that may exist during power transition. During power up the device automatically resets the state machine in the standby mode. In addition, with its control register architecture, alteration of the memory contents only occurs after successful completion of specific command sequences. The device also incorporates several features to prevent inadvertent write cycles resulting from VCC power-up and power-down transition or 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 command to change data. The WEL bit will return to reset stage under following situation: - Power-up - Write Disable (WRDI) command completion - Write Status Register (WRSR) command completion - Page Program (PP, 4PP) command completion - Continuously Program mode (CP) instruction completion - Sector Erase (SE) command completion - Block Erase (BE, BE32K) command completion - Chip Erase (CE) command completion - Single Block Lock/Unlock (SBLK/SBULK) instruction completion - Gang Block Lock/Unlock (GBLK/GBULK) instruction completion - 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). ## I. Block lock protection - The Software Protected Mode (SPM) uses (BP3, BP2, BP1, BP0) bits to allow part of memory to be protected as read only. The protected area definition is shown as table of "*Table 2. Protected Area Sizes*", the protected areas are more flexible which may protect various areas by setting value of BP0-BP3 bits. Please refer to table of "*Table 2. Protected Area Sizes*". - The Hardware Protected Mode (HPM) uses WP#/SIO2 to protect the (BP3, BP2, BP1, BP0) bits and SRWD bit. If the system goes into four I/O mode, the feature of HPM will be disabled. - MX25L12835E provides individual block (or sector) write protect & unprotect. User may enter the mode with WPSEL command and conduct individual block (or sector) write protect with SBLK instruction, or SBULK for individual block (or sector) unprotect. Under the mode, user may conduct whole chip (all blocks) protect with GBLK instruction and unlock the whole chip with GBULK instruction. **Table 2. Protected Area Sizes** | Status bit | | | | | |------------|-----|-----|-----|-----------------------------------| | BP3 | BP2 | BP1 | BP0 | | | 0 | 0 | 0 | 0 | 0 (none) | | 0 | 0 | 0 | 1 | 1 (2 blocks, block 254th-255th) | | 0 | 0 | 1 | 0 | 2 (4 blocks, block 252nd-255th) | | 0 | 0 | 1 | 1 | 3 (8 blocks, block 248th-255th) | | 0 | 1 | 0 | 0 | 4 (16 blocks, block 240th-255th) | | 0 | 1 | 0 | 1 | 5 (32 blocks, block 224th-255th) | | 0 | 1 | 1 | 0 | 6 (64 blocks, block 192nd-255th) | | 0 | 1 | 1 | 1 | 7 (128 blocks, block 128th-255th) | | 1 | 0 | 0 | 0 | 8 (256 blocks, all) | | 1 | 0 | 0 | 1 | 9 (256 blocks, all) | | 1 | 0 | 1 | 0 | 10 (256 blocks, all) | | 1 | 0 | 1 | 1 | 11 (256 blocks, all) | | 1 | 1 | 0 | 0 | 12 (256 blocks, all) | | 1 | 1 | 0 | 1 | 13 (256 blocks, all) | | 1 | 1 | 1 | 0 | 14 (256 blocks, all) | | 1 | 1 | 1 | 1 | 15 (256 blocks, all) | **Note:** The device is ready to accept a Chip Erase instruction if, and only if, all Block Protect (BP3, BP1, BP0) are 0. - II. Additional 4K-bit secured OTP for unique identifier: to provide 4K-bit One-Time Program area for setting device unique serial number Which may be set by factory or system maker. Please refer to Table 3. 4K-bit Secured OTP Definition. - Security register bit 0 indicates whether the chip is locked by factory or not. - To program the 4K-bit secured OTP by entering 4K-bit secured OTP mode (with ENSO command), and going through normal program procedure, and then exiting 4K-bit secured OTP mode by writing EXSO 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 of "Table 8. Security Register Definition" for security register bit definition and table of "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 quetemor | | xxx010~xxx1FF | 3968-bit | N/A | Determined by customer | ## 7. MEMORY ORGANIZATION Table 4. Memory Organization for MX25L12835E | | | T | T | T | | 7 | |-----------------------------------------------|-----------------|-----------------|--------|---------|---------|--------------------------| | | Block(64K-byte) | Block(32K-byte) | Sector | Address | Range | | | | | | 4095 | FFF000h | FFFFFFh | | | | | 511 | : | | | <b>*</b> | | | 255 | | 4088 | FF8000h | FF8FFFh | individual 16 sectors | | | 233 | | 4087 | FF7000h | FF7FFFh | lock/unlock unit:4K-byte | | | | 510 | : | | | <u> </u> | | | | | 4080 | FF0000h | FF0FFFh | <u> </u> | | | | | 4079 | FEF000h | FEFFFFh | | | | | 509 | : | | | | | | 254 | | 4072 | FE8000h | FE8FFFh | | | į. | 254 | | 4071 | FE7000h | FE7FFFh | | | ▼ | | 508 | : | | | | | individual block | | | 4064 | FE0000h | FE0FFFh | | | lock/unlock unit:64K-byte | | 507 | 4063 | FDF000h | FDFFFFh | | | | 253 | | : | | | | | | | | 4056 | FD8000h | FD8FFFh | | | | | | 4055 | FD7000h | FD7FFFh | | | | | 506 | : | | | | | | | | 4048 | FD0000h | FD0FFFh | | | individual block<br>lock/unlock unit:64K-byte | | | | | | | | | | | | 47 | 02F000h | 02FFFFh | | |-------|------------------------------------------|---|---|---------|---------|--------------------------|--| | | | | 5 | : | | | | | | | 2 | | 40 | 028000h | 028FFFh | | | | | | | 39 | 027000h | 027FFFh | | | | | | 4 | : | | | | | | individual block<br>unlock unit:64K-byte | | | 32 | 020000h | 020FFFh | | | IOCK/ | uniock unit.04K-byte | | | 31 | 01F000h | 01FFFFh | | | | <b>*</b> | 1 | 3 | : | | | | | | | | | 24 | 018000h | 018FFFh | | | | | | 2 | 23 | 017000h | 017FFFh | | | | | | | : | | | | | _ | ! | | | 16 | 010000h | 010FFFh | | | | | | | 15 | 00F000h | 00FFFFh | | | | | 1 | : | | | <b>*</b> | | | | 0 | | 8 | 008000h | 008FFFh | individual 16 sectors | | | | | 0 | 7 | 007000h | 007FFFh | lock/unlock unit:4K-byte | | | | | | : | | | <b>^</b> | | | | | | | 0 | 000000h | 000FFFh | | ## 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 incorrect command is inputted to this LSI, this LSI becomes standby mode and keeps the standby mode until next CS# falling edge. In standby mode, SO pin of this LSI should be High-Z. - 3. When correct command is inputted to this LSI, this LSI becomes active mode and keeps the active mode until next CS# rising edge. - 4. For standard single data rate serial mode, 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*. - 5. For the following instructions: RDID, RDSR, RDSCUR, READ, FAST\_READ, 2READ, DREAD, 4READ, QREAD, RDBLOCK, RES, REMS, REMS2, and REMS4 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, BE, BE32K, HPM, CE, PP, CP, 4PP, RDP, DP, WPSEL, SBLK, SBULK, GBULK, ENSO, EXSO, WRSCUR, ESRY, DSRY and CLSR the CS# must go high exactly at the byte boundary; otherwise, the instruction will be rejected and not executed. - 6. During the progress of Write Status Register, Program, Erase operation, to access the memory array is neglected and not affect the current operation of Write Status Register, Program, Erase. Figure 1. Serial Modes Supported (for Normal Serial mode) #### 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. ## 9. HOLD FEATURE HOLD# pin signal goes low to hold any serial communications with the device. The HOLD feature will not stop the operation of write status register, programming, or erasing in progress. The operation of HOLD requires Chip Select(CS#) keeping low and starts on falling edge of HOLD# pin signal while Serial Clock (SCLK) signal is being low (if Serial Clock signal is not being low, HOLD operation will not start until Serial Clock signal being low). The HOLD condition ends on the rising edge of HOLD# pin signal while Serial Clock(SCLK) signal is being low( if Serial Clock signal is not being low, HOLD operation will not end until Serial Clock being low), see *Figure 2*. Figure 2. Hold Condition Operation The Serial Data Output (SO) is high impedance, both Serial Data Input (SI) and Serial Clock (SCLK) are don't care during the HOLD operation. If Chip Select (CS#) drives high during HOLD operation, it will reset the internal logic of the device. To re-start communication with chip, the HOLD# must be at high and CS# must be at low. Note: The HOLD feature is disabled during Quad I/O mode. ## 10. COMMAND DESCRIPTION ## **Table 5. Command Sets** ## **Read Commands** | I/O | 1 | 1 | 2 | 2 | 4 | 4 | 4 | |---------------------|--------------------------------------------|--------------------------------------------|----------------------------------------------------------|------------------------------------|-----------------------------------------|---------------------------------------------|----------| | Read Mode | SPI | Command<br>(byte) | READ<br>(normal read) | FAST READ<br>(fast read<br>data) | 2READ (2<br>x I/O read<br>command)<br>Note1 | DREAD<br>(1I / 2O read<br>command) | W4READ | 4READ<br>(4 x I/O read<br>command)<br>Note1 | QREAD | | Clock rate<br>(MHz) | 50 | 104 | 70 | 70 | 54 | 70 | 70 | | 1st byte | 03 (hex) | 0B (hex) | BB (hex) | 3B (hex) | E7 (hex) | EB (hex) | 6B (hex) | | 2nd byte | AD1(8) | AD1(8) | AD1(4) | AD1(8) | AD1(2) | AD1(2) | AD1(8) | | 3rd byte | AD2(8) | AD2(8) | AD2(4) | AD2(8) | AD2(2) | AD2(2) | AD2(8) | | 4th byte | AD3(8) | AD3(8) | AD3(4) | AD3(8) | AD3(2) | AD3(2) | AD3(8) | | 5th byte | | Dummy(8) | Dummy(4) | Dummy(8) | Dummy(4) | Dummy(6) | Dummy(8) | | 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 | | Quad I/O read<br>with 4 dummy<br>cycles | Quad I/O read<br>with 6 dummy<br>cycles | | # MX25L12835E ## **Other Commands** | Command (byte) | WREN (write enable) | WRDI<br>(write disable) | RDSR (read status register) | WRSR (write status register) | 4PP (quad page program) | SE<br>(sector erase) | BE 32K (block erase 32KB) | |----------------|---------------------------------------------|--------------------------------------------------|-----------------------------------------------------|------------------------------|-----------------------------------------------|------------------------------------|----------------------------------------| | 1st byte | 06 (hex) | 04 (hex) | 05 (hex) | 01 (hex) | 38 (hex) | 20 (hex) | 52 (hex) | | 2nd byte | | | | Values | AD1 | AD1 | AD1 | | 3rd byte | | | | | AD2 | AD2 | AD2 | | 4th byte | | | | | AD3 | AD3 | AD3 | | Action | sets the (WEL)<br>write enable<br>latch bit | resets the<br>(WEL) write<br>enable latch<br>bit | to read out the<br>values of the<br>status register | values of the | quad input to<br>program the<br>selected page | to erase the<br>selected<br>sector | to erase the<br>selected 32KB<br>block | | Command (byte) | BE (block erase 64KB) | CE (chip<br>erase) | PP (page program) | CP (page program) | DP (Deep power down) | RDP (Release from deep power down) | RDID<br>(read identific-<br>ation) | |----------------|----------------------------------------|--------------------|------------------------------|---------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------------|-------------------------------------------------------------| | 1st byte | D8 (hex) | 60 or C7 (hex) | 02 (hex) | AD (hex) | B9 (hex) | AB (hex) | 9F (hex) | | 2nd byte | AD1 | | AD1 | AD1 | | | | | 3rd byte | AD2 | | AD2 | AD2 | | | | | 4th byte | AD3 | | AD3 | AD3 | | | | | Action | to erase the<br>selected 64KB<br>block | 1 | to program the selected page | continuously<br>program<br>whole chip,<br>the address is<br>automatically<br>increase | enters deep<br>power down<br>mode | release from<br>deep power<br>down mode | outputs JEDEC ID: 1-byte Manufacturer ID & 2-byte Device ID | | Command | RES (read | REMS (read electronic | REMS2 (read electronic | REMS4 (read electronic | ENSO (enter | |----------|----------------|-----------------------|------------------------|------------------------|----------------| | (byte) | electronic ID) | manufacturer | manufacturer | manufacturer | secured OTP) | | | | & device ID) | & device ID) | & device ID) | | | 1st byte | AB (hex) | 90 (hex) | EF (hex) | DF (hex) | B1 (hex) | | 2nd byte | Х | х | Х | Х | | | 3rd byte | Х | Х | Х | Х | | | 4th byte | Х | ADD (Note 2) | ADD | ADD | | | | to read out | output the | output the | output the | to enter the | | | 1-byte Device | Manufacturer | Manufacturer | Manufacturer | 4K-bit secured | | | ID | ID & Device ID | ID & Device ID | ID & device ID | OTP mode | | Action | | | | | | | | | | | | | | | | | | | | | | | | | | | ## MX25L12835E | Command (byte) | EXSO (exit secured OTP) | RDSCUR<br>(read security<br>register) | WRSCUR<br>(write security<br>register) | SBLK (single block lock | SBULK (single block unlock) | RDBLOCK<br>(block protect<br>read) | GBLK (gang<br>block lock) | |----------------|--------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------|-------------------------|------------------------------------------------------------------------|---------------------------------------------------------------|-----------------------------| | 1st byte | C1 (hex) | 2B (hex) | 2F (hex) | 36 (hex) | 39 (hex) | 3C (hex) | 7E (hex) | | 2nd byte | | | | AD1 | AD1 | AD1 | | | 3rd byte | | | | AD2 | AD2 | AD2 | | | 4th byte | | | | AD3 | AD3 | AD3 | | | Action | to exit the 4K-<br>bit secured<br>OTP mode | 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 update) | block (64K- | individual<br>block (64K-<br>byte) or sector<br>(4K-byte)<br>unprotect | read individual<br>block or sector<br>write protect<br>status | whole chip<br>write protect | | COMMAND (byte) | GBULK (gang block unlock) | NOP (No<br>Operation) | RSTEN<br>(Reset Enable) | RST (Reset<br>Memory) | SBL (Set Burst<br>Length) | WPSEL<br>(Write Protect<br>Selection) | ESRY (enable<br>SO to output<br>RY/BY#) | |----------------|---------------------------|-----------------------|-------------------------|-----------------------|---------------------------|-----------------------------------------------------------|--------------------------------------------------------| | 1st byte | 98 (hex) | 00 (hex) | 66 (hex) | 99 (hex) | 77 (hex) | 68 (hex) | 70 (hex) | | 2nd byte | | | | | Value | | | | 3rd byte | | | | | | | | | 4th byte | | | | | | | | | Action | whole chip<br>unprotect | | | | to set Burst<br>length | to enter<br>and enable<br>individal block<br>protect mode | to enable SO<br>to output RY/<br>BY# during CP<br>mode | | COMMAND (byte) | DSRY (disable<br>SO to output<br>RY/BY#) | CLSR (Clear<br>SR Fail Flags) | |----------------|---------------------------------------------------------|-----------------------------------------------| | 1st byte | 80 (hex) | 30 (hex) | | 2nd byte | | | | 3rd byte | | | | 4th byte | | | | Action | to disable SO<br>to output RY/<br>BY# during CP<br>mode | clear security<br>register bit 6<br>and bit 5 | - Note 1: The count base is 4-bit for ADD(2) and Dummy(2) because of 2 x I/O. And the MSB is on SI/SIO1 which is different from 1 x I/O condition. - Note 2: ADD=00H will output the manufacturer ID first and ADD=01H will output device ID first. - Note 3: It is not recommended to adopt any other code not in the command definition table, which will potentially enter the hidden mode. - Note 4: RST command only executed if RSTEN command is executed first. Any intervening command will disable Reset. ## 10-1. Write Enable (WREN) The Write Enable (WREN) instruction is for setting Write Enable Latch (WEL) bit. For those instructions like PP, 4PP, CP, SE, BE, BE32K, CE, WRSR, SBLK, SBULK, GBLK and GBULK, which are intended to change the device content, should be set every time after the WREN instruction setting the WEL bit. The sequence of issuing WREN instruction is: CS# goes low $\rightarrow$ sending WREN instruction code $\rightarrow$ CS# goes high. Figure 3. Write Enable (WREN) Sequence (Command 06) ## 10-2. Write Disable (WRDI) The Write Disable (WRDI) instruction is for resetting Write Enable Latch (WEL) bit. The sequence of issuing WRDI instruction is: CS# goes low→ sending WRDI instruction code→ CS# goes high. The WEL bit is reset by following situations: - Power-up - Write Disable (WRDI) instruction completion - Write Status Register (WRSR) instruction completion - Page Program (PP, 4PP) instruction completion - Sector Erase (SE) instruction completion - Block Erase (BE, BE32K) instruction completion - Chip Erase (CE) instruction completion - Continuously Program mode (CP) instruction completion - Single Block Lock/Unlock (SBLK/SBULK) instruction completion - Gang Block Lock/Unlock (GBLK/GBULK) instruction completion Figure 4. Write Disable (WRDI) Sequence (Command 04) ## 10-3. Read Identification (RDID) The RDID instruction is for reading the Manufacturer ID of 1-byte and followed by Device ID of 2-byte. The MXIC Manufacturer ID is C2(hex), the memory type ID is 20(hex) as the first-byte Device ID, and the individual Device ID of second-byte ID are listed as table of "Table 7. ID Definitions". The sequence of issuing RDID instruction is: CS# goes low $\rightarrow$ sending RDID instruction code $\rightarrow$ 24-bits ID data out on SO $\rightarrow$ to end RDID operation can use CS# to high at any time during data out. While Program/Erase operation is in progress, it will not decode the RDID instruction, so 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 5. Read Identification (RDID) Sequence (Command 9F) ## 10-4. Read Status Register (RDSR) The RDSR instruction is for reading Status Register. The Read Status Register can be read at any time (even in program/erase/write status register condition) and continuously. 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 $\rightarrow$ sending RDSR instruction code $\rightarrow$ Status Register data out on SO. Figure 6. Read Status Register (RDSR) Sequence (Command 05) 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, a volatile bit, indicates whether the device is set to internal write enable latch. When WEL bit sets to "1", which means the internal write enable latch is set, the device can accept program/erase/write status register instruction. When WEL bit sets to 0, which means no internal write enable latch; the device will not accept program/erase/write status register instruction. The program/erase command will be ignored and will reset WEL bit if it is applied to a protected memory area. To ensure both WIP bit & WEL bit are both set to 0 and available for next program/erase/operations, WIP bit needs to be confirm to be 0 before polling WEL bit. After WIP bit confirmed, WEL bit needs to be confirm to be 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 (BE) and Chip Erase (CE) instructions (only if all Block Protect bits set to 0, the CE instruction can be executed). The BP3, BP2, BP1, BP0 bits are "0" as default. Which is un-protected. **QE bit.** The Quad Enable (QE) bit, non-volatile bit, while it is "0" (factory default), it performs non-Quad and WP# is enable. While QE is "1", it performs Quad I/O mode and WP# is disabled. In the other word, if the system goes into four I/O mode (QE=1), the feature of HPM will be disabled. **SRWD** bit. The Status Register Write Disable (SRWD) bit, non-volatile bit, default value is "0". SRWD bit is operated together with Write Protection (WP#/SIO2) pin for providing hardware protection mode. The hardware protection mode requires SRWD sets to 1 and WP#/SIO2 pin signal is low stage. In the hardware protection mode, the Write Status Register (WRSR) instruction is no longer accepted for execution and the SRWD bit and Block Protect bits (BP3, BP2, BP1, BP0) are read only. The SRWD bit defaults to be "0". ## **Status Register** | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-----------------------------------------------|-------------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|--------------------------------------------|-----------------------------------------------------| | SRWD<br>(status<br>register write<br>protect) | 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) | | 1=status<br>register write<br>disable | 1= Quad<br>Enable<br>0=not Quad<br>Enable | (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 | | Non-volatile bit | Non-volatile bit | Non-volatile bit | Non-volatile bit | Non-volatile bit | Non-volatile bit | volatile bit | volatile bit | Note: see the "Table 2. Protected Area Sizes". ## 10-5. Write Status Register (WRSR) The WRSR instruction is for changing the values of Status 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*). The WRSR also can set or reset the Quad enable (QE) bit and set or reset the Status Register Write Disable (SRWD) bit in accordance with Write Protection (WP#/SIO2) pin signal, but has no effect on bit1(WEL) and bit0 (WIP) of the status register. The WRSR instruction cannot be executed once the Hardware Protected Mode (HPM) is entered. The sequence of issuing WRSR instruction is: CS# goes low $\rightarrow$ sending WRSR instruction code $\rightarrow$ Status Register data on SI $\rightarrow$ CS# goes high. The CS# must go high exactly at the byte 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 checked 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. **Table 6. Protection Modes** | Mode | Status register condition | WP# and SRWD bit status | Memory | |--------------------------------|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------| | Software protection mode (SPM) | Status register can be written in (WEL bit is set to "1") and the SRWD, BP0-BP3 bits can be changed | WP#=1 and SRWD bit=0, or<br>WP#=0 and SRWD bit=0, or<br>WP#=1 and SRWD=1 | | | Hardware protection mode (HPM) | The SRWD, BP0-BP3 of status register bits cannot be changed | WP#=0, SRWD bit=1 | 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*. As the table above showing, the summary of the Software Protected Mode (SPM) and Hardware Protected Mode (HPM): ## Software Protected Mode (SPM): - When SRWD bit=0, no matter WP#/SIO2 is low or high, the WREN instruction may set the WEL bit and can change the values of SRWD, BP3, BP2, BP1, BP0. The protected area, which is defined by BP3, BP2, BP1, BP0, is at software protected mode (SPM). - When SRWD bit=1 and WP#/SIO2 is high, the WREN instruction may set the WEL bit can change the values of SRWD, BP3, BP2, BP1, BP0. The protected area, which is defined by BP3, BP2, BP1, BP0, is at software protected mode (SPM) #### Hardware Protected Mode (HPM): - When SRWD bit=1, and then WP#/SIO2 is low (or WP#/SIO2 is low before SRWD bit=1), it enters the hardware protected mode (HPM). The data of the protected area is protected by software protected mode by BP3, BP2, BP1, BP0 and hardware protected mode by the WP#/SIO2 to against data modification. #### Note: To exit the hardware protected mode requires WP#/SIO2 driving high once the hardware protected mode is entered. If the WP#/SIO2 pin is permanently connected to high, the hardware protected mode can never be entered; only can use software protected mode via BP3, BP2, BP1, BP0. If the system goes into four I/O mode, the feature of HPM will be disabled. Figure 8. WRSR flow ## 10-6. 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$ 3-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. Figure 9. Read Data Bytes (READ) Sequence (Command 03) ## 10-7. 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$ sending FAST\_READ instruction code $\rightarrow$ 3-byte address on SI $\rightarrow$ 1-dummy byte (default) address on SI $\rightarrow$ data out on SO $\rightarrow$ to end FAST\_READ operation can use CS# to high at any time during data out. (Please refer to *Figure 10*) In the 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 reduce the next 4READ instruction. Once P[7:4] is no longer toggling with P[3:0]; likewise P[7:0]=FFh,00h,AAh or 55h and afterwards CS# is raised and then lowered, the system then will escape from performance enhance mode and return to normal operation. 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 10. Read at Higher Speed (FAST\_READ) Sequence (Command 0B) (104MHz) ## 10-8. Dual Read Mode (DREAD) The DREAD instruction enable double throughput of Serial 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$ sending DREAD instruction $\rightarrow$ 3-byte address on SI $\rightarrow$ 8-bit dummy cycle $\rightarrow$ data out interleave on SO1 & SO0 $\rightarrow$ to end DREAD operation 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. ## 10-9. 2 x I/O Read Mode (2READ) The 2READ instruction enables Double Transfer Rate of Serial 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$ sending 2READ instruction $\rightarrow$ 24-bit address interleave on SIO1 & SIO0 $\rightarrow$ 4-bit dummy cycle 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 12. 2 x I/O Read Mode Sequence (Command BB) **Note:** SI/SIO0 or SO/SIO1 should be kept "0h" or "Fh" in the first two dummy cycles. In other words, P2=P0 or P3=P1 is necessary. ## 10-10. Quad Read Mode (QREAD) The QREAD instruction enable quad throughput of Serial 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$ sending QREAD instruction $\rightarrow$ 3-byte address on SI $\rightarrow$ 8-bit dummy cycle $\rightarrow$ data out interleave on SO3, SO2, SO1 & SO0 $\rightarrow$ to end QREAD operation 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 13. Quad Read Mode Sequence (Command 6B) ## 10-11. 4 x I/O Read Mode (4READ) The 4READ instruction enables quad throughput of Serial Flash in read mode. A Quad Enable (QE) bit of status Register must be set to "1" before sending the 4READ instruction. 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. The sequence of issuing 4READ instruction is: CS# goes low $\rightarrow$ sending 4READ instruction $\rightarrow$ 24-bit address interleave on SIO3, SIO2, SIO1 & SIO0 $\rightarrow$ 2+4 dummy cycles $\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. (Please refer to *Figure 14* for 4 x I/O Read Mode Timing Waveform) W4READ instruction (E7) is also available for 4 I/O read. The sequence is similar to 4READ, but with only 4 dummy cycles. The clock rate runs at 54MHz. Figure 14. 4 x I/O Read Mode Sequence (Command EB) #### Note: - 1. Hi-impedance is inhibited for the two clock cycles. - 2. P7≠P3, P6≠P2, P5≠P1 & P4≠P0 (Toggling) is inhibited. ## MX25L12835E Another sequence of issuing 4READ instruction especially useful in random access is : CS# goes low $\rightarrow$ sending 4READ instruction $\rightarrow$ 3-bytes address interleave on SIO3, SIO2, SIO1 & SIO0 $\rightarrow$ performance enhance toggling bit P[7:0] $\rightarrow$ 4 dummy cycles $\rightarrow$ data out still CS# goes high $\rightarrow$ CS# goes low (reduce 4 Read instruction) $\rightarrow$ 24-bit random access address (Please refer to *Figure 15* for 4 x I/O Read Enhance Performance Mode timing waveform). In the performance-enhancing mode (Notes of *Figure 15*), 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 reduce the next 4READ instruction. Once P[7:4] is no longer toggling with P[3:0]; likewise P[7:0]=FFh, 00h, AAh or 55h. These commands will reset the performance enhance mode. And afterwards CS# is raised and then lowered, the system then will return to normal operation. 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. ## 10-12. Performance Enhance Mode The device could waive the command cycle bits if the two cycle bits after address cycle toggles. (Please note *Figure 15* 4xI/O Read enhance performance mode sequence) Please be noticed that "EBh" "E7h" commands support enhance mode. The performance enhance mode is not supported in dual I/O mode. After entering enhance mode, following CSB go high, the device will stay in the read mode and treat CSB go low of the first clock as address instead of command cycle. To exit enhance mode, a new fast read command whose first two dummy cycles is not toggle then exit. Or issue "FFh" command to exit enhance mode. ## 10-13. Performance Enhance Mode Reset (FFh) To conduct the Performance Enhance Mode Reset operation, FFh command code, 8 clocks, should be issued in 1I/O sequence. If the system controller is being Reset during operation, the flash device will return to the standard SPI operation. Upon Reset of main chip, SPI instruction would be issued from the system. Instructions like Read ID (9Fh) or Fast Read (0Bh) would be issued. Figure 15. 4 x I/O Read enhance performance Mode Sequence (Command EB) Note: Performance enhance mode, if P7≠P3 & P6≠P2 & P5≠P1 & P4≠P0 (Toggling), ex: A5, 5A, 0F, if not using performance enhance recommend to keep 1 or 0 in performance enhance indicator. Reset the performance enhance mode, if P7=P3 or P6=P2 or P5=P1 or P4=P0, ex: AA, 00, FF Figure 16. Performance Enhance Mode Reset for Fast Read Quad I/O ## 10-14. Burst Read To set the Burst length, following command operation is required Issuing command: "77h" in the first Byte (8-clocks), following 4 clocks defining wrap around enable with "0h" and disable with "1h". Next 4 clocks is to define wrap around depth. Definition as following table: | Data | Wrap Around | Wrap Depth | Data | Wrap Around | Wrap Depth | |------|-------------|------------|------|-------------|------------| | 1xh | No | Χ | 00h | Yes | 8-byte | | 1xh | No | X | 01h | Yes | 16-byte | | 1xh | No | Х | 02h | Yes | 32-byte | | 1xh | No | Х | 03h | Yes | 64-byte | The wrap around unit is defined within the 256Byte page, with random initial address. It's defined as "wrap-around mode disable" for the default state of the device. To exit wrap around, it is required to issue another "77" command in which data='1xh". Otherwise, wrap around status will be retained until power down or reset command. To change wrap around depth, it is required to issue another "77" command in which data="0xh". SPI "EBh" "E7h" support wrap around feature after wrap around enable. The Device ID default without Burst read. Figure 17. Burst Read ## 10-15. 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 (see *Table 4. Memory Organization for MX25-L12835E*) is a valid address for Sector Erase (SE) instruction. The CS# must go high exactly at the byte boundary (the latest eighth of address byte has been latched-in); otherwise, the instruction will be rejected and not executed. The sequence of issuing SE instruction is: CS# goes low $\rightarrow$ sending SE instruction code $\rightarrow$ 3-byte address on SI $\rightarrow$ CS# goes high. 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 out during the Sector Erase cycle is in progress. The WIP sets 1 during the tSE timing, and sets 0 when Sector Erase Cycle is completed, and the Write Enable Latch (WEL) bit is reset. If the sector is protected by BP3~0 (WPSEL=0) or by individual lock (WPSEL=1), the array data will be protected (no change) and the WEL bit still be reset. Figure 18. Sector Erase (SE) Sequence (Command 20) #### 10-16. 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 execute to set the Write Enable Latch (WEL) bit before sending the Block Erase (BE). Any address of the block (see *Table 4. Memory Organization for MX25L12835E*) is a valid address for Block Erase (BE) instruction. The CS# must go high exactly at the byte boundary (the latest eighth of address byte has been latched-in); otherwise, the instruction will be rejected and not executed. The sequence of issuing BE instruction is: CS# goes low $\rightarrow$ sending BE instruction code $\rightarrow$ 3-byte address on SI $\rightarrow$ CS# goes high. 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 out during the Sector Erase cycle is in progress. The WIP sets 1 during the tBE timing, and sets 0 when Sector Erase Cycle is completed, and the Write Enable Latch (WEL) bit is reset. If the block is protected by BP3~0 (WPSEL=0) or by individual lock (WPSEL=1), the array data will be protected (no change) and the WEL bit still be reset. Figure 19. Block Erase (BE) Sequence (Command D8) #### 10-17. Block Erase (BE32K) The Block Erase (BE32) 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 execute to set the Write Enable Latch (WEL) bit before sending the Block Erase (BE32). Any address of the block (see *Table 4. Memory Organization for MX25L12835E*) is a valid address for Block Erase (BE32) instruction. The CS# must go high exactly at the byte boundary (the latest eighth of address byte has been latched-in); otherwise, the instruction will be rejected and not executed. The sequence of issuing BE32 instruction is: CS# goes low $\rightarrow$ sending BE32 instruction code $\rightarrow$ 3-byte address on SI $\rightarrow$ CS# goes high. 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 out during the Sector Erase cycle is in progress. The WIP sets 1 during the tBE timing, and sets 0 when Sector Erase Cycle is completed, and the Write Enable Latch (WEL) bit is reset. If the block is protected by BP3~0 (WPSEL=0) or by individual lock (WPSEL=1), the array data will be protected (no change) and the WEL bit still be reset. Figure 20. Block Erase 32KB (BE32K) Sequence (Command 52) ### 10-18. 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 execute 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 $\rightarrow$ sending CE instruction code $\rightarrow$ CS# goes high. 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 out during the Chip Erase cycle is in progress. The WIP sets 1 during the tCE timing, and sets 0 when Chip Erase Cycle is completed, and the Write Enable Latch (WEL) bit is reset. If the chip is protected the Chip Erase (CE) instruction will not be executed, but WEL will be reset. Figure 21. Chip Erase (CE) Sequence (Command 60 or C7) #### 10-19. Page Program (PP) The Page Program (PP) instruction is for programming the memory to be "0". A Write Enable (WREN) instruction must execute to set the Write Enable Latch (WEL) bit before sending the Page Program (PP). The device programs only the last 256 data bytes sent to the device. If the entire 256 data bytes are going to be programmed, A7-A0 (The eight least significant address bits) should be set to 0. If the eight least significant address bits (A7-A0) are not all 0, all transmitted data going beyond the end of the current page are programmed from the start address of the same page (from the address A7-A0 are all 0). If more than 256 bytes are sent to the device, the data of the last 256-byte is programmed at the request page and previous data will be disregarded. If less than 256 bytes are sent to the device, the data is programmed at the requested address of the page without effect on other address of the same page. The sequence of issuing PP instruction is: CS# goes low $\rightarrow$ sending PP instruction code $\rightarrow$ 3-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 out during the Page Program cycle is in progress. The WIP sets 1 during the tPP timing, and sets 0 when Page Program Cycle is completed, and the Write Enable Latch (WEL) bit is reset. If the page is protected by BP3~0 (WPSEL=0) or by individual lock (WPSEL=1), the array data will be protected (no change) and the WEL bit will still be reset. Figure 22. Page Program (PP) Sequence (Command 02) #### 10-20. 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 execute to set the Write Enable Latch (WEL) bit and Quad Enable (QE) bit must be set to "1" before sending the Quad Page Program (4PP). The Quad Page Programming takes four pins: SIO0, SIO1, SIO2, and SIO3, which can raise programmer performance and the effectiveness of application of lower clock less than 70MHz. For system with faster clock, the Quad page program cannot provide more actual favors, because the required internal page program time is far more than the time data flows in. Therefore, we suggest that while executing this command (especially during sending data), user can slow the clock speed down to 70MHz below. The other function descriptions are as same as standard page program. The sequence of issuing 4PP instruction is: CS# goes low $\rightarrow$ sending 4PP instruction code $\rightarrow$ 3-byte address on SIO[3:0] $\rightarrow$ at least 1-byte on data on SIO[3:0] $\rightarrow$ CS# goes high. If the page is protected by BP3~0 (WPSEL=0) or by individual lock (WPSEL=1), the array data will be protected (no change) and the WEL bit will still be reset. The Program/Erase function instruction function flow is as follows: Figure 24. Program/Erase Flow(1) with read array data Figure 25. Program/Erase Flow(2) without read array data #### 10-21. Continuously program mode (CP mode) The CP mode may enhance program performance by automatically increasing address to the next higher address after each byte data has been programmed. The Continuously program (CP) instruction is for multiple bytes program to Flash. A write Enable (WREN) instruction must execute to set the Write Enable Latch (WEL) bit before sending the Continuously program (CP) instruction. CS# requires to go high before CP instruction is executing. After CP instruction and address input, two bytes of data is input sequentially from MSB(bit7) to LSB(bit0). The first byte data will be programmed to the initial address range with A0=0 and second byte data with A0=1. If only one byte data is input, the CP mode will not process. If more than two bytes data are input, the additional data will be ignored and only two byte data are valid. Any byte to be programmed should be in the erase state (FF) first. It will not roll over during the CP mode, once the last unprotected address has been reached, the chip will exit CP mode and reset write Enable Latch bit (WEL) as "0" and CP mode bit as "0". Please check the WIP bit status if it is not in write progress before entering next valid instruction. During CP mode, the valid commands are CP command (AD hex), WRDI command (04 hex), RDSR command (05 hex), and RDSCUR command (2B hex). And the WRDI command is valid after completion of a CP programming cycle, which means the WIP bit=0. The sequence of issuing CP instruction is : CS# goes low $\rightarrow$ sending CP instruction code $\rightarrow$ 3-byte address on SI pin $\rightarrow$ two data bytes on SI $\rightarrow$ CS# goes high to low $\rightarrow$ sending CP instruction and then continue two data bytes are programmed $\rightarrow$ CS# goes high to low $\rightarrow$ sending WRDI (Write Disable) instruction to end CP mode $\rightarrow$ send RDSR instruction to verify if CP mode word program ends, or send RDSCUR to check bit4 to verify if CP mode ends. Three methods to detect the completion of a program cycle during CP mode: - 1) Software method-I: by checking WIP bit of Status Register to detect the completion of CP mode. - 2) Software method-II: by waiting for a tBP time out to determine if it may load next valid command or not. - 3) Hardware method: by writing ESRY (enable SO to output RY/BY#) instruction to detect the completion of a program cycle during CP mode. The ESRY instruction must be executed before CP mode execution. Once it is enable in CP mode, the CS# goes low will drive out the RY/BY# status on SO, "0" indicates busy stage, "1" indicates ready stage, SO pin outputs tri-state if CS# goes high. DSRY (disable SO to output RY/BY#) instruction to disable the SO to output RY/BY# and return to status register data output during CP mode. Please note that the ESRY/DSRY commands are not accepted unless the completion of CP mode. If the page is protected by BP3~0 (WPSEL=0) or by individual lock (WPSEL=1), the array data will be protected (no change) and the WEL bit will still be reset. Figure 26. Continously Program (CP) Mode Sequence with Hardware Detection (Command AD) #### Notes: - (1) During CP mode, the valid commands are CP command (AD hex), WRDI command (04 hex), RDSR command (05 hex), RDSCUR command (2B hex), RSTEN command (66 hex) and RST command (99hex). - (2) Once an internal programming operation begins, CS# goes low will drive the status on the SO pin and CS# goes high will return the SO pin to tri-state. - (3) To end the CP mode, either reaching the highest unprotected address or sending Write Disable (WRDI) command (04 hex) may achieve it and then it is recommended to send RDSR command (05 hex) to verify if CP mode is ended. Please be noticed that Software reset and Hardware reset can end the CP mode. #### 10-22. Deep Power-down (DP) The Deep Power-down (DP) instruction is for setting the device on the minimizing the power consumption (to entering the Deep Power-down mode), the standby current is reduced from ISB1 to ISB2). The Deep Power-down mode requires the Deep Power-down (DP) instruction to enter, during the Deep Power-down mode, the device is not active and all Write/Program/Erase instructions are ignored. When CS# goes high, it's only in standby mode not deep power-down mode. It's different from Standby mode. The sequence of issuing DP instruction is: CS# goes low→ sending DP instruction code→ CS# goes high. Once the DP instruction is set, all instructions will be ignored except the Release from Deep Power-down mode (RDP) and Read Electronic Signature (RES) instruction. (those instructions allow the ID being reading out). When Power-down, the deep power-down mode automatically stops, and when power-up, the device automatically is in standby mode. For RDP instruction the CS# must go high exactly at the byte boundary (the latest eighth bit of instruction code has been latched-in); otherwise, the instruction will not be executed. As soon as Chip Select (CS#) goes high, a delay of tDP is required before entering the Deep Power-down mode and reducing the current to ISB2. Figure 27. Deep Power-down (DP) Sequence (Command B9) ### 10-23. Release from Deep Power-down (RDP), Read Electronic Signature (RES) The Release from Deep Power-down (RDP) instruction is terminated by driving Chip Select (CS#) High. When Chip Select (CS#) is driven High, the device is put in the standby Power mode. If the device was not previously in the Deep Power-down mode, the transition to the standby Power mode is immediate. If the device was previously in the Deep Power-down mode, though, the transition to the standby Power mode is delayed by tRES2, and Chip Select (CS#) must remain High for at least tRES2(max), as specified in *Table 10. AC CHARACTERISTICS* (*Temperature = -40°C to 85°C for Industrial grade, VCC = 2.7V ~ 3.6V*). Once in the standby mode, the device waits to be selected, so that it can receive, decode and execute instructions. RES instruction is for reading out the old style of 8-bit Electronic Signature, whose values are shown as *Table 7. 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. Even in Deep power-down mode, the RDP and RES are also allowed to be executed, only except the device is in progress of program/erase/write cycles; there's no effect on the current program/erase/write cycles in progress. The sequence is shown as *Figure 28*, *Figure 29*. 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 receive, decode, and execute instruction. The RDP instruction is for releasing from Deep Power-down Mode. Figure 28. Release from Deep Power-down and Read Electronic Signature (RES) Sequence (Command AB) Figure 29. Release from Deep Power-down (RDP) Sequence (Command AB) #### 10-24. Read Electronic Manufacturer ID & Device ID (REMS), (REMS2), (REMS4) The REMS, REMS2, and REMS4 instruction provides both the JEDEC assigned Manufacturer ID and the specific Device ID. The instruction is initiated by driving the CS# pin low and shift the instruction code "90h", "DFh" or "EFh" followed by two dummy bytes and one byte address (A7~A0). After which, the Manufacturer ID for MXIC (C2h) and the Device ID are shifted out on the falling edge of SCLK with most significant bit (MSB) first as shown in *Figure 30*. The Device ID values are listed in table of *Table 7*. *ID Definitions*. If the one-byte address is initially set to 01h, then the Device ID will be read first and then followed by the Manufacturer ID. The Manufacturer and Device IDs can be read continuously, alternating from one to the other. The instruction is completed by driving CS# high. Figure 30. Read Electronic Manufacturer & Device ID (REMS) Sequence (Command 90 or EF or DF) #### Notes: - 1. A0=0 will output the Manufacturer ID first and A0=1 will output Device ID first. A1~A23 are don't care. - 2. Instruction is either 90(hex) or EF(hex) or DF(hex). #### 10-25. ID Read The ID Read instruction identifies the devices as MX25L12835E and manufacturer as MXIC. The sequence of issue ID instruction is CS# goes low $\rightarrow$ sending ID instruction $\rightarrow$ Data out on SO $\rightarrow$ CS# goes high. Most significant bit (MSB) first. Immediately following the command cycle the device outputs data on the falling edge of the SCLK signal. The data output stream is continuous until terminated by a low-tohigh transition of CS#. The device outputs three bytes of data: manufacturer, device type, and device ID. Table 7. ID Definitions | Command Type | | MX25L12835E | | | | |--------------|-----------------|-------------|----------------|--|--| | RDID | manufacturer ID | memory type | memory density | | | | KUIU | C2 | 20 | 18 | | | | RES | electronic ID | | | | | | KES | 17 | | | | | | REMS/REMS2/ | manufacturer ID | device ID | | | | | REMS4 | C2 | 17 | | | | #### 10-26. Enter Secured OTP (ENSO) The ENSO instruction is for entering the additional 4K-bit Secured OTP mode. The additional 4K-bit Secured OTP is independent from main array, which may use to store unique serial number for system identifier. After entering the Secured OTP mode, and then 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$ sending ENSO instruction to enter Secured OTP mode $\rightarrow$ CS# goes high. Please note that WRSR/WRSCUR/WPSEL/SBLK/GBLK/SBULK/GBULK/CE/BE/SE/BE32K commands are not acceptable during the access of secure OTP region, once Security OTP is locked down, only read related commands are valid. #### 10-27. 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→ sending EXSO instruction to exit Secured OTP mode→ CS# goes high. #### 10-28. Read Security Register (RDSCUR) The RDSCUR instruction is for reading the value of Security Register. 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$ sending RDSCUR instruction $\rightarrow$ Security Register data out on SO $\rightarrow$ CS# goes high. Please refer to *Figure 31*. Figure 31. Read Security Register (RDSCUR) Sequence (Command 2B) The definition of the Security Register is as below: **Secured OTP Indicator bit.** The Secured OTP indicator bit shows the chip is locked by factory before ex- 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, array access is not allowed. **Continuously Program Mode (CP mode) bit.** The Continuously Program Mode bit indicates the status of CP mode, "0" indicates not in CP mode; "1" indicates in CP mode. **Program Fail Flag bit.** While a program failure happened, the Program Fail Flag bit would be set. This bit will also be set when the user attempts to program a protected main memory region or a locked OTP region. This bit can indicate whether one or more of program operations fail, and can be reset by command CLSR (30h) **Erase Fail Flag bit.** While an erase failure happened, the Erase Fail Flag bit would be set. This bit will also be set when the user attempts to erase a protected main memory region or a locked OTP region. This bit can indicate whether one or more of erase operations fail, and can be reset by command CLSR (30h) ## MX25L12835E **Write Protection Select bit.** The Write Protection Select bit indicates that WPSEL has been executed successfully. Once this bit has been set (WPSEL=1), all the blocks or sectors will be write-protected after the power-on every time. Once WPSEL has been set, it cannot be changed again, which means it's only for individual WP mode. Under the individual block protection mode (WPSEL=1), hardware protection is performed by driving WP#=0. Once WP#=0, all array blocks/sectors are protected regardless of the contents of SRAM lock bits. **Table 8. Security Register Definition** | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |---------------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------------------------------|--------------|--------------|----------------------------------------------------------------------------------|--------------------------------------| | WPSEL | E_FAIL | P_FAIL | Continuously Program mode (CP mode) | x | x | LDSO<br>(lock-down<br>4K-bit Se-<br>cured OTP) | 4K-bit<br>Secured OTP | | 0=normal<br>WP mode<br>1=individual<br>WP mode<br>(default=0) | 0=normal Erase succeed 1=indicate Erase failed (default=0) | 0=normal Program succeed 1=indicate Program failed (default=0) | 0=normal<br>Program<br>mode<br>1=CP mode<br>(default=0) | reserved | reserved | 0 = not<br>lockdown<br>1 = lock-<br>down<br>(cannot<br>program/<br>erase<br>OTP) | 0 = nonfactory lock 1 = factory lock | | non-volatile<br>bit | volatile bit | volatile bit | volatile bit | volatile bit | volatile bit | non-volatile<br>bit | non-volatile<br>bit | | OTP | Read Only | Read Only | Read Only | Read Only | Read Only | OTP | Read Only | #### 10-29. Write Security Register (WRSCUR) The WRSCUR instruction is for changing the values of Security Register Bits. Unlike write status register, the WREN instruction is not required before sending 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$ sending WRSCUR instruction $\rightarrow$ CS# goes high. The CS# must go high exactly at the boundary; otherwise, the instruction will be rejected and not executed. Figure 32. Write Security Register (WRSCUR) Sequence (Command 2F) #### 10-30. Write Protection Selection (WPSEL) There are two write protection methods, (1) BP protection mode (2) individual block protection mode. If WPSEL=0, flash is under BP protection mode. If WPSEL=1, flash is under individual block protection mode. The default value of WPSEL is "0". WPSEL command can be used to set WPSEL=1. Please note that WPSEL is an OTP bit. Once WPSEL is set to 1, there is no chance to recovery WPSEL back to "0". If the flash is put on BP mode, the individual block protection mode is disabled. Contrarily, if flash is on the individual block protection mode, the BP mode is disabled. Every time after the system is powered-on, and the Security Register bit 7 is checked to be WPSEL=1, all the blocks or sectors will be write protected by default. User may only unlock the blocks or sectors via SBULK and GBULK instruction. Program or erase functions can only be operated after the Unlock instruction is conducted. ### BP protection mode, WPSEL=0: ARRAY is protected by BP3~BP0 and BP3~BP0 bits are protected by "SRWD=1 and WP#=0", where SRWD is bit 7 of status register that can be set by WRSR command. #### Individual block protection mode, WPSEL=1: Blocks are individually protected by their own SRAM lock bits which are set to "1" after power up. SBULK and SBLK command can set SRAM lock bit to "0" and "1". When the system accepts and executes WPSEL instruction, the bit 7 in security register will be set. It will activate SBLK, SBULK, RDBLOCK, GBLK, GBULK etc instructions to conduct block lock protection and replace the original Software Protect Mode (SPM) use (BP3~BP0) indicated block methods. Under the individual block protection mode (WPSEL=1), hardware protection is performed by driving WP#=0. Once WP#=0, all array blocks/sectors are protected regardless of the contents of SRAM lock bits. The sequence of issuing WPSEL instruction is: CS# goes low $\rightarrow$ sending WPSEL instruction to enter the individual block protect mode $\rightarrow$ CS# goes high. Please refer to *Figure 33*. Figure 33. Write Protection Selection (WPSEL) Sequence (Command 68) WPSEL instruction function flow is as follows: Figure 34. BP and SRWD if WPSEL=0 Figure 35. The individual block lock mode is effective after setting WPSEL=1 Figure 36. WPSEL Flow ## 10-31. Single Block Lock/Unlock Protection (SBLK/SBULK) These instructions are only effective after WPSEL was executed. The SBLK instruction is for write protection a specified block(or sector) of memory, using A23-A16 or (A23-A12) address bits to assign a 64Kbytes block (or 4K bytes sector) to be protected as read only. The SBULK instruction will cancel the block (or sector) write protection state. This feature allows user to stop protecting the entire block (or sector) through the chip unprotect command (GBULK). The WREN (Write Enable) instruction is required before issuing SBLK/SBULK instruction. The sequence of issuing SBLK/SBULK instruction is: CS# goes low $\rightarrow$ send SBLK/SBULK (36h/39h) instruction $\rightarrow$ send 3 address bytes assign one block (or sector) to be protected on SI pin $\rightarrow$ CS# goes high. The CS# must go high exactly at the byte boundary, otherwise the instruction will be rejected and not be executed. Figure 37. Single Block Lock/Unlock Protection (SBLK/SBULK) Sequence (Command 36/39) SBLK/SBULK instruction function flow is as follows: Figure 38. Block Lock Flow Figure 39. Block Unlock Flow #### 10-32. Read Block Lock Status (RDBLOCK) This instruction is only effective after WPSEL was executed. The RDBLOCK instruction is for reading the status of protection lock of a specified block(or sector), using A23-A16 (or A23-A12) address bits to assign a 64K bytes block (4K bytes sector) and read protection lock status bit which the first byte of Read-out cycle. The status bit is"1" to indicate that this block has been protected, that user can read only but cannot write/program /erase this block. The status bit is "0" to indicate that this block hasn't be protected, and user can read and write this block. The sequence of issuing RDBLOCK instruction is: CS# goes low $\rightarrow$ send RDBLOCK (3Ch) instruction $\rightarrow$ send 3 address bytes to assign one block on SI pin $\rightarrow$ read block's protection lock status bit on SO pin $\rightarrow$ CS# goes high. Figure 40. Read Block Protection Lock Status (RDBLOCK) Sequence (Command 3C) ### 10-33. Gang Block Lock/Unlock (GBLK/GBULK) These instructions are only effective after WPSEL was executed. The GBLK/GBULK instruction is for enable/ disable the lock protection block of the whole chip. The WREN (Write Enable) instruction is required before issuing 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. Figure 41. Gang Block Lock/Unlock (GBLK/GBULK) Sequence (Command 7E/98) ## MX25L12835E #### 10-34. Clear SR Fail Flags (CLSR) The CLSR instruction is for resetting the Program/Erase Fail Flag bit of Security Register. It should be executed before program/erase another block during programming/erasing flow without read array data. The sequence of issuing CLSR instruction is: CS# goes low $\rightarrow$ send CLSR instruction code $\rightarrow$ CS# goes high. The CS# must go high exactly at the byte boundary; otherwise, the instruction will be rejected and not executed. #### 10-35. Enable SO to Output RY/BY# (ESRY) The ESRY instruction is for outputting the ready/busy status to SO during CP mode. The sequence of issuing ESRY instruction is: CS# goes low $\rightarrow$ sending ESRY instruction code $\rightarrow$ CS# goes high. The CS# must go high exactly at the byte boundary; otherwise, the instruction will be rejected and not executed. #### 10-36. Disable SO to Output RY/BY# (DSRY) The DSRY instruction is for resetting ESRY during CP mode. The ready/busy status will not output to SO after DSRY issued. The sequence of issuing DSRY instruction is: CS# goes low $\rightarrow$ send DSRY instruction code $\rightarrow$ CS# goes high. The CS# must go high exactly at the byte boundary; otherwise, the instruction will be rejected and not executed. #### 10-37. No Operation (NOP) The No Operation command only cancels a Reset Enable command. NOP has no impact on any other command. #### 10-38. Software Reset (Reset-Enable (RSTEN) and Reset (RST)) The Reset operation is used as a system (software) reset that puts the device in normal operating Ready mode. This operation consists of two commands: Reset-Enable (RSTEN) and Reset (RST). To reset the device, the host drives CS# low, sends the Reset-Enable command (66H), and drives CS# high. Next, the host drives CS# low again, sends the Reset command (99H), and drives CS# high. The Reset operation requires the Reset-Enable command followed by the Reset command. Any command other than the Reset command after the Reset-Enable command will disable the Reset-Enable. A successful command execution will reset the device to SPI stand-by read mode, which are their respective default states. A device reset during an active Program or Erase operation aborts the operation, which can cause the data of the targeted address range to be corrupted or lost. Depending on the prior operation, the reset timing may vary. Recovery from a Write operation requires more latency time than recovery from other operations. Figure 42. Software Reset Recovery #### 11. POWER-ON STATE The device is at below states when 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 unless the VCC achieves below correct level: - 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. For further protection on the device, if the VCC does not reach the VCC minimum level, the correct operation is not guaranteed. The read, write, erase, and program command should be sent after the 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. #### Note: - To stabilize the VCC level, the VCC rail decoupled by a suitable capacitor close to package pins is recommended. (generally around 0.1uF) #### 12. ELECTRICAL SPECIFICATIONS #### 12-1. ABSOLUTE MAXIMUM RATINGS | RATING | VALUE | | |-------------------------------|----------------|---------------| | Ambient Operating Temperature | -40°C to 85°C | | | Storage Temperature | -65°C to 150°C | | | Applied Input Voltage | | -0.5V to 4.6V | | Applied Output Voltage | | -0.5V to 4.6V | | VCC to Ground Potential | | -0.5V to 4.6V | #### 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 Vss to -2.0V and Vcc to +2.0V for periods up to 20ns, see *Figure 43, Figure 44*. Figure 43. Maximum Negative Overshoot Waveform Figure 44. Maximum Positive Overshoot Waveform #### 12-2. CAPACITANCE TA = 25°C, f = 1.0 MHz | SYMBOL | PARAMETER | MIN. | TYP | MAX. | UNIT | CONDITIONS | |--------|--------------------|------|-----|------|------|------------| | CIN | Input Capacitance | | | 20 | pF | VIN = 0V | | COUT | Output Capacitance | | | 20 | pF | VOUT = 0V | ## Figure 45. INPUT TEST WAVEFORMS AND MEASUREMENT LEVEL ## Figure 46. OUTPUT LOADING ## Table 9. DC CHARACTERISTICS (Temperature = -40°C to 85°C for Industrial grade, 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>VIN = VCC or GND | | ISB1 | VCC Standby Current | 1 | | 100 | uA | VIN = VCC or GND, CS# = VCC | | ISB2 | Deep Power-down<br>Current | | | 40 | uA | VIN = VCC or GND, CS# = VCC | | | | | | 22 | mA | fQ=70MHz (4 x I/O read)<br>SCLK=0.1VCC/0.9VCC, SO=Open | | | | | | 19 | mA | f=104MHz<br>SCLK=0.1VCC/0.9VCC, SO=Open | | ICC1 | VCC Read | 1 | | 17 | mA | fT=70MHz (2 x I/O read)<br>SCLK=0.1VCC/0.9VCC, SO=Open | | | | | | 15 | mA | f=66MHz<br>SCLK=0.1VCC/0.9VCC, SO=Open | | | | | | 10 | mA | f=33MHz,<br>SCLK=0.1VCC/0.9VCC, SO=Open | | ICC2 | VCC Program Current (PP) | 1 | | 25 | mA | Program in Progress, CS# = VCC | | ICC3 | VCC Write Status<br>Register (WRSR) Current | | | 20 | mA | Program status register in progress, CS#=VCC | | ICC4 | VCC Sector Erase<br>Current (SE) | 1 | | 25 | mA | Erase in Progress, CS#=VCC | | ICC5 | VCC Chip Erase Current (CE) | 1 | | 20 | mA | Erase in Progress, CS#=VCC | | VIL | Input Low Voltage | | -0.5 | 8.0 | V | | | VIH | Input High Voltage | | 0.7VCC | VCC+0.4 | V | | | VOL | Output Low Voltage | | | 0.4 | V | IOL = 1.6mA | | VOH | Output High Voltage | | VCC-0.2 | | V | IOH = -100uA | #### Notes: <sup>1.</sup> Typical values at VCC = 3.3V, T = 25°C. These currents are valid for all product versions (package and speeds). <sup>2.</sup> Typical value is calculated by simulation. ## Table 10. AC CHARACTERISTICS (Temperature = -40°C to 85°C for Industrial grade, VCC = 2.7V ~ 3.6V) | Symbol | Alt. | Parameter | | | Min. | Тур. | Max. | Unit | |----------------|-------|-----------------------------------------------------------------------------------------------------------------------|-----------------|-------------------------|------|------|-------|------| | fSCLK | fC | Clock Frequency for the following instructions: FAST_READ, PP, SE, BE, CE, DP, RES, RDP, WREN, WRDI, RDID, RDSR, WRSR | | | D.C. | | 104 | MHz | | fRSCLK | fR | Clock Frequency for READ i | instructions | | | | 50 | MHz | | ETCOLIV | fT | Clock Frequency for 2READ | | tions | | | 70 | MHz | | fTSCLK | fQ | Clock Frequency for 4READ | /QREAD instruc | ctions (4) | | | 70/54 | MHz | | f4PP | | Clock Frequency for 4PP (Q | uad page progra | am) | | | 70 | MHz | | +CL1/4) | 40111 | Clask High Time | | Fast_Read | 4.5 | | | ns | | tCH(1) | ICLH | Clock High Time | | Read | 9 | | | ns | | +CL (4) | +011 | Clock Low Time | | Fast_Read | 4.5 | | | ns | | tCL(1) | ICLL | Clock Low Time | | Read | 9 | | | ns | | tCLCH(2) | | Clock Rise Time (3) (peak to | peak) | | 0.1 | | | V/ns | | tCHCL(2) | | Clock Fall Time (3) (peak to | peak) | | 0.1 | | | V/ns | | tSLCH | tCSS | CS# Active Setup Time (rela | tive to SCLK) | | 5 | | | ns | | tCHSL | | CS# Not Active Hold Time (r | elative to SCLK | ) | 5 | | | ns | | tDVCH | tDSU | Data In Setup Time | , | | | | | ns | | tCHDX | tDH | Data In Hold Time | | | | | | ns | | tCHSH | | CS# Active Hold Time (relative to SCLK) | | | | | | ns | | tSHCH | | CS# Not Active Setup Time (relative to SCLK) | | | | | | ns | | | | | | Read | 15 | | | ns | | tSHSL(3) | tCSH | CS# Deselect Time | | Write/Erase/<br>Program | 50 | | | ns | | 101107(0) | 4010 | Outset Disable Time | | 2.7V-3.6V | | | 10 | ns | | tSHQZ(2) | tDIS | Output Disable Time | | 3.0V-3.6V | | | 8 | ns | | tHLCH | | HOLD# Setup Time (relative | to SCLK) | | 5 | | | ns | | tCHHH | | HOLD# Hold Time (relative t | to SCLK) | | 5 | | | ns | | tHHCH | | HOLD Setup Time (relative t | to SCLK) | | 5 | | | ns | | tCHHL | | HOLD Hold Time (relative to | | | 5 | | | ns | | 11 11 10 1/(0) | 41.7 | HOLD to Output Low-Z | , | 2.7V-3.6V | | | 10 | ns | | tHHQX(2) | tLZ | Loading=30pF | | 3.0V-3.6V | | | 8 | ns | | 0.7(0) | | HOLD# to Output High-Z | | 2.7V-3.6V | | | 10 | ns | | tHLQZ(2) | tHZ | Loading=30pF | | 3.0V-3.6V | | | 8 | ns | | | | | | 1 I/O | | | 9 | ns | | tCLQV | tV | Clock Low to Output Valid L | oading: 15pF | 2 I/O & 4 I/O | | | 9.5 | ns | | | '' | VCC=2.7V~3.6V | oading: 30pF | 2 1/0 & 4 1/0 | | | 12 | ns | | tCLQX | tHO | Output Hold Time | oading. Jopi | 2 1/0 4 4 1/0 | 1 | | 12 | ns | | tWHSL(4) | 1110 | Write Protect Setup Time | | | 20 | | | + | | tSHWL(4) | | Write Protect Setup Time Write Protect Hold Time | | | 100 | | | ns | | tDP(2) | | CS# High to Deep Power-do | wn Mode | | 100 | | 10 | ns | | (2) | | CS# High to Standby Mode | | nic Signatura | | | 10 | us | | tRES1(2) | | Read | | | | | 100 | us | | tRES2(2) | | CS# High to Standby Mod Read | de with Electro | nic Signature | | | 100 | us | ## MX25L12835E | Symbol | Alt. | Parameter | Min. | Тур. | Max. | Unit | |--------|------|----------------------------------|------|------|------|------| | tW | | Write Status Register Cycle Time | | 40 | 100 | ms | | tBP | | Byte-Program | | 9 | 300 | us | | tPP | | Page Program Cycle Time | | 1.4 | 5 | ms | | tSE | | Sector Erase Cycle Time (4KB) | | 60 | 300 | ms | | tBE | | Block Erase Cycle Time (32KB) | | 0.5 | 2 | S | | tBE | | Block Erase Cycle Time (64KB) | | 0.7 | 2 | S | | tCE | | Chip Erase Cycle Time | | 80 | 200 | S | | tWPS | | Write Protection Selection Time | | | 1 | ms | | tWSR | | Write Security Register Time | | | 1 | ms | #### Notes: - tCH + tCL must be greater than or equal to 1/ fC. Value guaranteed by characterization, not 100% tested in production. Only applicable as a constraint for a WRSR instruction when SRWD is set at 1. When dummy cycle=4, clock rate is 54MHz; When dummy cycle=6, clock rate is 70MHz. ## 13. TIMING ANALYSIS Figure 47. Serial Input Timing Figure 48. Output Timing ## Figure 49. Hold Timing Figure 50. WP# Setup Timing and Hold Timing during WRSR when SRWD=1 ### 13-1. RESET Driving the RESET# pin low for a period of tRLRH or longer will reset the device. After the reset cycle, the device is at the following state: - Standby mode - All the volatile bit such as WEL/WIP/SRAM lock bit will return to the default state as power on. If the device is under the programming or erasing, driving the reset# pin low will also terminate the operation and data could be lost. During the reset cycle, the SO data becomes high impedance and the current will be reduced to minimum. Figure 51. RESET Timing Table 11. Reset Timing | Symbol | Parameter | Min. | Тур. | Max. | Unit | |--------|----------------------------------|------|------|------|------| | tRLRH | Reset pulse width | 10 | | | us | | tRS | Reset set time | 15 | | | ns | | tRH | Reset hold time | 15 | | | ns | | | Reset recovery time from read | | | 200 | ns | | tRHSL | Reset recovery time from program | | | 20 | us | | | Reset recovery time from erase | | | 20 | ms | | | Reset recovery time from WRSR | | | tW | ms | **Notes:** tW is the write status register cycle time. Figure 52. Power-Up Timing Note: VCC (max.) is 3.6V and VCC (min.) is 2.7V. **Table 12. Power-Up Timing** | Symbol | Parameter | Min. | Max. | Unit | |---------|---------------------|------|------|------| | tVSL(1) | VCC(min) to CS# low | 300 | | us | Note: The parameter is characterized only. ### 13-2. 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 00h (all Status Register bits are 0). ### 14. OPERATING CONDITIONS #### At Device Power-Up and Power-Down AC timing illustrated in *Figure 53* and *Figure 54* 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 53. AC Timing at Device Power-Up | Symbol | Parameter | Notes | Min. | Max. | Unit | |--------|---------------|-------|------|--------|------| | tVR | VCC Rise Time | 1 | 5 | 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 10. AC CHARACTERISTICS (Temperature = -40°C to 85°C for Industrial grade, VCC = $2.7V \sim 3.6V$ )". P/N: PM1676 REV. 1.0, APR. 25, 2011 ## Figure 54. Power-Down Sequence During power-down, CS# needs to follow the voltage drop on VCC to avoid mis-operation. ### 15. ERASE AND PROGRAMMING PERFORMANCE | PARAMETER | TYP. (1) | Max. (2) | UNIT | |----------------------------------------------|----------|----------|--------| | Write Status Register Cycle Time | 40 | 100 | ms | | Sector Erase Time (4KB) | 60 | 300 | ms | | Block Erase Time (64KB) | 0.7 | 2 | s | | Block Erase Time (32KB) | 0.5 | 2 | s | | Chip Erase Time | 80 | 200 | s | | Byte Program Time (via page program command) | 9 | 300 | us | | Page Program Time | 1.4 | 5 | ms | | Erase/Program Cycle | 100,000 | | cycles | #### Notes: - 1. Typical program and erase time assumes the following conditions: 25°C, 3.3V, and checker board pattern. - 2. Under worst conditions of 85°C and 2.7V. - 3. System-level overhead is the time required to execute the first-bus-cycle sequence for the programming command. #### **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, SI, CS# | -1.0V | 2 VCCmax | | Input Voltage with respect to GND on SO | -1.0V | VCC + 1.0V | | Current | -100mA | +100mA | | Includes all pins except VCC. Test conditions: VCC = 3.0V, one pin at a time | | - | # MX25L12835E ## **18. ORDERING INFORMATION** | PART NO. CLOCI (MHz) | | OPERATING<br>CURRENT<br>MAX. (mA) | STANDBY<br>CURRENT<br>MAX. (uA) | TEMPERATURE | PACKAGE | Remark | |------------------------|-----|-----------------------------------|---------------------------------|-------------------------|----------|-----------| | MX25L12835EMI-10G | 104 | 19 | 100 | -40°C~85°C | 16-SOP | RoHS | | INIXECE TEOGOEINI TOO | 104 | 10 | 100 | 40 0 00 0 | (300mil) | Compliant | | MX25L12835EZNI-10G | 104 | 10 | 100 | -40°C~85°C | 8-WSON | RoHS | | IVIAZUL IZOSUEZNI- IUG | 104 | 19 | 100 | - <del>4</del> 0 C~65 C | (8x6mm) | Compliant | ### 19. PART NAME DESCRIPTION ## **20. PACKAGE INFORMATION** 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.34 | 0.36 | 0.20 | 10.10 | 10.10 | 7.42 | - | 0.40 | 1.31 | 0.51 | 0 | | mm | Nom. | | 0.20 | 2.39 | 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.44 | 0.51 | 0.30 | 10.50 | 10.50 | 7.60 | | 1.27 | 1.57 | 0.77 | 8 | | | Min. | | 0.004 | 0.092 | 0.014 | 0.008 | 0.397 | 0.397 | 0.292 | | 0.016 | 0.052 | 0.020 | 0 | | Inch | Nom. | | 0.008 | 0.094 | 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 | | D N- | Revision | Reference | | | | | | |-----------|----------|-----------|------|--|--|--|--| | Dwg. No. | | JEDEC | EIAJ | | | | | | 6110-1402 | 9 | MS-013 | | | | | | Doc. Title: Package Outline for WSON 8L (8x6x0.8MM, LEAD PITCH 1.27MM) Dimensions (inch dimensions are derived from the original mm dimensions) \*1 : This package has exposed metal pad underneath the package, it can't contact to metal trace or pad on board. \*2 : The exposed pad size must not violate the min. metal separtion requirement, 0.2mm with terminals. | SY | MBOL | A | A1 | A2 | b | D | D1 | Е | E1 | ١ | е | у | |------|------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|-------| | | Min. | 0.70 | | | 0.35 | 7.90 | 4.65 | 5.90 | 4.55 | 0.40 | - | 0.00 | | mm | Nom. | _ | | 0.20 | 0.40 | 8.00 | 4.70 | 6.00 | 4.60 | 0.50 | 1.27 | _ | | | Max. | 0.80 | 0.05 | - | 0.48 | 8.10 | 4.75 | 6.10 | 4.65 | 0.60 | | 80.0 | | | Min. | 0.028 | | | 0.014 | 0.311 | 0.183 | 0.232 | 0.179 | 0.016 | - | 0.00 | | Inch | Nom. | _ | | 0.008 | 0.016 | 0.315 | 0.185 | 0.236 | 0.181 | 0.020 | 0.05 | | | | Max. | 0.032 | 0.002 | - | 0.019 | 0.319 | 0.187 | 0.240 | 0.183 | 0.024 | I | 0.003 | | Dwg. No. | Revision | Reference | | | | | | |-----------|----------|-----------|------|--|--|--|--| | | | JEDEC | EIAJ | | | | | | 6110-3402 | 5 | MO-220 | | | | | | # MX25L12835E ## **21. REVISION HISTORY** | Revision No. | Description | Page | Date | |--------------|------------------------------------------------------------|------------|-------------| | 0.01 | 1. Added Software RESET | All | NOV/09/2010 | | | 2. Added Warp Around Burst Read mode | | | | | Revised Quad Page Program frequency | | | | | from 20MHz to 70MHz | P43, 71 | | | | 4. Change tCLQX min. value from 2ns to 1ns | P71 | | | 0.02 | 1. Revised WRSCUR figure | P55 | JAN/21/2011 | | | 2. Revised tREC to tRCE on Software Reset Recovery figure | P66 | | | | 3. Revised min. VCC Rise Time from 20 to 5 us | P77 | | | 0.03 | Adjusted function descriptions. | P13~14,50, | FEB/22/2011 | | | | P52,53 | | | 1.0 | Removed "Preliminary" | P4 | APR/25/2011 | | | 2. Modified CIN/COUT from 6pF/8pF(max.) to 20pF/20pF(max.) | P65 | | ## MX25L12835E 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. 2010~2011. All rights reserved. Macronix, MXIC, MXIC Logo, MX Logo, Integrated Solutions Provider, NBit, NBiit, Macronix NBit, eLiteFlash, XtraROM, Phines, BE-SONOS, KSMC, Kingtech, MXSMIO, Macronix vEE are trademarks or registered trademarks of Macronix International Co., Ltd. The names and brands of other companies are for identification purposes only and may be claimed as the property of the respective companies. For the contact and order information, please visit Macronix's Web site at: http://www.macronix.com MACRONIX INTERNATIONAL CO., LTD. reserves the right to change product and specifications without notice.