## M29F040 | PIN NAMES | | | | | | | | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | A0 - A18 Address Input CE Chip Enable WE Write Enable OE Output Enable DQ0 - DQ7 Data Input/Output VCC Power Supply VSS Ground | | | | | | | | | | ## Advance Information # **4M CMOS Sector Erase Flash Memory** The M29F040 is a 4M, 5 V-only, sector erase flash memory organized as 512K bytes of 8 bits each. The M29F040 is offered in JEDEC-standard 32-pin packages. - 5.0 V ± 10% Read, Write and Erase Minimizes System Level Power Requirements - JEDEC Industry Standard Pin-Out and Architecture - Compatible with JEDEC-Standard (E<sup>2</sup>PROM) Commands - Minimum 100,000 Write/Erase Cycles - · Sector Erase Architecture: Eight Equal Size Sectors of 64K Bytes Each Any Combination of Sectors can be Concurrently Erased Supports Full Chip Erase - Embedded Erase™ Algorithms Allow Automatic Preprogram and Erase at any Sector - Embedded Program™ Algorithms Allow Automatic Write and Verify of Data at a Specified Address - Data Polling and Toggle Bit Feature for Detection of Program or Erase Cycle Completion - Sector Protection Allows Hardware Disable of Sectors from Write or Erase Operations - Low V<sub>CC</sub> Write Inhibit ≤ 3.2 V - Suspend Erase/Resume Feature to Allow a Read Cycle in Another Sector Within the Same Device - Fast Access Time: M29F040-75 = 70 ns (Max) M29F040-90 = 90 ns (Max) M29F040-12 = 120 (Max) Low Active Power Dissipation: M29F040-75 = 315 mW M29F040-90 = 330 mWM29F040-12 = 330 mW • Low Standby Power Dissipation: TTL Levels: M29F040-75 = 5.3 mW M29F040-90 = 5.5 mW M29F040-12 = 5.5 mW CMOS Levels: M29F040-75 = 0.53 mW M29F040-90 = 0.55 mW M29F040-12 = 0.55 mW \*MOTOS251\* Embedded Erase and Embedded Program are trademarks of Advanced Micro Devices, Inc. This document contains information on a new product. Specifications and information herein are subject to change without notice. ## PIN ASSIGNMENTS PLCC #### TSOP STANDARD PINOUT #### TSOP REVERSE PINOUT #### **BLOCK DIAGRAM** MOTOROLA FLASH M29F040 #### ABSOLUTE MAXIMUM RATINGS (See Notes 1 through 4) | Rating | Symbol | Value | Unit | |----------------------------------------------------------------------------------------------|------------------------------------|--------------------------------|------| | Power Supply Voltage (Note 1) | Vcc | - 2.0 to + 7 | ٧ | | Voltage Relative to V <sub>SS</sub> : All Pins Except A9, CE, and OE (Note 1) A9, CE, and OE | V <sub>in</sub> , V <sub>out</sub> | - 2.0 to + 7<br>- 2.0 to + 14 | V | | Output Short Circuit Current (Note 3) | lout | 200 | mA | | Power Dissipation | PD | 420 | mW | | Ambient Temperature with Power Applied | TA | - 55 to + 125 | °C | | Storage Temperature Range<br>Ceramic Package<br>Plastic Package | T <sub>stg</sub> | - 65 to + 150<br>- 65 to + 125 | °C | #### NOTES: - 1. Minimum dc voltage on input or I/O pins is -0.5 V. During voltage transitions, inputs may undershoot VSS to -2.0 V for periods of up to 20 ns. Maximum dc voltage on output and I/O pins is VCC + 0.5 V. During voltage transitions, outputs may overshoot to VCC + 2.0 V for periods of up to 20 ns. - 2. Minimum dc voltage on pin A9, $\overline{\text{CE}}$ , and $\overline{\text{OE}}$ is 0.5 V. During voltage transitions, A9, $\overline{\text{CE}}$ , and $\overline{\text{OE}}$ may undershoot V to 2.0 V for periods of up to 20 ns. Maximum dc input voltage on A9, $\overline{\text{CE}}$ , and $\overline{\text{OE}}$ is + 13.5 V which may overshoot to 14.0 VSS for periods up to 20 ns. - 3. No more than one output shorted at a time Duration of the short circuit should not be longer than one second. - 4. Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to RECOMMENDED OPER-ATING CONDITIONS. Exposure to higher than recommended voltages for extended periods of time could affect device reliability #### **OPERATING RANGES** (See Note) | Rating | Symbol | Value | Unit | | |----------------------------------------------------------------------------------|--------|--------------------------------------|------|--| | Supply Voltages<br>M29F040-75 = 70 ns<br>M29F040-90 = 90 ns, M29F040-12 = 120 ns | Vcc | + 4.75 to + 5.25<br>+ 4.50 to + 5.50 | V | | | Operating Temperature Range<br>Commercial<br>Industrial | ТС | 0 to + 70<br>- 40 to + 85 | °C | | NOTE: Operating ranges define those limits between which the functionality of the device is guaranteed. #### LATCHUP CHARACTERISTICS | | Min | Max | |---------------------------------------------------------------|----------|-------------------------| | Input Voltage with respect to V <sub>SS</sub> on all I/O pins | – 1.0 V | V <sub>CC</sub> + 1.0 V | | V <sub>CC</sub> Current | – 100 mA | + 100 mA | Includes all pins except $V_{CC}$ . Test conditions: $V_{CC} = 5.0 \text{ V}$ , one pin at a time. #### DC OPERATING CONDITIONS AND CHARACTERISTICS #### **DC CHARACTERISTICS** | Characteristic | Symbol | Min | Max | Unit | Notes | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------|------------------------------------------------|----------|-------| | V <sub>CC</sub> Active Current (CE = V <sub>IL</sub> , OE = V <sub>IH</sub> ) | ICC1 | | 40 | mA | 1 | | V <sub>CC</sub> Active Current (CE = V <sub>IL</sub> , OE = V <sub>IH</sub> ) | ICC2 | | 60 | mA | 2, 3 | | $V_{CC}$ Standby Current TTL/NMOS Levels ( $V_{CC} = V_{CC}$ max, $\overline{CE} = V_{IH}$ , $\overline{OE} = V_{IH}$ ) CMOS Levels ( $V_{CC} = V_{CC}$ max, $\overline{CE} = V_{CC} \pm 0.5 \text{ V}$ ) | lcc3 | | 1.0<br>100 | mA<br>μA | | | Input Load Current (Vin = VSS to VCC, VCC = VCC max) | ΙLΙ | | ± 1.0 | μА | | | A9, CE, and OE Input Load Current (VCC = VCC max A9, CE, and OE = 12.5 V) | LIT | | 50 | μА | | | Output Leakage Current (V <sub>OUt</sub> = V <sub>SS</sub> to V <sub>CC</sub> , V <sub>CC</sub> = V <sub>CC</sub> max) | <sup>I</sup> LO | _ | ± 1.0 | μА | | | Input Low Level | VIL | - 0.5 | 0.8 | ٧ | | | Input High Voltage TTL/NMOS Levels CMOS Levels | V <sub>IH</sub> | 2<br>0.7 x V <sub>CC</sub> | V <sub>CC</sub> + 0.5<br>V <sub>CC</sub> + 0.3 | V | | | Voltage for Autoselect and Sector Protect (V <sub>CC</sub> = 5.0 V) | V <sub>ID</sub> | 11.5 | 12.5 | ٧ | | | Output Low Voltage (IOL = 12 mA, VCC = VCC min) | VOL | | 0.45 | ٧ | | | Output High Voltage<br>TTL/NMOS Levels (I <sub>OH</sub> = - 2.5 mA, V <sub>CC</sub> = V <sub>CC</sub> min) | VOH | 2.4 | | ٧ | | | Output High Levels CMOS Levels ( $I_{OH}$ = $-2.5$ mA, $V_{CC}$ = $V_{CC}$ min) CMOS Levels ( $I_{OH}$ = $-100$ $\mu$ A, $V_{CC}$ = $V_{CC}$ min) | VOH1<br>VOH2 | 0.85 V <sub>CC</sub><br>V <sub>CC</sub> - 0.4 | | V | | | Low V <sub>CC</sub> Lock-Out Voltage | VLKO | 3.2 | 4.2 | ٧ | | #### NOTES: - 1. The I<sub>CC</sub> current listed includes both the dc operating current and the frequency dependent component (at 6 MHz). The frequency component typically is less than 2 mA/MHz, with $\overline{OE}$ at V<sub>IH</sub>. 2. I<sub>CC</sub> active while Embedded Algorithm (program or erase) is in progress. - 3. Not 100% tested. #### CAPACITANCE (f = 1.0 MHz, T<sub>A</sub> = 25°C, V<sub>CC</sub> = 5 V. Periodically Sampled Rather Than 100% Tested) | Parameter | | Symbol | Тур | Max | Unit | |-----------------------------------------------|--------------|------------------|----------|----------|------| | Input Capacitance (V <sub>in</sub> = 0) | TSOP<br>PLCC | C <sub>in</sub> | 6<br>4 | 7.5<br>6 | рF | | Control Pin Capacitance (V <sub>in</sub> = 0) | TSOP<br>PLCC | C <sub>in2</sub> | 7.5<br>8 | 9<br>12 | pF | | Output Capacitance (V <sub>Out</sub> = 0) | TSOP<br>PLCC | C <sub>out</sub> | 8.5<br>8 | 12<br>12 | pF | #### **AC OPERATING CONDITIONS AND CHARACTERISTICS** #### **READ ONLY OPERATIONS CYCLE** (See Note 1) | | Sym | bol | M29F040-75<br>(Note 1) | | | M29F040-90<br>(Note 2) | | M29F040-12<br>(Note 2) | | | |------------------------------------------------------------------------------------------------|-------------------|-----------------|------------------------|-----|-----|------------------------|-----|------------------------|------|-------| | Parameter | Std | Alt | Min | Max | Min | Max | Min | Max | Unit | Notes | | Read Cycle Time | †AVAV | <sup>t</sup> RC | 70 | | 90 | | 120 | | ns | 4 | | Address to Output Delay, $\overline{CE} = V_{\parallel L}$ , $\overline{OE} = V_{\parallel L}$ | V©VA <sup>†</sup> | †ACC | | 70 | | 90 | _ | 120 | ns | | | Chip Enable to Output Delay, $\overline{OE} = V_{IL}$ | tEL∕3V | <sup>t</sup> CE | _ | 70 | _ | 90 | | 120 | ns | | | Output Enable to Output Delay | <sup>t</sup> GLQV | tOE | | 30 | _ | 35 | _ | 50 | ns | | | Chip Enable to Output High-Z | t <sub>EHQZ</sub> | t <sub>DF</sub> | | 20 | | 20 | | 30 | ns | 3, 4 | | Output Enable to Output High-Z | t <sub>GHQZ</sub> | t <sub>DF</sub> | | 20 | _ | 20 | | 30 | ns | 3, 4 | | Output Hold from Addresses, $\overline{CE}$ , or $\overline{OE}$ , Whichever Occurs First | XQXA <sup>†</sup> | tОН | 0 | | 0 | | 0 | _ | ns | | #### NOTES: - 1. Test conditions output load: one TTL gate and 30 pF; input rise and fall times: 5 ns; input pulse levels: 0 to 3 V; timing measurement reference level: input, 1.5 V; output, 1.5 V. - 2. Test conditions output load: one TTL gate and 100 pF; input rise and fall times: 20 ns; input pulse levels: 0.45 to 2.4 V; timing measurement reference level: input, 0.8 and 2.0 V; output, 0.8 and 2.0 V. - 3. Output driver disable time. - 4. Not 100% tested. NOTE: $C_L = 100 \text{ pF}$ including jig capacitance. Figure 1. Test Conditions #### **READ CYCLE** #### WRITE/ERASE/PROGRAM OPERATIONS (See Note 6) | | Sym | bol | M29F | 040-75 | M29F0 | 040-90 | M29F | 040-12 | | | |------------------------------------------------------|-------------------|------------------|---------|--------|---------|--------|---------|--------|--------|-------| | Parameter | Std | Alt | Min | Max | Min | Max | Min | Max | Unit | Notes | | Write Cycle Time | t <sub>AVAV</sub> | tWC | 70 | _ | 90 | | 120 | | ns | 1 | | Address Setup Time | t <sub>AVWL</sub> | t <sub>AS</sub> | 0 | _ | 0 | _ | 0 | _ | ns | | | Address Hold Time | tWLAX | <sup>t</sup> AH | 45 | _ | 45 | | 50 | _ | ns | | | Data Setup Time | tDVWH | tDS | 30 | | 45 | | 50 | | ns | | | Data Hold Time | twHQX | t <sub>DH</sub> | 0 | | 0 | _ | 0 | _ | ns | | | Output Enable Setup Time | | t <sub>OES</sub> | 0 | _ | 0 | _ | 0 | | ns | | | Output Enable Hold Time Read Toggle and Data Polling | | <sup>t</sup> OEH | 0<br>10 | | 0<br>10 | | 0<br>10 | | ns | 1 | | Read Recovery Time Before Write | tGHWL | | 0 | _ | 0 | | 0 | | ns | | | CE Setup Time | <sup>†</sup> ELWL | tcs | 0 | | 0 | | 0 | | ns | | | CE Hold Time | <sup>t</sup> WHEH | <sup>t</sup> CH | 0 | - | 0 | | 0 | _ | ns | | | Write Pulse Width | tWLWH | t <sub>WP</sub> | 35 | _ | 45 | _ | 50 | | ns | | | Write Pulse Width High | tWHWL | tWPH | 20 | _ | 20 | | 20 | | ns | | | Byte Programming Operation | tWHWH1 | | 16 | _ | 16 | 1 | 16 | _ | μs | | | Erase Operation | tWHWH2 | | 1.5 | 30 | 1.5 | 30 | 1.5 | 30 | s | 2 | | V <sub>CC</sub> Setup Time | • | tvcs | 50 | | 50 | _ | 50 | | μs | 1 | | Voltage Transition Time | | tvLHT | 4 | _ | 4 | _ | 4 | _ | μs | 1, 3 | | Write Pulse Width | | tWPP | 100 | _ | 100 | _ | 100 | _ | μs | 3 | | OE Setup Time to WE Active | | tOESP | 4 | | 4 | | 4 | | μs | 1, 3 | | CE Setup Time to WE Active | | tCSP | 4 | _ | 4 | | 4 | _ | μs | 1, 4 | | Chip Programming Time | | | _ | 50 | _ | 50 | | 50 | s | 5 | | Erase/Program Cycles | | | 100k | | 100k | - | 100k | | cycles | | #### NOTES: - 1. Not 100% tested. - This does not include the preprogramming time. These timings are for Sector Protect/Unprotect operations. - 4. This timing is only for Sector Unprotect. - 5. 25°C, 5 V V<sub>CC</sub>, 100,000 cycles. - 6. When programming a "1" over a "0", the Embedded Algorithms allow for 48 ms byte program time. MOTOROLA FLASH M29F040 #### **PROGRAM OPERATIONS** #### NOTES: - Figure indicates last two bus cycles of four bus cycle sequence. PA is address of the memory location to be programmed. - 3. PD is data to be programmed at byte address. - 4. DQ7 is the output of the complement of the data written to the device. - 5. $D_{out}$ is the output of the data written to the device. #### **CHIP/SECTOR ERASE OPERATIONS** NOTE: SA is the sector address for Sector Erase. MOTOROLA FLASH #### SECTOR PROTECT CYCLE $SA_X = Sector Address for initial sector$ SAy = Sector Address for next sector #### SECTOR UNPROTECT CYCLE ### ALTERNATE CE CONTROLLED WRITE CYCLES | | Syn | bol | M29F0 | )40-75 | M29F | 040-90 | M29F | 040-12 | | | |------------------------------------------------------|--------------------|-------------------|---------|-------------|---------|--------|---------|--------|------|-------| | Parameter | Std | Alt | Min | Max | Min | Max | Min | Max | Unit | Notes | | Write Cycle Time | <sup>†</sup> AVAV | twc | 70 | <del></del> | 90 | | 120 | - | ns | 1 | | Address Setup Time | <sup>†</sup> AVEL | tAS | 0 | | 0 | | 0 | - | ns | | | Address Hold Time | †ELAX | <sup>t</sup> AH | 45 | | 45 | | 50 | | ns | | | Data Setup Time | <sup>t</sup> DVEH | t <sub>D</sub> S | 30 | | 45 | | 50 | | ns | | | Data Hold Time | <sup>†</sup> EHDX | tDH | 0 | " | 0 | _ | 0 | - | ns | | | Output Enable Setup Time | | toes | 0 | | 0 | | 0 | _ | ns | | | Output Enable Hold Time Read Toggle and Data Polling | | <sup>t</sup> OEH | 0<br>10 | | 0<br>10 | _ | 0<br>10 | _ | ns | 1 | | Read Recover Time before Write | | <sup>t</sup> GHEL | 0 | | 0 | _ | 0 | | ns | | | WE Setup Time | tWLEL | tws | 0 | | 0 | _ | 0 | | ns | | | WE Hold Time | <sup>t</sup> EHWH | tw⊢ | 0 | | 0 | | 0 | | ns | | | CE Pulse Width | tELEH | tCP | 35 | | 45 | | 50 | _ | ns | | | CE Pulse Width High | †EHEL | t <sub>CPH</sub> | 20 | | 20 | | 20 | _ | ns | _ | | Byte Programming Operation | tWHWH1 | twHWH1 | 16 | | 16 | _ | 16 | | μs | | | Erase Operation | <sup>t</sup> WHWH2 | twHwH2 | 1.5 | 30 | 1.5 | 30 | 1.5 | 30 | s | 2 | | V <sub>CC</sub> Setup Time | | tvcs | 50 | | 50 | - | 50 | | μs | 1 | #### NOTES: - Not 100% tested. This does not include the preprogramming time. #### ALTERNATE CE CONTROLLED WRITE CYCLE #### NOTES: - 1. Figure indicates last two bus cycles of four bus cycle sequence. - 2. PA is address of the memory location to be programmed. - 3. PD is data to be programmed at byte address. - 4. DQ7 is the output of the complement of the data written to the device. - 5. Dout is the output of the data written to the device. #### **GENERAL DESCRIPTION** The Motorola M29F040 is a 4M Flash Memory device designed to be programmed in-system with the standard system 5.0 V V<sub>CC</sub> supply. A 12.0 V Vpp is not required for write or erase options. The device can also be reprogrammed in standard EPROM programmers. The M29F040 offers access times between 70 and 120 nanoseconds, allowing operation of high-speed microprocessors without wait states. To eliminate bus contention, the device has separate chip enable $(\overline{CE})$ , write enable $(\overline{WE})$ , and output enable $(\overline{OE})$ controls. This device is entirely pin and command set compatible with JEDEC standard 4M E<sup>2</sup>PROMs. Commands are written to the command register using standard microprocessor write timings. Register contents serve as input to an internal state-machine which controls the erase and programming circuitry. Write cycles also internally latch addresses and data needed for the programming and erase operations. Reading data out of the device is similar to reading from 12.0 V Flash or EPROM devices. The M29F040 is programmed by executing the program command sequence. This will invoke the Embedded Program Algorithm which is an internal algorithm that automatically times the program pulse widths and verifies proper cell margin. Typically, each sector can be programmed and verified in less than one second. Erase is accomplished by executing the erase command sequence. This will invoke the Embedded Erase Algorithm which is an internal algorithm that automatically preprograms the array if it is not already programmed before executing the erase operation. During erase, the device automatically times the erase pulse widths and verifies proper cell margin. This entire chip or any individual sector is typically erased and verified in 1.5 seconds (if already completely preprogrammed). This device also features a sector erase architecture. The sector mode allows for 64K byte blocks of memory to be erased and reprogrammed without affecting other blocks. The device features single 5.0 V power supply operation for both read and write functions. Internally generated and regulated voltages are provided for the program and erase operations. A low V<sub>CC</sub> detector automatically inhibits write operations on the loss of power. The end of program or erase is detected by Data Polling of DQ7 or by the toggle bit feature on DQ6. Once the end of a program or erase cycle has been completed, the device internally resets to the read mode. Flash Technology combines years of EPROM and E<sup>2</sup>PROM experience to produce the highest levels of quality, reliability and cost effectiveness. The M29F040 memory electrically erases the entire chip or all bits within a sector simultaneously via Fowler–Nordhiem tunneling. The bytes are programmed one byte at a time using the EPROM programming mechanism of hot electron injection. #### FLEXIBLE SECTOR-ERASE ARCHITECTURE - 64K Bytes per sector - Individual-sector, multiple-sector, or bulk-erase capability - Individual or multiple-sector protection is user definable Table 1. User Bus Operations (see Note 1) | Operation | CE | ŌĒ | WE | A0 | A1 | A6 | A9 | VO | |----------------------------------------|----|-----|----|----|----|----|-----------------|-----------------------------| | Auto-Select Manufacturer Code (Note 2) | L | L | Н | L. | L | L | VID | Code | | Auto-Select Device Code (Note 2) | L | L | Н | Н | L | L | VID | Code | | Read (Note 3) | L | L | н | A0 | A1 | A6 | A9 | Dout | | Standby | Н | Х | Х | Х | х | X | Х | High Z | | Output Disable | L | Н | Н | Х | X | X | Х | High Z | | Write | L | Н | L | A0 | A1 | A6 | A9 | D <sub>in</sub><br>(Note 4) | | Enable Sector Protect | L | VID | L | Х | Х | Х | V <sub>ID</sub> | × | | Verify Sector Protect (Note 5) | L | L | Н | L | Н | L | V <sub>ID</sub> | Code | #### NOTES: - 1. L = $V_{IL}$ , H = $V_{IH}$ , X = Don't Care. See DC Characteristics for voltage levels. - 2. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Tables 2 and 3. - 3. $\overline{\text{WE}}$ can be $V_{IL}$ if $\overline{\text{OE}}$ is $V_{IL}$ , $\overline{\text{OE}}$ at $V_{IH}$ initiates the write operations. - Refer to Table 4 for valid D<sub>in</sub> during a write operation. - 5. Refer to Sector Protection section. #### **READ MODE** The M29F040 has two control functions which must be satisfied in order to obtain data at the outputs. $\overline{CE}$ is the power control and should be used for device selection. $\overline{OE}$ is the output control and should be used to gate data to the output pins if a device is selected. Address access time (tACC) is equal to the delay from stable addresses to valid output data. The chip enable access time (tCE) is the delay from stable addresses and stable $\overline{CE}$ to valid data at the output pins. The output enable access time is the delay from the falling edge of $\overline{OE}$ to valid data at the cutput pins (assuming the addresses have been stable for at least tACC – tOE time). #### STANDBY MODE The device has two standby modes, a CMOS standby mode ( $\overline{\text{CE}}$ input held at V<sub>CC</sub> $\pm$ 0.5 V), when the current consumed is 100 $\mu$ A; and a TTL standby mode ( $\overline{\text{CE}}$ is held at V<sub>[H]</sub>) when the current required is reduced to approximately 1 mA. In the standby mode the outputs are in a high impedance state, independent of the $\overline{\text{OE}}$ input. If the device is deselected during erasure or programming, the device will draw active current until the operation is completed. #### **OUTPUT DISABLE** With the $\overline{OE}$ input at a logic high level (V<sub>IH</sub>), output from the device is disabled. This will cause the output pins to be in a high impedance state. #### **AUTOSELECT** The autoselect mode allows the reading out of a binary code from the device and will identify the Flash component manufacturer and type. This mode is intended for use by programming equipment for the purpose of automatically matching the device to be programmed with its corresponding programming algorithm. This mode is functional over the entire temperature range of the device. To activate this mode, the programming equipment must force V<sub>ID</sub> (11.5 V to 12.5 V) on address pin A9. Two identifier bytes may then be sequenced from the device outputs by toggling address A0 from V<sub>IL</sub> to V<sub>IH</sub>. All addresses are don't cares except A0, A1, and A6. The manufacturer and device codes may also be read via the command register, when the device is erased or programmed in a system without access to high voltage on the A9 pin. The command sequence is illustrated in Table 4 (refer to Autoselect Command section). Byte 0 (A0 = $V_{IL}$ ) represents the manufacturer's code (for example, AMD = 01H) and byte 1 (A0 = $V_{IH}$ ) the device identifier code (for example, Am29F040 = A4H). These two bytes are given in the table below. All identifiers for manufacturers and device will exhibit odd parity with the MSB (DQ7) defined as the parity bit. In order to read the proper device codes when executing the autoselect, A1 must be $V_{II}$ (seeTable 2). **Table 2. Sector Protection Verify Autoselect Codes** | Туре | A18 | A17 | A16 | A6 | A1 | <b>A</b> 0 | Code<br>(HEX) | DQ7 | DQ6 | DQ5 | DQ4 | DQ3 | DQ2 | DQ1 | DQ0 | |-------------------|-------|----------|-------|-----|-----|------------|---------------|-----|-----|-----|-----|-----|-----|-----|-----| | Manufacture Code | × | Х | Х | VIL | ۷ıL | VIL | 01H | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | Device Code | × | X | Х | VIL | VIL | VIH | A4H | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | | Sector Protection | Secto | or Addre | esses | VIL | ViH | VIL | 01H* | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | <sup>\*</sup>Outputs 01H at protected sector addresses. **Table 3. Sector Address Tables** | | A18 | A17 | A16 | Address Range | |-----|-----|-----|-----|---------------| | SA0 | 0 | 0 | 0 | 00000h-0FFFFh | | SA1 | 0 | . 0 | 1 | 10000h-1FFFFh | | SA2 | 0 | 1 | 0 | 20000h-2FFFFh | | SA3 | 0 | 1 | 1 | 30000h-3FFFFh | | SA4 | 1 | 0 | 0 | 40000h-4FFFFh | | SA5 | 1 | 0 | 1 | 50000h-5FFFFh | | SA6 | 1 | 1 | 0 | 60000h-6FFFFh | | SA7 | 1 | 11 | 1 | 70000h-7FFFFh | #### WRITE Device erasure and programming are accomplished via the command register. The contents of the register serve as inputs to the internal state machine. The state machine outputs dictate the function of the device. The command register itself does not occupy any addressable memory location. The register is a latch used to store the commands, along with the address and data information needed to execute the command. The command register is written by bringing $\overline{WE}$ to $V_{|L}$ , while $\overline{CE}$ is at $V_{|L}$ and $\overline{OE}$ is at $V_{|H}$ . Addresses are latched on the falling edge of $\overline{WE}$ or $\overline{CE}$ , whichever happens later; while data is latched on the rising edge of $\overline{WE}$ or $\overline{CE}$ , whichever happens first. Standard microprocessor write timings are used. Refer to AC Write Characteristics and the Erase/Programming Waveforms for specific timing parameters. #### **SECTOR PROTECTION** The flash device features hardware sector protection. This feature will disable both program and erase operations in any number of sectors (0 through 8). The sector protect feature is enabled using programming equipment at the user's site. The device is shipped with all sectors unprotected. To activate this mode, the programming equipment must force $V_{ID}$ on address pin A9 and control pin $\overline{OE}$ , and $\overline{CE}$ = $V_{IH}$ . The sector addresses (A18, A17, and A16) should be set to the sector to be protected. Table 3 defines the sector address for each of the eight (8) individual sectors. Programming of the protection circuitry begins on the falling edge of the $\overline{WE}$ pulse and is terminated with the rising edge of the same. Sector addresses must be held constant during the $\overline{WE}$ pulse. To verify programming of the protection circuitry, the programming equipment must force $V_{ID}$ on address pin A9 with $\overline{CE}$ and $\overline{OE}$ at $V_{IL}$ and $\overline{WE}$ at $V_{IH}$ . Scanning the sector addresses (A16, A17, and A18) while (A6, A1, A0) = (0, 1, 0) will produce a logical 1 code at device DQ0 output for a protected sector. Otherwise the device will read 00H for unprotected sector. In this mode, the lower order addresses, except for A0, A1, and A6 are don't care. Address locations with A1 = $V_{IL}$ are reserved for Autoselect manufacturer and device codes. It is also possible to determine if a sector is protected in the system by writing an Autoselect command. Performing a read operation at the address location XX02H, where the higher order addresses (A16, A17, and A18) are the sector address, will produce a logical 1 at DQ0 outputs for a protected sector. See Table 2 for Autoselect codes. #### **COMMAND DEFINITIONS** Device operations are selected by writing specific address and data sequences into the command register. Writing incorrect address and data values or writing them in the improper sequence will reset the device to read mode. Table 4 defines the valid register command sequences. Note that the Erase Suspend (B0H) and Erase Resume (30H) commands are valid only while the Sector Erase operation is in progress. Either of the two reset commands will reset the device (when applicable). #### READ/RESET COMMAND The read or reset operation is initiated by writing the read/ reset command sequence into the command register. Microprocessor read cycles retrieve array data from the memory. The device remains enabled for reads until the command register contents are altered. The device will automatically power-up in the read/reset state. In this case, a command sequence is not required to read data. Standard microprocessor read cycles will retrieve array data. This default value ensures that no spurious alteration of the memory content occurs during the power transition. Refer to the AC Read Characteristics and Waveforms for the specific timing parameters. Reset is needed to terminate the autoselect operation. It can be used to terminate an Erase or Sector Erase operation, but the data in the sector or device being erased would then be undefined. #### **AUTOSELECT COMMAND** Flash memories are intended for use in applications where the local CPU alters memory contents. As such, manufacture and device codes must be accessible while the device resides in the target system. PROM programmers typically access the signature codes by raising A9 to a high voltage. However, multiplexing high voltage onto the address lines is not generally desired system design practice. The device contains a command autoselect operation to supplement traditional PROM programming methodology. The operation is initiated by writing the autoselect command sequence into the command register. Following the command write, a read cycle from address XX00H retrieves the manufacture code of 01H. A read cycle from address XX01H returns the device code A4H (see Table 2). All manufacturer and device codes will exhibit odd parity with the MSB (DQ7) defined as the parity bit. Scanning the sector addresses (A16, A17, A18) while (A6, A1, A0) = (0, 1, 0) will produce a logical 1 at device output DQ0 for a protected sector. To terminate the operation, it is necessary to write the read/reset command sequence into the register. **Table 4. Command Definitions** | Command | Bus<br>Write<br>Cycles | First Bus<br>Write Cycle | | Second Bus<br>Write Cycle | | Third Bus<br>Write Cycle | | Fourth Bus<br>Read/Write<br>Cycle | | Fifth Bus<br>Write Cycle | | Sixth Bus<br>Write Cycle | | |----------------------|------------------------|--------------------------|------------------------------------------------------------------------------|---------------------------|----------|--------------------------|-------------|-----------------------------------|-------|--------------------------|------|----------------------------------------|------| | Sequence | Req'd | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | | Read/Reset | 1 | XXXH | F0H | | | | | | | | | | | | Reset/Read | 4 | 5555H | AAH | 2AAAH | 55H | 5555H | F0H | RÃ | RD | | | —————————————————————————————————————— | | | Autoselect | 4 | 5555H | AAH | 2AAAH | 55H | 5555H | 90H | | | | | | | | Byte Program | 4 | 5555H | AAH | 2AAAH | 55H | 5555H | A0H | PA | Data | | | | | | Chip Erase | 6 | 5555H | AAH | 2AAAH | 55H | 5555H | 80H | 5555H | AAH | 2AAAH | 55H | 5555H | 10H | | Sector Erase | 6 | 5555H | AAH | 2AAAH | 55H | 5555H | 80H | 5555H | AAH | 2AAAH | 55H | SA | 30H | | Sector Erase Suspend | | Е | rase can be suspended during sector erase with Addr (don't care), Data (B0H) | | | | <del></del> | <b>L</b> | | | | | | | Sector Erase Resume | | Erase o | can be re | sumed aft | er suspe | nd with Add | dr (don't d | care), Data | (30H) | | · | | | #### NOTES: - 1. Address bits A15, A16, A17, and A18 = X = don't care. Write Sequences may be initiated with A15 in either state. - 2. Address bits A15, A16, A17, and A18 = X = don't care for all address commands except for program address (PA) and sector address (SA). - 3. Bus operations are defined in Table 1. - 4. RA = Address of the memory location to be read. - PA ≈ Address of the memory location to be programmed. Addresses are latched on the falling edge of the WE pulse. - SA = Address of the sector to be erased. The combination of A18, A17, A16 will uniquely select any sector. - 5. RD = Data read from location RA during read operation. - PD = Data to be programmed at location PA. Data is latched on the rising edge of WE. #### BYTE PROGRAMMING The Flash chip is programmed on a byte-by-byte basis. Programming is a four bus cycle operation. There are two "unlock" write cycles. These are followed by the program setup command and data write cycles. Addresses are latched on the falling edge of $\overline{CE}$ or $\overline{WE}$ , whichever happens later and the data is latched on the rising edge of $\overline{CE}$ or $\overline{WE}$ , whichever happens first. The rising edge of $\overline{CE}$ or $\overline{WE}$ (whichever happens first) begins programming. Upon executing the Embedded Program Algorithm command sequence the system is *not* required to provide further controls or timings. The Flash chip will automatically provide adequate internally generated program pulses and verify the programmed cell margin. The automatic programming operation is completed when the data on DQ7 is equivalent to data written to this bit (see Write Operation Status section) at which time the device returns to the read mode and addresses are no longer latched. Therefore, the device requires that a valid address to the device be supplied by the system at this particular instance of time. Hence, Data Polling must be performed at the memory location which is being programmed. Any commands written to the chip during this period will be ignored. Programming is allowed in any sequence and across sector boundaries. Beware that a data 0 cannot be programmed back to a 1. Attempting to do so will probably hang up the device (exceed timing limits), or perhaps result in an apparent success according to the data polling algorithm but a read from reset/read mode will show that the data is still 0. Only erase operations can convert 0s to 1s. Figure 2 illustrates the Embedded Programming Algorithm using typical command strings and bus operations. #### **CHIP ERASE** Chip erase is a six bus cycle operation. There are two "unlock" write cycles. These are followed by writing the "set-up" command. Two more "unlock" write cycles are then followed by the chip erase command. Chip erase does *not* require the user to program the device prior to erase. Upon executing the Embedded Erase Algorithm command sequence the device automatically will program and verify the entire memory for an all zero data pattern prior to electrical erase. The system is not required to provide any controls or timings during these operations. A Reset command will terminate the Erase but the data in the chip will be undefined. In that case, perform the Erase operation again and allow it to complete. The automatic erase begins on the rising edge of the last $\overline{\text{WE}}$ pulse in the command sequence and terminates when the data on DQ7 of each byte is 1 (see Write Operation Status section) at which time the device returns to read the mode. Figure 3 illustrates the Embedded Erase Algorithm using typical command strings and bus operations. #### **SECTOR ERASE** Sector erase is a six bus cycle operation. There are two "unlock" write cycles. These are followed by writing the "set-up" command. Two more "unlock" write cycles are then followed by the sector erase command. The sector address (any address location within the desired sector) is latched on the falling edge of $\overline{WE}$ , while the command (data) is latched on the rising edge of $\overline{WE}$ . A time-out of 80 $\mu s$ from the rising edge of the last sector erase command will initiate the sector erase command(s). #### **CAUTION** Do not attempt to write an invalid command sequence during the sector erase timeout. Otherwise, it will terminate the sector erase operation and the device will reset back into the read mode. Multiple sectors may be erased concurrently by writing the six bus cycle operations as described above. This sequence is followed with writes of the Sector Erase command to addresses in other sectors desired to be concurrently erased. The time between writes must be less than 80 µs, otherwise that command will not be accepted. It is recommended that processor interrupts be disabled during this time to guarantee this condition. The interrupts can be re-enabled after the last Sector Erase command is written. A timeout of 80 us from the rising edge of the last WE will initiate the execution of the Sector Erase command(s). If another falling edge of the WE occurs within the 80 µs time-out window the timer is reset. (Monitor DQ3 to determine if the sector erease window is still open, see section DQ3, Sector Erase Timer). Any command other than Sector Erase or Erase Suspend during this period will reset the device to read mode, ignoring the previous command string. Resetting the device after it has begun execution will result in the data of the operated sectors being undefined. In that case, restart the erase on those sectors and allow them to complete. (Refer to the Write Operation Status section for Sector Erase Timer operation.) Loading the sector erase buffer may be done in any sequence and with any number of sectors (1 to 8). Sector erase does *not* require the user to program the device prior to erase. The device automatically programs all memory locations in the sector(s) to be erased prior to electrical erase. When erasing a sector or sectors the remaining unselected sectors are not affected. The system is *not* required to provide any controls or timings during these operations. A Reset command will terminate the Sector Erase but the data in the sector will be undefined. In that case, perform the Sector Erase operation again and allow it to complete The automatic sector erase begins after the 100 µs time out from the rising edge of the WE pulse for the last sector erase command pulse and terminates when the data on DQ7 of each byte is 1 (see Write Operation Status section) at which time the device returns to read mode. During the execution of the sector erase command, only the erase suspend and erase resume commands are allowed. All other commands will reset the device to read mode. Data polling must be performed at an address within any of the sectors being erased. Figure 3 illustrates the Embedded Erase Algorithm using typical command strings and bus operations. #### **ERASE SUSPEND** Erase Suspend command allows the user to interrupt the chip and then do data reads (not program) from a non-busy sector while it is in the middle of a Sector Erase operation (which may take up to several seconds). This command is applicable ONLY during the Sector Erase operation and will be ignored if written during the chip Erase or Programming operation. The Erase Suspend command (B0H) will be allowed only during the Sector Erase Operation that will include the sector erase time-out period after the Sector Erase commands (30H). Writing this command during the time-out will result in immediate termination of the time-out period. Any subsequent writes of the Sector Erase command will be taken as the Erase Resume command. Note that any other commands during the time out will reset the device to read mode. The addresses are don't-cares in writing the erase Suspend or Erase Resume commands. When the Erase Suspend command is written during a Sector Erase operation, the device will take between 0.1 us to 15 us to suspend the erase operation and go into erase suspended read mode (pseudo-read mode), during which the user can read from a sector that is NOT being erased. A read from a sector being erased may result in invalid data. The user must monitor the toggle bit to determine if the device has entered the pseudo-read mode, at which time the toggle bit stops toggling. An address of a sector NOT being erased must be used to read the toggle bit, otherwise the user may encounter intermittent problems. Note that the user must keep track of what state the chip is in since there is no external indication of whether the chip is in pseudo-read mode or actual read mode. After the user writes the Erase Suspend command and waits until the toggle bit stops toggling, data reads from the device may then be performed. Any further writes of the Erase Suspend command at this time will be ignored. Every time an Erase Suspend command followed by an Erase Resume command is written, the internal (pulse) counters are reset. These counters are used to count the number of high voltage pulses the memory cell requires to program or erase. If the count exceeds a certain limit, then the DQ5 bit will be set (Exceeded Time Limit flag). This resetting of the counters is necessary since the Erase Suspend command can potentially interrupt or disrupt the high voltage pulses. To resume the operation of Sector Erase, the Resume command (30H) should be written. Any further writes of the Resume command at this point will be ignore. Another Erase Suspend command can be written after the device has resumed. #### **WRITE OPERATION STATUS** **Table 5. Hardware Sequence Flags** | | Status | DQ7 | DQ6 | DQ5 | DQ3 | DQ2 – DQ0 | |----------------------|-----------------------------|-----|--------|-----|-----|------------------| | In Progress | Auto-Programming | DQ7 | Toggle | 0 | 0 | ( <del>D</del> ) | | | Program/Erase in Auto Erase | 0 | Toggle | 0 | 1 | 1 | | Exceeded Time Limits | Auto-Programming | DQ7 | Toggle | 1 | 1 | ( <del>D</del> ) | | | Program/Erase in Auto Erase | 0 | Toggle | 1 | 1 | 1 | NOTE: DQ0, DQ1, and DQ2 are reserve pins for future use. DQ4 is for Motorola internal use only. #### DQ7 #### **Data Polling** The device features Data Polling as a method to indicate to the host that the Embedded Algorithms are in progress or completed. During the Embedded Program Algorithm an attempt to read the device will produce the compliment of the data last written to DQ7. Upon completion of the Embedded Program Algorithm, an attempt to read the device will produce the true data last written to DQ7. During the Embedded Erase Algorithm, an attempt to read the device will produce a 0 at the DQ7 output. Upon completion of the Embedded Erase Algorithm an attempt to read the device will produce a 1 at the DQ7 output. The flowchart for Data Polling (DQ7) is shown in Figure 4. For chip erase, the Data Polling is valid after the rising edge of the sixth WE pulse in the six write pulse sequence. For sector erase, the Data Polling is valid after the last rising edge of the sector erase WE pulse. Data Polling must be performed at sector address within any of the sectors being erased and not a protected sector. Otherwise, the status may not be valid. Once the Embedded Algorithm operation is close to being completed, the data pins (DQ7) may change asynchronously while the output enable (OE) is asserted low. This means that the device is driving status information on DQ7 at one instant of time and then that byte's valid data at the next instant of time. Depending on when the system samples the DQ7 output, it may read the status or valid data. Even if the device has completed the Embedded Algorithm operation and DQ7 has a valid data, the data outputs on DQ0 DQ6 of each byte may be still invalid. The valid data on DQ0 - DQ7 will be read on the successive read attempts. The Data Polling feature is only active during the Embedded Programming Algorithm, Embedded Erase Algorithm, or sector erase time-out (see Table 5). See Figure 5 for the Data Polling timing specifications and diagrams. #### DQ6 Toggle Bit The device also features the "Toggle Bit" as a method to indicate to the host system that the Embedded Algorithms are in progress or completed. During an Embedded Program or Erase Algorithm cycle, successive attempts to read ( $\overline{OE}$ toggling) data from the device will result in DQ6 toggling between one and zero. Once the Embedded Program or Erase Algorithm cycle is completed, DQ6 will stop toggling and valid data will be read on the next successive attempts. During programming, the Toggle Bit is valid after the rising edge of the fourth $\overline{WE}$ pulse in the four write pulse sequence. For chip erase, the Toggle Bit is valid after the rising edge of the sixth $\overline{WE}$ pulse in the six write pulse sequence. For Sector erase, the Toggle Bit is valid after the last rising edge of the sector erase $\overline{WE}$ pulse. The Toggle Bit is active during the sector time out. In programming, if the sector being written to is protected, the toggle bit will toggle for about 2 $\mu s$ and then stop toggling without the data having changed. In erase, the device will erase all the selected sectors except for the ones that are protected. If all selected sectors are protected, the chip will toggle the toggle bit for about 100 $\mu s$ and then drop back into read mode, having changed none of the data. Either $\overline{\text{CE}}$ or $\overline{\text{OE}}$ toggling will cause the DQ6 to toggle. See Figure 6 for the Toggle Bit timing specifications and diagrams. #### DQ5 #### **Exceeded Timing Limits** DQ5 will indicate if the program or erase time has exceeded the specified limits (internal pulse count). Under these conditions DQ5 will produce a 1. This is a failure condition which indicates that the program or erase cycle was not successfully completed. Data Polling is the only operating function of the device under this condition. The $\overline{CE}$ circuit will partially power down the device under these conditions. The $\overline{OE}$ and $\overline{WE}$ pins will control the output disable functions as described in Table 1. If this failure condition occurs during sector erase operation, it specifies that a particular sector is bad and it may not be reused, however, other sectors are still functional and may be used for the program or erase operation. The device must be reset to use other sectors. Write the Reset command sequence to the device, and then execute program or erase command sequence. This allows the system to continue to use the other active sectors in the device. If this failure condition occurs during the chip erase operation, it specifies that the entire chip is bad or combination of sectors are bad. If this failure condition occurs during the byte programming operation, it specifies that the entire sector containing that byte is bad and this sector may not be reused, (other sectors are still functional and can be reused). The DQ5 failure condition may also appear if a user tries to program a non blank location without erasing. In this case the device locks out and never completes the Embedded Algorithm operation. Hence, the system never reads a valid data on DQ7 bit and DQ6 never stops toggling. Once the device has exceeded timing limits, the DQ5 bit will indicate a 1. Please note that this is not a device failure condition since the device was incorrectly used. #### DQ3 Sector Erase Timer After the completion of the initial sector erase command sequence the sector erase time-out will begin. DQ3 will remain low until the time-out is complete. Data Polling and Toggle Bit are valid after the initial sector erase command sequence. If Data Polling or the Toggle Bit indicates the device has been written with a valid erase command, DQ3 may be used to determine if the sector erase timer window is still open. If DQ3 is high (1) the internally controlled erase cycle has begun; attempts to write subsequent sector erase commands to the device will be ignored until the erase operation is completed as indicated by Data Polling or Toggle Bit. If DQ3 is low (0), the device will accept additional sector erase commands. To ensure the command has been accepted, the system software should check the status of DQ3 prior to and following each subsequent sector erase command. If DQ3 were high on the second status check, the command may not have been accepted. Refer to Table 5: Hardware Sequence Flags. MOTOROLA FLASH M29F040 #### **DATA PROTECTION** The device is designed to offer protection against accidental erasure or programming caused by spurious system level signals that may exist during power transitions. During power up the device automatically resets the internal state machine in the Read mode. Also, with its control register architecture, alteration of the memory contents only occurs after successful completion of specific multi-bus cycle command sequences. The device also incorporates several features to prevent inadvertent write cycles resulting from VCC power-up and power-down transitions or system noise. #### LOW VCC WRITE INHIBIT To avoid initiation of a write cycle during V<sub>CC</sub> power-up and power-down, a write cycle is locked out for V<sub>CC</sub> less than 3.2 V (typically 3.7 V). If V<sub>CC</sub> < V<sub>LKO</sub>, the command register is disabled and all internal program/erase circuits are disabled. Under this condition the device will reset to the read mode. Subsequent writes will be ignored until the V<sub>CC</sub> level is greater than V<sub>LKO</sub>. #### WRITE PULSE "GLITCH" PROTECTION Noise pulses of less than 5 ns (typical) on $\overline{OE}$ , $\overline{CE}$ or $\overline{WE}$ will not initiate a write cycle. #### **LOGICAL INHIBIT** Writing is inhibited by holding any one of $\overline{OE} = V_{IL}$ , $\overline{CE} = V_{IH}$ or $\overline{WE} = V_{IH}$ . To initiate a write cycle $\overline{CE}$ and $\overline{WE}$ must be a logical zero while $\overline{OE}$ is a logical one. #### **POWER-UP WRITE INHIBIT** Power-up of the device with $\overline{WE} = \overline{CE} = V_{||L|}$ and $\overline{OE} = V_{||H|}$ will not accept commands on the rising edge of $\overline{WE}$ . The internal state machine is automatically reset to the read mode on power-up. #### SECTOR PROTECT Sectors of the device may be hardware protected at the users factory. The protection circuitry will disable both program and erase functions for the protected sector(s). Requests to program or erase a protected sector will be ignored by the device. M29F040 MOTOROLA FLASH #### Program Command Sequence (Address/Command): Figure 2. Embedded Programming Algorithm **Table 6. Embedded Programming Algorithm** | Bus Operations | Command Sequence | Comments | | |--------------------|------------------|--------------------------------------|--| | Standby (see Note) | | | | | Write | Program | Valid Address/Data Sequence | | | Read | | Data Polling to Verify Programming | | | Standby (see Note) | | Compare Data Output to Data Expected | | NOTE: device is either powered-down, erase inhibit, or program inhibit. MOTOROLA FLASH M29F040 Figure 3. Embedded Erase Algorithm Table 7. Embedded Erase Algorithm | Bus Operations | Command Sequence | Comments | | | |----------------|------------------|--------------------------------|--|--| | Standby | | | | | | Write | Erase | | | | | Read | | Data Polling to Verify Erasure | | | | Standby | | Compare Output to FFH | | | NOTE: DQ7 is rechecked even if DQ5 = 1 because DQ7 may change simultaneously with DQ5. Figure 4. Data Polling Algorithm MOTOROLA FLASH M29F040 \*DQ7 = Valid Data (the device has completed the embedded operation). Figure 5. AC Waveforms for Data Polling During Embedded Algorithm Operations \*DQ6 Stops Toggling (the device has completed the embedded operation). Figure 6. AC Waveforms for Toggle Bit During Embedded Algorithm Operations NOTE: DQ6 is rechecked even if DQ5 = 1 because DQ6 may stop toggling at the same time as DQ5 changing to 1. Figure 7. Toggle Bit Algorithm Figure 8. Maximum Undershoot Waveform Figure 9. Maximum Overshoot Waveform MOTOROLA FLASH M29F040 #### SECTOR PROTECTION ALGORITHMS #### SECTOR PROTECTION The device features hardware sector protection which will disable both program and erase operations to an individual sector or any group of sectors. To activate this mode, the programming equipment must force V<sub>ID</sub> on control pin $\overline{OE}$ and address pin A9. The sector addresses should be set using higher address lines A18, A17, and A16. The protection mechanism begins on the falling edge of the $\overline{WE}$ pulse and is terminated with the rising edge of the same. It is also possible to verify if a sector is protected during the sector protection operation. This is done by setting A6 = $\overline{CE}$ = $\overline{OE}$ = $V_{IL}$ and $\overline{WE}$ = $V_{IH}$ (A9 remains high at $V_{ID}$ ). Reading the device at address location XXX2H, where the higher order addresses (A18, A17, and A16) define a particular sector, will produce 01H at data outputs (DQ0 – DQ7) for a protected sector. #### **SECTOR UNPROTECT** The device also features a sector unprotect mode, so that a protected sector may be unprotected to incorporate any changes in the code. All sectors should be protected prior to unprotecting any sector. To activate this mode, the programming equipment must force $V_{ID}$ on control pins $\overline{OE}$ , $\overline{CE}$ , and address pin A9. The address pins A6, A16, and A12 should be set to $V_{IH}$ . The unprotection mechanism begins on the falling edge of the $\overline{WE}$ pulse and is terminated with the rising edge of the same. It is also possible to determine if a sector is unprotected in the system by writing the autoselect command and A6 is set at $V_{IH}$ . Performing a read operation at address location XXX2H, where the higher order addresses (A18, A17, and A16) define a particular sector address, will produce 00H at data outputs (DQ0 – DQ7) for an unprotected sector. Figure 10. Sector Protection Algorithm MOTOROLA FLASH M29F040 SA0 = Sector Address for initial sector SA7 = Sector Address for last sector Please refer to Table 3 for details. Figure 11. Sector Unprotect Algorithm ## ORDERING INFORMATION (Order by Full Part Number) **MOTOROLA FLASH** #### **PACKAGE DIMENSIONS** **F PACKAGE** 32-PIN PLCC CASE 989A-01 **VIEW AA** VIEW AB-AB - NOTES: 1. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982. 2. CONTROLLING DIMENSION: INCH. 3. DATUMS L, M, AND N DETERMINED WHERE TOP OF LEAD SHOULDER EXITS PLASTIC BODY AT MOLD PARTING LINE. - DIMENSIONS G1 AND H MEASURED AT CLOSEST APPROACH OF RADIUS TO - 4. DIMENSIONS GT AND H MEASUHED AT CLOSEST APPROACH OF RADIUS TO SEATING PLANE. 5. DIMENSIONS A AND B DO NOT INCLUDE MOLD FLASH. ALLOWABLE MOLD FLASH IS 0.010 (0.25) PER SIDE. 6. THE PACKAGE TOP MAY BE SMALLER THAN THE PACKAGE BOTTOM BY UP TO 0.012 (0.3). DIMENSIONS S AND U ARE DETERMINED AT THE OUTERMOST EXTREMES OF THE PLASTIC BODY EXCLUSIVE OF MOLD FLASH. THE BAR BURBS, GATE BURBS AND INTERLEAD FLASH. BUT INCLUDING ANY MISMATCH BETWEEN THE TOP AND BOTTOM OF THE PLASTIC BODY 7. DIMENSION P DOES NOT INCLUDE DAMBAR PROTRUSION OF INTRUSION. THE DAMBAR PROTRUSION OR INTRUSION. THE DAMBAR PROTRUSIONS(S) SHALL NOT CAUSE THE P DIMENSIONTO BE SMALLER THAN 0.025 (0.64). | | INC | HES | MILLIMETERS | | | | |-----|-------|-------|-------------|-------|--|--| | DIM | MIN | MAX | MIN | MAX | | | | Α | 0.447 | 0.453 | 11.35 | 11.51 | | | | B_ | 0.547 | 0.553 | 13.89 | 14.05 | | | | C_ | 0.125 | 0.140 | 3.18 | 3.56 | | | | D_ | 0.013 | 0.021 | 0.33 | 0.53 | | | | E_ | 0.080 | 0.095 | 2.03 | 2.41 | | | | F | 0.042 | 0.056 | 1.07 | 1 42 | | | | G | 0.050 | BSC | 1.27 | BSC | | | | G1 | 0.188 | 0.223 | 4.78 | 5 66 | | | | H | 0.238 | 0.273 | 6.05 | 6 93 | | | | J | 0.020 | ł | 0.51 | | | | | _ K | 0 025 | | 0.64 | | | | | K1 | 0.025 | 1 | 0.64 | | | | | P. | 0.026 | 0.032 | 0.66 | 0.81 | | | | R | 0.025 | 0.045 | 0.64 | 1.14 | | | | S | 0.585 | 0.595 | 14.86 | 15 1° | | | | Ū | 0.485 | 0.495 | 12.32 | 12.57 | | | | ٧ | 0.042 | 0.048 | 1.07 | 1.22 | | | | W | 0.042 | 0.048 | 1.07 | 1.22 | | | | Y | | 0.020 | 1 | 0.50 | | | | Z | 2 ° | 10° | 20 | 1019 | | | #### **T PACKAGE** 32-PIN TSOP CASE 1110-01 | | MILLIN | IETERS | INCHES | | | | |-----|-----------|--------|-----------|-------|--|--| | DIM | MIN | MAX | MIN | MAX | | | | A | 18.40 BSC | | 0 724 BSC | | | | | В | 8.00 | BSC | 0 315 BSC | | | | | C | _ | 1.20 | | 0.047 | | | | D | 0.17 | 0.27 | 0.007 | 0.011 | | | | E | 0.95 | 1.05 | 0.037 | 0.041 | | | | F | 0.17 | 0.23 | 0.007 | 900.0 | | | | G | 0 50 | BSC | 0.020 BSC | | | | | Ŧ | 0.05 | 0.15 | 0.002 | 0.006 | | | | J_ | 0.10 | 0.21 | 0.004 | 0.008 | | | | K | 0.25 BSC | | 0.010 BSC | | | | | L | 0.50 | 0.70 | 0.020 | 0 028 | | | | N | 0.10 | 0.16 | 0.004 | 0.006 | | | | S | 20.00 BSC | | 0.787 | 7 BSC | | | 0 20 0.003 0.008 0.08 \_ WITH PLATING Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters can and do vary in different applications. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part. Motorola and (A) are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer. MOTOROLA FLASH M29F040 #### R PACKAGE 32-PIN REVERSE TSOP CASE 1110A-01 | X=Y OR Z | | |----------|--| | VIEW AB | | | В | 8.00 | BSC | 0.315 BSC | | | |---|-------|------|-----------|-------|--| | ٥ | | 1.20 | | 0.047 | | | o | 0.17 | 0.27 | 0.007 | 0.011 | | | E | 0.95 | 1.05 | 0.037 | 0.041 | | | F | 0.17 | 0.23 | 0.007 | 0.009 | | | G | 0.50 | BSC | 0.020 BSC | | | | Н | 0.05 | 0.15 | 0.002 | 0.006 | | | 7 | 0.10 | 0.21 | 0.004 | 0.008 | | | K | 0.25 | BSC | 0.010 BSC | | | | L | 0.50 | 0.70 | 0.020 | 0 028 | | | N | 0.10 | 0.16 | 0.004 | 0 006 | | | S | 20.00 | BSC | 0.787 | BSC | | | W | 80.0 | 0.20 | 0.003 | 0 008 | | | 0 | 0 0 | 5 ° | 0 % | 5° | | #### Literature Distribution Centers: USA: Motorola Literature Distribution; P.O. Box 20912; Phoenix, Arizona 85036. EUROPE: Motorola Ltd.; European Literature Centre; 88 Tanners Drive, Blakelands, Milton Keynes, MK14 5BP, England. JAPAN: Nippon Motorola Ltd.; 4-32-1, Nishi-Gotanda, Shinagawa-ku, Tokyo 141, Japan. ASIA PACIFIC: Motorola Semiconductors H.K. Ltd.; Silicon Harbour Center, No. 2 Dai King Street, Tai Po Industrial Estate, Tai Po, N.T., Hong Kong.