#### **Features** - Organization:512K words × 8 bits - Industrial and commercial temperature - Sector architecture - Eight 64K byte sectors - Erase any combination of sectors or full chip - Single 5.0±0.5V power supply for read/write operations - Sector protection - High speed 55/70/90/120/150 ns address access time - · Automated on-chip programming algorithm - Automatically programs/verifies data at specified address - Automated on-chip erase algorithm - Automatically preprograms/erases chip or specified sectors - 10,000 write/erase cycle endurance - Low power consumption - 30 mA maximum read current - 60 mA maximum program current - 400 µA typical standby current - JEDEC standard software, packages and pinouts - 32-pin TSOP - 32-pin PLCC - Detection of program/erase cycle completion - DQ7 DATA polling - DQ6 toggle bit - Erase suspend/resume - Supports reading data from or programming data to a sector not being erased - Low V<sub>CC</sub> write lock-out below 2.8V ### Logic block diagram ### Pin arrangement #### Selection guide | | | AS29F040-55 | AS29F040-70 | AS29F040-90 | AS29F040-120 | AS29F040-150 | Unit | |-----------------------------------|-----------------|-------------|-------------|-------------|--------------|--------------|------| | Maximum access time | $t_{AA}$ | 55 | 70 | 90 | 120 | 150 | ns | | Maximum chip enable access time | $t_{CE}$ | 55 | 70 | 90 | 120 | 150 | ns | | Maximum output enable access time | t <sub>OE</sub> | 25 | 30 | 35 | 50 | 55 | ns | #### Functional description The AS29F040 is a 4-megabit, 5-volt-only Flash memory device organized as 512K bytes of 8 bits each. For flexible erase an program capability, the 4 megabits of data is divided into eight 64K-byte sectors. The $\times 8$ data appears on DQ0–DQ7. The AS29F040 is offered in JEDEC standard 32-pin TSOP and 32-pin PLCC packages. This device is designed to be programmed an erased in-system with a single 5.0V $V_{CC}$ supply. The device can also be reprogrammed in standard EPROM programmers. The AS29F040 offers access times of 55/70/90/120/150 ns, allowing 0-wait state operation of high-speed microprocessors. To eliminate bus contention the device has separate chip enable ( $\overline{\text{CE}}$ ), write enable ( $\overline{\text{WE}}$ ), and output enable ( $\overline{\text{OE}}$ ) controls The AS29F040 is fully compatible with the JEDEC single power supply Flash standard. Write commands to the command register use standard microprocessor write timings. An internal state machine uses register contents to control the erase and programming circuitry. Write cycles also internally latch addresses and data needed for the programming and erase operations. Read data operates from the device in the same manner as other Flash or EPROM devices. The program command sequence is used to invoke the automated on-chip programming algorithm that automatically times the program pulse widths and verifies proper cell margin. The erase command sequence is used to invoke the automated on-chip erase algorithm that preprograms the sector if it is not already programmed before executing the erase operation, times the erase pulse widths, and verifies proper cell margin. Sector erase architecture allows specified sectors of memory to be erased and reprogrammed without altering data in other sectors. A sector typically erases and verifies within 1.0 seconds. Hardware sector protection disables both program and erase operations in any or all combinations of the eight sectors. The device provides true background erase with Erase Suspend, which puts erase operations on hold to either read data from or program data to a sector that is not being erased. The chip erase command will automatically erase all unprotected sectors. A factory shipped AS29F040 is fully erased (all bits = 1). The programming operation sets bits to 0. Data is programmed into the array one byte at a time in any sequence and across sector boundaries. A sector must be erased to change bits from 0 to 1. Erase returns all bytes in a sector to the erased state (all bits = 1). Each sector is erased individually with no effect on other sectors. The device features single 5.0V power supply operation for read, write, and erase functions. Internally generated and regulate voltages are provided for the program and erase operations. A low $V_{CC}$ detector automatically inhibits write operations during power transtitions. $\overline{DATA}$ polling of DQ7 or toggle bit (DQ6) may be used to detect end-of-program or erase operations. The device automatically resets to read mode after program and/or erase operations are completed. The AS29F040 resists accidental erasure or spurious programming signals resulting from power transitions. Control register architecture permits the alteration of memory contents only after successful completion of specific command sequences. During power up, the device is set to read mode with all program and/or erase commands disabled when $V_{CC}$ is less than $V_{LKO}$ (lockout voltage). The command registers are not affected by noise pulses of less than 5 ns on $\overline{OE}$ , $\overline{CE}$ , or $\overline{WE}$ . $\overline{CE}$ and $\overline{WE}$ must be logical zero and $\overline{OE}$ a logical one to initiate write commands. The AS29F040 uses Fowler-Nordheim tunnelling to electrically erase all bits within a sector simultaneously. Bytes are programme one at a time using the EPROM programming mechanism of hot electron injection. ### Operating modes | Mode | CE | <del>OE</del> | WE | A0 | A1 | A6 | A9 | DQ0-DQ7 | |-----------------------|----|---------------|---------|----|----|----|--------------|------------------| | ID read MFR code | L | L | Н | L | L | L | $V_{ID}$ | Code | | ID read device code | L | L | Н | Н | L | L | $V_{ID}$ | Code | | Read | L | L | Н | A0 | A1 | A6 | A9 | D <sub>OUT</sub> | | Standby | Н | X | X | X | X | X | X | High Z | | Output disable | L | Н | Н | X | X | X | X | High Z | | Write | L | Н | L | A0 | A1 | A6 | A9 | $D_{IN}$ | | Enable sector protect | L | $V_{ID}$ | Pulse/L | L | Н | L | $V_{ID}$ | X | | Sector unprotect | L | $V_{ID}$ | Pulse/L | L | Н | Н | $V_{ID}$ | X | | Verify sector protect | L | L | Н | L | Н | L | $V_{\rm ID}$ | Code | $L = Low~(<V_{II});~H = High~(>V_{IH});~V_{ID} = 12.0 \pm 0.5V;~X = don't~car~.$ ### Mode definitions | Item | Description | |-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ID MFR code,<br>device code | Selected by A9 = $V_{ID}(11.5-12.5V)$ , $\overline{CE} = \overline{OE} = A1 = A6 = L$ , enabling outputs. When A0 is low ( $V_{IL}$ ) the output data = 52h, a unique Mfr. code for Alliance Semiconductor Flash products. When A0 is high ( $V_{IH}$ ), $D_{OUT}$ represents the device code for the AS29F040. | | Read mode | Selected with $\overline{CE} = \overline{OE} = L$ , $\overline{WE} = H$ . Data is valid in $t_{ACC}$ time after addresses are stable, $t_{CE}$ after $\overline{CE}$ is low and $t_{OE}$ after $\overline{OE}$ is low. | | Standby | Selected with $\overline{\text{CE}}=\text{H}$ . Part is powered down, and $I_{CC}$ reduced to <1.0 mA for TTL input levels and <100 $\mu\text{A}$ for CMOS levels. If activated during an automated on-chip algorithm, the device completes the operation before entering standby. | | Output disable | Part remains powered up; but outputs disabled with $\overline{\text{OE}}$ pulled high. | | Write | Selected with $\overline{\text{CE}} = \overline{\text{WE}} = L$ , $\overline{\text{OE}} = H$ . Accomplish all Flash erasure and programming through the command register. Contents of command register serve as inputs to the internal state machine. Address latching occurs on the falling edge of $\overline{\text{WE}}$ or $\overline{\text{CE}}$ , whichever occurs late . Data latching occurs on the rising edge $\overline{\text{WE}}$ or $\overline{\text{CE}}$ , whichever occurs first. Filters on $\overline{\text{WE}}$ prevent spurious noise events from appearing as write commands. | | Enable sector protect | Hardware protection circuitry implemented with external programming equipment causes the device to disable program and erase operations for specified sectors. | | Sector<br>unprotect | Disables sector protection for all sectors using external programming equipment. All sectors must be protected prior to sector unprotection. | | Verify<br>sector protect | Verifies write protection for sector. Sectors are protected from program/erase operations on commercial programming equipment. Determine if sector protection exists in a system by writing the ID read command sequence and reading location XXX02h, where address bits A16–18 select the defined sector addresses. A logical 1 on DQ0 indicates a protected sector; a logical 0 indicates an unprotected sector. | ### Sector architecture and address table | | Equal sector arch | itecture | ID sector address | | | | | | | |--------|-------------------|---------------|-------------------|-----|-----|--|--|--|--| | Sector | Addresses | Size (Kbytes) | A18 | A17 | A16 | | | | | | 0 | 00000h-0FFFFh | 64 | 0 | 0 | 0 | | | | | | 1 | 10000h-1FFFFh | 64 | 0 | 0 | 1 | | | | | | 2 | 20000h-2FFFFh | 64 | 0 | 1 | 0 | | | | | | 3 | 30000h-3FFFFh | 64 | 0 | 1 | 1 | | | | | | 4 | 40000h-4FFFFh | 64 | 1 | 0 | 0 | | | | | | 5 | 50000h-5FFFFh | 64 | 1 | 0 | 1 | | | | | | 6 | 60000h-6FFFFh | 64 | 1 | 1 | 0 | | | | | | 7 | 70000h-7FFFFh | 64 | 1 | 1 | 1 | | | | | #### **READ** codes | Mode | A18-A16 | A9 | A8-A7 | A6 | A5-A2 | A1 | A0 | Code on DQ0-DQ7 | |--------------------------------------|-------------------|-----------------|-------------------|----|-------------------|----|----|----------------------------------| | MFG code (Alliance<br>Semiconductor) | X | V <sub>ID</sub> | X | L | X | L | L | 52h | | Device code | X | $V_{\rm ID}$ | X | L | X | L | Н | A4h | | Sector protection | Sector<br>address | V <sub>ID</sub> | Sector<br>address | L | Sector<br>address | Н | L | 01h protected<br>00h unprotected | $L = Low (\langle V_{IL} \rangle; H = High (\langle V_{IH} \rangle; X = Don't care.$ ### Command format | Command | Required | 1st bus write<br>cycle | | 2nd bus write<br>cycle | | 3rd bus<br>cycl | | 4th bus rea | | 5th bus write cycle | | 6th bus write<br>cycle | | |-------------------------|------------|------------------------|------|--------------------------------|--------------|-------------------------|------|---------------------------|-----------------|---------------------|------|------------------------|------| | sequence | bus cycles | Address | Data | Address | Data | Address | Data | Address | Data | Address | Data | Address | Data | | Reset/read | 1 | XXXXh | F0h | Read<br>Address | Read<br>Data | | | | | | | | | | Reset/read | 4 | 5555h | AAh | 2AAAh | 55h | 5555h | F0h | Read Read<br>Address Data | | | | | | | | 4 | 4 5555h | | | | 5555h | | 00h<br>MFR code | 52h | | | | | | Autoselect ID read | | | AAh | 2AAAh | 55h | | 90h | 01h<br>Device code | A4h | | | | | | read | | | | XXX02h<br>Sector<br>protection | | protected<br>nprotected | | | | | | | | | Program | 4 | 5555h | AAh | 2AAAh | 55h | 5555h | A0h | Program<br>Address | Program<br>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 | Sector<br>Address | 30h | | Sector erase<br>suspend | 1 | XXXXh | B0h | | | | | | | | | | | | Sector erase<br>resume | 1 | XXXXh | 30h | | | | | | | | | | | Bus operations defined in "Mode definitions," on page 3. - ${\it 2} \quad \ \ \, \text{Reading from or programming to non-erasing sectors allowed in Erase Suspend mode}.$ - 3 Address bit A15 = X = Don't care for all address commands except Program Address. - $4 \quad \text{Address bit A16} = X = Don't \ care \ for \ all \ address \ commands \ except \ Program \ Address \ and \ Sector \ Address.$ - $5 \qquad \text{Address bit A17} = X = \text{Don't care for all address commands except Program Address and Sector Address}.$ - $6 \qquad \text{Address bit A18} = X = \text{Don't care for all address commands except Program Address and Sector Address}. \\$ ### Command definitions | Item | Description | |-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reset/read | Initiate read or reset operations by writing the read/reset command sequence into the command register. This allows the microprocessor to retrieve data from the memory. Device remains in read mode until command register contents are altered. | | | Device automatically powers up in read/reset state. This feature allows only reads, therefore ensuring no spurious memory content alterations during power up. | | | AS29F040 provides manufacturer and device codes in two ways. External PROM programmers typically access the device codes by driving $+12V$ on A9. AS29F040 also contains an ID read command to read the device code with only $+5V$ , since multiplexing $+12V$ on address lines is generally undesirable. | | ID read | Initiate device ID read by writing the ID read command sequence into the command register. Follow with a read sequence from address XXX00h to return MFG code. Follow ID read command sequence with a read sequence from address XXX01h to return device code. | | | To verify write protect status on sectors, read address XXXO2h. Sector addresses A18–A16 produc e a1 on DQ0 for protected sector and a 0 for unprotected sector. | | | Exit from ID read mode with Read/Reset command sequence. | | | Programming the AS29F040 is a four bus cycle operation performed on a byte-by-byte basis. Two unlock write cycles precede the program setup command and program data write cycle. Upon execution of the program command, no additional CPU controls or timings are necessary. Addresses are latched on the falling edge of CE or WE, whichever is last; data is latched on the rising edge of CE or WE, whichever is first. The AS29F040's automated on-chip program algorithm provides adequate internally-generated programming pulses and verifies the programmed cell margin. | | Byte/word programming | Check programming status by sampling data on the $\overline{DATA}$ polling (DQ7), or toggle bit (DQ6). The AS29F040 returns the equivalent data that was written to it (as opposed to complemented data), to complete the programming operation. | | | The AS29F040 ignores commands written during the programming operation. | | | AS29F040 allows programming in any sequence, across any sector boundary. Changing data from 0 to 1 requires an erase operation. Attempting to program data 0 to 1 results in DQ5 = 1 (exceeded programming time limits); reading this data after a read/reset operation returns a 0. When programming time limit is exceeded, DQ5 reads high, and DQ6 continues to toggle. In this state , are set command returns the device to read mode. | | | Chip erase requires six bus cycles: two unlock write cycles; a setup command, two additional unlock write cycles; and finally the Chip erase command. | | Chip erase | Chip erase does not require logical 0s to be written prior to erasure. When the automated on-chip erase algorithm is invoked with the Chip erase command sequence, AS29F040 automatically programs and verifies the entire memory array for an all-zero pattern prior to erase. The AS29F040 returns to read mode upon completion of chip erase unless DQ5 is set high as a result of exceeding time limit. | | Item | Description | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Sector erase requires six bus cycles: two unlock write cycles, a setup command, two additional unlock write cycles, and finally the sector erase command. Identify the sector to be erased by addressing any location in the sector. The address is latched on the falling edge of $\overline{WE}$ ; the command, 30h, is latched on the rising edge of $\overline{WE}$ . The sector erase operation begins after a 80 $\mu$ s time-out. | | Sector erase | To erase multiple sectors, write the sector erase command to each of the addresses of sectors to erase after following the six bus cycle operation above. Timing between writes of additional sectors must be $<80~\mu s$ , or the AS29F040 ignores the command and erasure begins. During the erase time-out period any falling edge of WE resets the time-out. Any command (other than sector erase or erase suspend) during the time-out period resets the AS29F040 to read mode, and the device ignores the sector erase command string. Erase such ignored sectors by restarting the sector erase command on the ignored sectors. | | | The entire array need not be written with 0s prior to erasure. AS29F040 writes 0s to the entire sector prior to electrical erase; writing of 0s affects only selected sectors, leaving non-selected sectors unaffected. AS29F040 requires no CPU control or timing signals during sector erase operations. | | | Automatic sector erase begins after erase time-out from the last rising edge of WE from the sector erase command stream and ends when the DATA polling (DQ7) is logical 1. DATA polling must be performed on addresses that fall within the sectors being erased. AS29F040 returns to read mode after sector erase unless DQ5 is set high by exceeding the time limit. | | | Erase suspend allows interruption of sector erase operations to perform data reads from or writes to a sector not being erased. Erase suspend applies only during sector erase operations, including the time-out period. Writing an erase suspend command during sector erase time-out results in immediate termination of the time-out period and suspension of erase operation. | | | AS29F040 ignores any commands during erase suspend other than read/reset, program, or erase resume commands. Writing the Erase Resume command continues erase operations. Addresses are DON'T CARE when writing Erase suspend or Erase resume commands. | | Erase suspend | AS29F040 takes $0.2-15~\mu s$ to suspend erase operations after receiving erase suspend command. To determine completion of erase suspend, check DQ6 after selecting an address of a sector not being erased. Check DQ2 in conjunction with DQ6 to determine if a sector is being erased. AS29F040 ignores redundant writes of erase suspend. | | | While in erase-suspend mode AS29F040 allows reading data (erase-suspend-read mode) from or programming data (erase-suspend-program mode) to any sector not undergoing sector erase, treated as standard read or standard programming mode. AS29F040 defaults to erase-suspend-read mode while an erase operation has been suspended. | | | Write the resume command 30h to continue operation of sector erase. AS29F040 ignores redundant writes of the resume command. AS29F040 permits multiple suspend/resume operations during sector erase. | | Sector protect | When attempting to write to a protected sector, $\overline{DATA}$ polling and Toggle Bit 1 (DQ6) are activated for about <1 $\mu$ s. When attempting to erase a protected sector, $\overline{DATA}$ polling and Toggle Bit 1 (DQ6) are activated for about <5 $\mu$ s. In both cases, the device returns to read mode without altering the specified sectors. | ### Status operations | DATA polling (DQ7) | Only active during automated on-chip algorithms or sector erase time outs. DQ7 reflects complement of data last written when read during the automated on-chip algorithm (0 during erase algorithm); reflects true data when read after completion of an automated on-chip algorithm (1 after completion of erase agorithm). | |----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Toggle bit 1 (DQ6) | Active during automated on-chip algorithms or sector time outs. DQ6 toggles when $\overline{\text{CE}}$ or $\overline{\text{OE}}$ toggles, or an Erase Resume command is invoked. When the automated on-chip algorithm is complete, DQ6 stops toggling and valid data can be read. DQ6 is valid after the rising edge of the fourth pulse of $\overline{\text{WE}}$ during programming; after the rising edge of the sixth $\overline{\text{WE}}$ pulse during chip erase; after the last rising edge of the sector erase $\overline{\text{WE}}$ pulse for sector erase. For protected sectors, DQ6 toggles for <1 µs during writes, and <5 µs during erase (if all selected sectors are protected). | | Exceeding time limit (DQ5) | Indicates unsuccessful completion of program/erase operation (DQ5 = 1). $\overline{DATA}$ polling remains active; $\overline{CE}$ powers the device down to 2 mA. If DQ5 = 1 during chip erase, all or some sectors are defective; during sector erase, the sector is defective (in this case, reset the device and execute a program or erase command sequence to continue working with functional sectors); during byte programming, that particular byte is defective. Attempting to program 0 to 1 will set DQ5 = 1. | | Sector erase timer (DQ3) | Checks whether sector erase timer window is open. If $DQ3 = 1$ , erase is in progress; no commands will be accepted. If $DQ3 = 0$ , the device will accept additional sector erase commands. Check $DQ3$ before and after each Sector Erase command to verify that the command was accepted. | | Toggle bit 2 (DQ2) | During sector erase, DQ2 toggles with $\overline{OE}$ or $\overline{CE}$ only during an attempt to read a sector being erased. During chip erase, DQ2 toggles with $\overline{OE}$ or $\overline{CE}$ for all addresses. If DQ5 = 1, DQ2 toggles only at sector addresses where failure occurred, and will not toggle at other sector addresses. Use DQ2 in conjunction with DQ6 to determine whether device is in auto erase or erase suspend mode. | ### Write operation status | | Status | | DQ7 | DQ6 | DQ5 | DQ3 | DQ2 | |----------------------|--------------------------|--------------------------|-----------------|-----------|------|------|------------------------| | | Auto prograi | nming (byte) | <del>DQ</del> 7 | Toggle | 0 | 0 | No toggle | | | Program/era | se in auto erase | 0 | Toggle | 0 | 1 | Toggle* | | | | Read erasing sector | 1 | No toggle | 0 | 0 | Toggle | | In progress | Erase<br>suspend<br>mode | Read non-erasing sector | Data | Data | Data | Data | Data | | | | Program in erase suspend | <del>DQ</del> 7 | Toggle | 0 | 0 | Toggle* | | | Auto program | nming (byte) | <del>DQ</del> 7 | Toggle | 1 | 0 | No toggle | | Exceeded time limits | Program/era | se in auto erase | 0 | Toggle | 1 | 1 | Toggle <sup>†</sup> | | | Program in e | erase suspend | <del>DQ</del> 7 | Toggle | 1 | 0 | No toggle <sup>†</sup> | <sup>\*</sup> Toggles with $\overline{OE}$ or $\overline{CE}$ only for erasing or erase suspended sector addresses. † Toggles with $\overline{OE}$ or $\overline{CE}$ only for erasing or erase suspended sector addresses. Automated on-chip programming algorithm for each byte ### Automated on-chip erase algorithm The system software should check the status of DQ3 prior to and following each subsequent sector erase command to ensure command completion. The device may not have accepted the command if DQ3 is high on second status check. ### DATA polling algorithm # \* VA = Byte address for programming VA = any of the sector addresses within the sector being erased during sector erase. VA = valid address equals any non-protected sector group address during chip erase. ### Toggle bit algorithm $<sup>^{\</sup>mbox{\tiny $k$}}$ DQ6 rechecked even if DQ5 = 1 because DQ6 may stop toggling when DQ5 changes to 1. <sup>†</sup> DQ7 rechecked even if DQ5 = 1 because DQ5 and DQ7 may not change simultaneously. ### Programming algorithm for chip $<sup>^{*}</sup>$ VA = Current Address $<sup>^{\</sup>dagger}$ VA\_Start = Starting Address of Customer Code <sup>\*\*</sup> $VA\_End = Ending Address of Customer Code$ ### DC electrical characteristics $V_{CC} = 5.0 \pm 0.5 V$ | De ciccirical characteristic | <b>J</b> | | | • 66 – | J.0±0.5 | |------------------------------------------|------------------|--------------------------------------------------------------------------------------------------|-----------------------|----------------|---------| | Parameter | Symbol | Test conditions | Min | Max | Unit | | Input load current | $I_{LI}$ | $V_{IN} = V_{SS}$ to $V_{CC}$ , $V_{CC} = V_{CC \text{ MAX}}$ | - | ±1 | μΑ | | A9 Input load current | $I_{LIT}$ | $V_{CC} = V_{CC \text{ MAX}}, A9 = 12.5V$ | | 90 | μA | | Output leakage current | $I_{LO}$ | $V_{OUT} = V_{SS}$ to $V_{CC}$ , $V_{CC} = V_{CC MAX}$ | - | ±1 | μΑ | | Output short circuit current* | I <sub>OS</sub> | $V_{OUT} = 0.5V$ | - | 200 | mA | | Active current, read @ 6MHz <sup>†</sup> | I <sub>CC</sub> | $\overline{\text{CE}} = V_{\text{IL}}, \ \overline{\text{OE}} = V_{\text{IH}}$ | - | 30 | mA | | Active current, program/erase** | I <sub>CC2</sub> | $CE = V_{IL}$ , $OE = V_{IH}$ | - | 60 | mA | | Standby current (TTL) | I <sub>SB1</sub> | $\overline{\text{CE}} = \overline{\text{OE}} = V_{\text{IH}}, V_{\text{CC}} = V_{\text{CC MAX}}$ | - | 1.0 | mA | | Standby current (CMOS) | I <sub>SB2</sub> | $\overline{CE} = V_{CC} + 0.5V, \overline{OE} = V_{IH},$ $V_{CC} = V_{CC \text{ MAX}}$ | - | 400 | μА | | Input low voltage | V <sub>IL</sub> | | -0.5 | 0.8 | V | | Input high voltage | V <sub>IH</sub> | | 2.0 | $V_{CC} + 0.5$ | V | | Output low voltage | $V_{OL}$ | $I_{OL} = 12 \text{mA}, V_{CC} = V_{CC \text{ MIN}}$ | - | 0.45 | V | | Output high voltage | V <sub>OH1</sub> | $I_{OH} = -2.5$ mA, $V_{CC} = V_{CC \text{ MIN}}$ | 2.4 | - | V | | Output high voltage | $V_{OH2}$ | $I_{OH} = -100 \ \mu A, \ V_{CC} = V_{CC \ MIN}$ | V <sub>CC</sub> - 0.4 | - | V | | Low V <sub>CC</sub> lock out voltage | $V_{LKO}$ | | 2.8 | 4.2 | V | | Input HV select voltage | V <sub>ID</sub> | | 11.5 | 12.5 | V | | | _ | - | | | | <sup>\*</sup>Not more than one output tested simultaneously. Duration of the short circuit must not be >1 second. OUT = 0.5V was selected to avoid test problems caused by tester ground degradation. (This parameter is sampled and not 100% tested, but guaranteed by characterization.) ### Maximum negative overshoot waveform ### Maximum positive overshoot waveform <sup>&</sup>lt;sup>†</sup> The $I_{CC}$ current listed includes both the DC operating current and the frequency dependent component (@ 6 MHz). The frequency component typically is less than 2 mA/MHz with $\overline{OE}$ at $V_{IH}$ . $<sup>^{\</sup>ast\ast}$ $I_{CC}$ active while program or erase operations are in progress. AC parameters: read cycle | JEDEC | Std | | -55 | | -70 | | -90 | | -120 | | -150 | | | |-------------------|------------------|-------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|------|-----|------|-----|------| | Symbol | Symbol | Parameter | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | t <sub>AVAV</sub> | t <sub>RC</sub> | Read cycle time | 55 | - | 70 | - | 90 | - | 120 | - | 150 | - | ns | | t <sub>AVQV</sub> | t <sub>ACC</sub> | Address to output delay | - | 55 | - | 70 | - | 90 | - | 120 | - | 150 | ns | | $t_{\text{ELQV}}$ | t <sub>CE</sub> | Chip enable to output | - | 55 | - | 70 | - | 90 | - | 120 | - | 150 | ns | | $t_{GLQV}$ | t <sub>OE</sub> | Output enable to output | - | 25 | - | 30 | - | 35 | - | 50 | - | 55 | ns | | t <sub>EHQZ</sub> | t <sub>DF</sub> | Chip enable to output High Z | - | 15 | - | 20 | - | 20 | - | 30 | - | 35 | ns | | $t_{GHQZ}$ | t <sub>DF</sub> | Output enable to output High Z | - | 15 | - | 20 | - | 20 | - | 30 | - | 35 | ns | | t <sub>AXQX</sub> | t <sub>OH</sub> | Output hold time from addresses, CE or OE, whichever occurs first | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns | ### Key to switching waveforms ### Read waveform | JEDEC | Std | | -5 | 55 | -7 | 70 | -6 | 90 | -1 | 20 | -1 | 50 | | |--------------------|--------------------|-----------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------| | Symbol | Symbol | Parameter | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | t <sub>AVAV</sub> | t <sub>WC</sub> | Write cycle time | 55 | - | 70 | - | 90 | - | 120 | - | 150 | - | ns | | t <sub>AVWL</sub> | t <sub>AS</sub> | Address setup time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns | | t <sub>WLAX</sub> | t <sub>AH</sub> | Address hold time | 40 | - | 45 | - | 45 | - | 50 | - | 50 | - | ns | | t <sub>DVWH</sub> | t <sub>DS</sub> | Data setup time | 25 | - | 30 | - | 45 | - | 50 | - | 50 | - | ns | | t <sub>WHDX</sub> | t <sub>DH</sub> | Data hold time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns | | | t <sub>OES</sub> | Output enable setup time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns | | | t <sub>OEH</sub> | Output enable hold time:<br>Toggle and DATA polling | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns | | t <sub>GHWL</sub> | t <sub>GHWL</sub> | Read recover time before write | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns | | t <sub>ELWL</sub> | t <sub>CS</sub> | CE setup time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns | | t <sub>WHEH</sub> | t <sub>CH</sub> | CE hold time | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns | | t <sub>WLWH</sub> | t <sub>WP</sub> | Write pulse width | 35 | - | 35 | - | 45 | - | 50 | - | 50 | - | ns | | t <sub>WHWL</sub> | t <sub>WPH</sub> | Write pulse width high | 20 | - | 20 | - | 20 | - | 20 | - | 20 | - | ns | | t <sub>WHWH1</sub> | t <sub>WHWH1</sub> | Programming pulse time | 15 | - | 15 | - | 15 | - | 15 | - | 15 | - | μs | | t <sub>WHWH2</sub> | t <sub>WHWH2</sub> | Erase operation | 0.3 | - | 0.3 | - | 0.3 | - | 0.3 | - | 0.3 | - | sec | Write waveform WE controlled #### AC parameters—write cycle 2 CE controlled -55 -150 -70 -90 -120 **JEDEC** Std **Symbol** Symbol Min Max Min Max Min Max Min Max Min Parameter Max Unit 55 70 120 150 Write cycle time 90 ns $t_{WC}$ $t_{AVAV}$ Address setup time 0 0 0 0 0 ns $t_{AS}$ $t_{AVEL}$ Address hold time 40 45 45 50 50 $t_{ELAX}$ t<sub>AH</sub> ns Data setup time 25 30 45 50 50 $t_{DS}$ t<sub>DVEH</sub> Data hold time 0 0 0 \_ 0 0 $t_{DH}$ ns $t_{EHDX}$ Output enable setup time 0 \_ 0 0 \_ 0 0 $t_{OES}$ nsOutput enable hold time: t<sub>OEH</sub> 10 10 10 10 10 ns Toggle and DATA polling Read recover time before 0 0 0 0 0 ns t<sub>GHEL</sub> $t_{GHEL}$ write WE setup time 0 \_ 0 \_ 0 \_ 0 -0 \_ ns $t_{WS}$ tWLEL WE hold time 0 0 0 0 0 $t_{WH}$ ns $t_{EHWH}$ CE pulse width 35 35 $t_{CP}$ 45 50 50 ns $t_{\text{ELEH}}$ CE pulse width high 20 20 20 \_ 20 20 ns t<sub>ehel</sub> $t_{CPH}$ Programming pulse time 15 15 15 15 15 μs $t_{WHWH1}$ $t_{WHWH1} \\$ Write waveform 2 CE controlled 0.3 0.3 0.3 0.3 sec 0.3 Erase operation $t_{WHWH2}$ $t_{WHWH2}$ ### Erase waveform ## DATA polling waveform ### Toggle bit waveform ### Erase and programming performance | | Limits | | | | |--------------------------------------------------------------------------|--------|---------|--------|--------| | Parameter | Min | Typical | Max | Unit | | Sector erase and verify-1 time (excludes 00h programming prior to erase) | - | 1.0 | - | sec | | Byte program time | - | 45 | - | μs | | Chip programming time | - | 23 | - | sec | | Erase/program cycles | - | - | 10,000 | cycles | ### Latchup tolerance | Parameter | Min | Max | Unit | |-----------------------------------------------------------------------------------|------|----------------------|------| | Input voltage with respect to $V_{SS}$ on A9 and $\overline{OE}$ | -1.0 | +13.0 | V | | Input voltage with respect to V <sub>SS</sub> on all DQ, address and control pins | -1.0 | V <sub>CC</sub> +1.0 | V | | Current | -100 | +100 | mA | Includes all pins except $V_{CC}$ . Test conditions: $V_{CC} = 5.0V$ , one pin at a time. #### AC test conditions | Test condition | | | Unit | |--------------------------------------------|------------|------|------| | Output load | 1 TTL gate | | | | Input rise and fall times | 5 | 5 | ns | | Input pulse levels | 0.0- | -3.0 | V | | Input timing measurement reference levels | 1. | 5 | V | | Output timing measurement reference levels | 1. | 5 | | ### Absolute maximum ratings | Parameter | Symbol | Min | Max | Unit | |----------------------------------------|-----------------|------|-------|------| | Input voltage (Input or DQ pin) | $V_{IN}$ | -2.0 | +7.0 | V | | Input voltage (A9 pin, <del>OE</del> ) | V <sub>IN</sub> | -2.0 | +13.0 | V | | Power supply voltage | $V_{CC}$ | -0.5 | +5.5 | V | | Operating temperature | $T_{OPR}$ | -55 | +125 | °C | | Storage temperature (plastic) | $T_{STG}$ | -65 | +125 | °C | | Short circuit output current | $I_{OUT}$ | - | 200 | mA | NOTE: Stresses 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 outside those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. Includes all pins except $V_{\text{CC}}$ . Test conditions: $V_{\text{CC}} = 5.0 \text{V}$ , one pin at a time. ### Recommended operating conditions | Parameter | Symbol | Min | Тур | Max | Unit | |----------------|-----------------|------|-----|----------------|------| | Supply voltage | $V_{CC}$ | +4.5 | 5.0 | +5.5 | V | | Supply voltage | V <sub>SS</sub> | 0 | 0 | 0 | V | | Input valtage | $V_{IH}$ | 2.0 | - | $V_{CC} + 0.5$ | V | | Input voltage | $V_{IL}$ | -0.5 | - | 0.8 | V | ### TSOP pin capacitance | Symbol | Parameter | Test setup | Тур | Max | Unit | |------------------|-------------------------|---------------|-----|-----|------| | $C_{IN}$ | Input capacitance | $V_{IN} = 0$ | 6 | 7.5 | pF | | $C_{OUT}$ | Output capacitance | $V_{OUT} = 0$ | 8.5 | 12 | pF | | C <sub>IN2</sub> | Control pin capacitance | $V_{IN} = 0$ | 7.5 | 9 | pF | ### PLCC pin capacitance | Symbol | Parameter | Test setup | Тур | Max | Unit | |------------------|-------------------------|---------------|-----|-----|------| | C <sub>IN</sub> | Input capacitance | $V_{IN} = 0$ | 6 | 7.5 | pF | | C <sub>OUT</sub> | Output capacitance | $V_{OUT} = 0$ | 8.5 | 12 | pF | | C <sub>IN2</sub> | Control pin capacitance | $V_{IN} = 0$ | 7.5 | 9 | pF | ### Data retention | Parameter | Temp. (°C) | Min | Unit | |--------------------------------------|------------|-----|-------| | Minimum nottone data natanti an tima | 150° | 10 | years | | Minimum pattern data retention time | 125° | 20 | years | AS29F040 March 2000 ### Package dimensions | | 32-pin PLCC | |---|----------------| | | typical (inch) | | a | 0.49 | | b | 0.45 | | С | 0.59 | | d | 0.55 | | e | 0.52 | | f | 0.09 | | g | 0.136 | | h | 0.075 | | i | 0.52 | | j | 0.028 | | | | JEDEC outline MS-016 AE Body size 0.450 in. × 0.550 in. Package thickness 0.110 in. Board standoff 0.020 in. (min) Lead pitch 0.050 in. Coplanarity 0.004 in. (max) ### AS29F040 ordering codes\* | | • | | | | | | | | |--------------------------|---------------------------------|--------------------------------|----------------------------------|-----------------------------------|-----------------------------------|--|--|--| | Package \ Access time | 55ns<br>(commercial/industrial) | 70 ns (commercial/industrial) | 90 ns<br>(commercial/industrial) | 120 ns<br>(commercial/industrial) | 150 ns<br>(commercial/industrial) | | | | | TSOP, 8×20 mm, 32-pin | AS29F040-55TC<br>AS29F040-55TI | AS29F040-70TC<br>AS29F040-70TI | | AS29F040-120TC<br>AS29F040-120TI | AS29F040-150TC<br>AS29F040-150T | | | | | PLCC, 0.55×0.45", 32-pin | AS29F040-55LC<br>AS29F040-55LI | AS29F040-70LC<br>AS29F040-70LI | | AS29F040-120LC<br>AS29F040-120LI | AS29F040-150LC<br>AS29F040-150LI | | | | ### AS29F040 part numbering system | AS29F | 040 | -XXX | X | X | |---------------------|---------------|---------------------|-----------------------------|--------------------------------------------------------------------------------| | Flash EEPROM prefix | Device number | Address access time | Package: L= PLCC<br>T= TSOP | Temperature range: C = Commercial: 0°C to 70°C I = Industrial: -40°C to 85°C | <sup>\*</sup> Industrial and Commercial temperature range available #### 18 #### **ALLIANCE SEMICONDUCTOR**