# **CAT29F150** # 1.5 Megabit CMOS 5V Only Sector Flash Memory #### **FEATURES** - Fast Read Access Time: 90/120/150 ns - Sectored Architecture: - One 16-KB Boot Sector - Top or Bottom Locations - Two 8-KB Sectors - One 32-KB Sector - Two 64-KB Sectors - Hardware Data Protection - Automatic Program and Erase Algorithms - Commercial, Industrial and Automotive Temperature Ranges - 5V±10% Programming, Reading and Erase Voltage - **■** Electronic Signature - 100,000 Program/Erase Cycles and 10 Year Data Retention - **■** End of Write Detection - Toggle Bit - DATA Polling - Standard Pinouts: - 32-pin PLCC - 32-pin TSOP - **Low Power CMOS Dissipation** - Active Read: 30mA max. - Programming/Erase: 60mA max. - Standby: 1μA max. - Hardware RESET Pin #### **DESCRIPTION** The CAT29F150 is a high speed 192K X 8 electrically erasable and reprogrammable 5V only Flash memory ideally suited for applications requiring in-system or after sale code updates. The CAT29F150 has a sectored architecture with one 16 KB Boot sector, two 8 KB sectors, one 32 KB sector and two 64 KB sectors. The Boot sector can be at the top or bottom of the memory map. All six sectors include a lock out feature against program and erase operations to guarantee data integrity. The CAT29F150 is designed with a signature mode which allows the user to identify the IC manufacturer and device type. The CAT29F150 is also designed with onchip Address Latches, Data Latches, Programming and Erase Algorithms. DATA polling and Toggle status bits signal the start and end of the self time write cycle. Additionally, the CAT29F150 features a RESET pin, which when set LOW will abort the program or erase operations. The CAT29F150 is manufactured using Catalyst's advanced CMOS floating gate technology. It is designed to endure 100,000 program/erase cycles and has a data retention of 10 years. The device is available in JEDEC approved 32-pin TSOP and PLCC packages. #### **BLOCK DIAGRAM** Stock No. 21052-01 10/96 29F150 F01 #### PIN CONFIGURATION #### PLCC Package (P) A12 A15 A16 RESET VCC WE 3 2 1 32 31 30 29 $A_7 \square$ □ A<sub>14</sub> A<sub>6</sub> □ 6 28 🗖 A<sub>13</sub> 27 🗖 A<sub>8</sub> A<sub>5</sub> □ 26 🗖 A9 8 A4 □ Аз 🗆 25 🗀 A<sub>11</sub> 9 A<sub>2</sub> □ 10 24 🗀 😇 23 🗖 A<sub>10</sub> 11 A<sub>1</sub> □ 22 🗀 🖼 A<sub>0</sub> □ 12 21 DQ7 14 15 16 17 18 19 20 001 VSS VSS D03 D04 D05 #### **PIN FUNCTIONS** | Pin Name | Туре | Function | |------------------------------------|-------|--------------------------------------| | A <sub>0</sub> A <sub>17</sub> | I/P | Address inputs for memory addressing | | I/O <sub>0</sub> —I/O <sub>7</sub> | I/O | Data Input/Output | | CE | Input | Chip Enable | | ŌĒ | Input | Output Enable | | WE | Input | Write Enable | | RESET | Input | Reset | | Vcc | | Voltage Supply | | V <sub>SS</sub> | | Ground | TSOP Package (T) #### **MEMORY MAP** 29F150 F02 ### **ABSOLUTE MAXIMUM RATINGS\*** | Temperature Under Bias55°C to +95°C | |-------------------------------------------------------------------------------------------------------------------------------------------| | Storage Temperature65°C to +150°C | | Voltage on Any Pin with Respect to Ground <sup>(1)</sup> $-2.0V$ to $+V_{CC} + 2.0V$ (except A9, $\overline{OE}$ and $\overline{RESET}$ ) | | Voltage on Pin A <sub>9</sub> , $\overline{\text{OE}}$ and $\overline{\text{RESET}}$ with Respect to Ground –2.0V to +14.0V | | $V_{CC}$ with Respect to $Ground^{(1)}$ –2.0V to +7.0V | | Package Power Dissipation Capability (T <sub>A</sub> = 25°C) | | Lead Soldering Temperature (10 secs) 300°C | | Output Short Circuit Current <sup>(2)</sup> 200 mA | #### \*COMMENT Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions outside of those listed in the operational sections of this specification is not implied. Exposure to any absolute maximum rating for extended periods may affect device performance and reliability. #### **RELIABILITY CHARACTERISTICS** | Symbol | Parameter | Min. | Max. | Units | Test Method | | | | |---------------------------------|--------------------|------|------|-------------|-------------------------------|--|--|--| | N <sub>END</sub> (3) | Endurance | 100K | | Cycles/Byte | MIL-STD-883, Test Method 1033 | | | | | T <sub>DR</sub> <sup>(3)</sup> | Data Retention | 10 | | Years | MIL-STD-883, Test Method 100 | | | | | V <sub>ZAP</sub> <sup>(3)</sup> | ESD Susceptibility | 2000 | | Volts | MIL-STD-883, Test Method 3015 | | | | | I <sub>LTH</sub> (3)(4) | Latch-Up | 100 | | mA | JEDEC Standard 17 | | | | #### **CAPACITANCE** $T_A = 25^{\circ}C$ , f = 1.0 MHz | | | Lir | nits | | | |----------------------|-------------------------|-----|------|-------|----------------| | Symbol | Test | Min | Max. | Units | Conditions | | C <sub>IN</sub> (3) | Input Pin Capacitance | | 8 | pF | $V_{IN} = 0V$ | | Соит <sup>(3)</sup> | Output Pin Capacitance | | 12 | pF | $V_{OUT} = 0V$ | | C <sub>IN2</sub> (3) | Control Pin Capacitance | | 9 | pF | $V_{IN} = 0V$ | #### Note: - (1) The minimum DC input voltage is –0.5V. During transitions, inputs may undershoot to –2.0V for periods of less than 20 ns. Maximum DC voltage on output pins is V<sub>CC</sub> +0.5V, which may overshoot to V<sub>CC</sub> + 2.0V for periods of less than 20ns. - (2) Output shorted for no more than one second. No more than one output shorted at a time. - (3) This parameter is tested initially and after a design or process change that affects the parameter. - (4) Latch-up protection is provided for stresses up to 100 mA on address and data pins from -1V to V<sub>CC</sub> +1V. - (5) The minimum DC Input Voltage on pins A<sub>9</sub>, OE and RESET is -0.5V. During voltage transitions, A<sub>9</sub>, OE and RESET may undershoot to -2.0V for periods of less than 20ns. Maximum DC input on A<sub>9</sub> is 12.5V which may overshoot to 14.0V for periods up to 20ns. ### D.C. OPERATING CHARACTERISTICS $V_{CC}$ = +5V ±10%, unless otherwise specified | | | | Limits | | | |---------------------|---------------------------------------------------------|-----------------------|----------------------|------|-------------------------------------------------------------------------------------------------| | Symbol | Parameter | Min. | Max. | Unit | Test Conditions | | ILI | Input Leakage Current | | ±1.0 | μΑ | V <sub>IN</sub> = V <sub>CC</sub> or V <sub>SS</sub><br>V <sub>CC</sub> = 5.5V | | lLO | Output Leakage Current | | ±1 | μА | Vout = Vcc or Vss,<br>Vcc = 5.5V | | I <sub>SB1</sub> | Vcc Standby Current CMOS | | 1 | μА | $\overline{CE} = V_{CC} \pm 0.5V = \overline{RESET}$<br>$V_{CC} = 5.5V, \overline{OE} = V_{IH}$ | | I <sub>SB2</sub> | Vcc Standby Current TTL | | 400 | μА | CE = RESET = V <sub>IH</sub> ,<br>V <sub>CC</sub> = 5.5V | | Icc <sub>1</sub> | Vcc Active Read Current | | 30 | mA | CE = V <sub>IL</sub> ,<br>OE = V <sub>IH</sub> | | lcc2 <sup>(1)</sup> | V <sub>CC</sub> Program/Erase Current | | 60 | mA | CE = V <sub>IL</sub> , OE = V <sub>IH</sub><br>Program/Erase in Progress | | I <sub>CC4</sub> | V <sub>PP</sub> Reset Current | | 1 | μА | $\frac{V_{CC} = 5.5V}{RESET} = V_{SS} \pm 0.5V$ | | VIL | Input Low Level | -0.5 | 0.8 | V | | | V <sub>OL</sub> | Output Low Level | 0.7 x V <sub>CC</sub> | 0.45 | V | $I_{OL} = 12mA, V_{CC} = 4.5V$ | | V <sub>IH1</sub> | Input High Level CMOS | | V <sub>CC</sub> +0.3 | V | | | V <sub>OH2</sub> | Output High Level CMOS | V <sub>CC</sub> -0.4 | | V | $I_{OH} = -100 \mu A, V_{CC} = 4.5 V$ | | $V_{ID}$ | Voltage for Signature and<br>Temporary Sector Unprotect | 11.5 | 12.5 | V | Vcc = 5V | | V <sub>OH1</sub> | Output High Level CMOS | 0.85 V <sub>CC</sub> | | V | V <sub>CC</sub> = 4.5V<br>I <sub>OH</sub> = -2.5mA | | IL <sub>IT</sub> | Input Leakage Current<br>-High Voltage | | 50 | μА | $V_{CC} = 5.5V$ $A_9 = \overline{OE}, \overline{RESET} = 12.5V$ | | V <sub>IH2</sub> | Input High Level TTL | 2 | V <sub>CC</sub> +0.5 | V | | | V <sub>OH3</sub> | Output High Level TTL | 2.4 | | V | | Note: <sup>(1)</sup> This parameter is tested initially and after a design or process change that affects the parameter. #### **SUPPLY CHARACTERISTICS** | | | Lin | | | |------------------|------------------------------------------|-----|------|------| | Symbol | Parameter | Min | Max. | Unit | | V <sub>LKO</sub> | V <sub>CC</sub> Erase/Write Lock Voltage | 3.2 | 4.2 | V | | Vcc | V <sub>CC</sub> Supply Voltage | 4.5 | 5.5 | V | ### A.C. CHARACTERISTICS, Read Operation $V_{CC}$ = +5V ±10%, unless otherwise specified | JEDEC | Standard | | 29F1 | 50-12 | 29F1 | 50-15 | 29F1 | 50-20 | | |--------|-----------------------------------|---------------------------------------|------|-------|------|-------|------|-------|------| | Symbol | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | tavav | t <sub>RC</sub> | Read Cycle Time | 120 | | 150 | | 200 | | ns | | tELQV | tce | CE Access Time | | 120 | | 150 | | 200 | ns | | tavqv | tacc | Address Access Time | | 120 | | 150 | | 200 | ns | | tglav | toE | OE Access Time | | 35 | | 50 | | 50 | ns | | taxqx | tон | Output Hold from Address OE/CE Change | 0 | | 0 | | 0 | | ns | | tgнqz | t <sub>DF</sub> <sup>(1)(2)</sup> | OE High to Output High-Z | | 20 | | 30 | | 30 | ns | | tehqz | t <sub>HZ</sub> (1)(2) | CE High to Output High-Z | | 20 | | 30 | | 30 | ns | | | tready(1) | RESET Pin Low to Read Mode | | 20 | | 20 | | 20 | μs | Figure 1. A.C. Testing Input/Output Waveform (3)(4)(5)(6) Figure 2. A.C. Testing Load Circuit (example) Note: - (1) This parameter is tested initially and after a design or process change that affects the parameter. - (2) Output floating (High-Z) is defined as the state where the external data line is no longer driven by the output buffer. - (3) Input Rise and Fall Times (10% to 90%) = 20 ns. - (4) Input Pulse Levels = 0.45V and 2.4V. - (5) Input and Output Timing Reference = 0.8V and 2.0V. - (6) Output Load: ITTL gate and 100pF. Stock No. 21052-01 10/96 5108 FHD F04 # A.C. CHARACTERISTICS, Program/Erase Operation $V_{CC} = +5V \pm \! 10\%$ | JEDEC | Standard | | 29F1 | 50-12 | 29F1 | 50-15 | 29F1 | 50-20 | | |--------|---------------------|-----------------------------------------------------|------|-------|------|-------|------|-------|------| | Symbol | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | tavav | twc | Write Cycle Time | 120 | | 150 | | 200 | | ns | | tavwl | tas | Address Setup Time | 0 | | 0 | | 0 | | ns | | twLax | tah | Address Hold Time | 45 | | 45 | | 45 | | ns | | tovwh | tos | Data Setup Time | 45 | | 45 | | 45 | | ns | | twhox | t <sub>DH</sub> | Data Hold Time | 0 | | 0 | | 0 | | ns | | telwl | tcs | CE Setup Time | 0 | | 0 | | 0 | | ns | | twheh | tсн | CE Hold Time | 0 | | 0 | | 0 | | ns | | twLwH | twp | WE Pulse Width | 45 | | 45 | | 45 | | ns | | twhdL | twph | WE High Pulse Width | 20 | | 20 | | 20 | | ns | | twhwh1 | _ | Duration of Programming Operations | 16 | | 16 | | 16 | | μs | | twhwh2 | _ | Duration of Erase Operations (Sector) | 1 | | 1 | | 1 | | Sec | | | toes(1) | Output Enable Setup Time | 0 | | 0 | | 0 | | ns | | | toeH <sup>(1)</sup> | OE Hold Time | 0 | | 0 | | 0 | | ns | | | t <sub>GHWL</sub> | READ Recovery Time Before WRITE (OE HIGH to WE LOW) | 0 | | 0 | | 0 | | ns | | | tvcs <sup>(1)</sup> | V <sub>CC</sub> Setup Time | 50 | | 50 | | 50 | | μs | | | tvidr | Rise Time to V <sub>ID</sub> | 500 | | 500 | | 500 | | ns | | | t <sub>RP</sub> | RESET Pulse Width | 500 | | 500 | | 500 | | ns | | | t <sub>RSP</sub> | RESET Setup Time | 4 | | 4 | | 4 | | μs | #### Note # **ERASE AND PROGRAMMING PERFORMANCE**(10) | | 29F150-12 | | | 29F150-15 | | | 29 | | | | |-------------------|-----------|------|------|-----------|------|------|------|------|------|------| | Parameter | Min. | Тур. | Max. | Min. | Тур. | Max. | Min. | Тур. | Max. | Unit | | Sector Erase Time | | 1.0 | 15 | | 1.0 | 15 | | 1.0 | 15 | Sec | | Chip Program Time | | 3.6 | 25 | | 3.6 | 25 | | 3.6 | 25 | Sec | | Byte Program Time | | 7 | 1000 | | 7 | 1000 | | 7 | 1000 | μs | | Chip Erase Time | | 8 | 120 | | 8 | 120 | | 8 | 120 | Sec | <sup>(1)</sup> This parameter is tested initially and after a design or process change that affects the parameter. # FUNCTION TABLE<sup>(1)</sup> | | | | Pins | | | | |----------------------------|-----------------|-----------------|-----------------|-----------------|----------------------------|---------------------------------------------------------------------------------------| | Mode | RESET | CE | ŌE | WE | I/O | Notes | | Read | ViH | VIL | VIL | ViH | Dout | | | Output Disable | Х | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | High-Z | | | Standby | V <sub>IH</sub> | V <sub>IH</sub> | Х | Х | High-Z | | | Signature (MFG) | V <sub>IH</sub> | VIL | VIL | V <sub>IH</sub> | 31H | $A_0 = A_1 = A_6 = V_{IL}, A_9 = 12V$ | | Signature (Device) | V <sub>IH</sub> | VIL | VIL | ViH | DAH=29F150T<br>DBH=29F150B | $A_0 = V_{IH}, A_9 = 12V$<br>$A_1 = A_6 = V_{IL}$ | | Write Cycle | V <sub>IH</sub> | VIL | V <sub>IH</sub> | VIL | D <sub>IN</sub> | During Write Cycle | | Enable Sector Protect | ViH | VIL | V <sub>ID</sub> | VIL | Х | $A_6 = V_{IL}$ $A_9 = 12V$ | | Verify Sector Protect | V <sub>IH</sub> | Х | Х | Х | O1H | $A_0 = A_6 = V_{IL}$<br>$A_1 = V_{IH}, A_9 = 12V$<br>$A_{13} - A_{17} = Sector Addr.$ | | Temporary Sector Unprotect | V <sub>ID</sub> | Х | Х | Х | X | | | Reset | V <sub>IL</sub> | Х | Х | Х | HIGH-Z | | #### WRITE COMMAND TABLE Commands are written into the command register in one to six write cycles. Write cycles also internally latch addresses and data required for programming and erase operations. | | First | Bus C | ycle | Secon | d Bus | Cycle | Third | Bus C | ycle | F | ourth B | us Cycle | Fifth | Bus C | ycle | Sixth | Bus C | ycle | |--------------------------------|-------|-------|------|-------|-------|-------|-------|-------|------|-------|-----------------|---------------------------|-------|-------|------|-------|---------------|------| | Mode | Oper | Addr | Data | Oper | Addr | Data | Oper | Addr | Data | Oper | Addr | Data | Oper | Addr | Data | Oper | Addr | Data | | Read/Reset | Write | Х | F0H | | | | | | | | | | | | | | | | | Erase Suspend/<br>Erase Resume | Write | Х | В0Н | Write | Х | 30H | | | | | | | | | | | | | | Chip Erase | Write | 555H | AAH | Write | AAAH | 55H | Write | 555H | 80H | Write | 555H | AAH | Write | АААН | 55H | Write | 555H | 10H | | Sector Erase | Write | 555H | ААН | Write | AAAH | 55H | Write | 555H | 80H | Write | 555H | AAH | Write | AAAH | 55H | Write | Sect<br>Addr. | 30H | | Byte Program | Write | 555H | ААН | Write | АААН | 55H | Write | 555H | A0H | Write | Ain | Din | | | | | | | | Read Sig. (MFG) | Write | 555H | ААН | Write | AAAH | 55H | Write | 555H | 90H | Read | 0000Н | 31H | | | | | | | | Read Sig. (DEV) | Write | 555H | ААН | Write | AAAH | 55H | Write | 555H | 90H | Read | 0001H | DAH-29F150T<br>DB-29F150B | | | | | | | | READ/RESET | Write | 555H | ААН | Write | AAAH | 55H | Write | 555H | F0H | Read | A <sub>IN</sub> | Dout | | | | | | | Note (1) Logic Levels: $X = \text{Logic 'Do not care'}(V_{IH}, V_{IL}, V_{PPL}, V_{PPH})$ ### **READ OPERATIONS** #### **Read Mode** The CAT29F150 memory can be read from any of its sectors by sending the Read Command Mode to the command register. CAT29F150 automatically resets to Read Mode upon initial device power up. A read operation is performed with both $\overline{CE}$ and $\overline{OE}$ low and $\overline{WE}$ high. The data retrieved from the I/O pins reflects the contents of the memory location corresponding to the state of the 18 address pins. The respective timing waveforms for the read operation are shown in Figure 2. Refer to the AC Read Characteristics for specific timing parameters. #### Signature Mode The signature mode allows the user to identify the IC manufacturer and the type of the device while the device resides in the target system. This mode can be activated in either of two ways; through the conventional method of applying a high voltage (12V) to address pin A9 or by sending an instruction to the command register (see write operations). The conventional method is entered as a regular read mode by driving the $\overline{CE}$ and $\overline{OE}$ low (with $\overline{WE}$ high), and applying the required high voltage on address pin A9 while A0, A1 and A6 are $V_{IL}$ level and the rest of address are don't cares. A Read cycle from address 0000H retrieves the binary code for the IC manufacturer on Outputs $I/O_7$ to $I/O_0$ : Catalyst Code = 0011 0001(31H) A Read cycle from address 0001H retrieves the binary code for the device on outputs $I/O_7$ to $I/O_0$ : CAT29F150T = 1101 1010(DAH) CAT29F150B = 1101 1011(DBH) A Read cycle from address XX02H (A<sub>13</sub>-A<sub>17</sub> set to the desired sector) retrieves 01H for a protected sector and 00H for a non-protected sector. ### **Standby Mode** With $\overline{\text{CE}}$ and $\overline{\text{RESET}}$ at a logic-high level, the CAT29F150 is placed in a standby mode where most of the device circuitry is disabled, thereby substantially reducing power consumption. Also, when the $\overline{\text{RESET}}$ pin is low, the CAT29F150 is in a standby mode ( $\overline{\text{CE}}$ is don't care). The outputs are placed in a high-impedance state independent of the $\overline{\text{OE}}$ status. Figure 3. A.C. Timing for Read Operation 29F150 F05 ### WRITE OPERATIONS The following operations are initiated by observing the sequence specified in the Write Command Table. #### **Read Array** The device can be put into a Read Mode by initiating a write cycle Read/Reset Command on the data bus. The device is also in a standard Read Mode after the initial device power up. This eliminates any accidental writes during power up or power down. The device remains in the Read Mode until command register contents are changed. ### Signature Mode An alternative method for reading device signature (see Read Operations Signature Mode), is initiated by writing the command sequence into the command register. A read cycle from address XX00H with $\overline{\text{CE}}$ and $\overline{\text{OE}}$ low (and $\overline{\text{WE}}$ high) will output the device signature. A<sub>12</sub>-A<sub>17</sub> are don't cares for this operation. Catalyst Code = Catalyst Code = 0011 0001 (31H) A Read cycle from address XX01H retrieves the binary code for the device on outputs I/O<sub>7</sub> to I/O<sub>0</sub>: CAT29F150T = 1101 1010 (DAH) CAT29F150B = 1101 1011 (DBH) A Read cycle from address XX02H (A<sub>13</sub>-A<sub>17</sub> set to the desired sector) retrieves 01H for a protected sector and 00H for a non-protected sector. To terminate the operations, it is necessary to write another valid command into the register. #### Program/Erase Programming and erasing of the CAT29F150 is done by sending the command sequence as shown in Write Command Table to the command register. The command register is written by driving the $\overline{CE}$ and $\overline{WE}$ Low and $\overline{OE}$ High. Address inputs are latched on the falling edge of $\overline{WE}$ or $\overline{CE}$ , whichever occurs last. Data conversely, is latched on the rising edge of $\overline{WE}$ or $\overline{CE}$ whichever occurs first. Refer to AC characteristics and waveforms (Program/Erase) for specific timing parameters. #### **Sector Protection** All the six sectors can be protected in any combination by following the sequence in the function table. It is possible to determine if a certain sector is protected or not. A Read cycle from address XX02H (A<sub>13</sub>-A<sub>17</sub> set to the desired sector) retrieves 01H for a protected sector and 00H for a non-protected sector. The protected sectors can be temporarily unprotected by applying 12V to the RESET pin (Refer to figure for details). This enables writing or erasing the protected sector by specifying the sector address. Once the 12V is removed from the RESET pin the CAT29F150 goes back its original state. #### **Byte Programming** Byte programming is done using four write commands. The first two commands are used as unlock write commands. The third write command is the program set up command. The fourth write command is used to send the address and the data information. Addresses are latched on the falling edge of $\overline{WE}$ or $\overline{CE}$ whichever occurs last. Data conversely, is latched on the rising edge of $\overline{WE}$ or $\overline{CE}$ , whichever occurs first. The rising edge initiates programming. The Byte programming is done using the embedded programming algorithm. The device will automatically provide adequate internally generated program pulses and verify the programmed cell margin. Any command written to the chip during the programming algorithm will be ignored. As soon as the programming is done, the device resets to a read mode. If a hardware reset occurs during the programming operation, the data at that particular location will be corrupted. #### Chip Erase Chip erase is done using six write commands. The first two commands are unlock write commands. The third write command is Erase Setup command. This is followed by two more commands which are unlock write commands. The sixth command is the chip erase command. The rising edge of $\overline{CE}$ or $\overline{OE}$ initiates erasing. Chip erasing is done using the Embedded erasing algorithm. This algorithm does not require all locations to be programmed before the chip is erased, since it automatically programs and verifies all locations to a all zero pattern before it starts the chip erase. As soon as the erasing is done, the device resets to a read mode. #### **Sector Erase** Sector erase is done using six write commands. The first two commands are unlock write commands. The third write command is Erase Setup command. This is followed by two more commands which are unlock write commands. The sixth command is the sector erase command. The address part of the sixth write command specifies the sector address. The address can be anywhere within the sector that needs to be erased. The sector address is latched on the falling edge of WE, while the command 30H is latched on the rising edge of WE. The sector erase begins after a time out of 80 ms from the rising edge. Multiple sectors can be erased sequentially by writing the six write commands . This sequence is followed with writes of the Sector Erase command to addresses in other sectors to be sequentially erased. The time between writes must be less than 80 ms. After the complete sequence, the sector erase begins after a time out of 80 ms from the last $\overline{\text{WE}}$ or $\overline{\text{CE}}$ rising edge. If another falling edge occurs with the 80 ms time-out window the timer will be reset. Any command other than Sector Erase or Erase Suspend during the sector erase time out does not execute, resets the device to the read mode, and cancels the previous sector erase command. Sector erasing is done using the Embedded erasing algorithm. This algorithm does not require all locations to be programmed before the chip is erased, since it automatically programs and verifies all locations to a all zero pattern before it starts the chip erase. When performing sector erase, sectors that are protected or not selected for erasure will not be changed. As soon as the erasing is done, the device resets to a read mode. #### **Erase Suspend** The Erase Suspend Command allows erase sequence interruption in order to read data from or program data to another sector of memory not being erased (takes 20 ms to suspend the erase operation). Writing the erase suspend command during the sector erase time out results in termination of the time out period and suspension of the erase operation. The Erase suspend command is valid during erase operation only and the device defaults to a read mode until it receives another command. Any command other read, program or erase resume commands written during the erase suspend mode will be ignored. Sending the Erase Resume command (30H) will resume the erase operation. ### WRITE OPERATION STATUS #### **DATA** Polling $\overline{\text{DATA}}$ Polling is provided to indicate the completion of write or erase cycle. $\overline{\text{DATA}}$ Polling is active during the programming, Erasing, Erase Suspend and sector erase time out. Once these functions are initiated, attempting to read the last byte written will output the complement of that data on I/O<sub>7</sub> until the function is completed. Upon completion of the functions, all I/Os will output true data during a read cycle. DATA Polling is valid after the rising edge of WE or CE during the last write command of the sequence of that function (e.g. sixth WE or CE rising of edge for a erase cycle). DATA Polling can be done at an address within a sector that is being programmed or erased. DATA polling may give an inaccurate result if the address used is in a protected sector. #### **Toggle Bit** In addition to the DATA Polling feature, the device offers an additional method for determining the completion of write or erase cycle. While a write or erase cycle is in progress, reading data from the device will result in I/O6 toggling between one and zero. However, when the erase or write cycle is complete, I/O6 stops toggling and valid data can be read from the device. Toggle Bit function is also valid during Erase Suspend/Resume command and sector erase time out window. When the part has entered erase suspended mode, I/O6 will stop toggling. The user must use the address of a sector Not being erased when reading I/O6 to determine if the erase operation has been suspended. Toggle Bit is valid after the rising edge of $\overline{\text{WE}}$ or $\overline{\text{CE}}$ during the last write command of the sequence of that function (e.g. sixth $\overline{\text{WE}}$ or $\overline{\text{CE}}$ rising of edge for a erase cycle). #### **Exceeded Timing Limits** The CAT29F150 features a program or erase failure indicator. $I/O_5$ will produce a "1" (Failure Condition) when the specified limits for program or erase times have been exceeded. The $\overline{\text{CE}}$ circuit will partially power down the device under these conditions. The failure condition may also result if a user tries to program a "1" to a location that was previously programmed to a "0". If timing limits are exceeded, reset the device. #### **Sector Erase Timer** After the six command sequence for the sector erase, the sector erase time out will begin. $I/O_3$ will remain low until the time out is complete. If $\overline{DATA}$ Polling or the Toggle Bit indicates the device has been written with a sector Erase Command, $I/O_3$ may be used to determine if the sector erase timer window is still open. If $I/O_3$ is at "1", attempts to write subsequent commands (other than Erase Suspend) to the device will be ignored until the erase operation is complete. If $I/O_3$ is at "0", the device will accept additional sector erase commands. #### **Erase Toggle Bit** In the Erase (chip or sector) operation, I/O<sub>2</sub> will toggle with $\overline{OE}$ or $\overline{CE}$ when read is attempted. For a sector erase operation, I/O<sub>2</sub> will not toggle if the read address is not within the sector that is being erased. For the Multiple Sector Erasing, I/O<sub>2</sub> can be used to indicate which sector is being erased. Also, if I/O<sub>5</sub> is at "1" during Multiple Sector Erasing, I/O<sub>2</sub> toggling will help detect which sector exceeded timing limits. #### OTHER FEATURES ### Hardware RESET The RESET pin, when set to low will reset any operation that is in progress and sets the CAT29F150 to a read mode. The RESET pin must be kept low for at least 500ns. When RESET is low, the device will be in the standby mode for the duration of pulse (20ms) and all I/O pins are tri-stated. If a hardware reset occurs during a program or erase operation, the data at that particular location will be corrupted. #### **Hardware Protection** The following is a list of hardware data protection features that are incorporated into the CAT29F150. a) The internal command register for the CAT29F150 is reset to the Read Mode on power up. This offers protection against accidental programming or erasing caused by spurious system level signals that may exist during power up/down transitions. - b) The CAT29F150 requires multiple commands before a user can erase or program into the device. For example a write instruction requires four commands. - c) Vcc sense provides for write protection when Vcc falls $V_{\text{LKO}}$ voltage level. - d) Noise pulses of less than 5ns on the $\overline{WE}$ , $\overline{CE}$ or $\overline{OE}$ inputs will not result in a write cycle. - e) Write inhibited is activated by holding any one of $\overline{OE}$ low, $\overline{CE}$ high or $\overline{WE}$ high. - f) Power up of the device with $\overline{CE}$ low, $\overline{WE}$ low and $\overline{OE}$ high will not accept commands on the rising edge of $\overline{WE}$ . The device is in a read mode on power up. Figure 4. Automated Program Algorithm | Bus<br>Operation | Sequence | Comments | | | | | | |------------------|----------|-----------------------------------------|--|--|--|--|--| | Standby* | | | | | | | | | Write | Program | Valid Address/Data<br>Sequence | | | | | | | Read | | DATA Polling to Verify<br>Programming | | | | | | | Read | | Compare Data Output to<br>Data Expected | | | | | | Device is either powered-down in erase inhibit or in program inhibit. Figure 5. Embedded Erase Algorithm | Bus<br>Operation | Sequence | Comments | |------------------|----------|-----------------------------------| | Standby* | | | | Write | Erase | | | Read | | DATA Polling to Verify<br>Erasure | | Read | | Compare Output to FFH | Device is either powered-down in erase inhibit or in program inhibit. Figure 6. DATA Polling Algorithm Figure 7. Toggle Bit Algorithm Figure 8. Temporary Sector Unprotect Algorithm Note 1: All protected sectors unprotected Note 2: All previously protected sectors are protected once again Figure 10. AC Waveform for Chip/Sector Erase Operations Note: SA is the sector address for Sector Erase. Addresses = don't care for Chip Erase Figure 11. Program Operation Timings Note 1: I/O<sub>7</sub> is the output of the complement of the data written to the device Note 2: D<sub>OUT</sub> is the output of the data written to the device Note 3: PA is the address of the memory location to be programmed Note 4: PD is the data to be programmed at the byte address Note 5: Drawing shows the last two cycles of a two-bus sequence Figure 12. AC Waveforms for DATA Polling During Automated Algorithm Operations Figure 13. AC Waveforms for Toggle Bit During Automated Algorithm Operations Figure 14. Temporary Sector Unprotect Timing Diagram Figure 15. RESET Timing Diagram Figure 16. Alternate CE Controlled Write Operation Timings Note 1: PA is the address of the memory location to be programmed Note 2: PD is the data to be programmed at the byte address Note 3: $I/O_7$ is the output of the complement of the data written to the device Note 4: D<sub>OUT</sub> is the output of the data written to the device Note 5: Drawing shows the last two bus cycles of a four-bus sequence ## **ALTERNATE CE CONTROLLED WRITES** | JEDEC | Standard | | 29F150-12 | | 29F150-15 | | 29F150-20 | | | |--------|---------------------|-----------------------------------------------------|-----------|------|-----------|------|-----------|------|------| | Symbol | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | tavav | twc | Write Cycle Time | 120 | | 150 | | 200 | | ns | | tavel | tas | Address Setup Time | 0 | | 0 | | 0 | | ns | | telax | tah | Address Hold Time | 45 | | 45 | | 45 | | ns | | toveh | t <sub>DS</sub> | Data Setup Time | 45 | | 45 | | 45 | | ns | | tehdx | t <sub>DH</sub> | Data Hold Time | 0 | | 0 | | 0 | | ns | | telel | tws | WE Setup Time | 0 | | 0 | | 0 | | ns | | teheh | twH | WE Hold Time | 0 | | 0 | | 0 | | ns | | teleh | tcp | WE Pulse Width | 45 | | 45 | | 45 | | ns | | tehdl | tсрн | WE High Pulse Width | 20 | | 20 | | 20 | | ns | | twnwh1 | _ | Duration of Programming Operations | 16 | | 16 | | 16 | | μs | | twhwh2 | _ | Duration of Erase Operations (Sector) | 1 | | 1 | | 1 | | Sec | | | toes(1) | Output Enable Setup Time | 0 | | 0 | | 0 | | ns | | | toeH <sup>(1)</sup> | OE Hold Time | 0 | | 0 | | 0 | | ns | | | tGHEL | READ Recovery Time Before WRITE (OE HIGH to WE LOW) | 0 | | 0 | | 0 | | ns | | | tvcs <sup>(1)</sup> | V <sub>CC</sub> Setup Time | 50 | | 50 | | 50 | | μs | | | tvidr | Rise Time to V <sub>ID</sub> | 500 | | 500 | | 500 | | ns | | | t <sub>RP</sub> | RESET Pulse Width | 500 | | 500 | | 500 | | ns | | | trsp | RESET Setup Time | 4 | | 4 | | 4 | | μs | Note: # **ORDERING INFORMATION** <sup>(1)</sup> This parameter is tested initially and after a design or process change that affects the parameter.