# M29W640GH, M29W640GL M29W640GT, M29W640GB 64 Mbit (8Mb x8 or 4Mb x16, Page) 3V supply Flash memory ## Feature summary - Supply Voltage - V<sub>CC</sub> = 2.7V to 3.6V for Program, Erase, Read - V<sub>PP</sub> =12V for Fast Program (optional) - Asynchronous Random/Page Read - Page Width: 4 Words - Page Access: 25ns - Random Access: 60ns, 70ns - Fast Program commands - 2 Words/4 Bytes Program (without V<sub>PP</sub>=12V) - 4 Words/8 Bytes Program (with V<sub>PP</sub>=12V) - 16 Word/32 Byte Write Buffer - Programming time - 10 µs per Byte/Word typical - Chip Program time: 10s (using 4 Words Program) - Memory organization - M29W640GH/L: - 128 Main Blocks, 64 KBytes each - M29W640GT/B Eight 8 KBytes Boot Blocks (top or bottom location) - 127 Main Blocks, 64 KBytes each - Program/Erase controller - Embedded Byte/Word Program algorithms - Program/Erase Suspend and Resume - Read from any Block during Program Suspend - Read and Program another Block during Erase Suspend - Unlock Bypass Program command - Faster Production/Batch Programming - V<sub>PP</sub>/WP pin for Fast Program and Write Protect - Temporary Block Unprotection mode - Common Flash Interface - 64-bit Security Code - 128 Word Extended Memory Block - Extra block used as security block or to store additional information - Low power consumption - Standby and Automatic Standby - 100,000 Program/Erase cycles per block - ECOPACK<sup>®</sup> packages - Electronic Signature - Manufacturer Code: 0020h - Device code (see Table 1: Device codes) Table 1. Device codes | Root Part Number | Device code | |------------------------------------------------------------------|-----------------------| | M29W640GH: Uniform, Last Block protected by V <sub>PP</sub> /WP | 227Eh + 220Ch + 2201h | | M29W640GL: Uniform, First Block protected by V <sub>PP</sub> /WP | 227Eh + 220Ch + 2200h | | M29W640GT: Top Boot Blocks | 227Eh + 2210h + 2201h | | M29W640GB: Bottom Boot Blocks | 227Eh + 2210h + 2200h | ## **Contents** | 1 | Sum | nary description | |---|------|--------------------------------------------------| | 2 | Sign | ıl descriptions | | | 2.1 | Address Inputs (A0-A21) | | | 2.2 | Data Inputs/Outputs (DQ0-DQ7) | | | 2.3 | Data Inputs/Outputs (DQ8-DQ14) | | | 2.4 | Data Input/Output or Address Input (DQ15A-1) | | | 2.5 | Chip Enable (E) | | | 2.6 | Output Enable ( $\overline{G}$ ) | | | 2.7 | Write Enable (W) | | | 2.8 | $V_{PP}/W$ rite Protect $(V_{PP}/\overline{WP})$ | | | 2.9 | Reset/Block Temporary Unprotect (RP) | | | 2.10 | Ready/Busy Output (RB) | | | 2.11 | Byte/Word Organization Select (BYTE) 18 | | | 2.12 | V <sub>CC</sub> Supply Voltage | | | 2.13 | V <sub>SS</sub> Ground | | 3 | Bus | pperations | | | 3.1 | Bus Read 20 | | | 3.2 | Bus Write | | | 3.3 | Output Disable | | | 3.4 | Standby | | | 3.5 | Automatic Standby | | | 3.6 | Special Bus Operations | | | | 3.6.1 Electronic Signature | | | | 3.6.2 Block Protect and Chip Unprotect | | 4 | Com | nand Interface | | | 4.1 | Standard commands 24 | | | | 4.1.1 Read/Reset command | | | | 4.1.2 Auto Select command | | | | 4.1.3 Read CFI Query command | | | | 4.1.4 | Chip Erase command | . 25 | |---|-------|-----------|-----------------------------------------------------|------| | | | 4.1.5 | Block Erase command | . 26 | | | | 4.1.6 | Erase Suspend command | . 26 | | | | 4.1.7 | Erase Resume command | . 27 | | | | 4.1.8 | Program Suspend command | . 27 | | | | 4.1.9 | Program Resume command | . 27 | | | | 4.1.10 | Program command | . 28 | | | 4.2 | Fast Pro | ogram commands | . 29 | | | | 4.2.1 | Double Byte Program command | . 29 | | | | 4.2.2 | Quadruple Byte Program command | . 29 | | | | 4.2.3 | Octuple Byte Program command | . 30 | | | | 4.2.4 | Double Word Program command | . 30 | | | | 4.2.5 | Quadruple Word Program command | . 31 | | | | 4.2.6 | Unlock Bypass command | . 31 | | | | 4.2.7 | Unlock Bypass Program command | . 31 | | | | 4.2.8 | Unlock Bypass Reset command | . 32 | | | | 4.2.9 | Write to Buffer and Program command | . 32 | | | | 4.2.10 | Write to Buffer and Program Confirm command | . 33 | | | | 4.2.11 | Write to Buffer and Program Abort and Reset command | . 33 | | | 4.3 | Block P | rotection commands | . 33 | | | | 4.3.1 | Enter Extended Block command | . 33 | | | | 4.3.2 | Exit Extended Block command | . 33 | | | | 4.3.3 | Block Protect and Chip Unprotect commands | . 34 | | 5 | Statu | s Regis | ter | . 41 | | | 5.1 | Data Po | olling Bit (DQ7) | . 41 | | | 5.2 | Togale I | Bit (DQ6) | . 41 | | | 5.3 | | t (DQ5) | | | | 5.4 | | imer Bit (DQ3) | | | | 5.5 | | • | | | | | | ive Toggle Bit (DQ2) | | | | 5.6 | vvrite to | Buffer and Program Abort Bit (DQ1) | . 42 | | 6 | Maxir | num rat | ing | . 46 | | 7 | DC ar | nd AC p | arameters | . 47 | | 8 | Packa | age med | chanical | . 57 | | | | | | | | 9 | Par | t numbering | 61 | |------------|------|----------------------------------|----| | Appendix | Α | Block addresses | 62 | | Appendix | В | Common Flash Interface (CFI) | 75 | | Appendix | С | Extended Memory Block | 80 | | | C.1 | Factory Locked Extended Block | 80 | | | C.2 | Customer Lockable Extended Block | 80 | | Appendix | D | Block Protection | 82 | | | D.1 | Programmer Technique | 82 | | | D.2 | In-System Technique | 82 | | Appendix | Ε | Flowchart | 88 | | Pavision I | hiet | ory | ۵n | ## List of tables | Table 1. | Device codes | 2 | |-----------|---------------------------------------------------------------------------------|------| | Table 2. | Signal names | | | Table 3. | Protection granularity on the M29W640GH and M29W640GL | . 10 | | Table 4. | Protection granularity on the M29W640GT | . 10 | | Table 5. | Protection granularity on the M29W640GB | . 11 | | Table 6. | Hardware Protection | | | Table 7. | Bus Operations, BYTE = V <sub>IL</sub> | . 22 | | Table 8. | Bus Operations, BYTE = V <sub>IH</sub> | | | Table 9. | Read Electronic Signature addresses | . 23 | | Table 10. | Commands, 16-bit mode, BYTE = V <sub>IH</sub> | 35 | | Table 11. | Commands, 8-bit mode, BYTE = V <sub>II</sub> | 36 | | Table 12. | Program, Erase times and endurance cycles | . 37 | | Table 13. | Status Register bits | . 43 | | Table 14. | Absolute maximum ratings | . 46 | | Table 15. | Operating and AC measurement conditions | . 47 | | Table 16. | Device capacitance | . 48 | | Table 17. | DC characteristics | | | Table 18. | Read AC characteristics | . 50 | | Table 19. | Write AC characteristics | | | Table 20. | Reset/Block Temporary Unprotect AC Characteristics | . 54 | | Table 21. | Data polling and data toggle AC characteristics | | | Table 22. | TSOP48 – 48 lead Plastic Thin Small Outline, 12 x 20mm, package mechanical data | | | Table 23. | TSOP56 – 56 lead Plastic Thin Small Outline, 14 x 20mm, package mechanical data | . 58 | | Table 24. | TFBGA48 6x8mm - 6x8 active ball array, 0.8mm pitch, package mechanical data | | | Table 25. | TBGA64 10x13mm - 8x8 active ball array, 1mm pitch, package mechanical data | . 60 | | Table 26. | Ordering information scheme | | | Table 27. | M29W640GH and M29W640GL block addresses | | | Table 28. | Top boot block addresses, M29W640GT | | | Table 29. | Bottom boot block addresses, M29W640GB | | | Table 30. | Query structure overview | | | Table 31. | CFI query identification string | | | Table 32. | CFI query system interface information | . 76 | | Table 33. | Device geometry definition | | | Table 34. | Primary algorithm-specific extended query table | | | Table 35. | Security code area | | | Table 36. | Extended block address and data | . 81 | | Table 37. | Programmer technique bus operations, BYTE = V <sub>IH</sub> or V <sub>IL</sub> | 83 | | Table 38. | Document revision history | . 90 | # List of figures | Figure 1. | Logic diagram | 9 | |------------|----------------------------------------------------------------------------------|------| | Figure 2. | TSOP48 connections | | | Figure 3. | TSOP56 connections | | | Figure 4. | TFBGA48 connections (top view through package) | . 13 | | Figure 5. | TBGA64 connections (top view through package) | | | Figure 6. | Write Enable controlled Program waveforms (8-bit mode) | 38 | | Figure 7. | Chip Enable controlled Program waveforms (8-bit mode) | 39 | | Figure 8. | Chip/Block Erase waveforms (8-bit mode) | 40 | | Figure 9. | Data polling flowchart | 44 | | Figure 10. | Data toggle flowchart | 45 | | Figure 11. | AC measurement I/O waveform | 47 | | Figure 12. | AC measurement load circuit | | | Figure 13. | Read Mode AC waveforms (8-bit mode) | 49 | | Figure 14. | Page Read AC waveforms (8-bit mode) | 49 | | Figure 15. | Write AC waveforms, Write Enable Controlled (8-bit mode) | 51 | | Figure 16. | Write AC waveforms, Chip Enable Controlled (8-bit mode) | 52 | | Figure 17. | Reset/Block Temporary Unprotect AC waveforms | | | Figure 18. | Accelerated Program Timing waveforms | | | Figure 19. | Data Polling AC waveforms | | | Figure 20. | Toggle/alternative Toggle bit polling AC waveforms (8-bit mode) | | | Figure 21. | TSOP48 –48 lead Plastic Thin Small Outline, 12x20mm, top view package outline | | | Figure 22. | TSOP56 – 56 lead Plastic Thin Small Outline, 14 x 20mm, top view package outline | | | Figure 23. | TFBGA48 6x8mm - 6x8 active ball array, 0.8mm pitch, package outline | | | Figure 24. | TBGA64 10x13mm - 8x8 active ball array, 1mm pitch, package outline | | | Figure 25. | Programmer Equipment Group Protect flowchart | | | Figure 26. | Programmer Equipment Chip Unprotect flowchart | | | Figure 27. | In-System Equipment Group Protect flowchart | | | Figure 28. | In-System Equipment Chip Unprotect flowchart | | | Figure 29. | Write to Buffer and Program flowchart and pseudo code | . 88 | ## 1 Summary description The M29W640G is a 64 Mbit (8Mb x8 or 4Mb x16) non-volatile memory that can be read, erased and reprogrammed. These operations can be performed using a single low voltage (2.7 to 3.6V) supply. On power-up the memory defaults to its Read mode. The memory is divided into blocks that can be erased independently so it is possible to preserve valid data while old data is erased. Program and Erase commands are written to the Command Interface of the memory. An on-chip Program/Erase Controller simplifies the process of programming or erasing the memory by taking care of all of the special operations that are required to update the memory contents. The end of a program or erase operation can be detected and any error conditions identified. The command set required to control the memory is consistent with JEDEC standards. The M29W640GH and M29W640GL memory array is organized into 128 uniform Blocks of 64 KBytes each (or 32 KWords each). The M29W640GT and M29W640GB feature an asymmetric block architecture. The devices have an array of 135 blocks, divided into 8 Parameter Blocks of 8 KBytes each (or 4 KWords each), and 127 Main Blocks of 64 KBytes each (or 32 KWords each). The M29W640GT has the Parameter Blocks at the top of the memory address space while the M29W640GB locates the Parameter Blocks starting from the bottom. Blocks are protected by groups to prevent accidental Program or Erase commands from modifying the memory. - Table 3, describes the protection granularity on the M29W640GH and M29W640GL. - Table 4, and Table 5. describe the protection granularity on the M29W640GT and M29W640GB. The M29W640G support Asynchronous Random Read and Page Read from all blocks of the memory array. Chip Enable, Output Enable and Write Enable signals control the bus operation of the memory. They allow simple connection to most microprocessors, often without additional logic. The $V_{PP}/\overline{WP}$ signal is used to enable faster programming of the device. Protection from Program/Erase operation can be obtained by holding $V_{PP}/\overline{WP}$ to $V_{SS}$ : - On the M29W640GH and M29W640GL, the last and the first block is protected, respectively. - On the M29W640GT and M29W640GB, the first two and the last two boot blocks are protected. The devices feature a full set of Fast Program commands to improve the programming throughput: - 2 Byte Program: it is not necessary to raise V<sub>PP</sub>/WP to 12V before issuing this command - 2 Words/4 Bytes Program: it is not necessary to raise V<sub>PP</sub>/WP to 12V before issuing this command. - 4 Words/8 Bytes Program: V<sub>PP</sub>/WP must be raised to 12V before issuing this command. - Write to Buffer and Program, allowing to program in one shot a buffer of 16 Words/32 Bytes. The M29W640G has an extra block, the Extended Block, of 128 Words in x16 mode or of 256 Bytes in x8 mode that can be accessed using a dedicated command. The Extended Block can be protected and so is useful for storing security information. However the protection is not reversible, once protected the protection cannot be undone. The M29W640GT, M29W640GB, M29W640GH and M29W640GL, are offered in TSOP48 (12x 20mm), TSOP56 (14x 20mm), TFBGA48 (6 x8mm, 0.8mm pitch), and TBGA64 (10x 13mm, 1mm pitch) packages. In order to meet environmental requirements, ST offers the M29W640GH, M29W640GL, M29W640GT and M29W640GB in ECOPACK® packages. ECOPACK packages are Leadfree. The category of second Level Interconnect is marked on the package and on the inner box label, in compliance with JEDEC Standard JESD97. The maximum ratings related to soldering conditions are also marked on the inner box label. ECOPACK is an ST trademark. ECOPACK specifications are available at: www.st.com. The memory is delivered with all the bits erased (set to 1). Figure 1. Logic diagram Table 2. Signal names<sup>(1)</sup> | A0-A21 | Address Inputs | |---------------------|-------------------------------------------------------------| | DQ0-DQ7 | Data Inputs/Outputs | | DQ8-DQ14 | Data Inputs/Outputs | | DQ15A-1 (or DQ15) | Data Input/Output or Address Input (or Data Input/Output) | | Ē | Chip Enable | | G | Output Enable | | W | Write Enable | | RP | Reset/Block Temporary Unprotect | | RB | Ready/Busy Output | | BYTE | Byte/Word Organization Select | | V <sub>CC</sub> | Supply Voltage | | V <sub>PP</sub> /WP | Supply Voltage for Fast Program (optional) or Write Protect | | V <sub>SS</sub> | Ground | | NC | Not Connected Internally | <sup>1.</sup> $V_{PP}/\overline{WP}$ may be left floating since it is internally connected to an pull-up resistor to enable Program/Erase operations, Table 3. Protection granularity on the M29W640GH and M29W640GL | Block KBytes/KWords | | Protection Block Group | (x8) | (x16) | |---------------------|-----------|--------------------------------------------|--------------------------------|--------------------------------| | 0 to 3 | 4 x 64/32 | Block level | 000000h-03FFFFh <sup>(1)</sup> | 000000h-01FFFFh <sup>(1)</sup> | | 4 to 7 | 4 x 64/32 | Protection Group | 040000h-07FFFh | 020000h-03FFFFh | | | | | | | | 120 to 123 | 4 x 64/32 | 4 x 64/32 Protection Group 780000h–7BFFFFh | | 3C0000h-3DFFFFh | | 124 to 127 4x 64/32 | | Block level | 7C0000h-7FFFFFh 3E0000h- | | <sup>1.</sup> Used as the Extended Block Addresses in Extended Block mode. Table 4. Protection granularity on the M29W640GT | Block | KBytes/KWords | /KWords Protection Block Group ( | | (x16) | |----------------------------------|-----------------------------------------------------------|----------------------------------|--------------------------------|--------------------------------| | 0 to 3 | 4 x 64/32 Protection Group 000000h–03FFFFh <sup>(1)</sup> | | 000000h-03FFFFh <sup>(1)</sup> | 000000h-01FFFFh <sup>(1)</sup> | | 4 to 7 | 4 to 7 4 x 64/32 Protectio | | 040000h-07FFFh | 020000h-03FFFFh | | | | | | | | 120 to 123 | 4 x 64/32 | Protection Group | 780000h-7BFFFFh | 3C0000h-3DFFFFh | | 124 to 126 | 124 to 126 3 x 64/32 Prote | | 7C0000h-7EFFFFh | 3E0000h-3F7FFFh | | 127 to 134 8x 8/4 <sup>(2)</sup> | | Block level | 7F0000h-7FFFFFh | 3F8000h-3FFFFFh | <sup>1.</sup> Used as the Extended Block Addresses in Extended Block mode. <sup>2.</sup> Boot blocks. Table 5. Protection granularity on the M29W640GB | Block | KBytes/KWords Protection Block Group | | (x8) | (x16) | |----------------------|------------------------------------------|----------------------------------|--------------------------------|--------------------------------| | 0 to 7 | 0 to 7 8x 8/4 <sup>(1)</sup> Block level | | 000000h-00FFFFh <sup>(2)</sup> | 000000h-007FFFh <sup>(2)</sup> | | 8 to 10 | 3 x 64/32 | Protection Group | 010000h-03FFFFh | 008000h-01FFFFh | | 11 to 14 | 1 to 14 4 x 64/32 Protection Group 0 | | 040000h-07FFFFh | 020000h-03FFFFh | | | | | | | | 127 to 130 | 4 x 64/32 | Protection Group 780000h-7BFFFFh | | 3C0000h-3DFFFFh | | 131 to 134 4 x 64/32 | | Protection Group | 7C0000h-7FFFFh | 3E0000h-3FFFFh | <sup>1.</sup> Boot blocks. Figure 2. TSOP48 connections <sup>2.</sup> Used as the Extended Block Addresses in Extended Block mode. Figure 3. TSOP56 connections Figure 4. TFBGA48 connections (top view through package) TBGA64 connections (top view through package) Figure 5. 1. Pads D8 and F1 are not connected (NC) on the M29W640GT and M29W640GB devices. AI12719 ## 2 Signal descriptions See Figure 1: Logic diagram, and Table 2: Signal names, for a brief overview of the signals connected to the device. ## 2.1 Address Inputs (A0-A21) The Address Inputs select the cells in the memory array to access during Bus Read operations. During Bus Write operations they control the commands sent to the Command Interface of the Program/Erase Controller. ## 2.2 Data Inputs/Outputs (DQ0-DQ7) The Data I/O outputs the data stored at the selected address during a Bus Read operation. During Bus Write operations they represent the commands sent to the Command Interface of the Program/Erase Controller. ## 2.3 Data Inputs/Outputs (DQ8-DQ14) The Data I/O outputs the data stored at the selected address during a Bus Read operation when $\overline{\text{BYTE}}$ is High, V<sub>IH</sub>. When $\overline{\text{BYTE}}$ is Low, V<sub>IL</sub>, these pins are not used and are high impedance. During Bus Write operations the Command Register does not use these bits. When reading the Status Register these bits should be ignored. ## 2.4 Data Input/Output or Address Input (DQ15A-1) When $\overline{\text{BYTE}}$ is High, V<sub>IH</sub>, this pin behaves as a Data Input/Output pin (as DQ8-DQ14). When $\overline{\text{BYTE}}$ is Low, V<sub>IL</sub>, this pin behaves as an address pin; DQ15A–1 Low will select the LSB of the addressed Word, DQ15A–1 High will select the MSB. Throughout the text consider references to the Data Input/Output to include this pin when $\overline{\text{BYTE}}$ is High and references to the Address Inputs to include this pin when $\overline{\text{BYTE}}$ is Low except when stated explicitly otherwise. ## 2.5 Chip Enable $(\overline{E})$ The Chip Enable, $\overline{E}$ , activates the memory, allowing Bus Read and Bus Write operations to be performed. When Chip Enable is High, $V_{IH}$ , all other pins are ignored. ## 2.6 Output Enable (G) The Output Enable, $\overline{G}$ , controls the Bus Read operation of the memory. 5/ ## 2.7 Write Enable $(\overline{W})$ The Write Enable, $\overline{W}$ , controls the Bus Write operation of the memory's Command Interface. ## 2.8 V<sub>PP</sub>/Write Protect (V<sub>PP</sub>/WP) The $V_{PP}$ /Write Protect pin provides two functions. The $V_{PP}$ function allows the memory to use an external high voltage power supply to reduce the time required for Unlock Bypass Program operations. The Write Protect performs hardware protection: - It protects the first and last block on M29W640GH and M29W640GL devices. - It protects the first two and the last two boot blocks on M29W640GT and M29W640GB devices. The V<sub>PP</sub>/Write Protect pin may be left floating or unconnected (see *Table 17: DC characteristics*). When $V_{PP}$ /Write Protect is Low, $V_{IL}$ , the two outermost (M29W640GH and M29W640GL) or four outermost blocks (M29W640GT and M29W640GB) are protected. Program and Erase operations in this block are ignored while $V_{PP}$ /Write Protect is Low, even when $\overline{RP}$ is at $V_{ID}$ . When V<sub>PP</sub>/Write Protect is High, V<sub>IH</sub>, the memory reverts to the previous protection status of the outermost blocks. Program and Erase operations can now modify the data in the outermost blocks unless the block is protected using Block Protection. Applying 12V to the $V_{PP}/\overline{WP}$ pin will temporarily unprotect any block previously protected (including the outermost blocks) using a High Voltage Block Protection technique (In-System or Programmer technique). See *Table 6: Hardware Protection* for details. When $V_{PP}$ /Write Protect is raised to $V_{PP}$ the memory automatically enters the Unlock Bypass mode. When $V_{PP}$ /Write Protect returns to $V_{IH}$ or $V_{IL}$ normal operation resumes. During Unlock Bypass Program operations the memory draws $I_{PP}$ from the pin to supply the programming circuits. See the description of the Unlock Bypass command in the Command Interface section. The transitions from $V_{IH}$ to $V_{PP}$ and from $V_{PP}$ to $V_{IH}$ must be slower than $t_{VHVPP}$ see *Figure 18: Accelerated Program Timing waveforms*. Never raise $V_{PP}$ /Write Protect to $V_{PP}$ from any mode except Read mode, otherwise the memory may be left in an indeterminate state. A $0.1\mu F$ capacitor should be connected between the $V_{PP}/W$ rite Protect pin and the $V_{SS}$ Ground pin to decouple the current surges from the power supply. The PCB track widths must be sufficient to carry the currents required during Unlock Bypass Program, $I_{PP}$ Table 6. Hardware Protection | V <sub>PP</sub> /WP | RP | | Function | | | |------------------------------------|------------------------------------|-------------------------------|----------------------------------------------------------------------|--|--| | | M29W640G<br>and<br>M29W640G | | 4 outermost parameter blocks protected from Program/Erase operations | | | | V | V <sub>IH</sub> | M29W640GH<br>and<br>M29W640GL | 2 outermost blocks protected from Program/Erase operations | | | | V <sub>IL</sub> | V | M29W640GT<br>and<br>M29W640GB | All blocks temporarily unprotected except the 4 outermost blocks | | | | | V <sub>ID</sub> | M29W640GH<br>and<br>M29W640GL | All blocks temporarily unprotected except the 2 outermost blocks | | | | V <sub>IH</sub> or V <sub>ID</sub> | V <sub>ID</sub> | | All blocks temporarily unprotected | | | | $V_{PP}$ | V <sub>IH</sub> or V <sub>ID</sub> | | All blocks temporarily unprotected | | | **47/** ## 2.9 Reset/Block Temporary Unprotect (RP) The Reset/Block Temporary Unprotect pin can be used to apply a Hardware Reset to the memory or to temporarily unprotect all Blocks that have been protected. Note that if $V_{PP}/\overline{WP}$ is at $V_{IL}$ , then the two or four outermost blocks will remain protected even if RP is at $V_{ID}$ . A Hardware Reset is achieved by holding Reset/Block Temporary Unprotect Low, $V_{IL}$ , for at least $t_{PLPX}$ . After Reset/Block Temporary Unprotect goes High, $V_{IH}$ , the memory will be ready for Bus Read and Bus Write operations after $t_{PHEL}$ or $t_{RHEL}$ , whichever occurs last. See the Ready/Busy Output section, *Table 20: Reset/Block Temporary Unprotect AC Characteristics* and *Figure 17: Reset/Block Temporary Unprotect AC waveforms*, for more details Holding $\overline{RP}$ at $V_{ID}$ will temporarily unprotect the protected Blocks in the memory. Program and Erase operations on all blocks will be possible. The transition from $V_{IH}$ to $V_{ID}$ must be slower than $t_{PHPHH}$ . ## 2.10 Ready/Busy Output (RB) The Ready/Busy pin is an open-drain output that can be used to identify when the device is performing a Program or Erase operation. During Program or Erase operations Ready/Busy is Low, V<sub>OL</sub>. Ready/Busy is high-impedance during Read mode, Auto Select mode and Erase Suspend mode. After a Hardware Reset, Bus Read and Bus Write operations cannot begin until Ready/Busy becomes high-impedance. See *Table 20: Reset/Block Temporary Unprotect AC Characteristics* and *Figure 17: Reset/Block Temporary Unprotect AC waveforms*, for more details. The use of an open-drain output allows the Ready/Busy pins from several memories to be connected to a single pull-up resistor. A Low will then indicate that one, or more, of the memories is busy. ## 2.11 Byte/Word Organization Select (BYTE) The Byte/Word Organization Select pin is used to switch between the x8 and x16 Bus modes of the memory. When Byte/Word Organization Select is Low, $V_{IL}$ , the memory is in x8 mode, when it is High, $V_{IH}$ , the memory is in x16 mode. ## 2.12 V<sub>CC</sub> Supply Voltage V<sub>CC</sub> provides the power supply for all operations (Read, Program and Erase). The Command Interface is disabled when the $V_{CC}$ Supply Voltage is less than the Lockout Voltage, $V_{LKO}$ . This prevents Bus Write operations from accidentally damaging the data during power up, power down and power surges. If the Program/Erase Controller is programming or erasing during this time then the operation aborts and the memory contents being altered will be invalid. A 0.1 $\mu$ F capacitor should be connected between the V<sub>CC</sub> Supply Voltage pin and the V<sub>SS</sub> Ground pin to decouple the current surges from the power supply. The PCB track widths must be sufficient to carry the currents required during Program and Erase operations, I<sub>CC3</sub>. ## 2.13 V<sub>SS</sub> Ground $V_{SS}$ is the reference for all voltage measurements. The device features two $V_{SS}$ pins which must be both connected to the system ground. 5/ ## 3 Bus operations There are five standard bus operations that control the device. These are Bus Read, Bus Write, Output Disable, Standby and Automatic Standby. See *Table 7: Bus Operations, BYTE* = *VIL* and *Table 8: Bus Operations, BYTE* = *VIH*, for a summary. Typically glitches of less than 5ns on Chip Enable or Write Enable are ignored by the memory and do not affect bus operations. ### 3.1 Bus Read Bus Read operations read from the memory cells, or specific registers in the Command Interface. A valid Bus Read operation involves setting the desired address on the Address Inputs, applying a Low signal, V<sub>IL</sub>, to Chip Enable and Output Enable and keeping Write Enable High, V<sub>IH</sub>. The Data Inputs/Outputs will output the value, see *Figure 13: Read Mode AC waveforms (8-bit mode)*, and *Table 18: Read AC characteristics*, for details of when the output becomes valid. ### 3.2 Bus Write Bus Write operations write to the Command Interface. To speed up the read operation the memory array can be read in Page mode where data is internally read and stored in a page buffer. The Page has a size of 4 Words and is addressed by the address inputs A0-A1. A valid Bus Write operation begins by setting the desired address on the Address Inputs. The Address Inputs are latched by the Command Interface on the falling edge of Chip Enable or Write Enable, whichever occurs last. The Data Inputs/Outputs are latched by the Command Interface on the rising edge of Chip Enable or Write Enable, whichever occurs first. Output Enable must remain High, V<sub>IH</sub>, during the whole Bus Write operation. See *Figure 15: Write AC waveforms, Write Enable Controlled (8-bit mode)*, *Figure 16: Write AC waveforms, Chip Enable Controlled (8-bit mode)*, and *Table 19: Write AC characteristics* and *Table 19: Write AC characteristics*, for details of the timing requirements. ## 3.3 Output Disable The Data Inputs/Outputs are in the high impedance state when Output Enable is High, VIH. ## 3.4 Standby When Chip Enable is High, $V_{IH}$ , the memory enters Standby mode and the Data Inputs/Outputs pins are placed in the high-impedance state. To reduce the Supply Current to the Standby Supply Current, $I_{CC2}$ , Chip Enable should be held within $V_{CC} \pm 0.2V$ . For the Standby current level see *Table 17: DC characteristics*. During program or erase operations the memory will continue to use the Program/Erase Supply Current, $I_{CC3}$ , for Program or Erase operations until the operation completes. ## 3.5 Automatic Standby If CMOS levels ( $V_{CC} \pm 0.2V$ ) are used to drive the bus and the bus is inactive for 300ns or more the memory enters Automatic Standby where the internal Supply Current is reduced to the Standby Supply Current, $I_{CC2}$ . The Data Inputs/Outputs will still output data if a Bus Read operation is in progress. ## 3.6 Special Bus Operations Additional bus operations can be performed to read the Electronic Signature and also to apply and remove Block Protection. These bus operations are intended for use by programming equipment and are not usually used in applications. They require $V_{\text{ID}}$ to be applied to some pins. ## 3.6.1 Electronic Signature The memory has two codes, the manufacturer code and the device code, that can be read to identify the memory. These codes can be read by applying the signals listed in *Table 7:* Bus Operations, BYTE = VIL and Table 8: Bus Operations, BYTE = VIH, with A9 set to V<sub>ID</sub>. ### 3.6.2 Block Protect and Chip Unprotect Groups of blocks can be protected against accidental Program or Erase. The Protection Groups are shown in *Appendix A: Block addresses Table 28* and *Table 29*. The whole chip can be unprotected to allow the data inside the blocks to be changed. The $V_{PP}$ /Write Protect pin can be used to protect the two outermost blocks on the M29W640GH and M29W640GL, and the four outermost blocks on the M29W640GT and M29W640GB. When $V_{PP}$ /Write Protect is at $V_{IL}$ the outermost blocks are protected and remain protected regardless of the Block Protection Status or the Reset/Block Temporary Unprotect pin status. Block Protect and Chip Unprotect operations are described in : Revision history. Table 7. Bus Operations, $\overline{\text{BYTE}} = V_{\text{IL}}$ (1) | | Ē | G | w | Address Inputs<br>DQ15A–1, A0-A21 | Data Inputs/Outputs | | | | | | |---------------------------------|-----------------|-----------------|---------------------------------|-----------------------------------|---------------------|--------------------------------------|---------------------------------------------------|------|---------------------------------------|----------------------------------------------------| | Operation | | | | | DQ14-<br>DQ8 | Г | DQ7-DQ0 | | | | | Bus Read | $V_{IL}$ | $V_{IL}$ | $V_{IH}$ | Cell Address | Hi-Z | Da | ata Output | | | | | Bus Write | $V_{IL}$ | $V_{IH}$ | $V_{IL}$ | Command Address | Hi-Z | Г | Data Input | | | | | Output Disable | Χ | $V_{IH}$ | $V_{IH}$ | X | Hi-Z | | Hi-Z | | | | | Standby | $V_{IH}$ | Χ | Х | Х | Hi-Z | | Hi-Z | | | | | Read Manufacturer<br>Code | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | | Hi-Z | 20h | | | | | | Read Device Code (cycle 1) | | | | | | | 7Eh | | | | | Read Device Code | V <sub>IL</sub> | | V <sub>IH</sub> | ′ін<br>Table 9 | Hi-Z | M29W640GH,<br>M29W640GL | 0Ch | | | | | (cycle 2) | | V <sub>IL</sub> | | | | M29W640GT,<br>M29W640GB | 10h | | | | | Read Device Code | | | | | | M29W640GH,<br>M29W640GT | 01h | | | | | (cycle 3) | | | | | | M29W640GL,<br>M29W640GB | 00h | | | | | Read Extended<br>Memory Block | V <sub>IL</sub> | ., | ,, | | ., | \ <u>'</u> | | Hi-Z | M29W640GL,<br>M29W640GT,<br>M29W640GB | 88h (Factory locked)<br>08h (Customer<br>Lockable) | | Verify Code | | V <sub>IL</sub> | / <sub>IL</sub> V <sub>IH</sub> | | ΠI- <b>∠</b> | M29W640GH | 98h(Factory Locked)<br>18h (Customer<br>Lockable) | | | | | Read Block<br>Protection Status | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | | Hi-Z | 01h (protected)<br>00h (unprotected) | | | | | <sup>1.</sup> $X = V_{IL}$ or $V_{IH}$ . Table 8. Bus Operations, $\overline{\text{BYTE}} = V_{\text{IH}}^{(1)}$ | Operation | Operation E G W Address Inputs Data Inputs/Outputs | | | | | | | | | | |---------------------------------|----------------------------------------------------|-----------------|---------------------------------------|--------------------------------------------------------|------------------------------------------|-------------------------------------------------------|--|--|--|--| | Operation | | G | VV | A0-A21 | DQ15A-1, DQ14-DQ0 | | | | | | | Bus Read | $V_{IL}$ | $V_{IL}$ | $V_{IH}$ | Cell Address | Data Output | | | | | | | Bus Write | $V_{IL}$ | $V_{IH}$ | $V_{IL}$ | Command Address | | Data Input | | | | | | Output Disable | Х | $V_{IH}$ | $V_{IH}$ | X | Hi-Z | | | | | | | Standby | $V_{IH}$ | Х | Χ | X | Hi-Z | | | | | | | Read Manufacturer<br>Code | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | | | 0020h | | | | | | Read Device Code (cycle 1) | | | | | 227Eh | | | | | | | Read Device Code | | | | | M29W640GH,<br>M29W640GL | 220Ch | | | | | | (cycle 2) | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | | M29W640GT,<br>M29W640GB | 2210h | | | | | | Read Device Code | | | | Table 9 | M29W640GH,<br>M29W640GT | 2201h | | | | | | (cycle 3) | | | | Table 9 | M29W640GL,<br>M29W640GB | 2200h | | | | | | Read Extended<br>Memory Block | | | M29W640GL,<br>M29W640GT,<br>M29W640GB | 2288h (Factory locked)<br>2208h (Customer<br>Lockable) | | | | | | | | Verify Code | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | | M29W640GH | 2298h(Factory Locked)<br>2218h (Customer<br>Lockable) | | | | | | Read Block<br>Protection Status | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | | 0001h (protected)<br>0000h (unprotected) | | | | | | <sup>1.</sup> $X = V_{IL}$ or $V_{IH}$ . Table 9. Read Electronic Signature addresses<sup>(1)</sup> | Table 61 Read Electric elginataris additioned | | | | | | | | | | | | |-----------------------------------------------|------------------------------|------------------------------------------|--|--|--|--|--|--|--|--|--| | Code | A7-A0 BYTE = V <sub>IH</sub> | A6-A0, DQ15A-1<br>BYTE = V <sub>IL</sub> | | | | | | | | | | | Manufacturer Code | 00h | 00h | | | | | | | | | | | Device Code (cycle 1) | 01h | 02h | | | | | | | | | | | Device Code (cycle 2) | 0Eh | 1Ch | | | | | | | | | | | Device Code (cycle 3) | 0Fh | 1Eh | | | | | | | | | | | Extended Memory Block Verify Code | 03h | 06h | | | | | | | | | | | Block Protection Status | 02h <sup>(2)</sup> | 04h <sup>(2)</sup> | | | | | | | | | | <sup>1.</sup> A9 = $V_{ID}$ ; other address bits set to $V_{IL}$ or $V_{IH}$ . <sup>2.</sup> A12- A21 must be set to the block address. ## 4 Command Interface All Bus Write operations to the memory are interpreted by the Command Interface. Commands consist of one or more sequential Bus Write operations. Failure to observe a valid sequence of Bus Write operations will result in the memory returning to Read mode. The long command sequences are imposed to maximize data security. The address used for the commands changes depending on whether the memory is in 16-bit or 8-bit mode. See either *Table 10*, or *Table 11*, depending on the configuration that is being used, for a summary of the commands. ### 4.1 Standard commands #### 4.1.1 Read/Reset command The Read/Reset command returns the memory to its Read mode. It also resets the errors in the Status Register. Either one or three Bus Write operations can be used to issue the Read/Reset command. The Read/Reset command can be issued, between Bus Write cycles before the start of a program or erase operation, to return the device to read mode. If the Read/Reset command is issued during the timeout of a Block Erase operation then the memory will take up to 10µs to abort. During the abort period no valid data can be read from the memory. The Read/Reset command will not abort an Erase operation when issued while in Erase Suspend. #### 4.1.2 Auto Select command The Auto Select command is used to read the Manufacturer Code, the Device Code, the Block Protection Status and the Extended Memory Block Verify Code. Three consecutive Bus Write operations are required to issue the Auto Select command. Once the Auto Select command is issued the memory remains in Auto Select mode until a Read/Reset command is issued. Read CFI Query and Read/Reset commands are accepted in Auto Select mode, all other commands are ignored. In Auto Select mode, the Manufacturer Code and the Device Code can be read by using a Bus Read operation with addresses and control signals set as shown in *Table 7: Bus Operations, BYTE = VIL* and *Table 8: Bus Operations, BYTE = VIH*, except for A9 that is 'Don't Care'. The Block Protection Status of each block can be read using a Bus Read operation with addresses and control signals set as shown in *Table 7: Bus Operations, BYTE = VIL* and *Table 8: Bus Operations, BYTE = VIH*, except for A9 that is 'Don't Care'. If the addressed block is protected then 01h is output on Data Inputs/Outputs DQ0-DQ7, otherwise 00h is output (in 8-bit mode). The protection status of the Extended Memory block, or Extended Memory Block Verify code, can be read using a Bus Read operation with addresses and control signals set as shown in *Table 7: Bus Operations, BYTE = VIL* and *Table 8: Bus Operations, BYTE = VIH*, except for A9 that is 'Don't Care'. If the Extended Block is "Factory Locked" then 80h is output on Data Input/Outputs DQ0-DQ7, otherwise 00h is output (8-bit mode). ### 4.1.3 Read CFI Query command The Read CFI Query Command is used to read data from the Common Flash Interface (CFI) Memory Area. This command is valid when the device is in the Read Array mode, or when the device is in Autoselected mode. One Bus Write cycle is required to issue the Read CFI Query Command. Once the command is issued subsequent Bus Read operations read from the Common Flash Interface Memory Area. The Read/Reset command must be issued to return the device to the previous mode (the Read Array mode or Autoselected mode). A second Read/Reset command would be needed if the device is to be put in the Read Array mode from Autoselected mode. See *Appendix B: Common Flash Interface (CFI)*, Tables 30, 31, 32, 33, 34 and 35 for details on the information contained in the Common Flash Interface (CFI) memory area. ## 4.1.4 Chip Erase command The Chip Erase command can be used to erase the entire chip. Six Bus Write operations are required to issue the Chip Erase Command and start the Program/Erase Controller. If any blocks are protected then these are ignored and all the other blocks are erased. If all of the blocks are protected the Chip Erase operation appears to start but will terminate within about 100µs, leaving the data unchanged. No error condition is given when protected blocks are ignored. During the erase operation the memory will ignore all commands, including the Erase Suspend command. It is not possible to issue any command to abort the operation. Typical chip erase times are given in *Table 12: Program, Erase times and endurance cycles*. All Bus Read operations during the Chip Erase operation will output the Status Register on the Data Inputs/Outputs. See the section on the Status Register for more details. After the Chip Erase operation has completed the memory will return to the Read Mode, unless an error has occurred. When an error occurs the memory will continue to output the Status Register. A Read/Reset command must be issued to reset the error condition and return to Read Mode. The Chip Erase Command sets all of the bits in unprotected blocks of the memory to '1'. All previous data is lost. Refer to Figure 8: Chip/Block Erase waveforms (8-bit mode) for a description of Chip Erase AC waveforms. 5/ #### 4.1.5 Block Erase command The Block Erase command can be used to erase a list of one or more blocks. Six Bus Write operations are required to select the first block in the list. Each additional block in the list can be selected by repeating the sixth Bus Write operation using the address of the additional block. The Block Erase operation starts the Program/Erase Controller about 50µs after the last Bus Write operation. Once the Program/Erase Controller starts it is not possible to select any more blocks. Each additional block must therefore be selected within 50µs of the last block. The 50µs timer restarts when an additional block is selected. The Status Register can be read after the sixth Bus Write operation. See the Status Register section for details on how to identify if the Program/Erase Controller has started the Block Erase operation. If any selected blocks are protected then these are ignored and all the other selected blocks are erased. If all of the selected blocks are protected the Block Erase operation appears to start but will terminate within about 100µs, leaving the data unchanged. No error condition is given when protected blocks are ignored. During the Block Erase operation the memory will ignore all commands except the Erase Suspend command. Typical block erase times are given in *Table 12: Program, Erase times and endurance cycles*. All Bus Read operations during the Block Erase operation will output the Status Register on the Data Inputs/Outputs. See the section on the Status Register for more details. After the Block Erase operation has completed the memory will return to the Read Mode, unless an error has occurred. When an error occurs the memory will continue to output the Status Register. A Read/Reset command must be issued to reset the error condition and return to Read mode. The Block Erase Command sets all of the bits in the unprotected selected blocks to '1'. All previous data in the selected blocks is lost. Refer to Figure 8: Chip/Block Erase waveforms (8-bit mode) for a description of Block Erase AC waveforms. ### 4.1.6 Erase Suspend command The Erase Suspend Command may be used to temporarily suspend a Block Erase operation and return the memory to Read mode. The command requires one Bus Write operation. The Program/Erase Controller will suspend within the Erase Suspend Latency time of the Erase Suspend Command being issued. Once the Program/Erase Controller has stopped the memory will be set to Read mode and the Erase will be suspended. If the Erase Suspend command is issued during the period when the memory is waiting for an additional block (before the Program/Erase Controller starts) then the Erase is suspended immediately and will start immediately when the Erase Resume Command is issued. It is not possible to select any further blocks to erase after the Erase Resume. During Erase Suspend it is possible to Read and Program cells in blocks that are not being erased; both Read and Program operations behave as normal on these blocks. If any attempt is made to program in a protected block or in the suspended block then the Program command is ignored and the data remains unchanged. The Status Register is not read and no error condition is given. Reading from blocks that are being erased will output the Status Register. It is also possible to issue the Auto Select, Read CFI Query and Unlock Bypass commands during an Erase Suspend. The Read/Reset command must be issued to return the device to Read Array mode before the Resume command will be accepted. #### 4.1.7 Erase Resume command The Erase Resume command must be used to restart the Program/Erase Controller after an Erase Suspend. The device must be in Read Array mode before the Resume command will be accepted. An erase can be suspended and resumed more than once. ### 4.1.8 Program Suspend command The Program Suspend command allows the system to interrupt a program operation so that data can be read from any block. When the Program Suspend command is issued during a program operation, the device suspends the program operation within the Program Suspend Latency time (see *Table 12: Program, Erase times and endurance cycles* for value) and updates the Status Register bits. After the program operation has been suspended, the system can read array data from any address. However, data read from Program-Suspended addresses is not valid. The Program Suspend command may also be issued during a program operation while an erase is suspended. In this case, data may be read from any addresses not in Erase Suspend or Program Suspend. If a read is needed from the Extended Block area (One-time Program area), the user must use the proper command sequences to enter and exit this region. The system may also issue the Auto Select command sequence when the device is in the Program Suspend mode. The system can read as many Auto Select codes as required. When the device exits the Auto Select mode, the device reverts to the Program Suspend mode, and is ready for another valid operation. See Auto Select command sequence for more information. ### 4.1.9 Program Resume command After the Program Resume command is issued, the device reverts to programming. The controller can determine the status of the program operation using the DQ7 or DQ6 status bits, just as in the standard program operation. See Write Operation Status for more information. The system must write the Program Resume command, to exit the Program Suspend mode and to continue the programming operation. Further issuing of the Resume command is ignored. Another Program Suspend command can be written after the device has resumed programming. ## 4.1.10 Program command The Program command can be used to program a value to one address in the memory array at a time. The command requires four Bus Write operations, the final write operation latches the address and data, and starts the Program/Erase Controller. Programming can be suspended and then resumed by issuing a Program Suspend command and a Program Resume command, respectively (see Section 4.1.8: Program Suspend command and Section 4.1.9: Program Resume command). If the address falls in a protected block then the Program command is ignored, the data remains unchanged. The Status Register is never read and no error condition is given. During the program operation the memory will ignore all commands. It is not possible to issue any command to abort or pause the operation. Typical program times are given in *Table 12: Program, Erase times and endurance cycles*. Bus Read operations during the program operation will output the Status Register on the Data Inputs/Outputs. See the section on the Status Register for more details. After the program operation has completed the memory will return to the Read mode, unless an error has occurred. When an error occurs the memory will continue to output the Status Register. A Read/Reset command must be issued to reset the error condition and return to Read mode. Note that the Program command cannot change a bit set at '0' back to '1'. One of the Erase Commands must be used to set all the bits in a block or in the whole memory from '0' to '1'. Refer to Figure 6: Write Enable controlled Program waveforms (8-bit mode) and Figure 7: Chip Enable controlled Program waveforms (8-bit mode) for a description of Program AC waveforms. ## 4.2 Fast Program commands There are five Fast Program commands available to improve the programming throughput, by writing several adjacent words or bytes in parallel: - Quadruple and Octuple Byte Program, available for x8 operations - Double and Quadruple Word Program, available for x16 operations - Write to Buffer and Program Fast Program commands can be suspended and then resumed by issuing a Program Suspend command and a Program Resume command, respectively (see Section 4.1.8: Program Suspend command and Section 4.1.9: Program Resume command). ### 4.2.1 Double Byte Program command The Double Byte Program command is used to write a page of two adjacent Bytes in parallel. The two bytes must differ only in DQ15A-1. Three bus write cycles are necessary to issue the Double Byte Program command. - 1. The first bus cycle sets up the Double Byte Program Command. - 2. The second bus cycle latches the Address and the Data of the first byte to be written. - 3. The third bus cycle latches the Address and the Data of the second byte to be written. Note: It is not necessary to raise $V_{PP}/\overline{WP}$ to 12V before issuing this command. ## 4.2.2 Quadruple Byte Program command The Quadruple Byte Program command is used to write a page of four adjacent Bytes in parallel. The four bytes must differ only for addresses A0, DQ15A-1. Five bus write cycles are necessary to issue the Quadruple Byte Program command: - The first bus cycle sets up the Quadruple Byte Program Command. - 2. The second bus cycle latches the Address and the Data of the first byte to be written. - 3. The third bus cycle latches the Address and the Data of the second byte to be written. - 4. The fourth bus cycle latches the Address and the Data of the third byte to be written. - 5. The fifth bus cycle latches the Address and the Data of the fourth byte to be written and starts the Program/Erase Controller. Note: It is not necessary to raise $V_{PP}/\overline{WP}$ to 12V before issuing this command. **/** ## 4.2.3 Octuple Byte Program command This is used to write eight adjacent Bytes, in x8 mode, simultaneously. The addresses of the eight Bytes must differ only in A1, A0 and DQ15A-1. 12V must be applied to the $V_{PP}$ /Write Protect pin, $V_{PP}$ /WP, prior to issuing an Octuple Byte Program command. Care must be taken because applying a 12V voltage to the $V_{PP}$ /WP pin will temporarily unprotect any protected block. Nine bus write cycles are necessary to issue the command: - The first bus cycle sets up the command. - 2. The second bus cycle latches the Address and the Data of the first Byte to be written. - 3. The third bus cycle latches the Address and the Data of the second Byte to be written. - 4. The fourth bus cycle latches the Address and the Data of the third Byte to be written. - 5. The fifth bus cycle latches the Address and the Data of the fourth Byte to be written. - 6. The sixth bus cycle latches the Address and the Data of the fifth Byte to be written. - 7. The seventh bus cycle latches the Address and the Data of the sixth Byte to be written. - The eighth bus cycle latches the Address and the Data of the seventh Byte to be written. - 9. The ninth bus cycle latches the Address and the Data of the eighth Byte to be written and starts the Program/Erase Controller. ## 4.2.4 Double Word Program command The Double Word Program command is used to write a page of two adjacent Words in parallel. The two Words must differ only for the address A0. Three bus write cycles are necessary to issue the Double Word Program command. - The first bus cycle sets up the Double Word Program Command. - The second bus cycle latches the Address and the Data of the first Word to be written. - The third bus cycle latches the Address and the Data of the second Word to be written and starts the Program/Erase Controller. After the program operation has completed the memory will return to the Read mode, unless an error has occurred. When an error occurs Bus Read operations will continue to output the Status Register. A Read/Reset command must be issued to reset the error condition and return to Read mode. Note that the Fast Program commands cannot change a bit set at '0' back to '1'. One of the Erase Commands must be used to set all the bits in a block or in the whole memory from '0' to '1'. Typical Program times are given in Table 12: Program, Erase times and endurance cycles. Note: It is not necessary to raise $V_{PP}/\overline{WP}$ to 12V before issuing this command. 5/ ## 4.2.5 Quadruple Word Program command This is used to write a page of four adjacent Words (or 8 adjacent Bytes), in x16 mode, simultaneously. The addresses of the four Words must differ only in A1 and A0. 12V must be applied to the $V_{PP}/W$ rite Protect pin, $V_{PP}/\overline{WP}$ , prior to issuing a Quadruple Byte Program command. Care must be taken because applying a 12V voltage to the $V_{PP}/\overline{WP}$ pin will temporarily unprotect any protected block. Five bus write cycles are necessary to issue the command: - The first bus cycle sets up the command. - The second bus cycle latches the Address and the Data of the first Word to be written. - The third bus cycle latches the Address and the Data of the second Word to be written. - The fourth bus cycle latches the Address and the Data of the third Word to be written. - The fifth bus cycle latches the Address and the Data of the fourth Word to be written and starts the Program/Erase Controller. ## 4.2.6 Unlock Bypass command The Unlock Bypass command is used in conjunction with the Unlock Bypass Program command to program the memory faster than with the standard program commands. When the cycle time to the device is long, considerable time saving can be made by using these commands. Three Bus Write operations are required to issue the Unlock Bypass command. Once the Unlock Bypass command has been issued the memory will only accept the Unlock Bypass Program command and the Unlock Bypass Reset command. The memory can be read as if in Read mode. When $V_{PP}$ is applied to the $V_{PP}$ /Write Protect pin the memory automatically enters the Unlock Bypass mode and the Unlock Bypass Program command can be issued immediately. ### 4.2.7 Unlock Bypass Program command The Unlock Bypass command is used in conjunction with the Unlock Bypass Program command to program the memory. When the cycle time to the device is long, considerable time saving can be made by using these commands. Three Bus Write operations are required to issue the Unlock Bypass command. Once the Unlock Bypass command has been issued the memory will only accept the Unlock Bypass Program command and the Unlock Bypass Reset command. The memory can be read as if in Read mode. The memory offers accelerated program operations through the $V_{PP}$ /Write Protect pin. When the system asserts $V_{PP}$ on the $V_{PP}$ /Write Protect pin, the memory automatically enters the Unlock Bypass mode. The system may then write the two-cycle Unlock Bypass program command sequence. The memory uses the higher voltage on the $V_{PP}$ /Write Protect pin, to accelerate the Unlock Bypass Program operation. Never raise $V_{PP}$ /Write Protect to $V_{PP}$ from any mode except Read mode, otherwise the memory may be left in an indeterminate state. ## 4.2.8 Unlock Bypass Reset command The Unlock Bypass Reset command can be used to return to Read/Reset mode from Unlock Bypass Mode. Two Bus Write operations are required to issue the Unlock Bypass Reset command. Read/Reset command does not exit from Unlock Bypass Mode. ### 4.2.9 Write to Buffer and Program command The Write to Buffer and Program command makes use of the device's 32-Byte Write Buffer to speed up programming. 16 Words/32 Bytes can be loaded into the Write Buffer. Each Write Buffer has the same A4-A22 addresses. The Write to Buffer and Program command dramatically reduces system programming time compared to the standard non-buffered Program command. When issuing a Write to Buffer and Program command, the $V_{PP}/\overline{WP}$ pin can be either held High, $V_{IH}$ or raised to $V_{PPH}$ . See Table 12 for details on typical Write to Buffer and Program times in both cases. Five successive steps are required to issue the Write to Buffer and Program command: - The Write to Buffer and Program command starts with two unlock cycles. - 2. The third Bus Write cycle sets up the Write to Buffer and Program command. The setup code can be addressed to any location within the targeted block. - 3. The fourth Bus Write cycle sets up the number of Words to be programmed. Value n is written to the same block address, where n+1 is the number of Words to be programmed. n+1 must not exceed the size of the Write Buffer or the operation will abort. - 4. The fifth cycle loads the first address and data to be programmed. - 5. Use n Bus Write cycles to load the address and data for each Word into the Write Buffer. Addresses must lie within the range from the start address+1 to the start address + n-1. Optimum performance is obtained when the start address corresponds to a 64 Byte boundary. If the start address is not aligned to a 64 Byte boundary, the total programming time is doubled. All the addresses used in the Write to Buffer and Program operation must lie within the same page. If an address is written several times during a Write to Buffer and Program operation, the address/data counter will be decremented at each data load operation and the data will be programmed to the last word loaded into the Buffer. Invalid address combinations or failing to follow the correct sequence of Bus Write cycles will abort the Write to Buffer and Program. The Status Register bits DQ1, DQ5, DQ6, DQ7 can be used to monitor the device status during a Write to Buffer and Program operation. It is possible to detect Program operation fails when changing programmed data from '0' to '1', that is when reprogramming data in a portion of memory already programmed. The resulting data will be the logical OR between the previous value and the current value. To program the content of the Write Buffer, this command must be followed by a Write to Buffer and Program Confirm command. A Write to Buffer and Program Abort and Reset command must be issued to abort the Write to Buffer and Program operation and reset the device in Read mode. The Write Buffer Programming Sequence can be aborted in the following ways: - Load a value that is greater than the page buffer size during the Number of Locations to Program step. - Write to an address in a block different than the one specified during the Write-Buffer-Load command. - Write an Address/Data pair to a different write-buffer-page than the one selected by the Starting Address during the write buffer data loading stage of the operation. - Write data other than the Confirm Command after the specified number of data load cycles. The abort condition is indicated by DQ1 = 1, DQ7 = DATA# (for the last address location loaded), DQ6 = toggle, and DQ5=0. A Write-to-Buffer-Abort Reset command sequence must be written to reset the device for the next operation. Note that the full 3-cycle Write-to-Buffer-Abort Reset command sequence is required when using Write-Buffer-Programming features in Unlock Bypass mode. See Appendix E: Flowchart, Figure 29: Write to Buffer and Program flowchart and pseudo code, for a suggested flowchart on using the Write to Buffer and Program command. ### 4.2.10 Write to Buffer and Program Confirm command The Write to Buffer and Program Confirm command is used to confirm a Write to Buffer and Program command and to program the n+1 Words loaded in the Write Buffer by this command. ## 4.2.11 Write to Buffer and Program Abort and Reset command The Write to Buffer and Program Abort and Reset command is used to reset the device after a Write to Buffer and Program command has been aborted. ### 4.3 Block Protection commands #### 4.3.1 Enter Extended Block command The device has an extra 256 Byte block (Extended Block) that can only be accessed using the Enter Extended Block command. Three Bus write cycles are required to issue the Extended Block command. Once the command has been issued the device enters Extended Block mode where all Bus Read or Write operations to the Boot Block addresses access the Extended Block. The Extended Block (with the same address as the Boot Blocks) cannot be erased, and can be treated as one-time programmable (OTP) memory. In Extended Block mode the Boot Blocks are not accessible. To exit from the Extended Block mode the Exit Extended Block command must be issued. The Extended Block can be protected, however once protected the protection cannot be undone. #### 4.3.2 Exit Extended Block command The Exit Extended Block command is used to exit from the Extended Block mode and return the device to Read mode. Four Bus Write operations are required to issue the command. ## 4.3.3 Block Protect and Chip Unprotect commands Groups of blocks can be protected against accidental Program or Erase. The Protection Groups are shown in *Appendix A: Block addresses*, *Table 28: Top boot block addresses*, *M29W640GT* and *Table 29: Bottom boot block addresses*, *M29W640GB*. The whole chip can be unprotected to allow the data inside the blocks to be changed. Block Protect and Chip Unprotect operations are described in : Revision history. Table 10. Commands, 16-bit mode, $\overline{\text{BYTE}} = V_{\text{IH}}^{(1)}$ | Table 10. Comma | Bus Write Operations | | | | | | | | | | | | | | |---------------------------------------------------|----------------------|-------------------|------|------|------|------|---------|---------|------------------|-------------------|------|------------|------|--| | | ے | | | | | Bus | Write ( | Operati | ons | | | | | | | Command | Length | 1st | | 2nd | | 3rd | | 41 | h | 51 | th | 6th | | | | | د | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | | | Read/Reset | 1 | Χ | F0 | | | | | | | | | | | | | Reau/Reset | 3 | 555 | AA | 2AA | 55 | Х | F0 | | | | | | | | | Auto Select | 3 | 555 | AA | 2AA | 55 | 555 | 90 | | | | | | | | | Program | 4 | 555 | AA | 2AA | 55 | 555 | A0 | PA | PD | | | | | | | Double Word<br>Program | 3 | 555 | 50 | PA0 | PD0 | PA1 | PD1 | | | | | | | | | Quadruple Word<br>Program | 5 | 555 | 56 | PA0 | PD0 | PA1 | PD1 | PA2 | PD2 | PA3 | PD3 | | | | | Unlock Bypass | 3 | 555 | AA | 2AA | 55 | 555 | 20 | | | | | | | | | Unlock Bypass<br>Program | 2 | Х | A0 | PA | PD | | | | | | | | | | | Unlock Bypass Reset | 2 | Χ | 90 | Х | 00 | | | | | | | | | | | Write to Buffer and Program | N+5 | 555 | AA | 2AA | 55 | ВА | 25 | ВА | N <sup>(2)</sup> | PA <sup>(3)</sup> | PD | WBL<br>(4) | PD | | | Write to Buffer and<br>Program Abort and<br>Reset | 3 | 555 | AA | 2AA | 55 | 555 | F0 | | | | | | | | | Write to Buffer and Program Confirm | 1 | BA <sup>(5)</sup> | 29 | | | | | | | | | | | | | Chip Erase | 6 | 555 | AA | 2AA | 55 | 555 | 80 | 555 | AA | 2AA | 55 | 555 | 10 | | | Block Erase | 6+ | 555 | AA | 2AA | 55 | 555 | 80 | 555 | AA | 2AA | 55 | ВА | 30 | | | Program/Erase<br>Suspend | 1 | Х | В0 | | | | | | | | | | | | | Program/Erase<br>Resume | 1 | Х | 30 | | | | | | | | | | | | | Read CFI Query | 1 | 55 | 98 | | | | | | | | | | | | | Enter Extended Block | 3 | 555 | AA | 2AA | 55 | 555 | 88 | | | | | | | | | Exit Extended Block | 4 | 555 | AA | 2AA | 55 | 555 | 90 | Х | 00 | | | | | | X Don't Care, PA Program Address, PD Program Data, BA any address in the Block. All values in the table are in hexadecimal. The Command Interface only uses A-1, A0-A10 and DQ0-DQ7 to verify the commands; A11-A20, DQ8-DQ14 and DQ15 are Don't Care. DQ15A-1 is A-1 when BYTE is V<sub>IL</sub> or DQ15 when BYTE is V<sub>IH</sub>. - 3. Each buffer has the same A4-A22 addresses. A0-A3 are used to select a Word within the N+1 Word page. - 4. The 6th cycle has to be issued N time. WBL scans the Word inside the page. - 5. BA must be identical to the address loaded during the Write to buffer and Program 3rd and 4th cycles. <sup>2.</sup> The maximum number of cycles in the command sequence is 36. N+1 is the number of Words to be programmed during the Write to Buffer and Program operation. Table 11. Commands, 8-bit mode, $\overline{\text{BYTE}} = V_{IL}$ | Table 11. C | Length | ıman | Bus Write Operations <sup>(1)</sup> | | | | | | | | | | | | | | | | | |------------------------------------------------------|---------|------------|-------------------------------------|------------|----------|----------|------------|-----|------------------|-----------|------|------------|------|-----|------|-----|------|-----|------| | Command | | 1st | | 2nd | | 3rd | | 4th | | 5th | | 6th | | 7th | | 8th | | 9th | | | | | Add | Data | Read/Reset | 1 | X | F0 | | | | <b>5</b> 0 | | | | | | | | | | | | | | Auto Select | 3 | AAA<br>AAA | AA<br>AA | 555<br>555 | 55<br>55 | X<br>AAA | F0<br>90 | | | | | | | | | | | | | | Program | 4 | AAA | AA | 555 | 55 | AAA | A0 | PA | PD | | | | | | | | | | | | Double Byte<br>Program | 3 | AAA | 50 | PA0 | PD0 | PA1 | PD1 | | | | | | | | | | | | | | Quadruple<br>Byte Program | 5 | AAA | 56 | PA0 | PD0 | PA1 | PD1 | PA2 | PD2 | PA3 | PD3 | | | | | | | | | | Octuple Byte<br>Program | 9 | AAA | 8B | PA0 | PD0 | PA1 | PD1 | PA2 | PD2 | PA3 | PD3 | PA4 | PD4 | PA5 | PD5 | PA6 | PD6 | PA7 | PD7 | | Unlock Bypass | 3 | AAA | AA | 555 | 55 | AAA | 20 | | | | | | | | | | | | | | Unlock Bypass<br>Program | 2 | Χ | A0 | PA | PD | | | | | | | | | | | | | | | | Unlock Bypass<br>Reset | 2 | Х | 90 | Х | 00 | | | | | | | | | | | | | | | | Write to Buffer<br>and Program | N+<br>5 | AAA | AA | 555 | 55 | ВА | 25 | ВА | N <sup>(2)</sup> | PA<br>(3) | PD | WBL<br>(4) | PD | | | | | | | | Write to Buffer<br>and Program<br>Abort and<br>Reset | 3 | AAA | AA | 555 | 55 | AAA | F0 | | | | | | | | | | | | | | Write to Buffer<br>and Program<br>Confirm | 1 | BA<br>(5) | 29 | | | | | | | | | | | | | | | | | | Chip Erase | 6 | AAA | AA | 555 | 55 | AAA | 80 | AAA | AA | 555 | 55 | AAA | 10 | | | | | | | | Block Erase | 6+ | AAA | AA | 555 | 55 | AAA | 80 | AAA | AA | 555 | 55 | BA | 30 | | | | | | | | Program/Erase<br>Suspend | 1 | Х | В0 | | | | | | | | | | | | | | | | | | Program/Erase<br>Resume | 1 | Х | 30 | | | | | | | | | | | | | | | | | | Read CFI<br>Query | 1 | AA | 98 | | | | | | | | | | | | | | | | | | Enter<br>Extended<br>Block | 3 | AAA | AA | 555 | 55 | AAA | 88 | | | | | | | | | | | | | | Exit Extended<br>Block | 4 | AAA | AA | 555 | 55 | AAA | 90 | Х | 00 | | | | | | | | | | | X Don't Care, PA Program Address, PD Program Data, BA Any address in the Block. All values in the table are in hexadecimal. The Command Interface only uses A-1, A0-A10 and DQ0-DQ7 to verify the commands; A11-A20, DQ8-DQ14 and DQ15 are Don't Care. DQ15A-1 is A-1 when BYTE is V<sub>IL</sub> or DQ15 when BYTE is V<sub>IH</sub>. <sup>2.</sup> The maximum number of cycles in the command sequence is 68. N+1 is the number of Bytes to be programmed during the Write to Buffer and Program operation. <sup>3.</sup> Each buffer has the same A4-A22 addresses. A0-A3 and DQ15A-1 are used to select a Byte within the N+1 Byte page. <sup>4.</sup> The 6th cycle has to be issued N time. WBL scans the Byte inside the page. <sup>5.</sup> BA must be identical to the address loaded during the Write to buffer and Program 3rd and 4th cycles. Table 12. Program, Erase times and endurance cycles | Parameter | Symbol | Min | Typ <sup>(1)(2)</sup> | Max <sup>(2)</sup> | Unit | |------------------------------------------------------------------------------------------|--------------------|---------|-----------------------|--------------------|--------| | Chip Erase | | | 80 | 400 <sup>(3)</sup> | s | | Block Erase (64 KBytes) <sup>(4)(5)</sup> | t <sub>WHWH2</sub> | | 0.5 | | s | | Erase Suspend Latency Time | | | | 50 <sup>(6)</sup> | μs | | Program (Byte or Word) | | | 10 | 200 <sup>(3)</sup> | μs | | Double Byte | | | 10 | 200 <sup>(3)</sup> | μs | | Double Word /Quadruple Byte Program | | | 10 | 200 <sup>(3)</sup> | μs | | Quadruple Word / Octuple Byte Program | | | 10 | 200 <sup>(3)</sup> | μs | | Single Byte and Word Program <sup>(7)</sup> | t <sub>WHWH1</sub> | | 10 | | μs | | 32 Byte/16 Word Program using Write to Buffer and Program | | | 180 | | μs | | 32 Byte/16 Word Program using Write to Buffer and Program $(V_{PP}/\overline{WP} = 12V)$ | | | 45 | | μs | | Chip Program (Byte by Byte) | | | 80 | 400 <sup>(3)</sup> | S | | Chip Program (Word by Word) | | | 40 | 200 <sup>(3)</sup> | S | | Chip Program (Double Word/Quadruple Byte Program) | | | 20 | 100 <sup>(3)</sup> | S | | Chip Program (Quadruple Word/Octuple Byte Program) | | | 10 | 50 <sup>(3)</sup> | S | | Program Suspend Latency Time | | | | 4 | μs | | Program/Erase Cycles (per Block) | | 100,000 | | | cycles | | Data Retention | | 20 | | | years | <sup>1.</sup> Typical values measured at room temperature and nominal voltages. <sup>2.</sup> Sampled, but not 100% tested. <sup>3.</sup> Maximum value measured at worst case conditions for both temperature and $V_{CC}$ after 100,00 program/erase cycles. <sup>4.</sup> This time does not include the pre-programming time. <sup>5.</sup> Block erase polling cycle time (see Figure 19). <sup>6.</sup> Maximum value measured at worst case conditions for both temperature and $V_{\mbox{\footnotesize{CC}}}$ . <sup>7.</sup> Program polling cycle time (see Figure 6, Figure 7 and Figure 19). Figure 6. Write Enable controlled Program waveforms (8-bit mode) - Only the third and fourth cycles of the Program command are represented. The Program command is followed by the check of Status register Data Polling bit and by a read operation that outputs the data, D<sub>OUT</sub>, programmed by the previous Program command. - 2. PA is address of the memory location to be programmed. PD is the data to be programmed. - 3. $\overline{DQ7}$ is the complement of the data bit being programmed to DQ7 (see Section 5.1: Data Polling Bit (DQ7)). - 4. Addresses differ in x8 mode. - 5. See Table 19: Write AC characteristics and Table 18: Read AC characteristics for details on the timings. Figure 7. Chip Enable controlled Program waveforms (8-bit mode) - Only the third and fourth cycles of the Program command are represented. The Program command is followed by the check of Status register Data Polling bit. - 2. PA is address of the memory location to be programmed. PD is the data to be programmed. - 3. $\overline{DQ7}$ is the complement of the data bit being programmed to DQ7 (see Section 5.1: Data Polling Bit (DQ7)). - 4. Addresses differ in x8 mode. - 5. See Table 19: Write AC characteristics and Table 18: Read AC characteristics for details on the timings. Figure 8. Chip/Block Erase waveforms (8-bit mode) - 2. BA is the block address. - 3. See Table 19: Write AC characteristics and Table 18: Read AC characteristics for details on the timings. For a Chip Erase command, addresses and data are 555h and 10h, respectively, while they are BA and 30h for a Block Erase command. ### 5 Status Register Bus Read operations from any address always read the Status Register during Program and Erase operations. It is also read during Erase Suspend when an address within a block being erased is accessed. The bits in the Status Register are summarized in Table 13: Status Register bits. ### 5.1 Data Polling Bit (DQ7) The Data Polling Bit can be used to identify whether the Program/Erase Controller has successfully completed its operation or if it has responded to an Erase Suspend. The Data Polling Bit is output on DQ7 when the Status Register is read. During Program operations the Data Polling Bit outputs the complement of the bit being programmed to DQ7. After successful completion of the Program operation the memory returns to Read mode and Bus Read operations from the address just programmed output DQ7, not its complement. During Erase operations the Data Polling Bit outputs '0', the complement of the erased state of DQ7. After successful completion of the Erase operation the memory returns to Read Mode. In Erase Suspend mode the Data Polling Bit will output a '1' during a Bus Read operation within a block being erased. The Data Polling Bit will change from a '0' to a '1' when the Program/Erase Controller has suspended the Erase operation. Figure 9: Data polling flowchart, gives an example of how to use the Data Polling Bit. A Valid Address is the address being programmed or an address within the block being erased. Table 20: Reset/Block Temporary Unprotect AC Characteristics gives a description of the data polling operation and timings. ### 5.2 Toggle Bit (DQ6) The Toggle Bit can be used to identify whether the Program/Erase Controller has successfully completed its operation or if it has responded to an Erase Suspend. The Toggle Bit is output on DQ6 when the Status Register is read. During Program and Erase operations the Toggle Bit changes from '0' to '1' to '0', etc., with successive Bus Read operations at any address. After successful completion of the operation the memory returns to Read mode. During Erase Suspend mode the Toggle Bit will output when addressing a cell within a block being erased. The Toggle Bit will stop toggling when the Program/Erase Controller has suspended the Erase operation. Figure 10: Data toggle flowchart, gives an example of how to use the Data Toggle Bit. Figure 20: Toggle/alternative Toggle bit polling AC waveforms (8-bit mode) gives a description of the data polling operation and timings. #### 5.3 Error Bit (DQ5) The Error Bit can be used to identify errors detected by the Program/Erase Controller. The Error Bit is set to '1' when a Program, Block Erase or Chip Erase operation fails to write the correct data to the memory. If the Error Bit is set a Read/Reset command must be issued before other commands are issued. The Error bit is output on DQ5 when the Status Register is read. Note that the Program command cannot change a bit set to '0' back to '1' and attempting to do so will set DQ5 to '1'. A Bus Read operation to that address will show the bit is still '0'. One of the Erase commands must be used to set all the bits in a block or in the whole memory from '0' to '1'. #### 5.4 Erase Timer Bit (DQ3) The Erase Timer Bit can be used to identify the start of Program/Erase Controller operation during a Block Erase command. Once the Program/Erase Controller starts erasing the Erase Timer Bit is set to '1'. Before the Program/Erase Controller starts the Erase Timer Bit is set to '0' and additional blocks to be erased may be written to the Command Interface. The Erase Timer Bit is output on DQ3 when the Status Register is read. #### 5.5 Alternative Toggle Bit (DQ2) The Alternative Toggle Bit can be used to monitor the Program/Erase controller during Erase operations. The Alternative Toggle Bit is output on DQ2 when the Status Register is read. During Chip Erase and Block Erase operations the Toggle Bit changes from '0' to '1' to '0', etc., with successive Bus Read operations from addresses within the blocks being erased. A protected block is treated the same as a block not being erased. Once the operation completes the memory returns to Read mode. During Erase Suspend the Alternative Toggle Bit changes from '0' to '1' to '0', etc. with successive Bus Read operations from addresses within the blocks being erased. Bus Read operations to addresses within blocks not being erased will output the memory cell data as if in Read mode. After an Erase operation that causes the Error Bit to be set the Alternative Toggle Bit can be used to identify which block or blocks have caused the error. The Alternative Toggle Bit changes from '0' to '1' to '0', etc. with successive Bus Read Operations from addresses within blocks that have not erased correctly. The Alternative Toggle Bit does not change if the addressed block has erased correctly. Figure 20: Toggle/alternative Toggle bit polling AC waveforms (8-bit mode) gives a description of the data polling operation and timings. ## 5.6 Write to Buffer and Program Abort Bit (DQ1) The Write to Buffer and Program Abort bit, DQ1, is set to '1' when a Write to Buffer and Program operation aborts. Otherwise, DQ1 bit is set to '0'. The Write to Buffer and Program Abort and Reset command must be issued to return the device to Read mode (see Write to Buffer and Program in COMMANDS section). Table 13. Status Register bits<sup>(1)</sup> | Operation | Address | DQ7 | DQ6 | DQ5 | DQ3 | DQ2 | DQ1 | R₩ | |--------------------------------------|----------------------|-----|-----------|--------|--------|-----------|-----|------| | Program | Any Address | DQ7 | Toggle | 0 | _ | - | 0 | 0 | | Program During Erase<br>Suspend | Any Address | DQ7 | Toggle | 0 | - | _ | - | 0 | | Write to Buffer and<br>Program Abort | Any Address | DQ7 | Toggle | 0 | - | _ | 1 | 0 | | Write to Buffer and Program | Any Address | DQ7 | Toggle | 0 | - | - | 0 | 0 | | Program Error | Any Address | DQ7 | Toggle | 1 | _ | _ | _ | Hi-Z | | Chip Erase | Any Address | 0 | Toggle | 0 | 1 | Toggle | _ | Hi-Z | | Block Erase before | Erasing Block | 0 | Toggle | 0 | 0 | Toggle | _ | 0 | | timeout | Non-Erasing Block | 0 | Toggle | 0 | 0 | No Toggle | _ | 0 | | Block Erase | Erasing Block | 0 | Toggle | 0 | 1 | Toggle | _ | Hi-Z | | DIOCK ETase | Non-Erasing Block | 0 | Toggle | 0 | 1 | No Toggle | _ | 0 | | Franc Suppond | Erasing Block | 1 | No Toggle | 0 | _ | Toggle | _ | Hi-Z | | Erase Suspend | Non-Erasing Block | | Data r | ead as | normal | | _ | Hi-Z | | Erase Error | Good Block Address | 0 | Toggle | 1 | 1 | No Toggle | _ | 0 | | Elase Elloi | Faulty Block Address | 0 | Toggle | 1 | 1 | Toggle | _ | 0 | <sup>1.</sup> Unspecified data bits should be ignored. READ DQ5 & DQ7 at VALID ADDRESS PATA NO DQ5 TYES PATA NO DQ7 TYES DATA NO FAIL PASS Al90194 Figure 9. Data polling flowchart Figure 10. Data toggle flowchart # 6 Maximum rating Stressing the device above the rating listed in the Absolute Maximum Ratings table may cause permanent damage to the device. Exposure to Absolute Maximum Rating conditions for extended periods may affect device reliability. These are stress ratings only and operation of the device at these or any other conditions above those indicated in the Operating sections of this specification is not implied. Refer also to the STMicroelectronics SURE Program and other relevant quality documents. Table 14. Absolute maximum ratings | Symbol | Parameter | Min | Max | Unit | |--------------------------------|-------------------------------------------|-----------------|----------------------|------| | T <sub>BIAS</sub> | Temperature Under Bias | <b>-</b> 50 | 125 | °C | | T <sub>STG</sub> | Storage Temperature | <del>-</del> 65 | 150 | °C | | V <sub>IO</sub> | Input or Output Voltage <sup>(1)(2)</sup> | -0.6 | V <sub>CC</sub> +0.6 | V | | V <sub>CC</sub> | Supply Voltage | -0.6 | 4 | V | | V <sub>ID</sub> | Identification Voltage | -0.6 | 13.5 | V | | V <sub>PP</sub> <sup>(3)</sup> | Program Voltage | -0.6 | 13.5 | V | - 1. Minimum voltage may undershoot to -2V during transition and for less than 20ns during transitions. - 2. Maximum voltage may overshoot to V<sub>CC</sub> +2V during transition and for less than 20ns during transitions. - 3. $V_{PP}$ must not remain at 12V for more than a total of 80hrs. ## 7 DC and AC parameters This section summarizes the operating and measurement conditions, and the DC and AC characteristics of the device. The parameters in the DC and AC Characteristic tables that follow are derived from tests performed under the Measurement Conditions summarized in the relevant tables. Designers should check that the operating conditions in their circuit match the measurement conditions when relying on the quoted parameters. Table 15. Operating and AC measurement conditions | Parameter | | M29W640GB,<br>M29W640GL | Unit | | |---------------------------------------|----------------|-------------------------|------|--| | | Min | Max | | | | V <sub>CC</sub> Supply Voltage | 2.7 | 3.6 | V | | | Ambient Operating Temperature | -40 | 85 | °C | | | Load Capacitance (C <sub>L</sub> ) | 3 | 0 | pF | | | Input Rise and Fall Times | | 10 | ns | | | Input Pulse Voltages | 0 to | 0 to V <sub>CC</sub> | | | | Input and Output Timing Ref. Voltages | V <sub>C</sub> | V | | | Figure 11. AC measurement I/O waveform Figure 12. AC measurement load circuit Table 16. Device capacitance | Symbol | Parameter | Test Condition | Min | Max | Unit | |------------------|--------------------|-----------------------|-----|-----|------| | C <sub>IN</sub> | Input Capacitance | $V_{IN} = 0V$ | | 6 | pF | | C <sub>OUT</sub> | Output Capacitance | V <sub>OUT</sub> = 0V | | 12 | pF | <sup>1.</sup> Sampled only, not 100% tested. Table 17. DC characteristics | Symbol | Parameter | Test Co | ndition | Min | Max | Unit | |---------------------------------|---------------------------------------------------------|--------------------------------------------------------|--------------------------------|----------------------|----------------------|------| | I <sub>LI</sub> <sup>(1)</sup> | Input Leakage Current | 0V ≤V <sub>IN</sub> ≤V <sub>CC</sub> | | | ±1 | μΑ | | I <sub>LO</sub> | Output Leakage Current | 0V ≤V <sub>OU</sub> | <sub>IT</sub> ≤V <sub>CC</sub> | | ±1 | μΑ | | I <sub>CC1</sub> | Supply Current (Read) | $\overline{E} = V_{IL}, \overline{G}$ $f = 6N$ | | | 10 | mA | | I <sub>CC2</sub> | Supply Current (Standby) | $\frac{\overline{E} = V_{CC}}{\overline{RP} = V_{CC}}$ | | | 100 | μΑ | | I <sub>CC3</sub> | Supply Current<br>(Program/Erase) | Program/Erase Controller active | | | 20 | mA | | | (1 Togranii Erado) | | | | 20 | mA | | $V_{IL}$ | Input Low Voltage | | | -0.5 | 8.0 | ٧ | | V <sub>IH</sub> | Input High Voltage | | | 0.7V <sub>CC</sub> | V <sub>CC</sub> +0.3 | ٧ | | V <sub>PP</sub> | Voltage for V <sub>PP</sub> /WP<br>Program Acceleration | V <sub>CC</sub> = 2.7 | 'V ±10% | 11.5 | 12.5 | V | | I <sub>PP</sub> | Current for V <sub>PP</sub> /WP<br>Program Acceleration | V <sub>CC</sub> = 2.7 | 'V ±10% | | 15 | mA | | V <sub>OL</sub> | Output Low Voltage | I <sub>OL</sub> = 1 | .8mA | | 0.45 | V | | V <sub>OH</sub> | Output High Voltage | I <sub>OH</sub> = -100μA | | V <sub>CC</sub> -0.4 | | V | | V <sub>ID</sub> | Identification Voltage | | | 11.5 | 12.5 | V | | V <sub>LKO</sub> <sup>(2)</sup> | Program/Erase Lockout<br>Supply Voltage | | | 1.8 | 2.3 | V | <sup>1.</sup> The maximum input leakage current is $\pm$ 5 $\mu$ A on the $V_{PP}/\overline{WP}$ pin. <sup>2.</sup> Sampled only, not 100% tested. tAVAX A0-A20/ VALID A-1 tAVQV tAXQX Ē - tELQV tEHQX tELQX tEHQZ G - tGLQX → tGHQX tGLQV tGHQZ DQ0-DQ7/ VALID DQ8-DQ15 tBHQV BYTE tELBL/tELBH tBLQZ AI05559 Figure 13. Read Mode AC waveforms (8-bit mode) 1. Data are output on DQ0-DQ7. DQ8-DQ15 are Hi-Z. Figure 14. Page Read AC waveforms (8-bit mode) Table 18. Read AC characteristics | Symbol Alt | | Alt Parameter Te | | Test Condition | | M29W640GT,<br>M29W640GB,<br>M29W640GH, | | |-------------------------------------------------------------|-------------------|--------------------------------------------------------------------------|----------------------------------------------------------------|----------------|------|----------------------------------------|------| | - Cymiser | 7 | i aramete. | 1001 001141 | | M29W | 640GL | Unit | | | | | | | 60 | 70 | | | t <sub>AVAX</sub> | t <sub>RC</sub> | Address Valid to Next Address Valid | $\overline{\overline{E}} = V_{IL},$<br>$\overline{G} = V_{IL}$ | Min | 60 | 70 | ns | | t <sub>AVQV</sub> | t <sub>ACC</sub> | Address Valid to Output Valid | $\overline{\overline{G}} = V_{IL},$<br>$\overline{G} = V_{IL}$ | Max | 60 | 70 | ns | | t <sub>AVQV1</sub> | t <sub>PAGE</sub> | Address Valid to Output Valid (Page) | $\overline{E} = V_{IL},$<br>$\overline{G} = V_{IL}$ | Max | 25 | 30 | ns | | t <sub>ELQX</sub> <sup>(1)</sup> | $t_{LZ}$ | Chip Enable Low to Output Transition | $\overline{G} = V_{IL}$ | Min | 0 | 0 | ns | | t <sub>ELQV</sub> | t <sub>CE</sub> | Chip Enable Low to Output Valid | $\overline{G} = V_{IL}$ | Max | 60 | 70 | ns | | t <sub>GLQX</sub> <sup>(1)</sup> | t <sub>OLZ</sub> | Output Enable Low to Output Transition | $\overline{E} = V_{IL}$ | Min | 0 | 0 | ns | | t <sub>GLQV</sub> | t <sub>OE</sub> | Output Enable Low to Output Valid | $\overline{E} = V_{IL}$ | Max | 25 | 30 | ns | | t <sub>EHQZ</sub> (1) | t <sub>HZ</sub> | Chip Enable High to Output Hi-Z | $\overline{G} = V_{IL}$ | Max | 25 | 30 | ns | | t <sub>GHQZ</sub> | t <sub>DF</sub> | Output Enable High to Output Hi-Z | $\overline{E} = V_{IL}$ | Max | 25 | 30 | ns | | t <sub>EHQX</sub><br>t <sub>GHQX</sub><br>t <sub>AXQX</sub> | t <sub>OH</sub> | Chip Enable, Output Enable or Address<br>Transition to Output Transition | | Min | 0 | 0 | ns | | t <sub>ELBL</sub> | t <sub>ELFL</sub> | Chip Enable to BYTE Low or High | | Max | 5 | 5 | ns | | t <sub>BLQZ</sub> | t <sub>FLQZ</sub> | BYTE Low to Output Hi-Z | | Max | 25 | 25 | ns | | t <sub>BHQV</sub> | t <sub>FHQV</sub> | BYTE High to Output Valid | | Max | 25 | 30 | ns | <sup>1.</sup> Sampled only, not 100% tested. Figure 15. Write AC waveforms, Write Enable Controlled (8-bit mode) Figure 16. Write AC waveforms, Chip Enable Controlled (8-bit mode) Table 19. Write AC characteristics | Symbol | Alt | Parameter | | | M29W640GB,<br>M29W640GL | Unit | |-------------------------------------------------------|-------------------|-------------------------------------------------------|-----|----|-------------------------|------| | | | | | 60 | 70 | | | t <sub>AVAX</sub> | t <sub>WC</sub> | Address Valid to Next Address Valid | Min | 60 | 70 | ns | | t <sub>ELWL</sub> | t <sub>CS</sub> | Chip Enable Low to Write Enable Low | Min | 0 | 0 | ns | | t <sub>WLEL</sub> | t <sub>WS</sub> | Write Enable Low to Chip Enable Low | Min | 0 | 0 | ns | | t <sub>WLWH</sub> | t <sub>WP</sub> | Write Enable Low to Write Enable High | Min | 35 | 35 | ns | | t <sub>ELEH</sub> | t <sub>CP</sub> | Chip Enable Low to Chip Enable High | Min | 35 | 35 | ns | | t <sub>DVWH</sub><br>t <sub>DVEH</sub> | t <sub>DS</sub> | Input Valid to Write Enable or Chip Enable High | Min | 30 | 30 | ns | | t <sub>WHDX</sub> | t <sub>DH</sub> | Write Enable or Chip Enable High to Input Transition | Min | 0 | 0 | ns | | t <sub>WHEH</sub> | t <sub>CH</sub> | Write Enable High to Chip Enable High | Min | 0 | 0 | ns | | t <sub>EHWH</sub> | t <sub>WH</sub> | Chip Enable High to Write Enable High | Min | 0 | 0 | ns | | t <sub>WHWL</sub> | t <sub>WPH</sub> | Write Enable High to Write Enable Low | Min | 25 | 25 | ns | | t <sub>WHGL1</sub> | t <sub>OEH</sub> | Output Enable Hold time | Min | 0 | 0 | ns | | t <sub>EHEL1</sub> | t <sub>CPH</sub> | Chip Enable High to Chip Enable Low | Min | 25 | 25 | ns | | t <sub>AVWL</sub> | t <sub>AS</sub> | Address Valid to Write Enable or Chip Enable Low | Min | 0 | 0 | ns | | t <sub>WLAX</sub> | t <sub>AH</sub> | Write Enable or Chip Enable Low to Address Transition | Min | 45 | 45 | ns | | t <sub>GHWL</sub> | t <sub>GHWL</sub> | Output Enable High to Write Enable Low | Min | 0 | 0 | ns | | t <sub>GHEL</sub> | t <sub>GHEL</sub> | Output Enable High to Chip Enable Low | Min | 0 | 0 | ns | | t <sub>WHRL</sub> <sup>(1)</sup><br>t <sub>EHRL</sub> | t <sub>BUSY</sub> | Program/Erase Valid to RB Low Max | | 0 | 0 | ns | | t <sub>VCHEL</sub> | t <sub>VCS</sub> | V <sub>CC</sub> High to Chip Enable Low | Min | 50 | 50 | μs | <sup>1.</sup> Sampled only, not 100% tested. - tPHPHH AI02931B W, E, G RB tPHWL, tPHEL, tPHGL tRHWL, tRHEL, tRHGL Figure 17. Reset/Block Temporary Unprotect AC waveforms Figure 18. Accelerated Program Timing waveforms Table 20. Reset/Block Temporary Unprotect AC Characteristics tPLYH - | Symbol | Alt | Parameter | | M29W640GT, M29W640GB,<br>M29W640GH, M29W640GL | Unit | |----------------------------------------------------------------------------------------------------|--------------------|--------------------------------------------------------------------|-----|-----------------------------------------------|------| | t <sub>PHWL</sub> <sup>(1)</sup> t <sub>PHEL</sub> t <sub>PHGL</sub> <sup>(1)</sup> | t <sub>RH</sub> | RP High to Write Enable Low, Chip Enable Low,<br>Output Enable Low | Min | 200 | ns | | t <sub>RHWL</sub> <sup>(1)</sup> t <sub>RHEL</sub> <sup>(1)</sup> t <sub>RHGL</sub> <sup>(1)</sup> | t <sub>RB</sub> | RB High to Write Enable Low, Chip Enable Low,<br>Output Enable Low | Min | 0 | ns | | t <sub>PLPX</sub> | t <sub>RP</sub> | RP Pulse Width | Min | 500 | ns | | t <sub>PLYH</sub> | t <sub>READY</sub> | RP Low to Read Mode | Max | 50 | μs | | t <sub>PHPHH</sub> <sup>(1)(2)</sup> | t <sub>VIDR</sub> | RP Rise Time to V <sub>ID</sub> | Min | 500 | ns | | t <sub>VHVPP</sub> <sup>(1)</sup> | | V <sub>PP</sub> Rise and Fall Time | Min | 500 | ns | <sup>1.</sup> Sampled only, not 100% tested. <sup>2.</sup> For Fast program operations using $V_{\mbox{\footnotesize{PP}}}\mbox{\footnotesize{/WP}}$ at 12V. Figure 19. Data Polling AC waveforms - 1. DQ7 returns valid data bit when the ongoing Program or Erase command is completed. - See Table 21: Data polling and data toggle AC characteristics and Table 18: Read AC characteristics for details on the timings. Figure 20. Toggle/alternative Toggle bit polling AC waveforms (8-bit mode) - DQ6 stops toggling when the ongoing Program or Erase command is completed. DQ2 stops toggling when the ongoing Chip Erase or Block Erase command is completed. - 2. See Table 21: Data polling and data toggle AC characteristics and Table 18: Read AC characteristics for details on the timings. 5// Table 21. Data polling and data toggle AC characteristics | Symbol | Alt | Parameter | | | M29W640GB,<br>M29W640GL | Unit | |--------------------|-------------------|-------------------------------------------------------------------|-----|----|-------------------------|------| | | | | | 60 | | | | t <sub>AXGL</sub> | t <sub>ASO</sub> | Address setup time to Output Enable Low during Toggle bit polling | Min | 10 | 10 | ns | | t <sub>GHAX</sub> | t <sub>AHT</sub> | Address hold time from Output Enable during Toggle bit polling | Min | 10 | 10 | ns | | t <sub>EHEL2</sub> | t <sub>CEPH</sub> | Chip Enable High during Toggle bit polling | Min | 10 | 10 | ns | | t <sub>WHGL2</sub> | t <sub>OEH</sub> | Output Hold time during Data and Toggle bit Polling | Min | 20 | 20 | ns | # 8 Package mechanical Figure 21. TSOP48 -48 lead Plastic Thin Small Outline, 12x20mm, top view package outline 1. Drawing is not to scale. Table 22. TSOP48 – 48 lead Plastic Thin Small Outline, 12 x 20mm, package mechanical data | Sumbal | | millimeters | | | inches | | |--------|--------|-------------|--------|--------|--------|--------| | Symbol | Тур | Min | Max | Тур | Min | Max | | A | | | 1.200 | | | 0.0472 | | A1 | 0.100 | 0.050 | 0.150 | 0.0039 | 0.0020 | 0.0059 | | A2 | 1.000 | 0.950 | 1.050 | 0.0394 | 0.0374 | 0.0413 | | В | 0.220 | 0.170 | 0.270 | 0.0087 | 0.0067 | 0.0106 | | С | | 0.100 | 0.210 | | 0.0039 | 0.0083 | | СР | | | 0.100 | | | 0.0039 | | D1 | 12.000 | 11.900 | 12.100 | 0.4724 | 0.4685 | 0.4764 | | E | 20.000 | 19.800 | 20.200 | 0.7874 | 0.7795 | 0.7953 | | E1 | 18.400 | 18.300 | 18.500 | 0.7244 | 0.7205 | 0.7283 | | е | 0.500 | - | - | 0.0197 | - | _ | | L | 0.600 | 0.500 | 0.700 | 0.0236 | 0.0197 | 0.0276 | | L1 | 0.800 | | | 0.0315 | | | | α | 3° | 0° | 5° | 3° | 0° | 5° | DI E1 E1 CP TSOP-K Figure 22. TSOP56 – 56 lead Plastic Thin Small Outline, 14 x 20mm, top view package outline 1. Drawing is not to scale. Table 23. TSOP56 – 56 lead Plastic Thin Small Outline, 14 x 20mm, package mechanical data | Symbol | | millimeters | | | inches | | |--------|-------|-------------|-------|-------|--------|-------| | Symbol | Тур | Min | Max | Тур | Min | Max | | А | | | 1.20 | | | 0.047 | | A1 | 0.10 | 0.05 | 0.15 | 0.004 | 0.002 | 0.006 | | A2 | 1.00 | 0.95 | 1.05 | 0.039 | 0.037 | 0.041 | | В | 0.22 | 0.17 | 0.27 | 0.009 | 0.007 | 0.011 | | С | | 0.10 | 0.21 | | 0.004 | 0.008 | | СР | | | 0.10 | | | 0.004 | | D1 | 14.00 | 13.90 | 14.10 | 0.551 | 0.547 | 0.555 | | E | 20.00 | 19.80 | 20.20 | 0.787 | 0.780 | 0.795 | | E1 | 18.40 | 18.30 | 18.50 | 0.724 | 0.720 | 0.728 | | е | 0.50 | - | _ | 0.020 | _ | _ | | L | 0.60 | 0.50 | 0.70 | 0.024 | 0.020 | 0.028 | | α | 3° | 0° | 5° | 3° | 0° | 5° | Figure 23. TFBGA48 6x8mm - 6x8 active ball array, 0.8mm pitch, package outline 1. Drawing is not to scale. Table 24. TFBGA48 6x8mm - 6x8 active ball array, 0.8mm pitch, package mechanical data | Cumbal | millimeters | | | inches | | | |--------|-------------|-------|-------|--------|--------|--------| | Symbol | Тур | Min | Max | Тур | Min | Max | | А | | | 1.200 | | | 0.0472 | | A1 | | 0.260 | | | 0.0102 | | | A2 | | | 0.900 | | | 0.0354 | | b | | 0.350 | 0.450 | | 0.0138 | 0.0177 | | D | 6.000 | 5.900 | 6.100 | 0.2362 | 0.2323 | 0.2402 | | D1 | 4.000 | - | - | 0.1575 | - | - | | ddd | | | 0.100 | | | 0.0039 | | E | 8.000 | 7.900 | 8.100 | 0.3150 | 0.3110 | 0.3189 | | E1 | 5.600 | - | - | 0.2205 | - | - | | е | 0.800 | - | - | 0.0315 | - | - | | FD | 1.000 | - | - | 0.0394 | - | - | | FE | 1.200 | - | - | 0.0472 | - | - | | SD | 0.400 | - | - | 0.0157 | - | - | | SE | 0.400 | - | - | 0.0157 | - | - | Figure 24. TBGA64 10x13mm - 8x8 active ball array, 1mm pitch, package outline 1. Drawing is not to scale. Table 25. TBGA64 10x13mm - 8x8 active ball array, 1mm pitch, package mechanical data | Complete | millimeters | | | inches | | | |----------|-------------|--------|--------|--------|--------|--------| | Symbol | Тур | Min | Max | Тур | Min | Max | | А | | | 1.200 | | | 0.0472 | | A1 | 0.300 | 0.200 | 0.350 | 0.0118 | 0.0079 | 0.0138 | | A2 | 0.800 | | | 0.0315 | | | | b | | 0.350 | 0.500 | | 0.0138 | 0.0197 | | D | 10.000 | 9.900 | 10.100 | 0.3937 | 0.3898 | 0.3976 | | D1 | 7.000 | - | - | 0.2756 | _ | _ | | ddd | | | 0.100 | | | 0.0039 | | е | 1.000 | - | - | 0.0394 | _ | _ | | Е | 13.000 | 12.900 | 13.100 | 0.5118 | 0.5079 | 0.5157 | | E1 | 7.000 | - | - | 0.2756 | _ | _ | | FD | 1.500 | - | - | 0.0591 | _ | - | | FE | 3.000 | _ | _ | 0.1181 | _ | _ | | SD | 0.500 | _ | _ | 0.0197 | _ | _ | | SE | 0.500 | _ | _ | 0.0197 | _ | _ | ### 9 Part numbering Table 26. Ordering information scheme E = ECOPACK Package, Standard Packing F = ECOPACK Package, Tape & Reel Packing 1. Packages only available upon request. Note: This product is also available with the Extended Block factory locked. For further details and ordering information contact your nearest ST sales office. Devices are shipped from the factory with the memory content bits erased to 1. For a list of available options (Speed, Package, etc.) or for further information on any aspect of this device, please contact your nearest ST Sales Office. # Appendix A Block addresses Table 27. M29W640GH and M29W640GL block addresses | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|--------------------------------|--------------------------------| | 0 | 64/32 | Protection Group | 000000h-00FFFFh <sup>(1)</sup> | 000000h-007FFFh <sup>(1)</sup> | | 1 | 64/32 | Protection Group | 010000h-01FFFFh <sup>(1)</sup> | 008000h-00FFFFh | | 2 | 64/32 | Protection Group | 020000h-02FFFFh <sup>(1)</sup> | 010000h-017FFFh <sup>(1)</sup> | | 3 | 64/32 | Protection Group | 030000h-03FFFFh <sup>(1)</sup> | 018000h-01FFFFh <sup>(1)</sup> | | 4 | 64/32 | | 040000h-04FFFFh | 020000h-027FFFh | | 5 | 64/32 | Drotaction Croup | 050000h-05FFFFh | 028000h-02FFFFh | | 6 | 64/32 | Protection Group | 060000h-06FFFFh | 030000h-037FFFh | | 7 | 64/32 | | 070000h-07FFFh | 038000h-03FFFFh | | 8 | 64/32 | | 080000h-08FFFFh | 040000h-047FFFh | | 9 | 64/32 | Protection Group | 090000h-09FFFh | 048000h-04FFFFh | | 10 | 64/32 | Protection Group | 0A0000h-0AFFFFh | 050000h-057FFFh | | 11 | 64/32 | | 0B0000h-0BFFFFh | 058000h-05FFFFh | | 12 | 64/32 | | 0C0000h-0CFFFFh | 060000h-067FFh | | 13 | 64/32 | Protection Group | 0D0000h-0DFFFFh | 068000h-06FFFFh | | 14 | 64/32 | Protection Group | 0E0000h-0EFFFh | 070000h-077FFFh | | 15 | 64/32 | | 0F0000h-0FFFFh | 078000h-07FFFh | | 16 | 64/32 | | 100000h-10FFFFh | 080000h-087FFFh | | 17 | 64/32 | Protection Croup | 110000h-11FFFFh | 088000h-08FFFFh | | 18 | 64/32 | Protection Group | 120000h-12FFFFh | 090000h-097FFFh | | 19 | 64/32 | | 130000h-13FFFFh | 098000h-09FFFh | | 20 | 64/32 | | 140000h-14FFFFh | 0A0000h-0A7FFFh | | 21 | 64/32 | Protection Group | 150000h-15FFFFh | 0A8000h-0AFFFFh | | 22 | 64/32 | Protection Group | 160000h-16FFFFh | 0B0000h-0B7FFFh | | 23 | 64/32 | | 170000h-17FFFFh | 0B8000h-0BFFFFh | | 24 | 64/32 | | 180000h-18FFFFh | 0C0000h-0C7FFFh | | 25 | 64/32 | Protection Group | 190000h-19FFFFh | 0C8000h-0CFFFFh | | 26 | 64/32 | Protection Group | 1A0000h-1AFFFFh | 0D0000h-0D7FFFh | | 27 | 64/32 | | 1B0000h-1BFFFFh | 0D8000h-0DFFFFh | | 28 | 64/32 | | 1C0000h-1CFFFFh | 0E0000h-0E7FFh | | 29 | 64/32 | Protection Group | 1D0000h-1DFFFFh | 0E8000h-0EFFFFh | | 30 | 64/32 | Frotection Group | 1E0000h-1EFFFFh | 0F0000h-0F7FFh | | 31 | 64/32 | | 1F0000h-1FFFFFh | 0F8000h-0FFFFh | Table 27. M29W640GH and M29W640GL block addresses (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 32 | 64/32 | | 200000h-20FFFFh | 100000h-107FFFh | | 33 | 64/32 | Protection Group | 210000h-21FFFFh | 108000h-10FFFFh | | 34 | 64/32 | | 220000h-22FFFFh | 110000h-117FFFh | | 35 | 64/32 | | 230000h-23FFFFh | 118000h-11FFFFh | | 36 | 64/32 | | 240000h-24FFFFh | 120000h-127FFFh | | 37 | 64/32 | Dratastian Craus | 250000h-25FFFFh | 128000h-12FFFFh | | 38 | 64/32 | Protection Group | 260000h-26FFFFh | 130000h-137FFFh | | 39 | 64/32 | | 270000h-27FFFh | 138000h-13FFFFh | | 40 | 64/32 | | 280000h-28FFFFh | 140000h-147FFFh | | 41 | 64/32 | Drotaction Croup | 290000h-29FFFFh | 148000h-14FFFFh | | 42 | 64/32 | Protection Group | 2A0000h-2AFFFFh | 150000h-157FFFh | | 43 | 64/32 | | 2B0000h-2BFFFFh | 158000h-15FFFFh | | 44 | 64/32 | | 2C0000h-2CFFFFh | 160000h-167FFFh | | 45 | 64/32 | Dratastian Craus | 2D0000h-2DFFFFh | 168000h-16FFFFh | | 46 | 64/32 | Protection Group | 2E0000h-2EFFFFh | 170000h-177FFFh | | 47 | 64/32 | | 2F0000h-2FFFFh | 178000h-17FFFFh | | 48 | 64/32 | | 300000h-30FFFFh | 180000h-187FFFh | | 49 | 64/32 | Brotaction Croup | 310000h-31FFFFh | 188000h-18FFFFh | | 50 | 64/32 | Protection Group | 320000h-32FFFFh | 190000h-197FFFh | | 51 | 64/32 | | 330000h-33FFFFh | 198000h-19FFFFh | | 52 | 64/32 | | 340000h-34FFFFh | 1A0000h-1A7FFFh | | 53 | 64/32 | Protection Group | 350000h-35FFFFh | 1A8000h-1AFFFFh | | 54 | 64/32 | Frotection Group | 360000h-36FFFFh | 1B0000h-1B7FFFh | | 55 | 64/32 | | 370000h-37FFFh | 1B8000h-1BFFFFh | | 56 | 64/32 | | 380000h-38FFFFh | 1C0000h-1C7FFFh | | 57 | 64/32 | Brotaction Croup | 390000h-39FFFFh | 1C8000h-1CFFFFh | | 58 | 64/32 | Protection Group | 3A0000h-3AFFFFh | 1D0000h-1D7FFFh | | 59 | 64/32 | | 3B0000h-3BFFFFh | 1D8000h-1DFFFFh | | 60 | 64/32 | | 3C0000h-3CFFFh | 1E0000h-1E7FFh | | 61 | 64/32 | Protection Group | 3D0000h-3DFFFFh | 1E8000h-1EFFFFh | | 62 | 64/32 | Frotection Group | 3E0000h-3EFFFFh | 1F0000h-1F7FFFh | | 63 | 64/32 | | 3F0000h-3FFFFh | 1F8000h-1FFFFFh | Table 27. M29W640GH and M29W640GL block addresses (continued) | Block | | Protection Block Group | (x8) | (x16) | |-------|-------|------------------------|-----------------|-----------------| | 64 | 64/32 | | 400000h-40FFFh | 200000h-207FFFh | | 65 | 64/32 | Protection Group | 410000h-41FFFFh | 208000h-20FFFFh | | 66 | 64/32 | | 420000h-42FFFFh | 210000h-217FFFh | | 67 | 64/32 | | 430000h-43FFFFh | 218000h-21FFFFh | | 68 | 64/32 | | 440000h-44FFFFh | 220000h-227FFFh | | 69 | 64/32 | Destanting Occur | 450000h-45FFFFh | 228000h-22FFFFh | | 70 | 64/32 | Protection Group | 460000h-46FFFFh | 230000h-237FFFh | | 71 | 64/32 | | 470000h-47FFFFh | 238000h-23FFFFh | | 72 | 64/32 | | 480000h-48FFFFh | 240000h-247FFFh | | 73 | 64/32 | Drotaction Croup | 490000h-49FFFFh | 248000h-24FFFFh | | 74 | 64/32 | Protection Group | 4A0000h-4AFFFFh | 250000h-257FFFh | | 75 | 64/32 | | 4B0000h-4BFFFFh | 258000h-25FFFFh | | 76 | 64/32 | | 4C0000h-4CFFFFh | 260000h-267FFFh | | 77 | 64/32 | Protection Group | 4D0000h-4DFFFFh | 268000h-26FFFFh | | 78 | 64/32 | Protection Group | 4E0000h-4EFFFFh | 270000h-277FFFh | | 79 | 64/32 | | 4F0000h-4FFFFh | 278000h-27FFFh | | 80 | 64/32 | | 500000h-50FFFh | 280000h-287FFFh | | 81 | 64/32 | Protection Group | 510000h-51FFFFh | 288000h-28FFFFh | | 82 | 64/32 | Frotection Group | 520000h-52FFFh | 290000h-297FFFh | | 83 | 64/32 | | 530000h-53FFFFh | 298000h-29FFFFh | | 84 | 64/32 | | 540000h-54FFFFh | 2A0000h-2A7FFFh | | 85 | 64/32 | Protection Group | 550000h-55FFFFh | 2A8000h-2AFFFFh | | 86 | 64/32 | Frotection Group | 560000h-56FFFFh | 2B0000h-2B7FFFh | | 87 | 64/32 | | 570000h-57FFFh | 2B8000h-2BFFFFh | | 88 | 64/32 | | 580000h-58FFFFh | 2C0000h-2C7FFFh | | 89 | 64/32 | Protection Group | 590000h-59FFFh | 2C8000h-2CFFFFh | | 90 | 64/32 | Protection Group | 5A0000h-5AFFFFh | 2D0000h-2D7FFFh | | 91 | 64/32 | | 5B0000h-5BFFFFh | 2D8000h-2DFFFFh | | 92 | 64/32 | | 5C0000h-5CFFFh | 2E0000h-2E7FFh | | 93 | 64/32 | Protection Group | 5D0000h-5DFFFFh | 2E8000h-2EFFFFh | | 94 | 64/32 | i iotection Group | 5E0000h-5EFFFFh | 2F0000h-2F7FFh | | 95 | 64/32 | | 5F0000h-5FFFFh | 2F8000h-2FFFFh | Table 27. M29W640GH and M29W640GL block addresses (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 96 | 64/32 | | 600000h-60FFFh | 300000h-307FFFh | | 97 | 64/32 | Protection Group | 610000h-61FFFFh | 308000h-30FFFFh | | 98 | 64/32 | | 620000h-62FFFFh | 310000h-317FFFh | | 99 | 64/32 | | 630000h-63FFFFh | 318000h-31FFFFh | | 100 | 64/32 | | 640000h-64FFFFh | 320000h-327FFFh | | 101 | 64/32 | Brotaction Croup | 650000h-65FFFFh | 328000h-32FFFFh | | 102 | 64/32 | Protection Group | 660000h-66FFFFh | 330000h-337FFFh | | 103 | 64/32 | | 670000h-67FFFh | 338000h-33FFFFh | | 104 | 64/32 | | 680000h-68FFFFh | 340000h-347FFFh | | 105 | 64/32 | Protection Group | 690000h-69FFFh | 348000h-34FFFFh | | 106 | 64/32 | Protection Group | 6A0000h-6AFFFFh | 350000h-357FFFh | | 107 | 64/32 | | 6B0000h-6BFFFFh | 358000h-35FFFFh | | 108 | 64/32 | | 6C0000h-6CFFFFh | 360000h-367FFFh | | 109 | 64/32 | Protection Group | 6D0000h-6DFFFFh | 368000h-36FFFFh | | 110 | 64/32 | Protection Group | 6E0000h-6EFFFFh | 370000h-377FFFh | | 111 | 64/32 | | 6F0000h-6FFFFh | 378000h-37FFFFh | | 112 | 64/32 | | 700000h-70FFFh | 380000h-387FFFh | | 113 | 64/32 | Protection Group | 710000h-71FFFFh | 388000h-38FFFFh | | 114 | 64/32 | 1 Totection Group | 720000h-72FFFh | 390000h-397FFFh | | 115 | 64/32 | | 730000h-73FFFFh | 398000h-39FFFFh | | 116 | 64/32 | | 740000h-74FFFh | 3A0000h-3A7FFFh | | 117 | 64/32 | Protection Group | 750000h-75FFFFh | 3A8000h-3AFFFFh | | 118 | 64/32 | Frotection Group | 760000h-76FFFh | 3B0000h-3B7FFFh | | 119 | 64/32 | | 770000h-77FFFFh | 3B8000h-3BFFFFh | | 120 | 64/32 | | 780000h-78FFFFh | 3C0000h-3C7FFFh | | 121 | 64/32 | Brotaction Croup | 790000h-79FFFh | 3C8000h-3CFFFFh | | 122 | 64/32 | Protection Group | 7A0000h-7AFFFFh | 3D0000h-3D7FFFh | | 123 | 64/32 | | 7B0000h-7BFFFFh | 3D8000h-3DFFFFh | | 124 | 64/32 | Protection Group | 7C0000h-7CFFFh | 3E0000h-3E7FFh | | 125 | 64/32 | Protection Group | 7D0000h-7DFFFFh | 3E8000h-3EFFFFh | | 126 | 64/32 | Protection Group | 7E0000h-7EFFFh | 3F0000h-3F7FFFh | | 127 | 64/32 | Protection Group | 7F0000h-7FFFFh | 3F8000h-3FFFFFh | <sup>1.</sup> Used as the Extended Block Addresses in Extended Block mode. Table 28. Top boot block addresses, M29W640GT | Block | KBytes/KWords | Protection Block Group | (8x) | (x16) | |-------|---------------|------------------------|--------------------------------|--------------------------------| | 0 | 64/32 | | 000000h-00FFFFh <sup>(1)</sup> | 000000h-007FFFh <sup>(1)</sup> | | 1 | 64/32 | Protection Group | 010000h-01FFFFh <sup>(1)</sup> | 008000h-00FFFFh <sup>(1)</sup> | | 2 | 64/32 | | 020000h-02FFFFh <sup>(1)</sup> | 010000h-017FFFh <sup>(1)</sup> | | 3 | 64/32 | | 030000h-03FFFFh <sup>(1)</sup> | 018000h-01FFFFh <sup>(1)</sup> | | 4 | 64/32 | | 040000h-04FFFFh | 020000h-027FFFh | | 5 | 64/32 | Protection Group | 050000h-05FFFFh | 028000h-02FFFFh | | 6 | 64/32 | Protection Group | 060000h-06FFFFh | 030000h-037FFFh | | 7 | 64/32 | | 070000h-07FFFh | 038000h-03FFFFh | | 8 | 64/32 | | 080000h-08FFFFh | 040000h-047FFFh | | 9 | 64/32 | Protection Group | 090000h-09FFFFh | 048000h-04FFFFh | | 10 | 64/32 | Protection Group | 0A0000h-0AFFFFh | 050000h-057FFFh | | 11 | 64/32 | | 0B0000h-0BFFFFh | 058000h-05FFFFh | | 12 | 64/32 | | 0C0000h-0CFFFh | 060000h-067FFh | | 13 | 64/32 | Protection Group | 0D0000h-0DFFFFh | 068000h-06FFFFh | | 14 | 64/32 | Protection Group | 0E0000h-0EFFFh | 070000h-077FFFh | | 15 | 64/32 | | 0F0000h-0FFFFh | 078000h-07FFFh | | 16 | 64/32 | | 100000h-10FFFFh | 080000h-087FFFh | | 17 | 64/32 | Protection Group | 110000h-11FFFFh | 088000h-08FFFFh | | 18 | 64/32 | Frotection Group | 120000h-12FFFFh | 090000h-097FFh | | 19 | 64/32 | | 130000h-13FFFFh | 098000h-09FFFFh | | 20 | 64/32 | | 140000h-14FFFFh | 0A0000h-0A7FFFh | | 21 | 64/32 | Protection Croup | 150000h-15FFFFh | 0A8000h-0AFFFFh | | 22 | 64/32 | Protection Group | 160000h-16FFFFh | 0B0000h-0B7FFFh | | 23 | 64/32 | | 170000h-17FFFFh | 0B8000h-0BFFFFh | | 24 | 64/32 | | 180000h-18FFFFh | 0C0000h-0C7FFFh | | 25 | 64/32 | Protection Croup | 190000h-19FFFFh | 0C8000h-0CFFFFh | | 26 | 64/32 | Protection Group | 1A0000h-1AFFFFh | 0D0000h-0D7FFFh | | 27 | 64/32 | | 1B0000h-1BFFFFh | 0D8000h-0DFFFFh | | 28 | 64/32 | | 1C0000h-1CFFFFh | 0E0000h-0E7FFh | | 29 | 64/32 | Protection Group | 1D0000h-1DFFFFh | 0E8000h-0EFFFFh | | 30 | 64/32 | Frotection Group | 1E0000h-1EFFFFh | 0F0000h-0F7FFh | | 31 | 64/32 | | 1F0000h-1FFFFh | 0F8000h-0FFFFh | Table 28. Top boot block addresses, M29W640GT (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 32 | 64/32 | | 200000h-20FFFFh | 100000h-107FFFh | | 33 | 64/32 | Protection Group - | 210000h-21FFFFh | 108000h-10FFFFh | | 34 | 64/32 | | 220000h-22FFFFh | 110000h-117FFFh | | 35 | 64/32 | | 230000h-23FFFFh | 118000h-11FFFFh | | 36 | 64/32 | | 240000h-24FFFFh | 120000h-127FFFh | | 37 | 64/32 | Drotaction Croup | 250000h-25FFFFh | 128000h-12FFFFh | | 38 | 64/32 | Protection Group | 260000h-26FFFFh | 130000h-137FFFh | | 39 | 64/32 | | 270000h-27FFFh | 138000h-13FFFFh | | 40 | 64/32 | | 280000h-28FFFFh | 140000h-147FFFh | | 41 | 64/32 | Protection Group | 290000h-29FFFFh | 148000h-14FFFFh | | 42 | 64/32 | Protection Group | 2A0000h-2AFFFFh | 150000h-157FFFh | | 43 | 64/32 | | 2B0000h-2BFFFFh | 158000h-15FFFFh | | 44 | 64/32 | | 2C0000h-2CFFFFh | 160000h-167FFFh | | 45 | 64/32 | Protection Group | 2D0000h-2DFFFFh | 168000h-16FFFFh | | 46 | 64/32 | Protection Group | 2E0000h-2EFFFFh | 170000h-177FFFh | | 47 | 64/32 | | 2F0000h-2FFFFh | 178000h-17FFFFh | | 48 | 64/32 | | 300000h-30FFFFh | 180000h-187FFFh | | 49 | 64/32 | Protection Group | 310000h-31FFFFh | 188000h-18FFFFh | | 50 | 64/32 | Protection Group | 320000h-32FFFFh | 190000h-197FFFh | | 51 | 64/32 | | 330000h-33FFFFh | 198000h-19FFFFh | | 52 | 64/32 | | 340000h-34FFFFh | 1A0000h-1A7FFFh | | 53 | 64/32 | Protection Group | 350000h-35FFFFh | 1A8000h-1AFFFFh | | 54 | 64/32 | 1 Totection Group | 360000h-36FFFFh | 1B0000h-1B7FFFh | | 55 | 64/32 | | 370000h-37FFFFh | 1B8000h-1BFFFFh | | 56 | 64/32 | | 380000h-38FFFFh | 1C0000h-1C7FFFh | | 57 | 64/32 | Protection Croup | 390000h-39FFFFh | 1C8000h-1CFFFFh | | 58 | 64/32 | Protection Group | 3A0000h-3AFFFFh | 1D0000h-1D7FFFh | | 59 | 64/32 | | 3B0000h-3BFFFFh | 1D8000h-1DFFFFh | | 60 | 64/32 | | 3C0000h-3CFFFh | 1E0000h-1E7FFh | | 61 | 64/32 | Protection Group | 3D0000h-3DFFFFh | 1E8000h-1EFFFFh | | 62 | 64/32 | Frotection Group | 3E0000h-3EFFFFh | 1F0000h-1F7FFFh | | 63 | 64/32 | | 3F0000h-3FFFFh | 1F8000h-1FFFFFh | Table 28. Top boot block addresses, M29W640GT (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 64 | 64/32 | | 400000h-40FFFFh | 200000h-207FFFh | | 65 | 64/32 | Protection Group | 410000h-41FFFFh | 208000h-20FFFFh | | 66 | 64/32 | | 420000h-42FFFFh | 210000h-217FFFh | | 67 | 64/32 | | 430000h-43FFFFh | 218000h-21FFFFh | | 68 | 64/32 | | 440000h-44FFFFh | 220000h-227FFFh | | 69 | 64/32 | Dretesties Creus | 450000h-45FFFFh | 228000h-22FFFFh | | 70 | 64/32 | Protection Group | 460000h-46FFFFh | 230000h-237FFFh | | 71 | 64/32 | | 470000h-47FFFFh | 238000h-23FFFFh | | 72 | 64/32 | | 480000h-48FFFFh | 240000h-247FFFh | | 73 | 64/32 | Protection Group | 490000h-49FFFFh | 248000h-24FFFFh | | 74 | 64/32 | Protection Group | 4A0000h-4AFFFFh | 250000h-257FFFh | | 75 | 64/32 | | 4B0000h-4BFFFFh | 258000h-25FFFFh | | 76 | 64/32 | | 4C0000h-4CFFFFh | 260000h-267FFFh | | 77 | 64/32 | Protection Croup | 4D0000h-4DFFFFh | 268000h-26FFFFh | | 78 | 64/32 | Protection Group | 4E0000h-4EFFFFh | 270000h-277FFFh | | 79 | 64/32 | | 4F0000h-4FFFFh | 278000h-27FFFFh | | 80 | 64/32 | | 500000h-50FFFFh | 280000h-287FFFh | | 81 | 64/32 | Protection Group | 510000h-51FFFFh | 288000h-28FFFFh | | 82 | 64/32 | Protection Group | 520000h-52FFFFh | 290000h-297FFFh | | 83 | 64/32 | | 530000h-53FFFFh | 298000h-29FFFFh | | 84 | 64/32 | | 540000h-54FFFFh | 2A0000h-2A7FFFh | | 85 | 64/32 | Protection Group | 550000h-55FFFFh | 2A8000h-2AFFFFh | | 86 | 64/32 | 1 Totection Group | 560000h-56FFFFh | 2B0000h-2B7FFFh | | 87 | 64/32 | | 570000h-57FFFh | 2B8000h-2BFFFFh | | 88 | 64/32 | | 580000h-58FFFFh | 2C0000h-2C7FFFh | | 89 | 64/32 | Protection Group | 590000h-59FFFFh | 2C8000h-2CFFFFh | | 90 | 64/32 | Protection Group | 5A0000h-5AFFFFh | 2D0000h-2D7FFFh | | 91 | 64/32 | | 5B0000h-5BFFFFh | 2D8000h-2DFFFFh | | 92 | 64/32 | | 5C0000h-5CFFFh | 2E0000h-2E7FFh | | 93 | 64/32 | Protection Group | 5D0000h-5DFFFFh | 2E8000h-2EFFFFh | | 94 | 64/32 | 1 Tote-ction Group | 5E0000h-5EFFFh | 2F0000h-2F7FFh | | 95 | 64/32 | | 5F0000h-5FFFFh | 2F8000h-2FFFFFh | Table 28. Top boot block addresses, M29W640GT (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 96 | 64/32 | | 600000h-60FFFFh | 300000h-307FFFh | | 97 | 64/32 | Protection Group | 610000h-61FFFFh | 308000h-30FFFFh | | 98 | 64/32 | | 620000h-62FFFFh | 310000h-317FFFh | | 99 | 64/32 | | 630000h-63FFFFh | 318000h-31FFFFh | | 100 | 64/32 | | 640000h-64FFFFh | 320000h-327FFFh | | 101 | 64/32 | Dretesties Creus | 650000h-65FFFFh | 328000h-32FFFFh | | 102 | 64/32 | Protection Group | 660000h-66FFFFh | 330000h-337FFFh | | 103 | 64/32 | | 670000h-67FFFh | 338000h-33FFFFh | | 104 | 64/32 | | 680000h-68FFFFh | 340000h-347FFFh | | 105 | 64/32 | Dretesties Creus | 690000h-69FFFFh | 348000h-34FFFFh | | 106 | 64/32 | Protection Group | 6A0000h-6AFFFFh | 350000h-357FFFh | | 107 | 64/32 | | 6B0000h-6BFFFFh | 358000h-35FFFFh | | 108 | 64/32 | | 6C0000h-6CFFFFh | 360000h-367FFFh | | 109 | 64/32 | Don't and in a Comme | 6D0000h-6DFFFFh | 368000h-36FFFFh | | 110 | 64/32 | Protection Group | 6E0000h-6EFFFFh | 370000h-377FFFh | | 111 | 64/32 | | 6F0000h-6FFFFh | 378000h-37FFFFh | | 112 | 64/32 | | 700000h-70FFFFh | 380000h-387FFFh | | 113 | 64/32 | Dretesties Creus | 710000h-71FFFFh | 388000h-38FFFFh | | 114 | 64/32 | Protection Group | 720000h-72FFFFh | 390000h-397FFFh | | 115 | 64/32 | | 730000h-73FFFFh | 398000h-39FFFFh | | 116 | 64/32 | | 740000h-74FFFFh | 3A0000h-3A7FFFh | | 117 | 64/32 | Drotaction Croup | 750000h-75FFFFh | 3A8000h-3AFFFFh | | 118 | 64/32 | Protection Group | 760000h-76FFFFh | 3B0000h-3B7FFFh | | 119 | 64/32 | | 770000h-77FFFFh | 3B8000h-3BFFFFh | | 120 | 64/32 | | 780000h-78FFFFh | 3C0000h-3C7FFFh | | 121 | 64/32 | Dretesties Creus | 790000h-79FFFFh | 3C8000h-3CFFFFh | | 122 | 64/32 | Protection Group | 7A0000h-7AFFFFh | 3D0000h-3D7FFFh | | 123 | 64/32 | | 7B0000h-7BFFFFh | 3D8000h-3DFFFFh | | 124 | 64/32 | | 7C0000h-7CFFFh | 3E0000h-3E7FFFh | | 125 | 64/32 | Protection Group | 7D0000h-7DFFFFh | 3E8000h-3EFFFFh | | 126 | 64/32 | | 7E0000h-7EFFFFh | 3F0000h-3F7FFFh | | 127 | 8/4 | Protection Group | 7F0000h-7F1FFFh | 3F8000h-3F8FFFh | | 128 | 8/4 | Protection Group | 7F2000h-7F3FFFh | 3F9000h-3F9FFFh | | 129 | 8/4 | Protection Group | 7F4000h-7F5FFFh | 3FA000h-3FAFFFh | | 130 | 8/4 | Protection Group | 7F6000h-7F7FFh | 3FB000h-3FBFFFh | Table 28. Top boot block addresses, M29W640GT (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 131 | 8/4 | Protection Group | 7F8000h-7F9FFFh | 3FC000h-3FCFFFh | | 132 | 8/4 | Protection Group | 7FA000h-7FBFFFh | 3FD000h-3FDFFFh | | 133 | 8/4 | Protection Group | 7FC000h-7FDFFFh | 3FE000h-3FEFFFh | | 134 | 8/4 | Protection Group | 7FE000h-7FFFFh | 3FF000h-3FFFFh | <sup>1.</sup> Used as the Extended Block Addresses in Extended Block mode. Table 29. Bottom boot block addresses, M29W640GB | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|--------------------------------|--------------------------------| | 0 | 8/4 | Protection Group | 000000h-001FFFh <sup>(1)</sup> | 000000h-000FFFh <sup>(1)</sup> | | 1 | 8/4 | Protection Group | 002000h-003FFFh <sup>(1)</sup> | 001000h-001FFFh <sup>(1)</sup> | | 2 | 8/4 | Protection Group | 004000h-005FFFh <sup>(1)</sup> | 002000h-002FFFh <sup>(1)</sup> | | 3 | 8/4 | Protection Group | 006000h-007FFFh <sup>(1)</sup> | 003000h-003FFFh <sup>(1)</sup> | | 4 | 8/4 | Protection Group | 008000h-009FFFh | 004000h-004FFFh | | 5 | 8/4 | Protection Group | 00A000h-00BFFFh | 005000h-005FFFh | | 6 | 8/4 | Protection Group | 00C000h-00DFFFh | 006000h-006FFFh | | 7 | 8/4 | Protection Group | 00E000h-00FFFFh | 007000h-007FFFh | | 8 | 64/32 | | 010000h-01FFFFh | 008000h-00FFFFh | | 9 | 64/32 | Protection Group | 020000h-02FFFFh | 010000h-017FFFh | | 10 | 64/32 | | 030000h-03FFFFh | 018000h-01FFFFh | | 11 | 64/32 | | 040000h-04FFFFh | 020000h-027FFFh | | 12 | 64/32 | Protection Croup | 050000h-05FFFFh | 028000h-02FFFFh | | 13 | 64/32 | Protection Group | 060000h-06FFFFh | 030000h-037FFFh | | 14 | 64/32 | | 070000h-07FFFh | 038000h-03FFFFh | | 15 | 64/32 | | 080000h-08FFFFh | 040000h-047FFFh | | 16 | 64/32 | Protection Croup | 090000h-09FFFFh | 048000h-04FFFFh | | 17 | 64/32 | Protection Group | 0A0000h-0AFFFFh | 050000h-057FFh | | 18 | 64/32 | | 0B0000h-0BFFFFh | 058000h-05FFFFh | | 19 | 64/32 | | 0C0000h-0CFFFFh | 060000h-067FFFh | | 20 | 64/32 | Protection Croup | 0D0000h-0DFFFFh | 068000h-06FFFFh | | 21 | 64/32 | Protection Group | 0E0000h-0EFFFFh | 070000h-077FFFh | | 22 | 64/32 | | 0F0000h-0FFFFh | 078000h-07FFFh | | 23 | 64/32 | | 100000h-10FFFFh | 080000h-087FFFh | | 24 | 64/32 | Protection Group | 110000h-11FFFFh | 088000h-08FFFFh | | 25 | 64/32 | | 120000h-12FFFFh | 090000h-097FFh | | 26 | 64/32 | | 130000h-13FFFFh | 098000h-09FFFFh | Table 29. Bottom boot block addresses, M29W640GB (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 27 | 64/32 | Protection Group | 140000h-14FFFFh | 0A0000h-0A7FFFh | | 28 | 64/32 | | 150000h-15FFFFh | 0A8000h-0AFFFFh | | 29 | 64/32 | | 160000h-16FFFFh | 0B0000h-0B7FFFh | | 30 | 64/32 | | 170000h-17FFFFh | 0B8000h-0BFFFFh | | 31 | 64/32 | Protection Group | 180000h-18FFFFh | 0C0000h-0C7FFFh | | 32 | 64/32 | | 190000h-19FFFFh | 0C8000h-0CFFFFh | | 33 | 64/32 | | 1A0000h-1AFFFFh | 0D0000h-0D7FFFh | | 34 | 64/32 | | 1B0000h-1BFFFFh | 0D8000h-0DFFFFh | | 35 | 64/32 | Protection Group | 1C0000h-1CFFFFh | 0E0000h-0E7FFh | | 36 | 64/32 | | 1D0000h-1DFFFFh | 0E8000h-0EFFFFh | | 37 | 64/32 | | 1E0000h-1EFFFFh | 0F0000h-0F7FFh | | 38 | 64/32 | | 1F0000h-1FFFFFh | 0F8000h-0FFFFh | | 39 | 64/32 | Protection Group | 200000h-20FFFFh | 100000h-107FFFh | | 40 | 64/32 | | 210000h-21FFFFh | 108000h-10FFFFh | | 41 | 64/32 | | 220000h-22FFFFh | 110000h-117FFFh | | 42 | 64/32 | | 230000h-23FFFFh | 118000h-11FFFFh | | 43 | 64/32 | Protection Group | 240000h-24FFFFh | 120000h-127FFFh | | 44 | 64/32 | | 250000h-25FFFFh | 128000h-12FFFFh | | 45 | 64/32 | | 260000h-26FFFFh | 130000h-137FFFh | | 46 | 64/32 | | 270000h-27FFFh | 138000h-13FFFFh | | 47 | 64/32 | | 280000h-28FFFFh | 140000h-147FFFh | | 48 | 64/32 | Protection Group | 290000h-29FFFFh | 148000h-14FFFFh | | 49 | 64/32 | Protection Group | 2A0000h-2AFFFFh | 150000h-157FFFh | | 50 | 64/32 | | 2B0000h-2BFFFFh | 158000h-15FFFFh | | 51 | 64/32 | Protection Group | 2C0000h-2CFFFFh | 160000h-167FFFh | | 52 | 64/32 | | 2D0000h-2DFFFFh | 168000h-16FFFFh | | 53 | 64/32 | | 2E0000h-2EFFFFh | 170000h-177FFFh | | 54 | 64/32 | | 2F0000h-2FFFFh | 178000h-17FFFFh | | 55 | 64/32 | Protection Group | 300000h-30FFFFh | 180000h-187FFFh | | 56 | 64/32 | | 310000h-31FFFFh | 188000h-18FFFFh | | 57 | 64/32 | | 320000h-32FFFFh | 190000h-197FFFh | | 58 | 64/32 | | 330000h-33FFFFh | 198000h-19FFFFh | Table 29. Bottom boot block addresses, M29W640GB (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 59 | 64/32 | Protection Group | 340000h-34FFFFh | 1A0000h-1A7FFFh | | 60 | 64/32 | | 350000h-35FFFFh | 1A8000h-1AFFFFh | | 61 | 64/32 | | 360000h-36FFFFh | 1B0000h-1B7FFFh | | 62 | 64/32 | | 370000h-37FFFFh | 1B8000h-1BFFFFh | | 63 | 64/32 | Protection Group | 380000h-38FFFFh | 1C0000h-1C7FFFh | | 64 | 64/32 | | 390000h-39FFFFh | 1C8000h-1CFFFFh | | 65 | 64/32 | | 3A0000h-3AFFFFh | 1D0000h-1D7FFFh | | 66 | 64/32 | | 3B0000h-3BFFFFh | 1D8000h-1DFFFFh | | 67 | 64/32 | Protection Group | 3C0000h-3CFFFFh | 1E0000h-1E7FFh | | 68 | 64/32 | | 3D0000h-3DFFFFh | 1E8000h-1EFFFFh | | 69 | 64/32 | | 3E0000h-3EFFFFh | 1F0000h-1F7FFFh | | 70 | 64/32 | | 3F0000h-3FFFFFh | 1F8000h-1FFFFFh | | 71 | 64/32 | Protection Group | 400000h-40FFFFh | 200000h-207FFFh | | 72 | 64/32 | | 410000h-41FFFFh | 208000h-20FFFFh | | 73 | 64/32 | | 420000h-42FFFFh | 210000h-217FFFh | | 74 | 64/32 | | 430000h-43FFFFh | 218000h-21FFFFh | | 75 | 64/32 | Protection Group | 440000h-44FFFFh | 220000h-227FFFh | | 76 | 64/32 | | 450000h-45FFFFh | 228000h-22FFFFh | | 77 | 64/32 | | 460000h-46FFFFh | 230000h-237FFFh | | 78 | 64/32 | | 470000h-47FFFFh | 238000h-23FFFFh | | 79 | 64/32 | | 480000h-48FFFFh | 240000h-247FFFh | | 80 | 64/32 | Drataction Croup | 490000h-49FFFFh | 248000h-24FFFFh | | 81 | 64/32 | Protection Group | 4A0000h-4AFFFFh | 250000h-257FFFh | | 82 | 64/32 | | 4B0000h-4BFFFFh | 258000h-25FFFFh | | 83 | 64/32 | Protection Group | 4C0000h-4CFFFFh | 260000h-267FFFh | | 84 | 64/32 | | 4D0000h-4DFFFFh | 268000h-26FFFFh | | 85 | 64/32 | | 4E0000h-4EFFFFh | 270000h-277FFFh | | 86 | 64/32 | | 4F0000h-4FFFFFh | 278000h-27FFFFh | | 87 | 64/32 | Protection Group | 500000h-50FFFh | 280000h-287FFFh | | 88 | 64/32 | | 510000h-51FFFFh | 288000h-28FFFFh | | 89 | 64/32 | | 520000h-52FFFFh | 290000h-297FFh | | 90 | 64/32 | | 530000h-53FFFFh | 298000h-29FFFFh | Table 29. Bottom boot block addresses, M29W640GB (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 91 | 64/32 | | 540000h-54FFFFh | 2A0000h-2A7FFFh | | 92 | 64/32 | 5 | 550000h-55FFFFh | 2A8000h-2AFFFFh | | 93 | 64/32 | Protection Group | 560000h-56FFFFh | 2B0000h-2B7FFFh | | 94 | 64/32 | | 570000h-57FFFh | 2B8000h-2BFFFFh | | 95 | 64/32 | | 580000h-58FFFFh | 2C0000h-2C7FFFh | | 96 | 64/32 | Desta dia Garage | 590000h-59FFFFh | 2C8000h-2CFFFFh | | 97 | 64/32 | Protection Group | 5A0000h-5AFFFFh | 2D0000h-2D7FFFh | | 98 | 64/32 | | 5B0000h-5BFFFFh | 2D8000h-2DFFFFh | | 99 | 64/32 | | 5C0000h-5CFFFFh | 2E0000h-2E7FFh | | 100 | 64/32 | Drataction Croup | 5D0000h-5DFFFFh | 2E8000h-2EFFFFh | | 101 | 64/32 | Protection Group | 5E0000h-5EFFFFh | 2F0000h-2F7FFFh | | 102 | 64/32 | | 5F0000h-5FFFFFh | 2F8000h-2FFFFFh | | 103 | 64/32 | | 600000h-60FFFFh | 300000h-307FFFh | | 104 | 64/32 | Dratastian Craus | 610000h-61FFFFh | 308000h-30FFFFh | | 105 | 64/32 | Protection Group | 620000h-62FFFFh | 310000h-317FFFh | | 106 | 64/32 | | 630000h-63FFFFh | 318000h-31FFFFh | | 107 | 64/32 | | 640000h-64FFFFh | 320000h-327FFFh | | 108 | 64/32 | Protection Croup | 650000h-65FFFFh | 328000h-32FFFFh | | 109 | 64/32 | Protection Group | 660000h-66FFFFh | 330000h-337FFFh | | 110 | 64/32 | | 670000h-67FFFh | 338000h-33FFFFh | | 111 | 64/32 | | 680000h-68FFFFh | 340000h-347FFFh | | 112 | 64/32 | Protection Group | 690000h-69FFFFh | 348000h-34FFFFh | | 113 | 64/32 | Flotection Gloup | 6A0000h-6AFFFFh | 350000h-357FFFh | | 114 | 64/32 | | 6B0000h-6BFFFFh | 358000h-35FFFFh | | 115 | 64/32 | | 6C0000h-6CFFFh | 360000h-367FFFh | | 116 | 64/32 | Protection Group | 6D0000h-6DFFFFh | 368000h-36FFFFh | | 117 | 64/32 | Protection Group | 6E0000h-6EFFFFh | 370000h-377FFFh | | 118 | 64/32 | | 6F0000h-6FFFFh | 378000h-37FFFh | | 119 | 64/32 | | 700000h-70FFFh | 380000h-387FFFh | | 120 | 64/32 | Protection Group | 710000h-71FFFFh | 388000h-38FFFFh | | 121 | 64/32 | i iolection Group | 720000h-72FFFh | 390000h-397FFFh | | 122 | 64/32 | | 730000h-73FFFFh | 398000h-39FFFFh | Table 29. Bottom boot block addresses, M29W640GB (continued) | Block | KBytes/KWords | Protection Block Group | (x8) | (x16) | |-------|---------------|------------------------|-----------------|-----------------| | 123 | 64/32 | | 740000h-74FFFFh | 3A0000h-3A7FFFh | | 124 | 64/32 | Protection Group | 750000h-75FFFFh | 3A8000h-3AFFFFh | | 125 | 64/32 | r rotection Group | 760000h-76FFFh | 3B0000h-3B7FFFh | | 126 | 64/32 | | 770000h-77FFFFh | 3B8000h-3BFFFFh | | 127 | 64/32 | | 780000h-78FFFFh | 3C0000h-3C7FFFh | | 128 | 64/32 | Protection Group | 790000h-79FFFFh | 3C8000h-3CFFFFh | | 129 | 64/32 | Flotection Gloup | 7A0000h-7AFFFFh | 3D0000h-3D7FFFh | | 130 | 64/32 | | 7B0000h-7BFFFFh | 3D8000h-3DFFFFh | | 131 | 64/32 | | 7C0000h-7CFFFFh | 3E0000h-3E7FFh | | 132 | 64/32 | Protection Group | 7D0000h-7DFFFFh | 3E8000h-3EFFFFh | | 133 | 64/32 | r Totection Group | 7E0000h-7EFFFFh | 3F0000h-3F7FFFh | | 134 | 64/32 | | 7F0000h-7FFFFh | 3F8000h-3FFFFh | <sup>1.</sup> Used as the Extended Block Addresses in Extended Block mode. ### Appendix B Common Flash Interface (CFI) The Common Flash Interface is a JEDEC approved, standardized data structure that can be read from the Flash memory device. It allows a system software to query the device to determine various electrical and timing parameters, density information and functions supported by the memory. The system can interface easily with the device, enabling the software to upgrade itself when necessary. When the CFI Query Command is issued the device enters CFI Query mode and the data structure is read from the memory. Tables 30, 31, 32, 33, 34, and 35, show the addresses used to retrieve the data. The CFI data structure also contains a security area where a 64 bit unique security number is written (see *Table 35: Security code area*). This area can be accessed only in Read mode by the final user. It is impossible to change the security number after it has been written by ST. Table 30. Query structure overview<sup>(1)</sup> | Add | ress | Sub-section Name | Description | | |-----|------|-------------------------------------------------|---------------------------------------------------------------------|--| | x16 | x8 | Sub-section Name | | | | 10h | 20h | CFI Query Identification String | Command set ID and algorithm data offset | | | 1Bh | 36h | System Interface Information | Device timing & voltage information | | | 27h | 4Eh | Device Geometry Definition | Flash device layout | | | 40h | 80h | Primary Algorithm-specific Extended Query table | Additional information specific to the Primary Algorithm (optional) | | | 61h | C2h | Security Code Area | 64 bit unique device number | | <sup>1.</sup> Query data are always presented on the lowest order data outputs. Table 31. CFI query identification string<sup>(1)</sup> | Add | ress | Doto | Doscription | | | |-----|------|-------|-------------------------------------------------------------|------------|--| | x16 | х8 | Data | Description | Value | | | 10h | 20h | 0051h | | "Q" | | | 11h | 22h | 0052h | Query Unique ASCII String "QRY" | "R" | | | 12h | 24h | 0059h | | "Y" | | | 13h | 26h | 0002h | Primary Algorithm Command Set and Control Interface ID code | AMD | | | 14h | 28h | 0000h | 16 bit ID code defining a specific algorithm | Compatible | | | 15h | 2Ah | 0040h | Address for Primary Algorithm extended Query table (see | P = 40h | | | 16h | 2Ch | 0000h | Table 34) | P = 4011 | | | 17h | 2Eh | 0000h | Alternate Vendor Command Set and Control Interface ID Code | NA | | | 18h | 30h | 0000h | second vendor - specified algorithm supported | INA | | | 19h | 32h | 0000h | Address for Alternate Algerithm extended Query table | NA | | | 1Ah | 34h | 0000h | Address for Alternate Algorithm extended Query table | INA | | <sup>1.</sup> Query data are always presented on the lowest order data outputs (DQ7-DQ0) only. DQ8-DQ15 are '0'. Table 32. CFI query system interface information | Add | ress | Data | Description | Value | |-----|------|-------|-------------------------------------------------------------------------------------------------------------------------------------|-------| | x16 | х8 | Dala | Description | value | | 1Bh | 36h | 0027h | V <sub>CC</sub> Logic Supply Minimum Program/Erase voltage bit 7 to 4BCD value in volts bit 3 to 0BCD value in 100 mV | 2.7V | | 1Ch | 38h | 0036h | V <sub>CC</sub> Logic Supply Maximum Program/Erase voltage bit 7 to 4BCD value in volts bit 3 to 0BCD value in 100 mV | 3.6V | | 1Dh | 3Ah | 00B5h | V <sub>PP</sub> [Programming] Supply Minimum Program/Erase voltage<br>bit 7 to 4HEX value in volts<br>bit 3 to 0BCD value in 100 mV | 11.5V | | 1Eh | 3Ch | 00C5h | V <sub>PP</sub> [Programming] Supply Maximum Program/Erase voltage<br>bit 7 to 4HEX value in volts<br>bit 3 to 0BCD value in 100 mV | 12.5V | | 1Fh | 3Eh | 0004h | Typical timeout per single Byte/Word program = 2 <sup>n</sup> µs | 16µs | | 20h | 40h | 0000h | Typical timeout for minimum size write buffer program = 2 <sup>n</sup> µs | NA | | 21h | 42h | 000Ah | Typical timeout per individual Block Erase = 2 <sup>n</sup> ms | 1s | | 22h | 44h | 0000h | Typical timeout for full Chip Erase = 2 <sup>n</sup> ms | NA | | 23h | 46h | 0004h | Maximum timeout for Byte/Word program = 2 <sup>n</sup> times typical | 256µs | | 24h | 48h | 0000h | Maximum timeout for write buffer program = 2 <sup>n</sup> times typical | NA | | 25h | 4Ah | 0003h | Maximum timeout per individual Block Erase = 2 <sup>n</sup> times typical | 8s | | 26h | 4Ch | 0000h | Maximum timeout for Chip Erase = 2 <sup>n</sup> times typical | NA | Table 33. Device geometry definition<sup>(1)</sup> | Add | lress | - Data | | Description | Value | |--------------------------|--------------------------|---------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------| | x16 | x8 | | | Description | Value | | 27h | 4Eh | 0017h | | Device Size = 2 <sup>n</sup> in number of Bytes | 8 MBytes | | 28h<br>29h | 50h<br>52h | 0002h<br>0000h | | Flash Device Interface Code description | x8, x16<br>Async. | | 2Ah<br>2Bh | 54h<br>56h | 0005h<br>0000h | | Maximum number of Bytes in multi-byte program or page = 2 <sup>n</sup> | 32 Bytes | | 2Ch | 58h | M29W640GH,<br>M29W640GL | 0001h | Number of Erase Block Regions. It specifies the number of regions containing contiguous Erase Blocks of the same | 1 | | 2011 | 3011 | M29W640GT,<br>M29W640GB | 0002h | size. | 2 | | 2Dh<br>2Eh | 5Ah<br>5Ch | M29W640GH, | 007Fh<br>0000h | 3 - | 128 | | 2Fh<br>30h | 5Eh<br>60h | M29W640GL | 0000h<br>0001h | | 64KBytes | | 2Dh<br>2Eh | 5Ah<br>5Ch | M29W640GT, | 0007h<br>0000h | 3 | 8 | | 2Fh<br>30h | 5Eh<br>60h | M29W640GB | 0020h<br>0000h | | 8Kbyte | | 31h<br>32h | 62h<br>64h | | 007Eh<br>0000h | | 127 | | 33h<br>34h | 66h<br>68h | | 0000h<br>0001h | | 64KBytes | | 35h<br>36h<br>37h<br>38h | 6Ah<br>6Ch<br>6Eh<br>70h | M29W640GT,<br>M29W640GB<br>only | 0000h<br>0000h<br>0000h<br>0000h | Region 3 Information | 0 | | 39h<br>3Ah<br>3Bh | 72h<br>74h<br>76h | | 0000h<br>0000h<br>0000h | Number of Erase Blocks of Identical size=007Fh+1 Region 4 Information | 0 | | 3Ch | 78h | | 0000h | Block size in Region 4 = 0000h * 256 byte | 0 | For Bottom Boot devices, Erase Block Region 1 is located from address 000000h to 007FFFh and Erase Block Region 2 from address 008000h to 3FFFFFh. For Top Boot devices, Erase Block Region 1 is located from address 000000h to 3F7FFFh and Erase Block Region 2 from address 3F8000h to 3FFFFFh. 47/ Table 34. Primary algorithm-specific extended query table | Address | | Dete | Post 4 | | | | |---------|-----|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|--| | x16 | x8 | Data | Description | Value | | | | 40h | 80h | 0050h | | "P" | | | | 41h | 82h | 0052h | Primary Algorithm extended Query table unique ASCII string "PRI" | "R" | | | | 42h | 84h | 0049h | | " " | | | | 43h | 86h | 0031h | Major version number, ASCII | "1" | | | | 44h | 88h | 0033h | Minor version number, ASCII | "3" | | | | 45h | 8Ah | 0000h | Address Sensitive Unlock (bits 1 to 0) 00h = required, 01h = not required Silicon Revision Number (bits 7 to 2) | Yes | | | | 46h | 8Ch | 0002h | Erase Suspend 00h = not supported, 01h = Read only, 02 = Read and Write | 2 | | | | 47h | 8Eh | 0004h | Block Protection 00h = not supported, x = number of blocks per protection group | 4 | | | | 48h | 90h | 0001h | emporary Block Unprotect 0h = not supported, 01h = supported | | | | | 49h | 92h | 0004h | Block Protect /Unprotect | 04 | | | | 4Ah | 94h | 0000h | Simultaneous Operations, 00h = not supported | No | | | | 4Bh | 96h | 0000h | Burst Mode: 00h = not supported, 01h = supported | No | | | | 4Ch | 98h | 0001h | Page Mode: 00h = not supported, 01h = 4 page Word, 02h = 8 page Word | Yes | | | | 4Dh | 9Ah | 00B5h | PP Supply Minimum Program/Erase voltage it 7 to 4 HEX value in volts it 3 to 0 BCD value in 100 mV | | | | | 4Eh | 9Ch | 00C5h | / <sub>PP</sub> Supply Maximum Program/Erase voltage bit 7 to 4 HEX value in volts bit 3 to 0 BCD value in 100 mV | | | | | 4Fh | 9Eh | 0002h<br>0003h<br>0004h<br>0005h | Top/Bottom Boot Block Flag 129W640GB 129W640GT 129W640GL 129W640GL 129W640GL 129W640GH 129W640GH 129W640GH 129W640GH 129W640GH 129W640GH 129W640GH 129W640GH | | | | | 50h | A0h | 0001h | rogram Suspend Oh = Not Supported 1h = Supported | | | | Table 35. Security code area | Address | | Data | Description | | |---------|----------|------|------------------------------|--| | x16 | х8 | Data | Description | | | 61h | C3h, C2h | XXXX | | | | 62h | C5h, C4h | XXXX | 64 hit: unique device number | | | 63h | C7h, C6h | XXXX | 64 bit: unique device number | | | 64h | C9h, C8h | XXXX | | | ### **Appendix C** Extended Memory Block The M29W640G has an extra block, the Extended Block, that can be accessed using a dedicated command. This Extended Block is 128 Words in x16 mode and 256 Bytes in x8 mode. It is used as a security block to provide a permanent security identification number) or to store additional information. The Extended Block is either Factory Locked or Customer Lockable, its status is indicated by bit DQ7. This bit is permanently set to either '1' or '0' at the factory and cannot be changed. When set to '1', it indicates that the device is factory locked and the Extended Block is protected. When set to '0', it indicates that the device is customer lockable and the Extended Block is unprotected. Bit DQ7 being permanently locked to either '1' or '0' is another security feature which ensures that a customer lockable device cannot be used instead of a factory locked one. Bit DQ7 is the most significant bit in the Extended Block Verify Code and a specific procedure must be followed to read it. See "Extended Memory Block Verify Code" in *Table 7:* Bus Operations, BYTE = VIL and Table 8: Bus Operations, BYTE = VIH, for details of how to read bit DQ7. The Extended Block can only be accessed when the device is in Extended Block mode. For details of how the Extended Block mode is entered and exited, refer to the Section 4.3.1: Enter Extended Block command and Section 4.3.2: Exit Extended Block command, and to Table 10 and Table 11: Commands, 8-bit mode, BYTE = VIL. #### C.1 Factory Locked Extended Block In devices where the Extended Block is factory locked, the Security Identification Number is written to the Extended Block address space (see *Table 36: Extended block address and data*) in the factory. The DQ7 bit is set to '1' and the Extended Block cannot be unprotected. #### C.2 Customer Lockable Extended Block A device where the Extended Block is customer lockable is delivered with the DQ7 bit set to '0' and the Extended Block unprotected. It is up to the customer to program and protect the Extended Block but care must be taken because the protection of the Extended Block is not reversible. There are two ways of protecting the Extended Block: - Issue the Enter Extended Block command to place the device in Extended Block mode, then use the In-System Technique with RP either at V<sub>IH</sub> or at V<sub>ID</sub> (refer to Section D.2: In-System Technique and to the corresponding flowcharts, Figure 27 and Figure 28, for a detailed explanation of the technique). - Issue the Enter Extended Block command to place the device in Extended Block mode, then use the Programmer Technique (refer to, Section D.1: Programmer Technique and to the corresponding flowcharts, Figure 25 and Figure 26, for a detailed explanation of the technique). Once the Extended Block is programmed and protected, the Exit Extended Block command must be issued to exit the Extended Block mode and return the device to Read mode. Table 36. Extended block address and data | Add | ress | Data | | |-----------------|-----------------|--------------------------------|-------------------| | х8 | x16 | Factory Locked | Customer Lockable | | 000000h-00007Fh | 000000h-00003Fh | Security Identification Number | Determined by | | 000080h-0000FFh | 000040h-00007Fh | Unavailable | Customer | 81/91 ### Appendix D Block Protection Block protection can be used to prevent any operation from modifying the data stored in the memory. The blocks are protected in groups, refer to *Appendix A: Block addresses*, *Table 28* and *Table 29* for details of the Protection Groups. Once protected, Program and Erase operations within the protected group fail to change the data. There are three techniques that can be used to control Block Protection, these are the Programmer technique, the In-System technique and Temporary Unprotection. Temporary Unprotection is controlled by the Reset/Block Temporary Unprotection pin, $\overline{RP}$ ; this is described in the Signal Descriptions section. #### D.1 Programmer Technique The Programmer technique uses high $(V_{ID})$ voltage levels on some of the bus pins. These cannot be achieved using a standard microprocessor bus, therefore the technique is recommended only for use in Programming Equipment. To protect a group of blocks follow the flowchart in *Figure 25: Programmer Equipment Group Protect flowchart.* To unprotect the whole chip it is necessary to protect all of the groups first, then all groups can be unprotected at the same time. To unprotect the chip follow *Figure 26: Programmer Equipment Chip Unprotect flowchart. Table 37: Programmer technique bus operations, BYTE = VIH or VIL, gives a summary of each operation.* The timing on these flowcharts is critical. Care should be taken to ensure that, where a pause is specified, it is followed as closely as possible. Do not abort the procedure before reaching the end. Chip Unprotect can take several seconds and a user message should be provided to show that the operation is progressing. ## D.2 In-System Technique The In-System technique requires a high voltage level on the Reset/Blocks Temporary Unprotect pin, $\overline{RP}^{(1)}$ . This can be achieved without violating the maximum ratings of the components on the microprocessor bus, therefore this technique is suitable for use after the memory has been fitted to the system. To protect a group of blocks follow the flowchart in *Figure 27: In-System Equipment Group Protect flowchart*. To unprotect the whole chip it is necessary to protect all of the groups first, then all the groups can be unprotected at the same time. To unprotect the chip follow *Figure 28: In-System Equipment Chip Unprotect flowchart*. The timing on these flowcharts is critical. Care should be taken to ensure that, where a pause is specified, it is followed as closely as possible. Do not allow the microprocessor to service interrupts that will upset the timing and do not abort the procedure before reaching the end. Chip Unprotect can take several seconds and a user message should be provided to show that the operation is progressing. Note: $\overline{RP}$ can be either at $V_{IH}$ or at $V_{ID}$ when using the In-System Technique to protect the Extended Block. Table 37. Programmer technique bus operations, $\overline{\text{BYTE}} = V_{\text{IH}}$ or $V_{\text{IL}}$ | Operation | Ē | G | w | Address Inputs<br>A0-A21 | Data<br>Inputs/Outputs<br>DQ15A-1, DQ14-<br>DQ0 | |-----------------------------------------|-----------------|-----------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | Block (Group)<br>Protect <sup>(1)</sup> | V <sub>IL</sub> | V <sub>ID</sub> | V <sub>IL</sub> Pulse | $A9 = V_{ID}$ , $A12-A21 = Block Address$<br>Others = X | Х | | Chip Unprotect | V <sub>ID</sub> | V <sub>ID</sub> | V <sub>IL</sub> Pulse | $A9 = V_{ID}, A12 = V_{IH}, A15 = V_{IH}$ $Others = X$ | Х | | Block (Group)<br>Protection Verify | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | A0, A2, A3 = $V_{IL}$ , A1 = $V_{IH}$ , A6 = $V_{IL}$ ,<br>A9 = $V_{ID}$ , A12-A21 = Block Address<br>Others = X | Pass = XX01h<br>Retry = XX00h | | Block (Group)<br>Unprotection Verify | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | $\begin{array}{l} \text{A0, A2, A3} = \text{V}_{\text{IL}}, \text{A1} = \text{V}_{\text{IH}}, \text{A6} = \text{V}_{\text{IH}}, \\ \text{A9} = \text{V}_{\text{ID}}, \text{A12-A21} = \text{Block Address} \\ \text{Others} = \text{X} \end{array}$ | Retry = XX01h<br>Pass = XX00h | <sup>1.</sup> Block Protection Groups are shown in *Appendix A*, Tables 28 and 29. Figure 25. Programmer Equipment Group Protect flowchart 1. Block Protection Groups are shown in *Appendix A*, Tables 28 and 29. Figure 26. Programmer Equipment Chip Unprotect flowchart 1. Block Protection Groups are shown in Appendix A, Tables 28 and 29. Figure 27. In-System Equipment Group Protect flowchart - 2. Block Protection Groups are shown in *Appendix A*, Tables 28 and 29. - 3. $\overline{RP}$ can be either at $V_{IH}$ or at $V_{ID}$ when using the In-System Technique to protect the Extended Block. Figure 28. In-System Equipment Chip Unprotect flowchart 1. Block Protection Groups are shown in Appendix A, Tables 28 and 29. ## Appendix E Flowchart - 1. n+1 is the number of addresses to be programmed. - 2. A Write to Buffer and Program Abort and Reset must be issued to return the device in Read mode. - 3. When the block address is specified, any address in the selected block address space is acceptable. However when loading Write Buffer address with data, all addresses must fall within the selected Write Buffer page. - 4. DQ7 must be checked since DQ5 and DQ7 may change simultaneously. - 5. If this flowchart location is reached because DQ5='1', then the Write to Buffer and Program command failed. If this flowchart location is reached because DQ1='1', then the Write to Buffer and Program command aborted. In both cases, the appropriate reset command must be issued to return the device in Read mode: a Reset command if the operation failed, a Write to Buffer and Program Abort and Reset command if the operation aborted. - 6. See Table 10 and Table 11, for details on Write to Buffer and Program command sequence. # **Revision history** Table 38. Document revision history | Date | Version | Changes | |-------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 20-Jul-2006 | 1 | Initial release. | | 21-Aug-2006 | 2 | Datasheet status updated to full datasheet; added an explanation of how to abort the Write Buffer Programming Sequence in Section 4.2.9: Write to Buffer and Program command; amended text of 4.2.11: Write to Buffer and Program Abort and Reset command | #### Please Read Carefully: Information in this document is provided solely in connection with ST products. STMicroelectronics NV and its subsidiaries ("ST") reserve the right to make changes, corrections, modifications or improvements, to this document, and the products and services described herein at any time, without notice. All ST products are sold pursuant to ST's terms and conditions of sale. Purchasers are solely responsible for the choice, selection and use of the ST products and services described herein, and ST assumes no liability whatsoever relating to the choice, selection or use of the ST products and services described herein. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted under this document. If any part of this document refers to any third party products or services it shall not be deemed a license grant by ST for the use of such third party products or services, or any intellectual property contained therein or considered as a warranty covering the use in any manner whatsoever of such third party products or services or any intellectual property contained therein. UNLESS OTHERWISE SET FORTH IN ST'S TERMS AND CONDITIONS OF SALE ST DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY WITH RESPECT TO THE USE AND/OR SALE OF ST PRODUCTS INCLUDING WITHOUT LIMITATION IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE (AND THEIR EQUIVALENTS UNDER THE LAWS OF ANY JURISDICTION), OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT. UNLESS EXPRESSLY APPROVED IN WRITING BY AN AUTHORIZED ST REPRESENTATIVE, ST PRODUCTS ARE NOT RECOMMENDED, AUTHORIZED OR WARRANTED FOR USE IN MILITARY, AIR CRAFT, SPACE, LIFE SAVING, OR LIFE SUSTAINING APPLICATIONS, NOR IN PRODUCTS OR SYSTEMS WHERE FAILURE OR MALFUNCTION MAY RESULT IN PERSONAL INJURY, DEATH, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE. ST PRODUCTS WHICH ARE NOT SPECIFIED AS "AUTOMOTIVE GRADE" MAY ONLY BE USED IN AUTOMOTIVE APPLICATIONS AT USER'S OWN RISK. Resale of ST products with provisions different from the statements and/or technical features set forth in this document shall immediately void any warranty granted by ST for the ST product or service described herein and shall not create or extend in any manner whatsoever, any liability of ST. ST and the ST logo are trademarks or registered trademarks of ST in various countries. Information in this document supersedes and replaces all information previously supplied. The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners. © 2006 STMicroelectronics - All rights reserved STMicroelectronics group of companies Australia - Belgium - Brazil - Canada - China - Czech Republic - Finland - France - Germany - Hong Kong - India - Israel - Italy - Japan - Malaysia - Malta - Morocco - Singapore - Spain - Sweden - Switzerland - United Kingdom - United States of America www.st.com