IS29F010 IS29F010 # 1 MEGABIT (128K x 8-bit) CMOS, 5.0V Only Sectored Flash Memory ## PRELIMINARY OCTOBER 1998 #### **FEATURES** - High-performance CMOS 35, 45, 55, 70, and 90 ns max. access time - Single 5V-only power supply 5V ± 10% for Read, Program, and Erase - · CMOS low power consumption - 20 mA (typical) active read current - 30 mA (typical) Program/Erase current - Compatible with JEDEC-standard pinouts - 32-pin DIP - 32-pin PLCC - 32-pin TSOP - Program/Erase cycles: 100,000 minimum - Flexible sector architecture includes eight uniform sectors. Any combination of sectors can be erased as well as full chip erase - Sector protection/unprotection can be implemented using standard PROM programming equipment - Sector protection is enhanced with a hardwarebased feature that disables/re-enables program and erase operations in any combination of sectors - Embedded Program algorithm automatically programs and verifies data at specified address - Embedded Erase algorithm automatically preprograms and erases the chip or any combination of designated sector - Data/Polling and Toggle Bits detect program or erase cycle completion #### DESCRIPTION The *ISSI* IS29F010 is a 1 Megabit (131,072 bytes) single 5.0V-only Sectored Flash Memory. The IS29F010 provides in-system programming with the standard system 5.0V-only Vcc supply and can be programmed or erased in standard PROM programmers. The IS29F010 offers access times of 35, 45, 55, 70, and 90 ns allowing high-speed microprocessors to operate without wait states. Byte-wide data appears on DQ0-DQ7. Separate chip enable $(\overline{\text{CE}})$ , write enable $(\overline{\text{WE}})$ , and output enable $(\overline{\text{OE}})$ controls eliminates bus contention. Power consumption is greatly reduced when the system places the device into the Standby Mode. The device is offered in 32-pin PLCC, TSOP, and PDIP packages. ## **Principles of Operation** Only a single 5.0V power supply is required for both read and write functions. Program or erase operations do not require 12.0V VPP. Internally generated and regulated voltages are provided for the program and erase operations. The device is entirely command set compatible with the JEDEC single power supply Flash standard. Commands are written to the command register using standard microprocessor write timings. Register contents serve as input to an internal state machine that 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 other Flash or EPROM devices. Executing the Program Command Sequence invokes the Embedded Program Algorithm, an internal algorithm that automatically times the program pulse widths and verifies proper cell margin. This document contains PRELIMINARY data. ISSI reserves the right to make changes to its products at any time without notice in order to improve design and supply the best possible product. We assume no responsibility for any errors which may appear in this publication. © Copyright 1998, Integrated Silicon Solution, Inc. Executing the Erase Command Sequence invokes the Embedded Erase Algorithm, an internal algorithm that automatically pre-programs the array to all zeros (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 during erase. By reading the DQ7 (Data Polling) and DQ6 (toggle) status bits, the host system can detect whether a program or erase operation is complete. After completion, the device is ready to read array data or accept another command. The sector erase architecture is designed to allow memory sectors to be erased and reprogrammed without affecting the data contents of other sectors. The device is erased before it is shipped to customers. The hardware data protection includes a low Vcc detector that automatically inhibits write operations during power transitions. The hardware sector protection feature will disable both program and erase operations in any combination of the sectors of memory, and is implemented using standard EPROM programming algorithm. The device electrically erases all bits within a sector simultaneously via Fowler-Nordheim tunneling. Data are programmed one byte at a time using the EPROM programming algorithm of hot electron injection. Figure 1. IS29F010 Block Diagram #### PIN CONFIGURATIONS Figure 2. IS29F010 32-pin Plastic DIP ## **Table 1. Pin Descriptions** | A0-A16 | Address Inputs | |---------|------------------------| | DQ0-DQ7 | Data Inputs/Outputs | | CE | Chip Enable Input | | ŌĒ | Output Enable Input | | WE | Write Enable Input | | Vcc | Power Supply Voltage | | GND | Ground | | NC | No Internal Connection | Figure 3. IS29F010 32-pin PLCC Figure 4. IS29F010 32-pin TSOP #### **BUS OPERATIONS** Table 2. Device Bus Operations(1, 2) | Operation | CE | ŌĒ | WE | Address (A16-A0) | DQ0-DQ7 | |----------------|------------|----|----|------------------|----------| | Read | L | L | Н | Aın | Data Out | | Write | L | Н | L | <b>A</b> IN | Data In | | Standby | Vcc ± 0.5V | Х | X | X | High-Z | | Output Disable | L | Н | Н | Х | High-Z | #### Notes: - 1. L = V<sub>IL</sub> , H = V<sub>IH</sub> , X = Don't care, AIN = Address In. - 2. The sector protect and sector unprotect functions must be implemented via programming equipment. See the Sector Protection/Unprotection section. ## **Requirements for Reading Array Data** Upon device power-up, or after a hardware reset, the internal state machine is set for reading array data. This ensures that no spurious alteration of the memory content occurs during the power transition. No command is necessary in this mode to obtain array data. Standard microprocessor read cycles that assert valid addresses on the device address inputs produce valid data on the device data outputs. The device remains enabled for read access until the command register contents are altered. The system must drive the $\overline{CE}$ and $\overline{OE}$ pins to $V_{IL}$ to read array data from the outputs. $\overline{CE}$ is the power control and selects the device. $\overline{OE}$ is the output control that passes array data to the output pins. During a READ operation, $\overline{WE}$ must remain at $V_{IH}$ . ## Write Commands/Command Sequences The system must drive $\overline{WE}$ and $\overline{CE}$ to VIL, and $\overline{OE}$ to VIH to write a command or command sequence (which includes programming data to the device and erasing sectors of memory). An erase operation can erase one sector, multiple sectors, or the entire device. The Sector Address Table (see Table 3) indicate the address space that each sector occupies. A "sector address" consists of the address bits required to uniquely select a sector. See the "Command Definitions" section for details on erasing a sector or the entire chip. **Table 3. Sector Addresses Table** | Sector | A16 | A15 | A14 | Address Range | |-----------|-----|-----|-----|---------------| | Sector A0 | 0 | 0 | 0 | 00000H-03FFFH | | Sector A1 | 0 | 0 | 1 | 04000H-07FFFH | | Sector A2 | 0 | 1 | 0 | 08000H-0BFFFH | | Sector A3 | 0 | 1 | 1 | 0C000H-0FFFFH | | Sector A4 | 1 | 0 | 0 | 10000H-13FFFH | | Sector A5 | 1 | 0 | 1 | 14000H-17FFFH | | Sector A6 | 1 | 1 | 0 | 18000H-1BFFFH | | Sector A7 | 1 | 1 | 1 | 1C000H-1FFFFH | After the system writes the auto-select command sequence, the device enters the auto-select mode. The system can then read auto-select codes from the internal register (which is separate from the memory array) on DQ7-DQ0. Standard read cycle timings apply in this mode. Refer to the "Auto-select Mode and Auto-select Command Sequence" sections for more information. ## **Program and Erase Operation Status** By reading the status bits on DQ7-DQ0, the system may check the status of the operation during an erase or program operation. ## Standby Mode In the Standby Mode, current consumption is greatly reduced, and the outputs are placed in the high impedance state, independent of the $\overline{OE}$ input. The system can place the device in the standby mode when it is not reading or writing to the device. The device enters the CMOS standby mode when the $\overline{\text{CE}}$ pin is held at $V_{\text{CC}} \pm 0.5 \text{V}$ . The device enters the TTL standby mode when $\overline{\text{CE}}$ is held at $V_{\text{IH}}$ . The device requires the standard access time (tCE) before it is ready to read data. If the device is deselected during erasure or programming, the device draws active current until the operation is completed. ## **Output Disable Mode** When the $\overline{OE}$ = V<sub>IH</sub>, the output from the device is disabled and the output pins are placed in the high-impedance state. #### **Auto-select Mode** The auto-select mode provides access to the manufacturer and device equivalent codes, as well as sector protection verification codes, via the DQ7-DQ0 pins. This mode is primarily intended for programming equipment to automatically match a device to be programmed with its corresponding programming algorithm. However, the auto-select codes can also be accessed in-system through the command register. When using programming equipment, the auto-select mode requires V<sub>ID</sub> (11.5V to 12.5V) on address pin A9. Address pins A1 and A0 must be as shown in Auto-select Codes (High Voltage Method), Table 4. In addition, when verifying sector protection, the sector address must appear on the appropriate highest order address bits. Refer to the corresponding Sector Address Table (Table 3). The Command Definitions table shows the remaining address bits that are don't care. When all necessary bits have been set as required, the programming equipment may then read the corresponding identifier code on DQ7-DQ0. To access the auto-select codes in-system, the host system can issue the auto-select command via the command register, as shown in the Command Definitions table. This method does not require V<sub>ID</sub>. See "Command Definitions" for details on using the auto-select mode. ## **Sector Protection/Unprotection** The hardware sector protection feature disables both program and erase operations in any sector. The hardware sector unprotection feature re-enables both program and erase operations in previously protected sectors. Sector protection/unprotection procedure requires a high voltage ( $V_{\text{ID}}$ ) on address pin A9 and the control pins. Details on this method are provided in a supplement. Contact an ISSI representative to obtain a copy of the appropriate document. The device is shipped with all sectors unprotected. ISSI offers the option of programming and protecting sectors at its factory prior to shipping the device. Contact an ISSI representative for details. It is possible to determine whether a sector is protected or unprotected. See "Auto-select Mode" for details. Table 4. Auto-select Codes (High Voltage Method) | Description | CE | ŌĒ | WE | A16-A14 | A13-A10 | <b>A</b> 9 | A8-A2 | <b>A</b> 1 | A0 | DQ7-DQ0 | |-----------------------------------|----|----|----|---------|---------|-------------|-------|------------|----|----------------------| | Manufacturer<br>Equivalent ID | L | L | Н | Х | Х | <b>V</b> ID | Х | L | L | 01 (Hex) | | Device<br>Equivalent ID | L | L | Н | Х | Х | VID | Х | L | Н | 20 (Hex) | | Sector Protection<br>Verification | L | L | Н | SA | Х | <b>V</b> ID | Х | Н | L | 01H<br>(protected) | | | | | | | | | | | | 00H<br>(unprotected) | #### Note: 1. $L = V_{IL}$ , $H = V_{IH}$ , $V_{ID} = 11.5$ to 12.5V, SA = Address Sector, X = Don't care. #### **Hardware Data Protection** The command sequence requirement of unlock cycles for programming or erasing provides data protection against inadvertent writes (refer to the Command Definitions table). In addition, the following hardware data protection measures prevent accidental erasure or programming, which might otherwise be caused by spurious system level signals during Vcc power-up and power-down transitions, or from system noise. #### Low Vcc Write Inhibit When Vcc is less than VLKO , the device does not accept any write cycles. This protects data during Vcc power-up and power-down. The command register and all internal program/erase circuits are disabled, and the device resets. Subsequent writes are ignored until Vcc is greater than VLKO . The system must provide the proper signals to the control pins to prevent unintentional writes when Vcc is greater than VLKO . #### Write Pulse "Glitch" Protection Noise pulses of less than 5 ns (typical) on $\overline{OE}$ , $\overline{CE}$ , or $\overline{WE}$ do not initiate a write cycle. ## **Logical Inhibit** Write cycles are 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** If $\overline{WE} = \overline{CE} = V_{IL}$ and $\overline{OE} = V_{IH}$ during power-up, the device does not accept commands on the rising edge of $\overline{WE}$ . The internal state machine is automatically reset to reading array data on power-up. #### **COMMAND DEFINITIONS** Writing specific address and data commands or sequences into the command register initiates device operations. The Command Definitions Table 5 defines the valid register command sequences. Writing incorrect address and data values or writing them in the improper sequence resets the device to reading array data. All addresses are latched on the falling edge of $\overline{WE}$ or $\overline{CE}$ , whichever happens later. All data is latched on the rising edge of $\overline{WE}$ or $\overline{CE}$ , whichever happens first. Refer to the appropriate timing diagrams in the "AC Characteristics" section. ## **Reading Array Data** The device is automatically set to reading array data after device power-up. No commands are required to retrieve data. The device is also ready to read array data after completing an Embedded Program or Embedded Erase algorithm. The system must issue the reset command to re-enable the device for reading array data if the error status bit, DQ5, is set high after an erase or program operation, or while in the autoselect mode. See the "Reset Command" section, next. See also "Requirements for Reading Array Data" in the "Device Bus Operations" section for more information. The Read Operation's table provides the read parameters, and Read Operation Timings diagram shows the timing diagram. #### **Reset Command** The reset command may be written between the sequence cycles in an erase command sequence before erasing begins. This resets the device for reading array data. Once erasure begins, however, the device ignores reset commands until the operation is complete. The reset command may be written between the sequence cycles in a program command sequence before programming begins. This resets the device to reading array data. Once programming begins, however, the device ignores reset commands until the operation is complete. The reset command may be written between the sequence cycles in an auto-select command sequence. Once in the auto-select mode, the reset command must be written to return to reading array data. If the error status bit, DQ5, goes high during a program or erase operation, writing the reset command returns the device to reading array data. #### **Auto-select Command Sequence** The auto-select command sequence allows the host system to access the manufacturer and device equivalent codes, and determines whether or not a sector is protected. The Command Definitions Table 5 shows the address and data requirements. This method is an alternative to that shown in the Auto-select Codes (High Voltage Method) Table 4, which is intended for PROM programmers and requires VID on address bit A9. **Table 5. Command Definitions** | | | | | | | ( | Bus Cy<br>Hexade | | | | | | | |----------------------------|--------|------|------|------|------|------|------------------|------|-----------|------|------|------|------| | Command <sup>(1)</sup> | | 19 | st | 2n | | 3r | d | 4t | | 5t | | 61 | | | Sequence | Cycles | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | Addr | Data | | Read <sup>(3,4)</sup> | 1 | RA | RD | | | | | | | | | | | | Reset <sup>(5)</sup> | 3 | 5555 | AA | 2AAA | 55 | 5555 | F0 | | | | | | | | Auto-select <sup>(6)</sup> | | | | | | | | | | | | | | | Manufacturer Equiv | .ID 4 | 5555 | AA | 2AAA | 55 | 5555 | 90 | XX00 | 01 | | | | | | Device Equiv. ID | 4 | 5555 | AA | 2AAA | 55 | 5555 | 90 | XX01 | 20 | | | | | | Sector Protect | 4 | 5555 | AA | 2AAA | 55 | 5555 | 90 | (SA) | <u>00</u> | | | | | | Verify <sup>(7,8)</sup> | | | | | | | | X02 | 01 | | | | | | Program <sup>(9)</sup> | 4 | 5555 | AA | 2AAA | 55 | 5555 | A0 | PA | PD | | | | | | Chip Erase | 6 | 5555 | AA | 2AAA | 55 | 5555 | 80 | 5555 | AA | 2AAA | 55 | 5555 | 10 | | Sector Erase | 6 | 5555 | AA | 2AAA | 55 | 5555 | 80 | 5555 | AA | 2AAA | 55 | SA | 30 | #### Notes: - Bus Operations are described in Table 2. - All command bus cycles are write operations, except when reading array or auto-select data. - 3. No unlock or command cycles are required when reading array data. - 4. RA = Address of the memory location to be read; RD = Data read from location RA during read operation - 5. The Reset command is required to return to reading array data when device is in the auto-select mode, or if DQ5 goes high (while the device is providing status data). - 6. The fourth cycle of the "Auto-select Command Sequence" is a read operation. - The data is 00H for an unprotected sector and 01h for a protected sector. See "Auto-select Command Sequence" for more information. - 8. SA = Address of the sector to be verified (in auto-select mode) or erased. Address bits A16-A14 uniquely select any sector - 9. PA = Address of the memory location to be programmed. Addresses latch on the falling edge of the WE or CE pulse, whichever happens later; PD = Data to be programmed at location PA. Data latches on the rising edge of WE or CE pulse, whichever happens first. - 10. X = Don't Care. The auto-select command sequence is initiated by writing two unlock cycles, followed by the auto-select command. The device then enters the auto-select mode, and the system may read at any address any number of times, without initiating another command sequence. A read cycle at address XX00H or retrieves the manufacturer code. A read cycle at address XX01H returns the device code. A read cycle containing a sector address (SA) and the address 02H in returns 01H if that sector is protected, or 00H if it is unprotected. Refer to the Sector Address tables for valid sector addresses. The system must write the reset command to exit the autoselect mode and return to reading array data. ## **Byte Program Command Sequence** Programming is a four-bus-cycle operation. The program command sequence is initiated by writing two unlock write cycles, followed by the program setup command. The program address and data are written next, which in turn initiate the Embedded Program algorithm. The system is not required to provide further controls or timings. The device automatically provides internally generated program pulses and verify the programmed cell margin. The Command Definitions Table (Table 5) shows the address and data requirements for the byte program command sequence. When the Embedded Program algorithm is complete, the device then returns to reading array data and addresses are no longer latched. The system can determine the status of the program operation by using DQ7 or DQ6. See "Write Operation Status" for information on these status bits. Commands written to the device while the Embedded Program Algorithm is in progress are ignored. Programming is allowed in any sequence and across sector boundaries. A bit cannot be programmed from a '0' back to a '1'. Attempting to do so may halt the operation and set the error status bit, DQ5, to '1', or cause the Data Polling algorithm to indicate the operation was successful. However, a succeeding read will show that the data is still '0'. Only erase operations can convert a '0' to a '1'. **Note:** See Command Definitions (Table 5) for program command sequence. Figure 5. Program Operation ## **Chip Erase Command Sequence** Chip erase is a six-bus-cycle operation. The chip erase command sequence is initiated by writing two unlock cycles, followed by a setup command. Two additional unlock write cycles are then followed by the chip erase command, which in turn invokes the Embedded Erase algorithm. The device does not require the system to preprogram prior to erase. The Embedded Erase algorithm automatically preprograms and verifies 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. The Command Definitions table shows the address and data requirements for the chip erase command sequence. Commands written to the chip while the Embedded Erase Algorithm is in progress are ignored. The system can determine the status of the erase operation by using DQ7 or DQ6. See "Write Operation Status" for information on these status bits. When the Embedded Erase algorithm is complete, the device returns to reading array data and addresses are no longer latched. Figure 6 illustrates the algorithm for the erase operation. See the Erase/Program Operations tables in "AC Characteristics" for parameters, and to the Chip/Sector Erase Operation Timings for timing waveforms. ## **Sector Erase Command Sequence** Sector erase is a six bus cycle operation. The sector erase command sequence is initiated by writing two unlock cycles, followed by a setup command. Two additional unlock write cycles are then followed by the address of the sector to be erased, and the sector erase command. The Command Definitions Table (Table 5) shows the address and data requirements for the sector erase command sequence. The device does not require the system to preprogram the memory prior to erase. The embedded erase algorithm automatically programs and verifies the sector for an all zero data pattern prior to electrical erase. The system is not required to provide any controls or timings during these operations. After the command sequence is written, a sector erase time-out of 50 µs begins. During the time-out period, additional sector addresses and sector erase commands may be written. Loading the sector erase buffer may be done in any sequence, and the number of sectors may be from one sector to all sectors. The time between these additional Figure 6. Erase Operation #### Notes: - 1. For Erase Command Sequence. See Command Definitions - 2. See "DQ3: Sector Erase Timer" for more information. cycles must be less than 50 µs, otherwise the last address and command might not be accepted, and erasure may begin. It is recommended that processor interrupts be disabled during this time to ensure all commands are accepted. The interrupts can be re-enabled after the last Sector Erase command is written. If the time between additional sector erase commands can be assumed to be less than 50 µs, the system need not monitor DQ3. Any command during the time-out period resets the device to reading array data. The system must rewrite the command sequence and any additional sector addresses and commands. The system can monitor DQ3 to determine if the sector erase timer has timed out. (See the "DQ3: Sector Erase Timer" section.) The time-out begins from the rising edge of the final $\overline{WE}$ pulse in the command sequence. Once the sector erase operation has begun, all other commands are ignored. When the embedded erase algorithm is complete, the device returns to reading array data and addresses are no longer latched. The system can determine the status of the erase operation by using DQ7 or DQ6. Refer to "Write Operation Status" for information on these status bits. Figure 6 illustrates the algorithm for the erase operation. Refer to the Erase/Program Operations tables in the "AC Characteristics" section for parameters, and to the Sector Erase Operations Timing diagram for timing waveforms. #### WRITE OPERATION STATUS The device provides several bits to determine the status of a write operation: DQ3, DQ5, DQ6, and DQ7. DQ7 and DQ6 each offer a method for determining whether a program or erase operation is complete or in progress. Table 6 and the following subsections describe the functions of these bits. ## DQ7: Data Polling The Data Polling bit, DQ7, indicates to the host system whether an Embedded Algorithm is in progress or completed. Data Polling is valid after the rising edge of the final WE pulse in the program or erase command sequence. During the Embedded Program algorithm, the device outputs on DQ7 the complement of the datum programmed to DQ7. When the Embedded Program algorithm is complete, the device outputs the true datum programmed to DQ7. The system must provide the program address to read valid status information on DQ7. If a program address falls within a protected sector, $\overline{\text{Data}}$ Polling on DQ7 is active for approximately 2 $\mu$ s, then the device returns to reading array data. During the Embedded Erase algorithm, Data Polling produces a "0" on DQ7. When the Embedded Erase algorithm is complete, Data Polling produces a "1" on DQ7. This is analogous to the complement/true datum output described for the Embedded Program algorithm: the erase function changes all the bits in a sector to "1"; prior to this, the device outputs the "complement," or "0". The system must provide an address within any of the sectors selected for erasure to read valid status information on DQ7. After an erase command sequence is written, if all sectors selected for erasing are protected, Data Polling on DQ7 is active for approximately 100 $\mu$ s, then the device returns to reading array data. If not all selected sectors are protected, the Embedded Erase algorithm erases the unprotected sectors, and ignores the selected sectors that are protected. When the system detects DQ7 has changed from the complement to true data, it can read valid data at DQ7-DQ0 on the following read cycles. This is because DQ7 may change asynchronously with DQ0-DQ6 while Output Enable (OE) is asserted low. The Data Polling Timings (During Embedded Algorithms) figure in the "AC Characteristics" section illustrates this. - VA = Valid address for programming. During a sector erase operation, a valid address is an address within any sector selected for erasure. During chip erase, a valid address is any non-protected sector address. - DQ7 should be rechecked even if DQ5 = "1" because DQ7 may change simultaneously with DQ5. Figure 7. Data Polling Algorithm Table 6 shows the outputs for Data Polling on DQ7. Figure 7 shows the Data Polling algorithm. ## DQ6: Toggle Bit I Toggle Bit I on DQ6 indicates whether an Embedded Program or Erase algorithm is in progress or complete. Toggle Bit I may be read at any address, and is valid after the rising edge of the final WE pulse in the command sequence (prior to the program or erase operation), and during the sector erase time-out. During an Embedded Program or Erase algorithm operation, successive read cycles to any address cause DQ6 to toggle. (The system may use either $\overline{OE}$ or $\overline{CE}$ to control the read cycles.) When the operation is complete, DQ6 stops toggling. After an erase command sequence is written, if all sectors selected for erasing are protected, DQ6 toggles for approximately 100 us, then returns to reading array data. If not all selected sectors are protected, the Embedded Erase algorithm erases the unprotected sectors, and ignores the selected sectors that are protected. If a program address falls within a protected sector, DQ6 toggles for approximately 2 µs after the program command sequence is written, then returns to reading array data. The Write Operation Status table shows the outputs for Toggle Bit I on DQ6. Refer to Figure 8 for the toggle bit algorithm, and to the Toggle Bit Timings figure in the "AC Characteristics" section for the timing diagram. #### Reading Toggle Bit DQ6 Refer to Figure 8 for the following discussion. Whenever the system initially begins reading toggle bit status, it must read DQ7-DQ0 at least twice in a row to determine whether a toggle bit is toggling. Typically, a system would note and store the value of the togale bit after the first read. After the second read, the system would compare the new value of the toggle bit with the first. If the toggle bit is not toggling, the device has completed the program or erase operation. The system can read array data on DQ7-DQ0 on the following read cycle. - toggling. See text. - 2. Recheck toggle bit because it may stop toggling as DQ5 changes to '1'. See text. - 3. VA = Valid Address. Figure 8. Toggle Bit Algorithm However, if after the initial two read cycles, the system determines that the toggle bit is still toggling, the system also should note whether the value of DQ5 is high (see the section on DQ5). If it is, the system should then determine again whether the toggle bit is toggling, since the toggle bit may have stopped toggling just as DQ5 went high. If the toggle bit is no longer toggling, the device has successfully completed the program or erase operation. If it is still toggling, the device did not complete the operation successfully, and the system must write the reset command to return to reading array data. The remaining scenario is that the system initially determines that the toggle bit is toggling and DQ5 has not gone high. The system may continue to monitor the toggle bit and DQ5 through successive read cycles, determining the status as described in the previous paragraph. Alternatively, it may choose to perform other system tasks. In this case, the system must start at the beginning of the algorithm when it returns to determine the status of the operation (top of Figure 8). #### **DQ5: Exceeded Timing Limits** DQ5 indicates whether the program or erase time has exceeded a specified internal pulse count limit. Under these conditions DQ5 produces a "1." This is a failure condition that indicates the program or erase cycle as not successfully completed. The DQ5 failure condition may appear if the system tries to program a "1" to a location that is previously programmed to "0." Only an erase operation can change a "0" back to a "1." Under this condition, the device halts the operation, and when the operation has exceeded the timing limits, DQ5 produces a "1." Under both these conditions, the system must issue the reset command to return the device to reading array data. #### **DQ3: Sector Erase Timer** After writing a sector erase command sequence, the system may read DQ3 to determine whether or not an erase operation has begun. (The sector erase timer does not apply to the chip erase command.) If additional sectors are selected for erasure, the entire timeout also applies after each additional sector erase command. When the time-out is complete, DQ3 switches from "0" to "1." The system may ignore DQ3 if the system can guarantee that the time between additional sector erase commands will always be less than 50 µs. See also the "Sector Erase Command Sequence" section. After the sector erase command sequence is written, the system should read the status on DQ7 (Data Polling) or DQ6 (Toggle Bit I) to ensure the device has accepted the command sequence, and then read DQ3. If DQ3 is "1", the internally controlled erase cycle has begun; all further commands are ignored until the erase operation is complete. If DQ3 is "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 is high on the second status check, the last command might not have been accepted. Table 6 shows the outputs for DQ3. **Table 6. Write Operation Status** | Operation | DQ7 <sup>(1)</sup> | DQ6 | DQ5 <sup>(2)</sup> | DQ3 | |-------------------------------|--------------------|--------|--------------------|-----| | Embedded<br>Program Algorithm | DQ7# | Toggle | 0 | N/A | | Embedded<br>Erase Algorithm | 0 | Toggle | 0 | 1 | #### Notes: - DQ7 requires a valid address when reading status information. - DQ5 switches to '1' when an Embedded Program or Embedded Erase operation has exceeded the maximum timing limits. See "DQ5: Exceeded Timing Limits" for more information. ## **ABSOLUTE MAXIMUM RATINGS**(1) | Symbol | Parameter | Value | Unit | | |---------------|-------------------------------------------|-------------------------------|------|--| | <b>V</b> TERM | Terminal Voltage with Respect to GND | | | | | | Any Pin Except A9 | $-2.0$ to $+7.0^{(2)}$ | V | | | | A9 | $-2.0$ to $+12.5^{(2)}$ | V | | | | Vcc | $-2.0 \text{ to } +7.0^{(2)}$ | V | | | Isc | Output Short Circuit Current (Max. Limit) | 200 | mA | | | Та | Commercial Operating Temperature | 0 to +70 | °C | | | Та | Industrial Operating Temperature | -40 to +85 | °C | | | Tstg | Storage Temperature | -65 to +125 | °C | | #### Notes: - Stress greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. - 2. Minimum DC inputs, I/O, and A9 pins voltage is -0.5V. During transitions, inputs may undershoot to -2.0V for periods less than 20 ns. Maximum DC voltage on output pins is Vcc + 0.5V, which may overshoot to Vcc + 2.0V for periods less than 20 ns. Maximum DC voltage on A9 is +12.5V that may overshoot to +12.5V for periods less than 20 ns. - 3. No more than one output shorted at one time. Duration of short shall not exceed one second. Figure 9. Maximum Negative Overshoot Waveform Figure 10. Maximum Positive Overshoot Waveform ## **OPERATING RANGE** | Range | Ambient Temperature | Vcc | |---------------------------|---------------------|----------| | Commercial | 0°C to +70°C | 5V ± 10% | | Industrial <sup>(1)</sup> | –40°C to +85°C | 5V ± 10% | #### Note: 1. Operating ranges define those limits between which the functionally of the device is guaranteed. #### **CAPACITANCE** | Symbol | Parameter | Conditions | | Max. | Unit | |--------|--------------------|---------------|---|------|------| | Cin | Input Capacitance | $V_{IN} = 0V$ | _ | TBD | pF | | Соит | Output Capacitance | VOUT = $0V$ | _ | TBD | pF | ## DC CHARACTERISTICS: TTL/NMOS COMPATIBLE | Symbol | Parameter Description | Test Conditions | Min. | Max. | Unit | |--------------|------------------------------------------------------------|------------------------------------------------------------------------|------|-----------|------| | <b>I</b> LI | Input Leakage Current | Vcc = Vcc Max., Vin = Vcc to GND | _ | ±1.0 | μA | | <b>I</b> ∟ı2 | A9 Input Current | Vcc = Vcc Max., A9 = 12.5V | _ | 50 | μA | | ILO | Output Leakage Current | Vcc = Vcc Max., Vout = GND to Vcc | _ | ±1.0 | μA | | Iccs | Vcc Standby Current | Vcc = Vcc Max., CE and OE = V⊮ | _ | 1.0 | mA | | Icc1 | Vcc Active Current(1) | $V_{CC} = V_{CC} Max., \overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | _ | 30 | mA | | Icc2 | Vcc Active Current(2,3) | $V_{CC} = V_{CC} Max., \overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | _ | 50 | mA | | VIL | Input Low Voltage | | -0.5 | 0.8 | V | | VIH | Input High Voltage | | 2.0 | Vcc + 0.5 | V | | VID | Voltage For Auto-select and<br>Temporary Secctor Unprotect | Vcc = 5.0V | 11.5 | 12.5 | V | | <b>V</b> OL | Output Low Voltage | lot = 12 mA, Vcc = Vcc Min. | _ | 0.45 | V | | <b>V</b> он | Output High Voltage | lон = −2.5 mA, Vcc = Vcc Min. | 2.4 | _ | V | | <b>V</b> LKO | Low Vcc Lock-out Voltage | | 3.2 | 4.2 | V | - 2. Icc active while Embedded Program or Embedded Erase Algorithm is in progress. - 3. Not 100% tested. ## DC CHARACTERISTICS: CMOS COMPATIBLE | Symbol | Parameter Description | Test Conditions | Min. | Max. | Unit | |----------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------|-----------|------| | <b>I</b> LI | Input Leakage Current | Vcc = Vcc Max., Vin = Vcc or GND | _ | ±1.0 | μA | | I <sub>L</sub> 2 | A9 Input Current | Vcc = Vcc Max., A9 = 12.5V | <del></del> | 50 | μA | | ILO | Output Leakage Current | Vcc = Vcc Max., Vout = GND to Vcc | <del></del> | ±1.0 | μA | | Iccs | Vcc Standby Current | $V_{CC} = V_{CC} Max., \overline{CE} = V_{CC} \pm 0.5V,$<br>$\overline{OE} = V_{IH}$ | <del>_</del> | 100 | μΑ | | Icc1 | Vcc Active Current <sup>(1)</sup> | $V_{CC} = V_{CC} Max., \overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | _ | 30 | mA | | Icc2 | Vcc Active Current(2,3) | $V_{CC} = V_{CC} Max., \overline{CE} = V_{IL}, \overline{OE} = V_{IH}$ | <del></del> | 50 | mA | | VIL | Input Low Voltage | | -0.5 | 0.8 | V | | VIH | Input High Voltage | | 0.7 x Vcc | Vcc + 0.5 | V | | <b>V</b> ID | Voltage For Auto-select and<br>Temporary Secctor Unprotect | Vcc = 5.0V | 11.5 | 12.5 | V | | <b>V</b> OL | Output Low Voltage | lol = 12 mA, Vcc = Vcc Min. | <del></del> | 0.45 | V | | <b>V</b> OH <b>1</b> | Output High Voltage | lон = −2.5 mA, Vcc = Vcc Min. | 0.85 x Vcc | _ | V | | <b>V</b> OH2 | Output High Voltage | $I$ он = $-100 \mu A$ , $V$ сс = $V$ сс $Min$ . | Vcc - 0.4 | _ | V | | <b>V</b> LKO | Low Vcc Lock-out Voltage | | 3.2 | 4.2 | ٧ | #### Notes: - 1. The lcc current listed is typically less than 2 mA/MHz with $\overline{OE}$ at ViH. - 2. Icc active while Embedded Program or Embedded Erase Algorithm is in progress. - 3. Not 100% tested. ## AC CHARACTERISTICS: READ ONLY (Over Operating Range) | Std. | | -: | 35 | -4 | <b>1</b> 5 | -: | 55 | -; | 70 | -( | 90 | | |-----------------|-------------------------------------------------|------|------|------|------------|------|------|------|------|------|------|------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | trc | Read Cycle Time(1) | 35 | _ | 45 | _ | 55 | _ | 70 | _ | 90 | _ | ns | | tce | Chip Enable Access Time(2) | _ | 35 | _ | 45 | _ | 55 | _ | 70 | _ | 90 | ns | | tacc | Address Access Time(3) | _ | 35 | _ | 45 | _ | 55 | _ | 70 | _ | 90 | ns | | toe | Output Enable Access Time | _ | 25 | _ | 25 | _ | 30 | _ | 30 | _ | 35 | ns | | tDF | Chip Enable to Output High Z <sup>(1,4)</sup> | _ | 10 | _ | 10 | _ | 15 | _ | 20 | _ | 20 | ns | | tDF | Output Enable to Output High Z <sup>(1,4)</sup> | _ | 10 | _ | 10 | _ | 15 | _ | 20 | _ | 20 | ns | | toeh | Output Enable Hold Time(1) Read | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | | Toggle & Data Polling | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 10 | _ | | | to <sub>H</sub> | Output Hold from First of | 0 | | 0 | _ | 0 | _ | 0 | | 0 | _ | ns | | | Address, CE or OE | | | | | | | | | | | | | | Whichever Occurs First | | | | | | | | | | | | #### Notes: - Not 100% tested. OE = V | L. CE and OE = V | L. - 4. Output Driver Disable Time. - 5. See Figure 12 and Table 6 for test specifications. Figure 11. AC Waveform: READ Only ## **TEST CONDITIONS** ## **Table 6. AC Test Specifications** | Test Conditions | 35 ns | All Others | Unit | |---------------------------------------------------------|----------|-------------|------| | Output Load | | 1 TTL Gate | | | Output Load Capacitance, CL (including jig capacitance) | 30 | 100 | pF | | Input Rise and Fall Times | 5 | 20 | ns | | Input Pulse Levels | 0 to 3.0 | 0.45 to 2.4 | ٧ | | InputTiming Measurement<br>Reference Levels | 1.5 | 0.8 | V | | Output Timing Measurement<br>Reference Levels | 1.5 | 2.0 | V | Figure 12. Test Setup ## **AC CHARACTERISTICS: ERASE AND PROGRAM** | Std. | | -: | 35 | -4 | <b>1</b> 5 | -: | 55 | - | 70 | -( | 90 | | |--------------|-----------------------------------------------------|------|------|------|------------|------|------|------|------|------|------|------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | twc | Write Cycle Time(1) | 35 | _ | 45 | _ | 45 | _ | 45 | | 90 | _ | ns | | tas | Addess Setup Time | 0 | _ | 0 | _ | 0 | _ | 0 | | 0 | _ | ns | | tah | Address Hold Time | 30 | _ | 35 | _ | 45 | _ | 45 | _ | 45 | _ | ns | | tos | Data Setup Time | 15 | _ | 20 | _ | 20 | _ | 30 | _ | 45 | _ | ns | | <b>t</b> DH | Data Hold Time | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | tghwl | Read Recovery Time before Write (OE HIGH to WE LOW) | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | tcs | CE Setup Time | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | tcH | CE Hold Time | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | twp | Write Pulse Width | 20 | _ | 25 | _ | 30 | _ | 35 | _ | 45 | _ | ns | | <b>tw</b> PH | Write Pulse Width HIGH | 20 | _ | 20 | _ | 20 | _ | 20 | _ | 20 | _ | ns | | twhwh1 | Byte Programming Operation(2) | _ | 14 | _ | 14 | | 14 | _ | 14 | _ | 14 | μs | | twhwh2 | Sector Erase Operation(2) | _ | 1.0 | _ | 1.0 | _ | 1.0 | _ | 1.0 | _ | 1.0 | sec | | tvcs | Vcc Setup Time(1) | 50 | | 50 | _ | 1.0 | _ | 1.0 | _ | 1.0 | _ | μs | ## Note: 1. Not 100% tested. #### Note: Figure 13. AC Waveform: Program Operation 1. PA = Program Address, PD = Program Data, DOUT is the true data at the Program Address. Fligure 14. AC Waveform: Erase Operation #### Note: 1. SA = Sector Address (for Sector Erase), VA = Valid Address for reading status data (see "Write Operation Status"). Figure 15. AC Waveform: #### Note: 1. VA = Valid Address. Illustration shows first status cycle after command sequence, last status read cycle, and array data read cycle. Figure 16. AC Waveform: Erase and Program Operations, Alternate $\overline{\text{CE}}$ Controlled Writes #### Note: 1. VA = Valid Address, not required for DQ6. Illustration shows first two status cycles after command sequence, last status read cycle, and array data read cycle. | Std. | | -: | 35 | -6 | <b>4</b> 5 | = | 55 | | 70 | -( | 90 | | |------------------------|---------------------------------|------|------|------|------------|------|------|------|------|------|------|------| | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | twc | Write Cycle Time(1) | 35 | _ | 45 | _ | 55 | _ | 70 | _ | 90 | _ | ns | | tas | Addess Setup Time | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | tah | Address Hold Time | 30 | _ | 35 | _ | 45 | _ | 45 | _ | 45 | _ | ns | | tos | Data Setup Time | 20 | _ | 20 | _ | 20 | _ | 30 | _ | 45 | _ | ns | | <b>t</b> DH | Data Hold Time | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | toes | Output Enable SetupTime(1) | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | <b>t</b> GH <b>W</b> L | Read Recovery Time Before Write | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | tws | Write Enable Setup Time | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | twн | Write Enable Hold Time | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | ns | | tcp | Chip Enable Pulse Width | 20 | _ | 25 | _ | 30 | _ | 35 | _ | 45 | _ | ns | | <b>t</b> CPH | Chip Enable Pulse Width HIGH | 20 | _ | 20 | _ | 20 | _ | 20 | _ | 20 | _ | ns | | twnwh1 | Byte Programming Operation(2) | _ | 14 | _ | 14 | _ | 14 | | 14 | _ | 14 | μs | | twhwh2 | Sector Erase Operation(2) | _ | 1.0 | _ | 1.0 | _ | 1.0 | _ | 1.0 | _ | 1.0 | sec | #### Note: - 1. Not 100% tested. - 2. See the "Erase and Programming Performance" section for more information. Figure 17. AC Waveform: - 1. PA = Program Address, PD = Program Data, SA = Sector Address, DQ7# = Complement of Data Input, DOUT = Array Data. - 2. Figure indicates the last two bus cycles of the command sequence. #### **ERASE AND PROGRAMMING PERFORMANCE** | Parameter | <b>Typ.</b> <sup>(1)</sup> | Max. <sup>(2)</sup> | Unit | Comments | |--------------------------|----------------------------|---------------------|------|-----------------------------------------------| | Chip/Sector Erase Time | 1.0 | 15 | sec | Excludes 00H Programming Prior to Erase(4) | | Byte Programming Time | 14 | 1000 | μs | Excludes System Level Overhead <sup>(5)</sup> | | Chip Programming Time(3) | 1.8 | 12.5 | sec | | #### Notes: - 1. Typical program and erase times assume the following conditions: 25°C, 5.0V Vcc, 100,000 cycles. Additionally, programming typicals assume checkerboard pattern. - 2. Under worst case conditions of $90^{\circ}$ C, Vcc = 4.5V (4.75V for -35), 100,000 cycles. - 3. The typical chip programming time is considerably less than the maximum chip programming time listed, since most bytes program faster than the maximum byte program time listed. If the maximum byte program time given is exceeded, only then does the device set DQ5 = 1. See the section on DQ5 for further information. - 4. In the pre-programming step of the Embedded Erase algorithm, all bytes are programmed to 00h before erasure. - 5. System-level overhead is the time required to execute the four-bus-cycle command sequence for programming. See Table 2 for further information on command definitions. - 6. The device has a typical erase and program cycle endurance of 1,000,000 cycles. 100,000 cycles are guaranteed. #### LATCHUP CHARACTERISTIC | Parameter | Min. | Max. <sup>(2)</sup> | | |-----------------------------------------------|---------|---------------------|--| | Input Voltage with Respect to GND on I/O Pins | -1.0V | Vcc + 1.0V | | | Vcc Current | –100 mA | +100 mA | | #### Note: #### **DATA RETENTION** | Parameter | <b>Test Condtions</b> | Min. | Unit | |-------------------------------------|-----------------------|------|-------| | Minimum Pattern Data Retention Time | 150°C | 10 | Years | | Vcc Current | 125°C | 20 | Years | <sup>1.</sup> Includes all pins except Vcc. Test conditions: Vcc = 5.0V, one pin at a time. ## **ORDERING INFORMATION** Commerical Range: 0°C to +70°C | Speed (ns) | Order Part No. | Package | |------------|-----------------------------------------------|----------------------------------------------------------------------------| | 35 | IS29F010-35W<br>IS29F010-45PL<br>IS29F010-35T | 600-mil Plastic DIP<br>PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | | 45 | IS29F010-45W<br>IS29F010-45PL<br>IS29F010-45T | 600-mil Plastic DIP<br>PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | | 55 | IS29F010-55W<br>IS29F010-55PL<br>IS29F010-45T | 600-mil Plastic DIP<br>PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | | 70 | IS29F010-70W<br>IS29F010-70PL<br>IS29F010-70T | 600-mil Plastic DIP<br>PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | | 90 | IS29F010-90W<br>IS29F010-90PL<br>IS29F010-90T | 600-mil Plastic DIP<br>PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | ## **ORDERING INFORMATION** Industrial Range: -40°C to +85°C | Speed (ns) | Order Part No. | Package | |------------|---------------------------------|-----------------------------------------------------| | 45 | IS29F010-45PLI<br>IS29F010-45TI | PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | | 55 | IS29F010-55PLI<br>IS29F010-55TI | PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | | 70 | IS29F010-70PLI<br>IS29F010-70TI | PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | | 90 | IS29F010-90PLI<br>IS29F010-90TI | PLCC – Plastic Leaded Chip Carrier<br>TSOP (Type 1) | # Integrated Silicon Solution, Inc. 2231 Lawson Lane Santa Clara, CA 95054 Fax: (408) 588-0806 Toll Free: 1-800-379-4774 http://www.issi.com E-Mail: sales@issi.com