# MX68GL1G0F H/L DATASHEET # **Contents** | 1. FEATU | IRES | 6 | |--------------|-------------------------------------------------------------------|----| | 2. PIN CC | ONFIGURATION | 7 | | 3. PIN DE | SCRIPTION | 8 | | 4. BLOCK | CDIAGRAM | 9 | | 5. BLOCK | K DIAGRAM DESCRIPTION | 10 | | | STRUCTURE | | | | PERATION | | | | TIONAL OPERATION DESCRIPTION | | | 8-1. | READ OPERATION | | | 8-2. | PAGE READ | | | 8-3. | WRITE OPERATION | | | 8-4. | WRITE BUFFER PROGRAMMING OPERATION | | | 8-5. | DEVICE RESET | | | 8-6. | STANDBY MODE | | | 8-7. | OUTPUT DISABLE | 15 | | 8-8. | BYTE/WORD SELECTION | 16 | | 8-9. | HARDWARE WRITE PROTECT | 16 | | 8-10. | ACCELERATED PROGRAMMING OPERATION | 16 | | | SECTOR PROTECT OPERATION | | | | AUTOMATIC SELECT BUS OPERATIONS | | | | SECTOR LOCK STATUS VERIFICATION | | | | READ SILICON ID MANUFACTURER CODE | | | | READ INDICATOR BIT (Q7) FOR SECURITY SECTOR | | | | INHERENT DATA PROTECTION | | | | COMMAND COMPLETION | | | | LOW VCC WRITE INHIBIT | | | | WRITE PULSE "GLITCH" PROTECTION | | | | LOGICAL INHIBIT | | | | POWER-UP SEQUENCE | | | | POWER-UP WRITE INHIBIT POWER SUPPLY DECOUPLING | | | | AND OPERATIONS | | | | | | | 9-1. | READING THE MEMORY ARRAYAUTOMATIC PROGRAMMING OF THE MEMORY ARRAY | | | 9-2.<br>9-3. | ERASING THE MEMORY ARRAY | _ | | | SECTOR ERASE | _ | | 9-4.<br>9-5. | CHIP ERASE | | | 9-5.<br>9-6. | ERASE SUSPEND/RESUME | | | 9-0.<br>9-7. | SECTOR ERASE RESUME | | | 9-7.<br>9-8. | PROGRAM SUSPEND/RESUME | | | 9-9. | PROGRAM RESUME | | | | | | | | 9-10. | BUFFER WRITE ABORT | 23 | |-----|--------|-----------------------------------------------------------------------------------------------------------|----| | | 9-11. | AUTOMATIC SELECT OPERATIONS | 24 | | | 9-12. | AUTOMATIC SELECT COMMAND SEQUENCE | 24 | | | 9-13. | READ MANUFACTURER ID OR DEVICE ID | 24 | | | 9-14. | RESET | 25 | | | 9-15. | Advanced Sector Protection/Un-protection | 26 | | | | 9-15-1. Lock Register | | | | | 9-15-2. Solid write (non-volatile) protection Mode | | | | | 9-15-3. Temporary Un-protect Solid write protect bit (USPB) | | | | | 9-15-4. Solid Protection Bit Lock Bit | | | | 0.40 | 9-15-5. Password Protection Method | | | | | SECURITY SECTOR FLASH MEMORY REGIONFACTORY LOCKED: SECURITY SECTOR PROGRAMMED AND PROTECTED AT THE FACTOR | | | | 9-17. | FACTORY LOCKED: SECURITY SECTOR PROGRAMMED AND PROTECTED AT THE FACTOR | | | | 0.40 | CUSTOMER LOCKABLE: SECURITY SECTOR NOT PROGRAMMED OR PROTECTED AT THE | | | | 9-10. | FACTORY | | | 10 | COMM | ION FLASH MEMORY INTERFACE (CFI) MODE | | | | | FRICAL CHARACTERISTICS | | | П. | | | | | | | ABSOLUTE MAXIMUM STRESS RATINGS | | | 40 | | OPERATING TEMPERATURE AND VOLTAGE | | | | | COMMAND OPERATION | | | | | RESET OPERATION | | | | | E/PROGRAM OPERATION | | | 15. | SILICO | ON ID READ OPERATION | 54 | | 16. | WRITE | OPERATION STATUS | 55 | | 17. | PAGE | READ OPERATION | 60 | | 18. | DEEP | POWER DOWN MODE OPERATION | 61 | | 19. | WRITE | BUFFER PROGRAM OPERATION | 62 | | 20 | RECO | MMENDED OPERATING CONDITIONS | 63 | | | | E AND PROGRAMMING PERFORMANCE | | | | | | | | | | RETENTION | | | | | I-UP CHARACTERISTICS | | | | | APACITANCE | | | | | RING INFORMATION | | | 26. | PART | NAME DESCRIPTION | 66 | | 7 | DACK | AGE INFORMATION | 67 | # **Figures** | Figure 1. Advance Sector Protection/Unprotection SPB Program Algorithm | 26 | |-------------------------------------------------------------------------|----| | Figure 2. Lock Register Program Algorithm | | | Figure 3. SPB Program Algorithm | | | Figure 4. Maximum Negative Overshoot Waveform | 39 | | Figure 5. Maximum Positive Overshoot Waveform | | | Figure 6. SWITCHING TEST CIRCUITS | 41 | | Figure 7. SWITCHING TEST WAVEFORMS | 41 | | Figure 8. COMMAND WRITE OPERATION | 43 | | Figure 9. READ TIMING WAVEFORMS | 44 | | Figure 10. RESET# TIMING WAVEFORM | 45 | | Figure 11. AUTOMATIC CHIP ERASE TIMING WAVEFORM | 46 | | Figure 12. AUTOMATIC CHIP ERASE ALGORITHM FLOWCHART | 47 | | Figure 13. AUTOMATIC SECTOR ERASE TIMING WAVEFORM | 48 | | Figure 14. AUTOMATIC SECTOR ERASE ALGORITHM FLOWCHART | 49 | | Figure 15. ERASE SUSPEND/RESUME FLOWCHART | 50 | | Figure 16. AUTOMATIC PROGRAM TIMING WAVEFORMS | 51 | | Figure 17. ACCELERATED PROGRAM TIMING DIAGRAM | 51 | | Figure 18. CE# CONTROLLED WRITE TIMING WAVEFORM | 52 | | Figure 19. AUTOMATIC PROGRAMMING ALGORITHM FLOWCHART | 53 | | Figure 20. SILICON ID READ TIMING WAVEFORM | 54 | | Figure 21. DATA# POLLING TIMING WAVEFORMS (DURING AUTOMATIC ALGORITHMS) | 55 | | Figure 22. STATUS POLLING FOR WORD PROGRAM/ERASE | 56 | | Figure 23. STATUS POLLING FOR WRITE BUFFER PROGRAM | 57 | | Figure 24. TOGGLE BIT TIMING WAVEFORMS (DURING AUTOMATIC ALGORITHMS) | 58 | | Figure 25. TOGGLE BIT ALGORITHM | 59 | | Figure 26. PAGE READ TIMING WAVEFORM | 60 | | Figure 27. DEEP POWER DOWN MODE WAVEFORM | 61 | | Figure 28. WRITE BUFFER PROGRAM FLOWCHART | 62 | | Figure 29. AC Timing at Device Power-Up | 63 | ## **Tables** | Table 1. SECTOR ARCHITECTURE | 11 | |-----------------------------------------------------------------------|----| | Table 2. BUS OPERATION-1 | 12 | | Table 3. BUS OPERATION-2 | 13 | | Table 4. Sector Protection Status | 31 | | Table 5. COMMAND DEFINITIONS | 33 | | Table 6. CFI mode: Identification Data Values | | | Table 7. CFI mode: System Interface Data Values | 36 | | Table 8. CFI mode: Device Geometry Data Values | 37 | | Table 9. CFI mode: Primary Vendor-Specific Extended Query Data Values | 38 | | Table 10. DC CHARACTERISTICS | 40 | | Table 11. AC CHARACTERISTICS | 42 | | Table 12. AC CHARACTERISTICS-RESET# | 45 | | Table 13. AC CHARACTERISTICS - Deep Power Down Mode | 61 | ## SINGLE VOLTAGE 3V ONLY FLASH MEMORY ## 1. FEATURES #### **GENERAL FEATURES** - 2.7 to 3.6 volt for read, erase, and program operations - · Byte/Word mode switchable - 134,217,728 x 8 / 67,108,864 x 16 - 64KW/128KB uniform sector architecture - 1024 equal sectors - 16-byte/8-word page read buffer - 64-byte/32-word write buffer - Extra 128-word sector for security - Features factory locked and identifiable, and customer lockable - · Advanced sector protection function (Solid and Password Protect) - · Compatible with JEDEC standard - Pinout and software compatible to single power supply Flash #### **PERFORMANCE** - High Performance - Fast access time: 110ns - Page access time: 25ns - Fast program time: 11us/word - Fast erase time: 0.6s/sector - · Low Power Consumption - Low active read current: 20mA (typical) at 5MHz - Low standby current: 120uA (typical) - Minimum 100,000 erase/program cycle - · 20 years data retention ## **SOFTWARE FEATURES** - Program/Erase Suspend & Program/Erase Resume - · Status Reply - Data# Polling & Toggle bits provide detection of program and erase operation completion - Support Common Flash Interface (CFI) ## HARDWARE FEATURES - Ready/Busy# (RY/BY#) Output - Provides a hardware method of detecting program and erase operation completion - · Hardware Reset (RESET#) Input - Provides a hardware method to reset the internal state machine to read mode - WP#/ACC input pin - Hardware write protect pin/Provides accelerated program capability #### **PACKAGE** - 56-Pin TSOP - 64-Ball LFBGA (11mm x 13mm) - · All devices are RoHS Compliant ## 2. PIN CONFIGURATION ## **56 TSOP** ## 64 LFBGA ## 3. PIN DESCRIPTION | SYMBOL | PIN NAME | |----------|-------------------------------------------------------| | A0~A25 | Address Input | | Q0~Q14 | Data Inputs/Outputs | | Q15/A-1 | Q15(Word Mode)/LSB addr(Byte Mode) | | CE# | Chip Enable Input | | WE# | Write Enable Input | | OE# | Output Enable Input | | RESET# | Hardware Reset Pin, Active Low | | WP#/ACC* | Hardware Write Protect/Programming Acceleration input | | RY/BY# | Ready/Busy Output | | BYTE# | Selects 8 bits or 16 bits mode | | VCC | +3.0V single power supply | | GND | Device Ground | | NC | Not Connected | | VI/O | Power Supply for Input/Output | ## Notes: - 1. WP#/ACC has internal pull up. - 2. VI/O voltage must tight with VCC. VI/O = VCC =2.7V~3.6V. ## LOGIC SYMBOL ## 4. BLOCK DIAGRAM ## 5. BLOCK DIAGRAM DESCRIPTION The block diagram on Page 9 illustrates a simplified architecture of this device. Each block in the block diagram represents one or more circuit modules in the real chip used to access, erase, program, and read the memory array. The "CONTROL INPUT LOGIC" block receives input pins CE#, OE#, WE#, RESET#, BYTE#, and WP#/ACC. It creates internal timing control signals according to the input pins and outputs to the "ADDRESS LATCH AND BUFFER" to latch the external address pins A0-AM. The internal addresses are output from this block to the main array and decoders composed of "X-DECODER", "Y-DECODER", "Y-PASS GATE", AND "FLASH ARRAY". The X-DECODER decodes the word-lines of the flash array, while the Y-DECODER decodes the bit-lines of the flash array. The bit lines are electrically connected to the "SENSE AMPLIFIER" and "PGM DATA HV" selectively through the Y-PASS GATES. SENSE AMPLIFIERS are used to read out the contents of the flash memory, while the "PGM DATA HV" block is used to selectively deliver high power to bit-lines during programming. The "I/O BUFFER" controls the input and output on the Q0-Q15/A-1 pads. During read operation, the I/O BUFFER receives data from SENSE AMPLIFIERS and drives the output pads accordingly. In the last cycle of program command, the I/O BUFFER transmits the data on Q0-Q15/A-1 to "PROGRAM DATA LATCH", which controls the high power drivers in "PGM DATA HV" to selectively program the bits in a word or byte according to the user input pattern. The "PROGRAM/ERASE HIGH VOLTAGE" block comprises the circuits to generate and deliver the necessary high voltage to the X-DECODER, FLASH ARRAY, and "PGM DATA HV" blocks. The logic control module comprises of the "WRITE STATE MACHINE, WSM", "STATE REGISTER", "COMMAND DATA DECODER", and "COMMAND DATA LATCH". When the user issues a command by toggling WE#, the command on Q0-Q15/A-1 is latched in the COMMAND DATA LATCH and is decoded by the COMMAND DATA DECODER. The STATE REGISTER receives the command and records the current state of the device. The WSM implements the internal algorithms for program or erase according to the current command state by controlling each block in the block diagram. ## **ARRAY ARCHITECTURE** The main flash memory array can be organized as Byte mode (x8) or Word mode (x16). The details of the address ranges and the corresponding sector addresses are shown in *Table 1*. ## **6. BLOCK STRUCTURE** ## **Table 1. SECTOR ARCHITECTURE** | Secto | or Size | Saatar | Sector Address | Address Range | | | |--------|---------|--------|------------------|-------------------|--|--| | Kbytes | Kwords | Sector | A25-A16 | (x16) | | | | 128 | 64 | SA0 | 0000000000xxxx | 0000000h-000FFFFh | | | | 128 | 64 | SA1 | 000000001xxxx | 0010000h-001FFFFh | | | | 128 | 64 | SA2 | 000000010xxxx | 0020000h-002FFFFh | | | | : | : | : | : | : | | | | : | : | : | : | : | | | | 128 | 64 | SA1023 | 111111111111xxxx | 3FF0000h-3FFFFFh | | | ## 7. BUS OPERATION ## Table 2. BUS OPERATION-1 | | | | | | | Doto | Ву | te# | | |--------------------|------------|--------------|------|-----|---------|-------------|----------------------|-------|---------| | Mode Select | RE- | CE# | WE# | OE# | Address | Data<br>I/O | Vil | Vih | WP#/ | | Widde Select | SET# | OL# | VVL# | OL# | (Note4) | Q7~Q0 | Data (I/O)<br>Q15~Q8 | | ACC | | Device Reset | L | X | Х | Х | X | HighZ | HighZ | HighZ | L/H | | Standby Mode | Vcc ± 0.3V | Vcc±<br>0.3V | Х | Х | Х | HighZ | HighZ | HighZ | Н | | Output Disable | Н | L | Н | Н | X | HighZ | HighZ | HighZ | L/H | | Read Mode | Н | L | Н | L | AIN | DOUT | Q8-Q14= | DOUT | L/H | | Write | Н | L | L | Н | AIN | DIN | HighZ, | DIN | Note1,2 | | Accelerate Program | Н | L | L | Н | AIN | DIN | Q15=A-1 | DIN | Vhv | #### Notes: - 1. The first or last sector was protected if WP#/ACC=Vil. - 2. When WP#/ACC = Vih, the protection conditions of the outmost sector depends on previous protection conditions. Refer to the advanced protect feature. - 3. Q0~Q15 are input (DIN) or output (DOUT) pins according to the requests of command sequence, sector protection, or data polling algorithm. - 4. In Word Mode (Byte#=Vih), the addresses are AM to A0, AM: MSB of address. In Byte Mode (Byte#=Vil), the addresses are AM to A-1 (Q15), AM: MSB of address. ## **Table 3. BUS OPERATION-2** | | Con | trol Ir | nput | AM | A11 | | A8 | | A5 | <b>A3</b> | | | | | |-----------------------------------------|-------------------------------------------|---------|------|-------------------------|-----------|-----------------|----------|----|----------|-----------|------------|----|---------------------------|-------------------------| | Item | CE# | WE# | OE# | to<br>A12 | to<br>A10 | A9 | to<br>A7 | A6 | to<br>A4 | to<br>A2 | <b>A</b> 1 | A0 | Q7 ~ Q0 | Q15 ~ Q8 | | Sector Lock Status<br>Verification | L | Н | L | SA | X | V <sub>hv</sub> | Х | L | Х | L | Н | L | 01h or<br>00h<br>(Note 1) | Х | | Read Silicon ID<br>Manufacturer<br>Code | L | Н | L | Х | Х | $V_{hv}$ | Х | L | Х | L | L | L | C2H | Х | | Read Silicon ID | | | | | | | | | | | | | | | | Cycle 1 | L | Н | L | х | Х | V <sub>hv</sub> | Х | L | Х | L | L | Н | 7EH | 22H(Word),<br>XXH(Byte) | | Cycle 2 | 2 L H L X X V <sub>hv</sub> X L X H H L 2 | | 28H | 22H(Word),<br>XXH(Byte) | | | | | | | | | | | | Cycle 3 | L | Н | L | Х | Х | V <sub>hv</sub> | Х | L | Х | Н | Н | Н | 01H | 22H(Word),<br>XXH(Byte) | ## Notes: 1. Sector unprotected code:00h. Sector protected code:01h. 2. Factory locked code: WP# protects high address sector: 99h. WP# protects low address sector: 89h Factory unlocked code: WP# protects high address sector: 19h. WP# protects low address sector: 09h 3. AM: MSB of address. #### 8. FUNCTIONAL OPERATION DESCRIPTION #### 8-1. READ OPERATION To perform a read operation, the system addresses the desired memory array or status register location by providing its address on the address pins and simultaneously enabling the chip by driving CE# & OE# LOW, and WE# HIGH. After the Tce and Toe timing requirements have been met, the system can read the contents of the addressed location by reading the Data (I/O) pins. If either the CE# or OE# is held HIGH, the outputs will remain tri-stated and no data will appear on the output pins. ## 8-2. PAGE READ This device offered high performance page read. Page size is 16 bytes or 8 words. The higher address Amax ~ A3 select the certain page, while A2~A0 for word mode, A2~A-1 for byte mode select the particular word or byte in a page. The page access time is Taa or Tce, following by Tpa for the rest of the page read time. When CE# toggles, access time is Taa or Tce. Page mode can be turned on by keeping "page-read address" constant and changing the "intra-read page" addresses. ## 8-3. WRITE OPERATION To perform a write operation, the system provides the desired address on the address pins, enables the chip by asserting CE# LOW, and disables the Data (I/O) pins by holding OE# HIGH. The system then places data to be written on the Data (I/O) pins and pulses WE# LOW. The device captures the address information on the falling edge of WE# and the data on the rising edge of WE#. To see an example, please refer to the timing diagram in COMMAND WRITE OPERATION. The system is not allowed to write invalid commands (commands not defined in this datasheet) to the device. Writing an invalid command may put the device in an undefined state. #### 8-4. WRITE BUFFER PROGRAMMING OPERATION Programs 64bytes/32words in a programming operation. To trigger the Write Buffer Programming, start by the first two unlock cycles, then third cycle writes the Write Buffer Load command at the destined programming Sector Address. The forth cycle writes the "word locations subtract one" number. Following above operations, system starts to write the mingling of address and data. After the programming of the first address or data, the "write-buffer-page" is selected. The following data should be within the above mentioned page. The "write-buffer-page" is selected by choosing address Amax-A5. "Write-Buffer-Page" address has to be the same for all address/ data write into the write buffer. If not, operation will ABORT. To program the content of the write buffer page this command must be followed by a write to buffer Program confirm command. The operation of write-buffer can be suspended or resumed by the standard commands, once the write buffer programming operation is finished, it'll return to normal READ mode. ## **FUNCTIONAL OPERATION DESCRIPTION (cont'd)** ## WRITE BUFFER PROGRAMMING OPERATION (cont'd) ABORT will be executed for the Write Buffer Programming Sequence if following condition occurs: - The value loaded is bigger than the page buffer size during "Number of Locations to Program" - Address written in a sector is not the same as the one assigned during the Write-Buffer-Load command. - Address/ Data pair written to a different write-buffer-page than the one assigned by the "Starting Address" during the "write buffer data loading" operation. - Writing not "Confirm Command" after the assigned number of "data load" cycles. At Write Buffer Abort mode, the status register will be Q1=1, Q7=DATA# (last address written), Q6=toggle. A Write-to-Buffer-Abort Reset command sequence has to be written to reset the device for the next operation. Write buffer programming can be conducted in any sequence. However the CFI functions, autoselect, Secured Silicon sector are not functional when program operation is in progress. Multiple write buffer programming operations on the same write buffer address range without intervening erases is available. Any bit in a write buffer address range can't be programmed from 0 back to 1. #### 8-5. DEVICE RESET Driving the RESET# pin LOW for a period of Trp or more will return the device to Read mode. If the device is in the middle of a program or erase operation, the reset operation will take at most a period of Tready1 before the device returns to Read mode. Until the device does returns to Read mode, the RY/BY# pin will remain Low (Busy Status). When the RESET# pin is held at GND±0.3V, the device only consumes standby (lsbr) current. However, the device draws larger current if the RESET# pin is held at a voltage greater than GND+0.3V and less than or equal to Vil. It is recommended to tie the system reset signal to the RESET# pin of the flash memory. This allows the device to be reset with the system and puts it in a state where the system can immediately begin reading boot code from it. ## 8-6. STANDBY MODE The device enters Standby mode whenever the RESET# and CE# pins are both held High except in the embedded mode. While in this mode, WE# and OE# will be ignored, all Data Output pins will be in a high impedance state, and the device will draw minimal (Isb) current. ## 8-7. OUTPUT DISABLE While in active mode (RESET# HIGH and CE# LOW), the OE# pin controls the state of the output pins. If OE# is held HIGH, all Data (I/O) pins will remain tri-stated. If held LOW, the Byte or Word Data (I/O) pins will drive data. ## **FUNCTIONAL OPERATION DESCRIPTION (cont'd)** #### 8-8. BYTE/WORD SELECTION The BYTE# input pin is used to select the organization of the array data and how the data is input/output on the Data (I/O) pins. If the BYTE# pin is held HIGH, Word mode will be selected and all 16 data lines (Q0 to Q15) will be active. If BYTE# is forced LOW, Byte mode will be active and only data lines Q0 to Q7 will be active. Data lines Q8 to Q14 will remain in a high impedance state and Q15 becomes the A-1 address input pin. ## 8-9. HARDWARE WRITE PROTECT By driving the WP#/ACC pin LOW. The highest or lowest was protected from all erase/program operations. If WP#/ACC is held HIGH (Vih to VCC), these sectors revert to their previously protected/unprotected status. #### 8-10. ACCELERATED PROGRAMMING OPERATION By applying high voltage (Vhv) to the WP#/ACC pin, the device will enter the Accelerated Programming mode. This mode permits the system to skip the normal command unlock sequences and program byte/word locations directly. During accelerated programming, the current drawn from the WP#/ACC pin is no more than ICP1. ## 8-11. SECTOR PROTECT OPERATION The device provides user programmable protection operations for selected sectors. Please refer to *Table 1* which show all Sector assignments. During the protection operation, the sector address of any sector may be used to specify the Sector being protected. ## 8-12. AUTOMATIC SELECT BUS OPERATIONS The following five bus operations require A9 to be raised to Vhv. Please see AUTOMATIC SELECT COMMAND SEQUENCE in the COMMAND OPERATIONS section for details of equivalent command operations that do not require the use of Vhv. ## 8-13. SECTOR LOCK STATUS VERIFICATION To determine the protected state of any sector using bus operations, the system performs a READ OPERATION with A9 raised to Vhv, the sector address applied to address pins A25 to A16, address pins A6, A3, A2 & A0 held LOW, and address pin A1 held HIGH. If data bit Q0 is LOW, the sector is not protected, and if Q0 is HIGH, the sector is protected. ## **FUNCTIONAL OPERATION DESCRIPTION (cont'd)** #### 8-14. READ SILICON ID MANUFACTURER CODE To determine the Silicon ID Manufacturer Code, the system performs a READ OPERATION with A9 raised to Vhv and address pins A6, A3, A2, A1, & A0 held LOW. The Macronix ID code of C2h should be present on data bits Q7 to Q0. ## 8-15. READ INDICATOR BIT (Q7) FOR SECURITY SECTOR To determine if the Security Sector has been locked at the factory, the system performs a READ OPERATION with A9 raised to Vhv, address pin A6, A3 & A2 held LOW, and address pins A1 & A0 held HIGH. If the Security Sector has been locked at the factory, the code 99h(H)/89h(L) will be present on data bits Q7 to Q0. Otherwise, the factory unlocked code of 19h(H)/09h(L) will be present. #### 8-16. INHERENT DATA PROTECTION To avoid accidental erasure or programming of the device, the device is automatically reset to Read mode during power up. Additionally, the following design features protect the device from unintended data corruption. ## 8-17. COMMAND COMPLETION Only after the successful completion of the specified command sets will the device begin its erase or program operation. The failure in observing valid command sets will result in the memory returning to read mode. #### 8-18. LOW VCC WRITE INHIBIT The device refuses to accept any write command when Vcc is less than VLKO. This prevents data from spuriously being altered during power-up, power-down, or temporary power interruptions. The device automatically resets itself when Vcc is lower than VLKO and write cycles are ignored until Vcc is greater than VLKO. The system must provide proper signals on control pins after Vcc rises above VLKO to avoid unintentional program or erase operations. ## 8-19. WRITE PULSE "GLITCH" PROTECTION CE#, WE#, OE# pulses shorter than 5ns are treated as glitches and will not be regarded as an effective write cycle. ## 8-20. LOGICAL INHIBIT A valid write cycle requires both CE# and WE# at Vil with OE# at Vih. Write cycle is ignored when either CE# at Vih, WE# at Vih, or OE# at Vil. ## **FUNCTIONAL OPERATION DESCRIPTION (cont'd)** ## 8-21. POWER-UP SEQUENCE Upon power up, the device is placed in Read mode. Furthermore, program or erase operation will begin only after successful completion of specified command sequences. ## 8-22. POWER-UP WRITE INHIBIT When WE#, CE# is held at Vil and OE# is held at Vih during power up, the device ignores the first command on the rising edge of WE#. #### 8-23. POWER SUPPLY DECOUPLING A 0.1uF capacitor should be connected between the Vcc and GND to reduce the noise effect. ## 9. COMMAND OPERATIONS #### 9-1. READING THE MEMORY ARRAY Read mode is the default state after power up or after a reset operation. To perform a read operation, please refer to READ OPERATION in the BUS OPERATIONS section above at table 2 and table 3. If the device receives an Erase Suspend command while in the Sector Erase state, the erase operation will pause (after a time delay not exceeding 20us) and the device will enter Erase-Suspended Read mode. While in the Erase-Suspended Read mode, data can be programmed or read from any sector not being erased. Reading from addresses within sector (s) being erased will only return the contents of the status register, which is in fact how the current status of the device can be determined. If a program command is issued to any inactive (not currently being erased) sector during Erase-Suspended Read mode, the device will perform the program operation and automatically return to Erase-Suspended Read mode after the program operation completes successfully. While in Erase-Suspended Read mode, an Erase Resume command must be issued by the system to reactivate the erase operation. The erase operation will resume from where is was suspended and will continue until it completes successfully or another Erase Suspend command is received. After the memory device completes an embedded operation (automatic Chip Erase, Sector Erase, or Program) successfully, it will automatically return to Read mode and data can be read from any address in the array. If the embedded operation fails to complete, as indicated by status register bit Q5 (exceeds time limit flag) going HIGH during the operations, the system must perform a reset operation to return the device to Read mode. There are several states that require a reset operation to return to Read mode: - 1. A program or erase failure--indicated by status register bit Q5 going HIGH during the operation. Failures during either of these states will prevent the device from automatically returning to Read mode. - 2. The device is in Auto Select mode or CFI mode. These two states remain active until they are terminated by a reset operation. In the two situations above, if a reset operation (either hardware reset or software reset command) is not performed, the device will not return to Read mode and the system will not be able to read array data. #### 9-2. AUTOMATIC PROGRAMMING OF THE MEMORY ARRAY The device provides the user the ability to program the memory array in Byte mode or Word mode. As long as the users enters the correct cycle defined in the *Table 5* (including 2 unlock cycles and the A0H program command), any byte or word data provided on the data lines by the system will automatically be programmed into the array at the specified location. After the program command sequence has been executed, the internal write state machine (WSM) automatically executes the algorithms and timings necessary for programming and verification, which includes generating suitable program pulses, checking cell threshold voltage margins, and repeating the program pulse if any cells do not pass verification or have low margins. The internal controller protects cells that do pass verification and margin tests from being over-programmed by inhibiting further program pulses to these passing cells as weaker cells continue to be programmed. With the internal WSM automatically controlling the programming process, the user only needs to enter the program command and data once. ## **COMMAND OPERATIONS (cont'd)** ## AUTOMATIC PROGRAMMING OF THE MEMORY ARRAY (cont'd) Programming will only change the bit status from "1" to "0". It is not possible to change the bit status from "0" to "1" by programming. This can only be done by an erase operation. Furthermore, the internal write verification only checks and detects errors in cases where a "1" is not successfully programmed to "0". Any commands written to the device during programming will be ignored except hardware reset or program suspend. Hardware reset will terminate the program operation after a period of time no more than 10us. When the embedded program algorithm is complete or the program operation is terminated by a hardware reset, the device will return to Read mode. Program suspend ready, the device will enter program suspend read mode. After the embedded program operation has begun, the user can check for completion by reading the following bits in the status register: | Status | Q7 <sup>*1</sup> | Q6 <sup>*1</sup> | Q5 | Q1 | RY/BY# (Note) | |-------------------|------------------|------------------|----|-----|---------------| | In progress | Q7# | Toggling | 0 | 0 | 0 | | Exceed time limit | Q7# | Toggling | 1 | N/A | 0 | Note: RY/BY# is an open drain output pin and should be connected to VCC through a high value pull-up resistor. ## 9-3. ERASING THE MEMORY ARRAY There are two types of erase operations performed on the memory array -- Sector Erase and Chip Erase. In the Sector Erase operation, one or more selected sectors may be erased simultaneously. In the Chip Erase operation, the complete memory array is erased except for any protected sectors. More details of the protected sectors are explained in section 5. ## 9-4. SECTOR ERASE The sector erase operation is used to clear data within a sector by returning all of its memory locations to the "1" state. It requires six command cycles to initiate the erase operation. The first two cycles are "unlock cycles", the third is a configuration cycle, the fourth and fifth are also "unlock cycles", and the sixth cycle is the Sector Erase command. After the sector erase command sequence has been issued, an internal 50us time-out counter is started. Until this counter reaches zero, additional sector addresses and Sector Erase commands may be issued thus allowing multiple sectors to be selected and erased simultaneously. After the 50us time-out counter has expired, no new commands will be accepted and the embedded sector erase operation will begin. Note that the 50us timer-out counter is restarted after every erase command sequence. If the user enters any command other than Sector Erase or Erase Suspend during the time-out period, the erase operation will abort and the device will return to Read mode. After the embedded sector erase operation begins, all commands except Erase Suspend will be ignored. The only way to interrupt the operation is with an Erase Suspend command or with a hardware reset. The hardware reset will completely abort the operation and return the device to Read mode. ## **COMMAND OPERATIONS (cont'd)** ## **SECTOR ERASE (cont'd)** The system can determine the status of the embedded sector erase operation by the following methods: | Status | Q7 | Q6 | Q5 | Q3 <sup>*1</sup> | Q2 | RY/BY# <sup>*2</sup> | |---------------------|----|----------|----|------------------|----------|----------------------| | Time-out period | 0 | Toggling | 0 | 0 | Toggling | 0 | | In progress | 0 | Toggling | 0 | 1 | Toggling | 0 | | Exceeded time limit | 0 | Toggling | 1 | 1 | Toggling | 0 | #### Note: - 1. The Q3 status bit is the 50us time-out indicator. When Q3=0, the 50us time-out counter has not yet reached zero and a new Sector Erase command may be issued to specify the address of another sector to be erased. When Q3=1, the 50us time-out counter has expired and the Sector Erase operation has already begun. Erase Suspend is the only valid command that may be issued once the embedded erase operation is underway. - 2. RY/BY# is open drain output pin and should be connected to VCC through a high value pull-up resistor. - 3. When an attempt is made to erase only protected sector (s), the erase operation will abort thus preventing any data changes in the protected sector (s). Q7 will output "0" and Q6 will toggle briefly (100us or less) before aborting and returning the device to Read mode. If unprotected sectors are also specified, however, they will be erased normally and the protected sector (s) will remain unchanged. - 4. Q2 is a localized indicator showing a specified sector is undergoing erase operation or not. Q2 toggles when user reads at addresses where the sectors are actively being erased (in erase mode) or to be erased (in erase suspend mode). ## 9-5. CHIP ERASE The Chip Erase operation is used erase all the data within the memory array. All memory cells containing a "0" will be returned to the erased state of "1". This operation requires 6 write cycles to initiate the action. The first two cycles are "unlock" cycles, the third is a configuration cycle, the fourth and fifth are also "unlock" cycles, and the sixth cycle initiates the chip erase operation. During the chip erase operation, no other software commands will be accepted, but if a hardware reset is received or the working voltage is too low, that chip erase will be terminated. After Chip Erase, the chip will automatically return to Read mode. The system can determine the status of the embedded chip erase operation by the following methods: | Status | Q7 | Q6 | Q5 | Q2 | RY/BY# <sup>*1</sup> | |-------------------|----|----------|----|----------|----------------------| | In progress | 0 | Toggling | 0 | Toggling | 0 | | Exceed time limit | 0 | Toggling | 1 | Toggling | 0 | <sup>\*1:</sup> RY/BY# is open drain output pin and should be connected to VCC through a high value pull-up resistor. ## **COMMAND OPERATIONS (cont'd)** #### 9-6. ERASE SUSPEND/RESUME After beginning a sector erase operation, Erase Suspend is the only valid command that may be issued. If system issues an Erase Suspend command during the 50us time-out period following a Sector Erase command, the time-out period will terminate immediately and the device will enter Erase-Suspended Read mode. If the system issues an Erase Suspend command after the sector erase operation has already begun, the device will not enter Erase-Suspended Read mode until 20us time has elapsed. The system can determine if the device has entered the Erase-Suspended Read mode through Q6, Q7, and RY/BY#. After the device has entered Erase-Suspended Read mode, the system can read or program any sector (s) except those being erased by the suspended erase operation. Reading any sector being erased or programmed will return the contents of the status register. Whenever a suspend command is issued, user must issue a resume command and check Q6 toggle bit status, before issue another erase command. The system can use the status register bits shown in the following table to determine the current state of the device: | Status | Q7 | Q6 | Q5 | Q3 | Q2 | Q1 | RY/BY# | |-----------------------------------------------------|------|-----------|------|------|--------|------|--------| | Erase suspend read in erase suspended sector | 1 | No toggle | 0 | N/A | toggle | N/A | 1 | | Erase suspend read in non-erase suspended sector | Data | Data | Data | Data | Data | Data | 1 | | Erase suspend program in non-erase suspended sector | Q7# | Toggle | 0 | N/A | N/A | N/A | 0 | When the device has suspended erasing, user can execute the command sets, such as read silicon ID, sector protect verify, program, CFI query and erase resume. After the device has entered Erase-Suspended Read Mode, Sector Erase, Chip Erase and Program Suspend commands are forbidden. ### 9-7. SECTOR ERASE RESUME The sector Erase Resume command is valid only when the device is in Erase-Suspended Read mode. After erase resumes, the user can issue another Ease Suspend command, but there should be a 400us interval between Ease Resume and the next Erase Suspend command. ## **COMMAND OPERATIONS (cont'd)** #### 9-8. PROGRAM SUSPEND/RESUME After beginning a program operation, Program Suspend is the only valid command that may be issued. The system can determine if the device has entered the Program-Suspended Read mode through Q6 and RY/BY#. After the device has entered Program-Suspended mode, the system can read any sector (s) except those being programmed by the suspended program operation. Reading the sector being program suspended is invalid. Whenever a suspend command is issued, user must issue a resume command and check Q6 toggle bit status, before issue another program command. The system can use the status register bits shown in the following table to determine the current state of the device: | Status | Q7 | Q6 | Q5 | Q3 | Q2 | Q1 | RY/BY# | |------------------------------------------------------|------|------|------|------|------|------|--------| | Program suspend read in program suspended sector | | | Inv | alid | | | 1 | | Program suspend read in non-program suspended sector | Data | Data | Data | Data | Data | Data | 1 | When the device has Program suspended, user can execute read array, auto-select, read CFI, read security silicon. Program and Erase Suspend commands are forbidden after the device entered Program-Suspend mode. ## 9-9. PROGRAM RESUME The Program Resume command is valid only when the device is in Program-Suspended mode. After program resumes, the user can issue another Program Suspend command, but there should be a 5us interval between Program Resume and the next Program Suspend command. ## 9-10. BUFFER WRITE ABORT Q1 is the indicator of Buffer Write Abort. When Q1=1, the device will abort from buffer write and go back to read status register shown as following table: | Status | Q7 | Q6 | Q5 | Q3 | Q2 | Q1 | RY/BY# | |----------------------------------|-----|--------|----|-----|-----|----|--------| | Buffer Write Busy | Q7# | Toggle | 0 | N/A | N/A | 0 | 0 | | Buffer Write Abort | Q7# | Toggle | 0 | N/A | N/A | 1 | 0 | | Buffer Write Exceeded Time Limit | Q7# | Toggle | 1 | N/A | N/A | 0 | 0 | ## **COMMAND OPERATIONS (cont'd)** ## 9-11. AUTOMATIC SELECT OPERATIONS When the device is in Read mode, Program Suspended mode, Erase-Suspended Read mode, or CFI mode, the user can issue the Automatic Select command shown in *Table 5* (two unlock cycles followed by the Automatic Select command 90h) to enter Automatic Select mode. After entering Automatic Select mode, the user can query the Manufacturer ID, Device ID, Security Sector locked status, or Sector protected status multiple times without issuing a new Automatic Select command. While In Automatic Select mode, issuing a Reset command (F0h) will return the device to Read mode (or Ease-Suspended Read mode if Erase-Suspend was active) or Program Suspended Read mode if Program Suspend was active. Another way to enter Automatic Select mode is to use one of the bus operations shown in *Table 2*. BUS OPERATION. After the high voltage (Vhv) is removed from the A9 pin, the device will automatically return to Read mode or Erase-Suspended Read mode. #### 9-12. AUTOMATIC SELECT COMMAND SEQUENCE Automatic Select mode is used to access the manufacturer ID, device ID and to verify whether or not secured silicon is locked and whether or not a sector is protected. The automatic select mode has four command cycles. The first two are unlock cycles, and followed by a specific command. The fourth cycle is a normal read cycle, and user can read at any address any number of times without entering another command sequence. The Reset command is necessary to exit the Automatic Select mode and back to read array. After entering automatic select mode, no other commands are allowed except the reset command. #### 9-13. READ MANUFACTURER ID OR DEVICE ID The Manufacturer ID (identification) is a unique hexadecimal number assigned to each manufacturer by the JE-DEC committee. Each company has its own manufacturer ID, which is different from the ID of all other companies. The number assigned to Macronix is C2h. After entering Automatic Select mode, performing a read operation with A1 & A0 held LOW will cause the device to output the Manufacturer ID on the Data I/O (Q7 to Q0) pins. ## **COMMAND OPERATIONS (cont'd)** #### 9-14. RESET In the following situations, executing reset command will reset device back to Read mode: - Among erase command sequence (before the full command set is completed) - Sector erase time-out period - Erase fail (while Q5 is high) - Among program command sequence (before the full command set is completed, erase-suspended program included) - Program fail (while Q5 is high, and erase-suspended program fail is included) - Auto-select mode - · CFI mode While device is at the status of program fail or erase fail (Q5 is high), user must issue reset command to reset device back to read array mode. While the device is in Auto-Select mode or CFI mode, user must issue reset command to reset device back to read array mode. When the device is in the progress of programming (not program fail) or erasing (not erase fail), device will ignore reset command. ## 9-15. Advanced Sector Protection/Un-protection There are two ways to implement software Advanced Sector Protection on this device: Password method or Solid methods. Through these two protection method, user can disable or enable the programming or erasing operation to any individual sector or whole chip. The figure below helps describe an overview of these methods. The device is default to the Solid mode and all sectors are unprotected when shipped from factory. Shows the detail algorithm of advance sector protecting. Figure 1. Advance Sector Protection/Unprotection SPB Program Algorithm ## 9-15-1. Lock Register User can choose favorite sector protecting method via setting Lock Register bits Q1 and Q2. Lock Register is a 16-bit one-time programmable register. Once programming either Q1 or Q2, they will be locked in that mode and the others will be disabled permanently. Q1 and Q2 can not be programmed at the same time, otherwise the device will abort the operation. If user selects Password Protection mode, the password setting is required. User can set password by issuing password program command. After the Lock Register Bits Command Set Entry command sequence is issued, the read and write operations for normal sectors are disabled until this mode exits. A Lock Register allows the memory sectors and extended memory sector protection to be configured. ## **Lock Register bits** | Q15-Q3 | Q2 | Q1 | Q0 | |------------|--------------------------|-----------------------|------------------------| | Don't care | Password Protection Mode | Solid Protection Mode | Secured Silicon Sector | | Don't care | Lock Bit | Lock Bit | Protection Bit | Please refer to the command for Lock Register command set to read and program the Lock register. Figure 2. Lock Register Program Algorithm ## 9-15-2. Solid write (non-volatile) protection Mode ## Solid write Protection Bits (SPB) The Solid write Protection bit (SPB) is a nonvolatile bit with the same endurances as the Flash memory. It is assigned to each sector individually. The SPB is Preprogramming, and its verification prior to erasure are managed by the device, so system monitoring is not necessary. When a SPB is set to "0", the associated sector is protected, preventing any program or erase operation on this sector. The SPB bits are set individually by SPB program command. However, it cannot be cleared individually. Issuing the All SPB Erase command will erase all SPB in the same time. During SPB programming period, the read and write operations are disabled for normal sector until this mode exits. If one of the protected sector need to be unprotected (corresponding SPB set to "1"), a few more steps are required. First, the SPB Lock Bit must be cleared by either putting the device through a power-cycle, or hardware reset. The SPBs can then be changed to reflect the desired settings. Setting the SPB Lock Bit once again locks the SPBs, and the device operates normally again. To verify the programming state of the SPB for a given sector, issuing a SPB Status Read Command to the device is required. Refer to the flow chart below for details of SPB Program Algorithm. #### Notes - 1. The Read actions within that sector will bring the SPB status back for that sector. All Read actions must be executed by read mode. The specific sector address is written as the program command at the same time. - 2.Once SPB Lock Bit is set, its Program or erase command will not be executed and times-out without programming or erasing the SPB. - 3. Always issue exit command after the execution of resetting the device to read mode and re-enables read and write actions for normal array. - 4. To achieve the best effect of protection, it is recommended to execute the SPB Lock Bit Set command early in the boot code and protect the boot code by holding WP#/ACC = VIL. Note that the SPB and DPB bits have the same function when WP#/ACC = VHH, and it is same when ACC = VIH. ## **Dynamic Protection Bits (DPBS)** The Dynamic Protection allows the software application to easily protect sectors against inadvertent change. However, the protection can be easily disabled when changes are necessary. All Dynamic Protection bit (DPB) are volatile and assigned to each sector. It can be modify individual. DPBs provide the protection scheme only for unprotected sectors that have their SPBs cleared (erase can be individually modified d to "1"). To modify the DPB status by issuing the DPB Set (programmed to "0") or DPB Clear (erased to "1") commands, then placing each sector in the protected or unprotected state seperately. After the DPB Clear command is issued(erased to "1"), the sector may be modified depending on the SPB state of that sector When the parts are first shipped, the SPBs are cleared (erased to "1") and upon power up or reset, the DPBs can be set or cleared depending upon the ordering option chosen. ## 9-15-3. Temporary Un-protect Solid write protect bit (USPB) Temporary Un-protect Solid write Protect Bits are volatile and unique for each sector and can be individually modified. By issuing the USPB Set or Clear command sequences, the USPBs are set (programmed to "0") or cleared (erased to "1"), thus mask each sector's solid write protect bit property. This feature allows software to temp unprotect write protect sectors despite of SPB's property when DPBs are cleared. #### Notes: - 1. The USPBs can be set (programmed to "0") or cleared (erased to "1") as often as needed. The USPBs are cleared (all 1s) upon power up. Hardware reset won"t change USPBs/DPBs status. The sectors SPBs would be in effective state after power up is chosen. - 2. However, if there is a need to write a solid protect bit protect sector status, user don't have to clear all SPB bits. They just use software to set corresponding USPB to 0, which guarantees that corresponding DPB status is clear, and original solid protect bit protected sectors can be temporary written. - 3. SPBLK should be cleared to modify USPB status. Figure 3. SPB Program Algorithm Note: SPB program/ erase status polling flowchart: check Q6 toggle, when Q6 stop toggle, the read status is 00H /01H (00H for program/ 01H for erase), otherwise the status is "fail" and "exit". ### 9-15-4. Solid Protection Bit Lock Bit The Solid Protection Bit Lock Bit (SPB) is assign to control all SPB status. It is a unique and volatile. When SPB=0 (set), all SPBs are locked and can not be changed. When SPB=1 (cleared), all SPBs are unlock and allows to be changed. There is no software command sequence requested to unlocks this bit, unless the device is in the password protection mode. To clear the SPB lock bit, just take the device through a hardware reset or a power-up cycle. In order to prevent moified, the SPB Lock Bit must be set (SPB=0) after all SPBs are setting the desired status. #### 9-15-5. Password Protection Method The security level of Password Protection Method is higher then the Solid protection mode. The 64 bit password is requested before modify SPB lock bit status. When device is under password protection mode, the SPB lock bit is set "0", after a power-up cycle or Reset Command. A correct password is required for password Unlock command, to unlock the SPB lock bit. Await 2us is necessary to unlocked the device after valid password is given. After that, the SPB bits are allows to be changed. The Password Unlock command are issued slower then 2us every time,. to prevent hacker from trying all the 64-bit password combinations. To place the device in password protection mode, a few more steps are required. First, prior to entering the password protection mode, it is necessary to set a 64-bit password to verify it. Password verification is only allowed during the password programming operation. Second, the password protection mode is then activated by programming the password the Password Protection Mode Lock Bit to "0". This operation is not reversible. Once the bit is programmed, it cannot be erased, and the device remains permanently in password protection mode, and the 64-bit password can neither be retrieved nor reprogrammed. Moreover, all commands to the address where the password is stored are disabled. The password is all "1"s when shipped from the factory, it is only capable to programming "0"s under password program command. All 64-bit password combinations are valid as a password. No special address is required for programming the password. In order to prevent access, the Password Mode Locking Bit must be set after the Password is programmed and verified. Once the Password Mode Lock Bit is set, prevents reading 64-bits password on the data bus and any future modification. There is no means to verify what the password is after it is set. Entry command sequence will cause the read and write operation to be disabled for normal sector until this mode exits. Once sector under protected status, device will ignores the program/erase command, enable status polling and returns to read mode without contents change. The DPB, SPB,USPB and SPB lock bit status of each sector can be verified by issue status read commands. **Table 4. Sector Protection Status** | F | Protection | Bit Statu | S | Sector Status | |-------|------------|-----------|-------|-------------------------------------------------------------| | DPB | SPBLK | SPB | USPB | Sector Status | | clear | clear | clear | clear | unprotect, DPB/SPB/USPB are changeable | | clear | clear | clear | set | unprotect, DPB/SPB/USPB are changeable | | clear | clear | set | clear | protect, DPB/SPB/USPB are changeable | | clear | clear | set | set | unprotect, DPB/SPB/USPB are changeable | | clear | set | clear | clear | (1) unprotect, DPB is changeable, SPB/USPB are unchangeable | | clear | set | clear | set | (1) unprotect, DPB is changeable, SPB/USPB are unchangeable | | clear | set | set | clear | (1) protect, DPB is changeable, SPB/USPB are unchangeable | | clear | set | set | set | (1) unprotect, DPB is changeable, SPB/USPB are unchangeable | | set | clear | clear | clear | protect, DPB/SPB/USPB are changeable | | set | clear | clear | set | protect, DPB/SPB/USPB are changeable | | set | clear | set | clear | protect, DPB/SPB/USPB are changeable | | set | clear | set | set | protect, DPB/SPB/USPB are changeable | | set | set | clear | clear | protect, DPB is changeable, SPB/USPB are unchangeable | | set | set | clear | set | protect, DPB is changeable, SPB/USPB are unchangeable | | set | set | set | clear | protect, DPB is changeable, SPB/USPB are unchangeable | | set | set | set | set | protect, DPB is changeable, SPB/USPB are unchangeable | ## Note: (1) If STBLK is set, SPB/USPB will be unchangable, the protection staus of Sector depends on previous setting of DPB/SPB/USPB. ## 9-16. SECURITY SECTOR FLASH MEMORY REGION The Security Sector region is an extra OTP memory space of 128 words in length. The security sector can be locked upon shipping from factory, or it can be locked by customer after shipping. Customer can issue Security Sector Factory Protect Verify and/or Security Sector Protect Verify to query the lock status of the device. After enter Security Sector region, it is forbidden to enter Lock Register, DPB, SPB lock region. In factory-locked device, security sector region is protected when shipped from factory and the security silicon sector indicator bit is set to "1". In customer lockable device, security sector region is unprotected when shipped from factory and the security silicon indicator bit is set to "0". ## 9-17. FACTORY LOCKED: SECURITY SECTOR PROGRAMMED AND PROTECTED AT THE FACTORY In a factory locked device, the Security Sector is permanently locked before shipping from the factory. The device will have a 16-byte (8-word) ESN in the security region. The ESN occupies addresses 00000h to 0000Fh in byte mode or 00000h to 00007h in word mode. | Secured Silicon Sector<br>Address Range | Standard Factory Locked | Express Flash<br>Factory Locked | Customer Lockable | |-----------------------------------------|-------------------------|----------------------------------|------------------------| | 0000000h-0000007h | ESN | ESN or Determined by<br>Customer | Determined by Customer | | 0000008h-000007Fh | Unavailable | Determined by Customer | | # 9-18. CUSTOMER LOCKABLE: SECURITY SECTOR NOT PROGRAMMED OR PROTECTED AT THE FACTORY When the security feature is not required, the security region can act as an extra memory space. Security silicon sector can also be protected by two methods. Note that once the security silicon sector is protected, there is no way to unprotect the security silicon sector and the content of it can no longer be altered. After the security silicon is locked and verified, system must write Exit Security Sector Region, go through a power cycle, or issue a hardware reset to return the device to read normal array mode. ## **Table 5. COMMAND DEFINITIONS** | | | | | Automatic Select | | | | | | | Secu | ırity | Exit Se | ourity | | |--------------|------|--------------|---------------|------------------|------|-----------|------|------------------------|------|-----------------|-----------------|------------|---------|--------|------| | Comm-<br>and | | Read<br>Mode | Reset<br>Mode | Silicon ID | | Device ID | | Factory Protect Verify | | Sector Pro | tect Verify | Sec<br>Reg | | Sec | - 1 | | | | | | Word | Byte | Word | Byte | Word | Byte | Word | Byte | Word | Byte | Word | Byte | | 1st Bus | Addr | Addr | XXX | 555 | AAA | 555 | AAA | 555 | AAA | 555 | AAA | 555 | AAA | 555 | AAA | | Cycle | Data | Data | F0 | AA | 2nd Bus | Addr | | | 2AA | 555 | 2AA | 555 | 2AA | 555 | 2AA | 555 | 2AA | 555 | 2AA | 555 | | Cycle | Data | | | 55 | 55 | 55 | 55 | 55 | 55 | 55 | 55 | 55 | 55 | 55 | 55 | | 3rd Bus | Addr | | | 555 | AAA | 555 | AAA | 555 | AAA | 555 | AAA | 555 | AAA | 555 | AAA | | Cycle | Data | | | 90 | 90 | 90 | 90 | 90 | 90 | 90 | 90 | 88 | 88 | 90 | 90 | | 4th Bus | Addr | | | X00 | X00 | X01 | X02 | X03 | X06 | (Sector)<br>X02 | (Sector)<br>X04 | | | XXX | xxx | | Cycle | Data | | | C2h | C2h | ID1 | ID1 | 99/19(H)<br>89/09(L) | | 00/01 | 00/01 | | | 00 | 00 | | 5th Bus | Addr | | | | | X0E | X1C | | | | | | | | | | Cycle | Data | | | | | ID2 | ID2 | | | | | | | | | | 6th Bus | Addr | | | | | X0F | X1E | | | | | | | | | | Cycle | Data | | | | | ID3 | ID3 | | | | | | | | | | Comm-<br>and | | Prog | | Writ<br>Buf<br>Prog | ffer<br>Iram | Writ<br>Buf<br>Prog<br>Abort | fer<br>ram<br>Reset | | fer<br>ram<br>firm | Chip E | | Sec<br>Era | se | CFI F | | Prog<br>Era<br>Susp | ise<br>end | Prog<br>Era<br>Resi | ase<br>ume | |--------------|------|------|------|---------------------|--------------|------------------------------|---------------------|------|--------------------|--------|------|-------------|-------------|-------|------|---------------------|------------|---------------------|------------| | | | Word | Byte | 1st Bus | Addr | 555 | AAA | 555 | AAA | 555 | AAA | SA | SA | 555 | AAA | 555 | AAA | 55 | AA | XXX | xxx | XXX | xxx | | Cycle | Data | AA | AA | AA | AA | AA | AA | 29 | 29 | AA | AA | AA | AA | 98 | 98 | B0 | B0 | 30 | 30 | | 2nd Bus | Addr | 2AA | 555 | 2AA | 555 | 2AA | 555 | | | 2AA | 555 | 2AA | 555 | | | | | | | | Cycle | Data | 55 | 55 | 55 | 55 | 55 | 55 | | | 55 | 55 | 55 | 55 | | | | | | | | 3rd Bus | Addr | 555 | AAA | SA | SA | 555 | AAA | | | 555 | AAA | 555 | AAA | | | | | | | | Cycle | Data | A0 | A0 | 25 | 25 | F0 | F0 | | | 80 | 80 | 80 | 80 | | | | | | | | 4th Bus | Addr | Addr | Addr | SA | SA | | | | | 555 | AAA | 555 | AAA | | | | | | | | Cycle | Data | Data | Data | N-1 | N-1 | | | | | AA | AA | AA | AA | | | | | | | | 5th Bus | Addr | | | WA | WA | | | | | 2AA | 555 | 2AA | 555 | | | | | | | | Cycle | Data | | | WD | WD | | | | | 55 | 55 | 55 | 55 | | | | | | | | 6th Bus | Addr | | | WBL | WBL | | | | | 555 | AAA | Sec-<br>tor | Sec-<br>tor | | | | | | | | Cycle | Data | | | WD | WD | | | | | 10 | 10 | 30 | 30 | | | | | | | WA= Write Address WD= Write Data SA= Sector Address N-1= Word Count WBL= Write Buffer Location PWD= Password PWDn=Password word 0, word 1, word n ID1/ID2/ID3: Refer to *Table 3* for detail ID. | | | D | eep Pov | wer Dow | /n | | | | Pa | ssword | Protecti | ion | | | | |----------|------|------|---------|---------|------|----------------------------------|------|---------|------|------------|----------|------|-------------|------|------------------------| | Comma | and | En | ter | E | xit | Password<br>Command Set<br>Entry | | Program | | Pass<br>Re | | | word<br>ock | | word<br>and Set<br>kit | | | | Word | Byte | 1st Bus | Addr | 555 | AAA | XXX | XXX | 555 | AAA | XXX | XXX | X00 | X00 | 00 | 00 | XXX | XXX | | Cycle | Data | AA | AA | AB | AB | AA | AA | A0 | A0 | PWD0 | PWD0 | 25 | 25 | 90 | 90 | | 2nd Bus | Addr | 2AA | 555 | | | 2AA | 555 | PWA | PWA | X01 | X01 | 00 | 00 | XXX | XXX | | Cycle | Data | 55 | 55 | | | 55 | 55 | PWD | PWD | PWD1 | PWD1 | 03 | 03 | 00 | 00 | | 3rd Bus | Addr | XXX | XXX | | | 555 | AAA | | | X02 | X02 | X00 | X00 | | | | Cycle | Data | B9 | B9 | | | 60 | 60 | | | PWD2 | PWD2 | PWD0 | PWD0 | | | | 4th Bus | Addr | | | | | | | | | X03 | X03 | X01 | X01 | | | | Cycle | Data | | | | | | | | | PWD3 | PWD3 | PWD1 | PWD1 | | | | 5th Bus | Addr | | | | | | | | | | X04 | X02 | X02 | | | | Cycle | Data | | | | | | | | | | PWD4 | PWD2 | PWD2 | | | | 6th Bus | Addr | | | | | | | | | | X05 | X03 | X03 | | | | Cycle | Data | | | | | | | | | | PWD5 | PWD3 | PWD3 | | | | 7th Bus | Addr | | | | | | | | | | X06 | 00 | X04 | | | | Cycle | Data | | | | | | | | | | PWD6 | 29 | PWD4 | | | | 8th Bus | Addr | | | | | | | | | | X07 | | X05 | | | | Cycle | Data | | | | | | | | | | PWD7 | | PWD5 | | | | 9th Bus | Addr | | | | | | | | | | | | X06 | | | | Cycle | Data | | | | | | | | | | | | PWD6 | | | | 10th Bus | Addr | | | | | | | | | | | | X07 | | | | Cycle | Data | | | | | | | | | | | | PWD7 | | | | 11th Bus | Addr | | | | | | | | | | | | 00 | | | | Cycle | Data | | | | | | | | | | | | 29 | | | P/N:PM1727 REV. 0.00, NOV. 03, 2011 | | Lock Register | | | | | | | | Global Non-Volatile | | | | | | | | | |---------|---------------|--------------------------|------|------|------|------|------|------------------------|---------------------|---------------------|------|------------|------|--------------|------|-------------|-------| | Comm | and | Lock re<br>Comr<br>Set E | | Prog | ıram | Re | ad | Lock re<br>Comi<br>Set | | SF<br>Comr<br>Set E | mand | SF<br>Prog | _ | All S<br>Era | | SPB S<br>Re | | | | | Word | Byte | 1st Bus | Addr | 555 | AAA | XXX | XXX | XXX | XXX | XXX | XXX | 555 | AAA | XXX | XXX | XXX | XXX | SA | SA | | Cycle | Data | AA | AA | A0 | A0 | DATA | DATA | 90 | 90 | AA | AA | A0 | A0 | 80 | 80 | 00/01 | 00/01 | | 2nd Bus | Addr | 2AA | 555 | XXX | XXX | | | XXX | XXX | 2AA | 555 | SA | SA | 00 | 00 | | | | Cycle | Data | 55 | 55 | Data | Data | | | 00 | 00 | 55 | 55 | 00 | 00 | 30 | 30 | | | | 3rd Bus | Addr | 555 | AAA | | | | | | | 555 | AAA | | | | | | | | Cycle | Data | 40 | 40 | | | | | | | C0 | C0 | | | | | | | | 4th Bus | Addr | | | | | | | | | | | | | | | | | | Cycle | Data | | | | | | | | | | | | | | | | | | 5th Bus | Addr | | | | | | | | | | | | | | | | | | Cycle | Data | | | | | | | | | | | | | | | | | | | Global Non-<br>Volatile<br>SPB SI | | | | Global Volatile Freeze | | | | | | | | | Volatile | | | | | | |---------|-----------------------------------|-------------------|------|----------------------|------------------------|------|------------|---------------|-------|--------------------|------|---------------------|------|----------|------|------|-------|--|--| | Comma | and | SF<br>Comr<br>Set | mand | SPB<br>Comr<br>Set B | | | Lock<br>et | SPB<br>Status | | SPB<br>Comr<br>Set | mand | DF<br>Comr<br>Set E | nand | DPB | Set | DPB | Clear | | | | | | Word | Byte | | | 1st Bus | Addr | XXX | XXX | 555 | AAA | XXX | XXX | XXX | XXX | XXX | XXX | 555 | AAA | XXX | XXX | XXX | XXX | | | | Cycle | Data | 90 | 90 | AA | AA | A0 | A0 | 00/01 | 00/01 | 90 | 90 | AA | AA | A0 | A0 | A0 | A0 | | | | 2nd Bus | Addr | XXX | XXX | 2AA | 555 | XXX | XXX | | | XXX | XXX | 2AA | 555 | SA | SA | SA | SA | | | | Cycle | Data | 00 | 00 | 55 | 55 | 00 | 00 | | | 00 | 00 | 55 | 55 | 00 | 00 | 01 | 01 | | | | 3rd Bus | Addr | | | 555 | AAA | | | | | | | 555 | AAA | | | | | | | | Cycle | Data | | | 50 | 50 | | | | | | | E0 | E0 | | | | | | | | 4th Bus | Addr | | | | | | | | | | | | | | | | | | | | Cycle | Data | | | | | | | | | | | | | | | | | | | | 5th Bus | Addr | | | | | | | | | | | | | | | | | | | | Cycle | Data | | | | | | | | | | | | | | | | | | | | | | Volatile | | | | | | | | | |---------|------|----------|--------|--------|-------|--|--|--|--|--| | Comma | and | DPB S | Status | DPB Co | mmand | | | | | | | | | Re | ad | Set I | Exit | | | | | | | | | Word | Byte | Word | Byte | | | | | | | 1st Bus | Addr | SA | SA | XXX | XXX | | | | | | | Cycle | Data | 00/01 | 00/01 | 90 | 90 | | | | | | | 2nd Bus | Addr | | | XXX | XXX | | | | | | | Cycle | Data | | | 00 | 00 | | | | | | | 3rd Bus | Addr | | | | | | | | | | | Cycle | Data | | | | | | | | | | | 4th Bus | Addr | | | | | | | | | | | Cycle | Data | | | | | | | | | | | 5th Bus | Addr | | | | | | | | | | | Cycle | Data | | | | | | | | | | ## Notes: P/N:PM1727 REV. 0.00, NOV. 03, 2011 <sup>\*</sup> It is not recommended to adopt any other code not in the command definition table which will potentially enter the hidden mode. <sup>\*</sup> For the SPB Lock and DPB Status Read "00" means lock (protect), "01" means unlock (unprotect). ## 10. COMMON FLASH MEMORY INTERFACE (CFI) MODE ## QUERY COMMAND AND COMMAND FLASH MEMORY INTERFACE (CFI) MODE The device features CFI mode. Host system can retrieve the operating characteristics, structure and vendor-specified information such as identifying information, memory size, byte/word configuration, operating voltages and timing information of this device by CFI mode. If the system writes the CFI Query command "98h", to address "55h"/"AAh" (depending on Word/Byte mode), the device will enter the CFI Query Mode, any time the device is ready to read array data. The system can read CFI information at the addresses given in Table 6~9. Once user enters CFI query mode, user can issue reset command to exit CFI mode and return to read array mode. The CFI unused area is reserved by Macronix. Table 6. CFI mode: Identification Data Values (All values in these tables are in hexadecimal) | Description | Address (h) | Address (h) | Data (h) | |------------------------------------------------------------|-------------|-------------|----------| | Description | (Word Mode) | (Byte Mode) | Data (h) | | | 10 | 20 | 0051 | | Query-unique ASCII string "QRY" | 11 | 22 | 0052 | | | 12 | 24 | 0059 | | Primary vendor command set and control interface ID code | 13 | 26 | 0002 | | Filmary vendor command set and control interface iD code | 14 | 28 | 0000 | | Address for primary algorithm extended query table | 15 | 2A | 0040 | | Address for primary algorithm extended query table | 16 | 2C | 0000 | | Alternate vendor command set and control interface ID code | 17 | 2E | 0000 | | Alternate vendor command set and control interface ib code | 18 | 30 | 0000 | | Address for alternate algorithm extended query table | 19 | 32 | 0000 | | Address for alternate algorithm extended query table | 1A | 34 | 0000 | Table 7. CFI mode: System Interface Data Values | Description | Address (h) | Address (h) | Data (h) | |----------------------------------------------------------------------------|-------------|-------------|----------| | | (Word Mode) | (Byte Mode) | | | Vcc supply minimum program/erase voltage | 1B | 36 | 0027 | | Vcc supply maximum program/erase voltage | 1C | 38 | 0036 | | VPP supply minimum program/erase voltage | 1D | 3A | 0000 | | VPP supply maximum program/erase voltage | 1E | 3C | 0000 | | Typical timeout per single word/byte write, 2 <sup>n</sup> us | 1F | 3E | 0003 | | Typical timeout for maximum-size buffer write, 2 <sup>n</sup> us (00h, not | 20 | 40 | 0006 | | support) | 20 | 40 | 0006 | | Typical timeout per individual block erase, 2 <sup>n</sup> ms | 21 | 42 | 0009 | | Typical timeout for full chip erase, 2 <sup>n</sup> ms (00h, not support) | 22 | 44 | 0018 | | Maximum timeout for word/byte write, 2 <sup>n</sup> times typical | 23 | 46 | 0003 | | Maximum timeout for buffer write, 2 <sup>n</sup> times typical | 24 | 48 | 0005 | | Maximum timeout per individual block erase, 2 <sup>n</sup> times typical | 25 | 4A | 0003 | | Maximum timeout for chip erase, 2 <sup>n</sup> times typical (00h, not | 26 | 4C | 0002 | | support) | | | | Table 8. CFI mode: Device Geometry Data Values | Description | Address (h) | Address (h) | Data (b) | |----------------------------------------------------------------------------------------------------|-------------|-------------|----------| | Description | (Word Mode) | (Byte Mode) | Data (h) | | Device size = 2 <sup>n</sup> in number of bytes (1B=1Gb) | 27 | 4E | 001B | | Electrical interference description (00 consultances of 40) | 28 | 50 | 0002 | | Flash device interface description (02=asynchronous x8/x16) | 29 | 52 | 0000 | | Maximum number of butes in buffer write = 2 <sup>n</sup> (00b, net support) | 2A | 54 | 0006 | | Maximum number of bytes in buffer write = 2 <sup>n</sup> (00h, not support) | 2B | 56 | 0000 | | Number of erase regions within device (01h:uniform, 02h:boot) | 2C | 58 | 0001 | | | 2D | 5A | 00FF | | Index for Erase Bank Area 1: | 2E | 5C | 0003 | | [2E,2D] = # of same-size sectors in region 1-1<br>[30, 2F] = sector size in multiples of 256 bytes | 2F | 5E | 0000 | | [50, 21] - 300tol 3ize in multiples of 250 bytes | 30 | 60 | 0002 | | | 31 | 62 | 0000 | | Index for France Book Area 2 | 32 | 64 | 0000 | | Index for Erase Bank Area 2 | 33 | 66 | 0000 | | | 34 | 68 | 0000 | | | 35 | 6A | 0000 | | Index for France Bords Area 2 | 36 | 6C | 0000 | | Index for Erase Bank Area 3 | 37 | 6E | 0000 | | | 38 | 70 | 0000 | | | 39 | 72 | 0000 | | Index for Free Bords Area 4 | 3A | 74 | 0000 | | Index for Erase Bank Area 4 | 3B | 76 | 0000 | | | 3C | 78 | 0000 | Table 9. CFI mode: Primary Vendor-Specific Extended Query Data Values | Description | Address (h) | Address (h) | Doto (b) | |------------------------------------------------------------------------------------------|-------------|-------------|---------------| | Description | (Word Mode) | (Byte Mode) | Data (h) | | | 40 | 80 | 0050 | | Query - Primary extended table, unique ASCII string, PRI | 41 | 82 | 0052 | | | 42 | 84 | 0049 | | Major version number, ASCII | 43 | 86 | 0031 | | Minor version number, ASCII | 44 | 88 | 0033 | | Unlock recognizes address (0= recognize, 1= don't recognize) | 45 | 8A | 0014 | | Erase suspend (2= to both read and program) | 46 | 8C | 0002 | | Sector protect (N= # of sectors/group) | 47 | 8E | 0001 | | Temporary sector unprotect (1=supported) | 48 | 90 | 0000 | | Sector protect/Chip unprotect scheme | 49 | 92 | 8000 | | Simultaneous R/W operation (0=not supported) | 4A | 94 | 0000 | | Burst mode (0=not supported) | 4B | 96 | 0000 | | Page mode (0=not supported, 01 = 4 word page, 02 = 8 word page) | 4C | 98 | 0002 | | Minimum ACC(acceleration) supply (0= not supported), [D7:D4] for volt, [D3:D0] for 100mV | 4D | 9A | 0095 | | Maximum ACC(acceleration) supply (0= not supported), [D7:D4] for volt, [D3:D0] for 100mV | 4E | 9C | 00A5 | | WP# Protection 04=Uniform sectors bottom WP# protect 05=Uniform sectors top WP# protect | 4F | 9E | 0004/<br>0005 | | Program Suspend (0=not supported, 1=supported) | 50 | A0 | 0001 | ### 11. ELECTRICAL CHARACTERISTICS #### 11-1. ABSOLUTE MAXIMUM STRESS RATINGS | Storage Temperature | | -65°C to +150°C | |---------------------------------|----------------------|--------------------| | Voltage Denge | VCC | -0.5V to +4.0V | | | VI/O | -0.5V to +4.0V | | Voltage Range | A9 , WP#/ACC | -0.5V to +10.5V | | | The other pins. | -0.5V to Vcc +0.5V | | Output Short Circuit Current (I | ess than one second) | 200 mA | #### 11-2. OPERATING TEMPERATURE AND VOLTAGE | Industrial (I) Grade | Surrounding Temperature (TA) | -40°C to +85°C | |----------------------|------------------------------|----------------| | | Full VCC range | +2.7V to 3.6V | | VCC Supply Voltages | Regulated VCC range | +3.0V to 3.6V | | | VI/O range | +2.7V to 3.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 GND to -2.0V and Vcc to +2.0V for periods up to 20ns, see below Figure. Figure 4. Maximum Negative Overshoot Waveform Figure 5. Maximum Positive Overshoot Waveform ## Table 10. DC CHARACTERISTICS | Symbol | Description | Min. | Тур. | Max. | Remark | |--------|-----------------------------------------------------------|----------|-------|----------|-------------------------------------------------------| | lilk | Input Leak | | | ±8.0uA | | | lilk9 | A9 Leak | | | 140uA | A9=10.5V | | lolk | Output Leak | | | ±1.0uA | | | | | | 6mA | 20mA | CE#=Vil, OE#=Vih,<br>Vcc=Vccmax;<br>f=1MHz, Byte Mode | | lcr1 | Read Current | | 20mA | 50mA | CE#=Vil, OE#=Vih,<br>Vcc=Vccmax;<br>f=5MHz, Byte Mode | | | | | 60mA | 100mA | CE#=Vil, OE#=Vih,<br>Vcc=Vccmax;<br>f=10MHz | | lcr2 | VCC Page Read Current | | 2mA | 10mA | CE#=Vil, OE#=Vih,<br>Vcc=Vccmax;<br>f=10MHz | | ICIZ | VOC Page Read Current | | 5mA | 20mA | CE#=Vil, OE#=Vih,<br>Vcc=Vccmax;<br>f=33MHz | | Icw | Write Current | | 36mA | 60mA | CE#=Vil, OE#=Vih,<br>WE#=Vil | | Isb | Standby Current | | 120uA | 400uA | Vcc=Vcc max, other pin disable | | Isbr | Reset Current | | 120uA | 400uA | Vcc=Vccmax,<br>RESET# enable,<br>other pin disable | | Isbs | Sleep Mode Current *1 | | 120uA | 400uA | | | Idpd | Vcc deep power down current | | 40uA | 120uA | | | lcp1 | Accelerated Pgm Current, WP#/Acc pin (Word/Byte) | | 5mA | 10mA | CE#=Vil, OE#=Vih | | Icp2 | Accelerated Pgm Current, Vcc pin, (Word/Byte) | | 20mA | 30mA | CE#=Vil, OE#=Vih | | Vil | Input Low Voltage | -0.1V | | 0.3xVCC | | | Vih | Input High Voltage | 0.7xVCC | | VCC+0.3V | | | Vhv | Very High Voltage for Auto Select/<br>Accelerated Program | 9.5V | | 10.5V | | | Vol | Output Low Voltage | | | 0.45V | Iol=100uA | | Voh | Ouput High Voltage | 0.85xVCC | | | loh=-100uA | | Vlko | Low Vcc Lock-out voltage *2 | 2.1V | | 2.4V | | ## Note: - 1. Sleep mode enables the lower power when address remain stable for taa+30ns. - 2. Not 100% tested. ## Figure 6. SWITCHING TEST CIRCUITS **Test Condition** Output Load Capacitance, CL: 1TTL gate, 30pF Rise/Fall Times: 5ns Input Pulse levels :0.0 ~ VCC In/Out reference levels :0.5VCC Figure 7. SWITCHING TEST WAVEFORMS **Table 11. AC CHARACTERISTICS** | 0 | Description | | VCC | =2.7V~ | 3.6V | 11:-24 | |-------------|------------------------------------------------------------------|------------------------|------|--------|------|--------| | Symbol | Description | | Min. | Тур. | Max. | Unit | | Taa | Valid data output after address | | | | 110 | ns | | Тра | Page access time | | | ĺ | 25 | ns | | Tce | Valid data output after CE# low | | | | 110 | ns | | Toe | Valid data output after OE# low | | | | 25 | ns | | Tdf | Data output floating after OE# high or CE# hig | h | | | 20 | ns | | Tsrw | Latency between read and write operation (No | te) | 35 | | | ns | | Toh | Output hold time from the earliest rising edge | of address, CE#, OE# | 0 | | | ns | | Trc | Read period time | | 110 | | | ns | | Twc | Write period time | | 110 | | | ns | | Tcwc | Command write period time | | 110 | | | ns | | Tas | Address setup time | | 0 | | | ns | | Taso | Address setup time to OE# low during toggle b | pit polling | 15 | | | ns | | Tah | Address hold time | | 45 | | | ns | | Taht | Address hold time from CE# or OE# high during toggle bit polling | | 0 | | | ns | | Tds | Data setup time | | 30 | | | ns | | Tdh | Data hold time | | 0 | | | ns | | Tvcs | Vcc setup time | | 500 | | | us | | Tcs | Chip enable Setup time | | 0 | | | ns | | Tch | Chip enable hold time | | 0 | | | ns | | Toes | Output enable setup time | | 0 | | | ns | | Took | Output anable hold time | Read | 0 | | | ns | | Toeh | Output enable hold time | Toggle & Data# Polling | 10 | | | ns | | Tws | WE# setup time | • | 0 | | | ns | | Twh | WE# hold time | | 0 | | | ns | | Tcepw | CE# pulse width | | 35 | | | ns | | Tcepwh | CE# pulse width high | | 30 | | | ns | | Twp | WE# pulse width | | 35 | | | ns | | Twph | WE# pulse width high | | 30 | | | ns | | Tbusy | Program/Erase active time by RY/BY# | | | | 110 | ns | | Tghwl | Read recover time before write | | 0 | | | ns | | Tghel | | | 0 | | | ns | | Tundan da 4 | Dragram anaration | Byte | | 11 | | us | | ıwnwn1 | Program operation | Word | | 11 | | us | | Twhwh1 | Acc program operation (Word/Byte) | | | 11 | | us | | Twhwh2 | Sector erase operation | | | 0.6 | 5 | sec | | Tbal | Sector add hold time | | | | 50 | us | | Trdp | Release from deep power down mode | | | | 200 | us | Note: Not 100% tested. ## 12. WRITE COMMAND OPERATION Figure 8. COMMAND WRITE OPERATION ## 13. READ/RESET OPERATION ## Figure 9. READ TIMING WAVEFORMS Table 12. AC CHARACTERISTICS-RESET# | Item | Description | Setup | Speed | Unit | |---------|-------------------------------------------------------------------|-------|-------|------| | Trp1 | RESET# Pulse Width (During Automatic Algorithms) | MIN | 10 | us | | Trp2 | RESET# Pulse Width (NOT During Automatic Algorithms) | MIN | 500 | ns | | Trh | RESET# High Time Before Read | MIN | 200 | ns | | Trb1 | RY/BY# Recovery Time (to CE#, OE# go low) | MIN | 0 | ns | | Trb2 | RY/BY# Recovery Time (to WE# go low) | MIN | 50 | ns | | Tready1 | RESET# PIN Low (During Automatic Algorithms) to Read or Write | MAX | 20 | us | | Tready2 | RESET# PIN Low (NOT During Automatic Algorithms) to Read or Write | MAX | 500 | ns | Figure 10. RESET# TIMING WAVEFORM ## 14. ERASE/PROGRAM OPERATION Figure 11. AUTOMATIC CHIP ERASE TIMING WAVEFORM Figure 12. AUTOMATIC CHIP ERASE ALGORITHM FLOWCHART Figure 13. AUTOMATIC SECTOR ERASE TIMING WAVEFORM Figure 14. AUTOMATIC SECTOR ERASE ALGORITHM FLOWCHART Figure 15. ERASE SUSPEND/RESUME FLOWCHART Figure 16. AUTOMATIC PROGRAM TIMING WAVEFORMS Figure 17. ACCELERATED PROGRAM TIMING DIAGRAM Figure 18. CE# CONTROLLED WRITE TIMING WAVEFORM Figure 19. AUTOMATIC PROGRAMMING ALGORITHM FLOWCHART ## 15. SILICON ID READ OPERATION Figure 20. SILICON ID READ TIMING WAVEFORM ## **16. WRITE OPERATION STATUS** Figure 21. DATA# POLLING TIMING WAVEFORMS (DURING AUTOMATIC ALGORITHMS) Start Read Q7~Q0 at valid address (Note 1) No Q7 = Data# ? Yes No Q5 = 1? Yes Read Q7~Q0 at valid address Q7 = Data# ? No (Note 2) Yes FAIL Pass Figure 22. STATUS POLLING FOR WORD PROGRAM/ERASE #### Notes: - 1. Q7 should be rechecked even Q5="1" because Q7 may change simultaneously with Q5. - 2. It is requested to provide valid address to read out correct Q5 status. For program mode and single sector erase mode: means polling status with the program/page program address or sector address. For multi-sector erase mode and chip erase mode: The lowest and highest erased sector need to be provided for time-out check. If Q5=1 when do status polling check for one sector address, it means erase time out. - 3. During erase mode: Q2 is "don't care" after erase time out. Start Read Q7~Q0 at last write address (Note 1) No Q7 = Data# ? Yes Q1=1? Yes Only for write buffer program No No Q5=1? Read Q7~Q0 at last write address (Note 1) Yes Read Q7~Q0 at last write address (Note 1) No Q7 = Data# ? (Note 2) No Q7 = Data# ? Yes (Note 2) Write Buffer Abort Yes **FAIL** Pass Figure 23. STATUS POLLING FOR WRITE BUFFER PROGRAM #### Notes - 1. Q7 should be rechecked even Q5="1" because Q7 may change simultaneously with Q5. - 2. It is requested to provide valid address to read out correct Q5 status. For program mode and single sector erase mode: means polling status with the program/page program address or sector address. For multi-sector erase mode and chip erase mode: The lowest and highest erased sector need to be provided for time-out check. If Q5=1 when do status polling check for one sector address, it means erase time out. - 3. During erase mode: Q2 is "don't care" after erase time out. Figure 24. TOGGLE BIT TIMING WAVEFORMS (DURING AUTOMATIC ALGORITHMS) Figure 25. TOGGLE BIT ALGORITHM #### Notes: - Read toggle bit twice to determine whether or not it is toggling. Recheck toggle bit because it may stop toggling as Q5 changes to "1". ## 17. PAGE READ OPERATION ### Figure 26. PAGE READ TIMING WAVEFORM ## 18. DEEP POWER DOWN MODE OPERATION Table 13. AC CHARACTERISTICS - Deep Power Down Mode | ITEM | | TYP | MAX | |-----------------------------------------------|------|-------|-------| | WEB high to release from deep power down mode | tRDP | 100us | 200us | | WEB high to deep power down mode | tDP | 10us | 20us | Figure 27. DEEP POWER DOWN MODE WAVEFORM ### 19. WRITE BUFFER PROGRAM OPERATION Figure 28. WRITE BUFFER PROGRAM FLOWCHART ### 20. RECOMMENDED OPERATING CONDITIONS ### At Device Power-Up AC timing illustrated in Figure 29 is recommended for the supply voltages and the control signals at device power-up (e.g. Vcc and CE# ramp up simultaneously). If the timing in the figure is ignored, the device may not operate correctly. Figure 29. AC Timing at Device Power-Up | Symbol | Parameter | Min. | Max. | Unit | |--------|------------------------|------|--------|------| | Tvr | Vcc Rise Time | 20 | 500000 | us/V | | Tr | Input Signal Rise Time | | 20 | us/V | | Tf | Input Signal Fall Time | | 20 | us/V | | Tvcs | Vcc Setup Time | 500 | | us | Note: Not 100% tested. ### 21. ERASE AND PROGRAMMING PERFORMANCE | PARAMETER | LIMITS | | | | |-----------------------------|---------|----------|----------|--------| | PARAIVIETER | MIN. | TYP. (1) | MAX. (2) | UNITS | | Chip Erase Time | | 512 | 1200 | sec | | Sector Erase Time | | 0.6 | 5 | sec | | Chip Programming Time | | 400 | 1400 | sec | | Word Program Time | | 11 | 360 | us | | Total Write Buffer Time | | 70 | | us | | ACC Total Write Buffer Time | | 70 | | us | | Erase/Program Cycles | 100,000 | | | Cycles | #### Notes: - 1. Typical program and erase times assume the following conditions: 25°C, 3.0V VCC. Programming specifications assume checkboard data pattern. - 2. Maximum values are measured at VCC = 3.0 V, worst case temperature. Maximum values are valid up to and including 100,000 program/erase cycles. - 3. Erase/Program cycles comply with JEDEC JESD-47 & JESD 22-A117 standard. - 4. Exclude 00h program before erase operation. ### 22. DATA RETENTION | PARAMETER | Condition | MIN. | MAX. | UNIT | |----------------|-----------|------|------|-------| | Data retention | 55°C | 20 | | years | ## 23. LATCH-UP CHARACTERISTICS | | MIN. | MAX. | |--------------------------------------------------------------------------------|--------|--------| | Input Voltage voltage difference with GND on WP#/ACC and A9 pins | -1.0V | 10.5V | | Input Voltage voltage difference with GND on all normal pins input | -1.0V | 1.5Vcc | | Vcc Current | -100mA | +100mA | | All pins included except Vcc. Test conditions: Vcc = 3.0V, one pin per testing | | | ### 24. PIN CAPACITANCE | Parameter Symbol | Parameter Description | Test Set | TYP. | MAX. | UNIT | |------------------|-------------------------|----------|------|------|------| | CIN2 | Control Pin Capacitance | VIN=0 | 15 | 70 | pF | | COUT | Output Capacitance | VOUT=0 | 17 | 24 | pF | | CIN | Input Capacitance | VIN=0 | 20 | 30 | pF | P/N:PM1727 REV. 0.00, NOV. 03, 2011 ## **25. ORDERING INFORMATION** | PART NO. | ACCESS TIME (ns) | PACKAGE | Remark | |--------------------|------------------|-------------|----------| | MX68GL1G0FHXFI-11G | 110 | 64 LFBGA | VI/O=VCC | | MX68GL1G0FLXFI-11G | 110 | 64 LFBGA | VI/O=VCC | | MX68GL1G0FHT2I-11G | 110 | 56 Pin TSOP | VI/O=VCC | | MX68GL1G0FLT2I-11G | 110 | 56 Pin TSOP | VI/O=VCC | ### **26. PART NAME DESCRIPTION** ## **27. PACKAGE INFORMATION** Doc. Title: Package Outline for TSOP(I) 56L (14X20mm) Dimensions (inch dimensions are derived from the original mm dimensions) | UNIT | MBOL | Α | A1 | <b>A</b> 2 | b | С | D | D1 | E | е | L | L1 | Θ | |------|------|-------|-------|------------|-------|-------|-------|-------|-------|-------|-------|-------|---| | | Min. | | 0.05 | 0.95 | 0.17 | 0.10 | 19.80 | 18.30 | 13.90 | | 0.50 | 0.70 | 0 | | mm | Nom. | | 0.10 | 1.00 | 0.20 | 0.13 | 20.00 | 18.40 | 14.00 | 0.50 | 0.60 | 0.80 | 5 | | | Max. | 1.20 | 0.15 | 1.05 | 0.27 | 0.21 | 20.20 | 18.50 | 14.10 | | 0.70 | 0.90 | 8 | | | Min. | | 0.002 | 0.037 | 0.007 | 0.004 | 0.780 | 0.720 | 0.547 | | 0.020 | 0.028 | 0 | | Inch | Nom. | | 0.004 | 0.039 | 0.008 | 0.005 | 0.787 | 0.724 | 0.551 | 0.020 | 0.024 | 0.031 | 5 | | | Max. | 0.047 | 0.006 | 0.041 | 0.011 | 0.008 | 0.795 | 0.728 | 0.555 | | 0.028 | 0.035 | 8 | | Dwg. No. | Revision | Reference | | | | | | |-----------|----------|-----------|------|--|--|--|--| | | | JEDEC | EIAJ | | | | | | 6110-1608 | 5 | MO-142 | | | | | | Doc. Title: Package Outline for CSP 64BALL(11X13X1.4MM,BALL PITCH 1.00MM,BALL DIAMETER 0.6MM) Dimensions (inch dimensions are derived from the original mm dimensions) | \ | /MBOL | Α | A1 | A2 | b | D | D1 | E | E1 | e | |------|---------------|-------|-------|-------|-------|-------|-------|-------|-------|-------| | UNIT | $\overline{}$ | | | | | | | | | | | | Min. | | 0.40 | 0.65 | 0.50 | 10.90 | | 12.90 | | | | mm | Nom. | | 0.50 | | 0.60 | 11.00 | 7.00 | 13.00 | 7.00 | 1.00 | | | Max. | 1.40 | 0.60 | 1 | 0.70 | 11.10 | | 13.10 | | | | | Min. | | 0.016 | 0.026 | 0.020 | 0.429 | | 0.508 | | | | Inch | Nom. | | 0.020 | | 0.024 | 0.433 | 0.276 | 0.512 | 0.276 | 0.039 | | | Max. | 0.055 | 0.024 | | 0.028 | 0.437 | | 0.516 | | | | Davis, No. | Davisian | Reference | | | | | | |------------|-------------------|-----------|------|--|--|--|--| | Dwg. No. | Owg. No. Revision | | EIAJ | | | | | | 6110-4247 | 1 | MO-192 | | | | | | 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. 2011. All rights reserved. Macronix, MXIC, MXIC Logo, MX Logo, Integrated Solutions Provider, NBit, NBit, 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.