# 27F256 256K (32K x 8) CMOS FLASH MEMORY - Flash Electrical Chip-Erase 1 Second Typical Chip-Erase - Quick-Pulse Programming™ — 100 µs Typical Byte-Program — 4 Second Chip-Program - **EPROM-Compatible 12.75V VPP Supply** - 100 Erase/Program Cycles Minimum - High-Performance Speeds 170 ns Maximum Access Time - Low Power Consumption — 100 µA Maximum Standby Current - Command Register Architecture for Microprocessor/Microcontroller Compatible Write Interface - Noise Immunity Features - ± 10% V<sub>CC</sub> Tolerance - Maximum Latch-Up Immunity through EPI Processing - **■** ETOX<sup>™</sup> Flash-Memory Technology - EPROM-Compatible Process Base - --- High-Volume Manufacturing Experience - Compatible with JEDEC-Standard Byte-Wide EPROM Pinouts — 28-Pin "Windowless" Cerdip (See Packaging Spec., Order #231369) Intel's 27F256 CMOS flash-memory offers the most cost-effective and reliable alternative for updatable nonvolatile memory. The 27F256 adds electrical chip-erasure and reprogramming to familiar EPROM technology. Memory contents can be erased and reprogrammed: in a test socket; in a PROM-programmer socket; onboard during subassembly test; in-system during final test; and in-system after-sale. The 27F256 increases memory flexibility, while contributing to time- and cost-savings. The 27F256 is targetted for alterable codeor data-storage applications where EPROM ultraviolet erasure is impractical or time consuming. The 27F256 can also be applied where traditional EEPROM functionality (byte-erasure) is either not required or not cost-effective. The 27F256 is a 256-kilobit nonvolatile memory organized as 32768 bytes of 8 bits. Intel's 27F256 is offered in a 28-pin "windowless" cerdip package. Pin assignments conform to JEDEC standards for byte-wide EPROMs. Intel's 27F256 employs advanced CMOS circuitry for systems requiring high-performance access speeds, low power consumption, and immunity to noise. Its 170 nanosecond access time provides no-WAIT-state performance for a wide range of microprocessors and microcontrollers. Maximum standby current of 100 microamps translates into power savings when the device is deselected. Finally, the highest degree of latch-up protection is achieved through Intel's unique EPI processing. Prevention of latch-up is provided for stresses up to 100 milliamps on address and data pins, from $\sim$ 1V to V<sub>CC</sub> + 1V. With Intel's ETOXTM (EPROM tunnel oxide) process base, the 27F256 levers years of EPROM experience to yield the highest levels of quality, reliability, and cost-effectiveness. Figure 1. 27F256 Block Diagram Pin Names | A <sub>0</sub> -A <sub>13</sub> | Address Inputs | |----------------------------------|----------------------| | DQ <sub>0</sub> -DQ <sub>7</sub> | Data Input/Output | | CE | Chip Enable | | ŌĒ | Output Enable | | A <sub>14</sub> /WE | Address/Write Enable | | V <sub>PP</sub> | Program/Erase Power | | V <sub>CC</sub> | Device Power | | V <sub>SS</sub> | Ground | Figure 2. Cerdip (D) Pin Configuration **Table 1. Pin Description** | Symbol | Туре | Name and Function | |----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A <sub>0</sub> -A <sub>13</sub> | INPUT | ADDRESS INPUTS for memory addresses. Addresses are internally latched during a write cycle. | | DQ <sub>0</sub> -DQ <sub>7</sub> | INPUT/<br>OUTPUT | DATA INPUT/OUTPUT: Inputs data during memory write cycles; outputs data during memory read cycles. The data pins are active high and float to tri-state OFF when the chip is deselected or the outputs are disabled. Data is internally latched during a write cycle. | | CE | INPUT | CHIP ENABLE: Activates the device's control logic, input buffers, decoders, and sense amplifiers. $\overline{\text{CE}}$ is active low; $\overline{\text{CE}}$ high deselects the memory device and reduces power consumption to standby levels. | | ŌĒ | INPUT | OUTPUT ENABLE: Gates the device's output through the data buffers during a read cycle. OE is active low. | | A <sub>14</sub> /WE | INPUT | ADDRESS/WRITE ENABLE are multiplexed to maintain EPROM pinout compatibility. With Vpp high, A <sub>14</sub> /WE functions as the write control pin. With Vpp low, A <sub>14</sub> /WE functions as an address input line. WE is active low. Addresses are latched on the falling edge of WE. Data is latched on the rising edge of the WE pulse. Note: With Vpp = VppL, memory contents cannot be altered. | | V <sub>PP</sub> | | <b>ERASE/PROGRAM POWER SUPPLY</b> for writing the command register, erasing the entire array, or programming bytes in the array. | | V <sub>CC</sub> | | DEVICE POWER SUPPLY (5V ± 10%) | | V <sub>SS</sub> | | GROUND | ### **APPLICATIONS** The 27F256 flash-memory adds electrical chip-erasure and reprogrammability to EPROM non-volatility and ease of use. As such, the 27F256 is ideal for storing code or data-tables in embedded control applications where periodic updates are required. The need for code updates pervades all phases of a system's life—from prototyping to system manufacture to after-sale service. In the factory, during prototyping, revisions to control code necessitate ultraviolet erasure and reprogramming of EPROM-based prototype codes. The 27F256 replaces the 15- to 20-minute ultraviolet erasure with one-second electrical erasure. Electrical chip-erasure and reprogramming occur in the same workstation or PROM-programmer socket. Diagnostics, performed at subassembly or final assembly stages, often require the socketing of EPROMs. Socketed test codes are ultimately replaced with EPROMs containing the final program. With electrical chip-erasure and reprogramming, the 27F256 is soldered to the circuit board. Test codes are programmed into the 27F256 as it resides on the circuit board. Ultimately, the final code can be downloaded to the device. The 27F256's in-circuit alterability eliminates unnecessary handling and less-reliable socketed connections, while adding greater test flexibility. Material and labor costs associated with code changes increase at higher levels of system integration—the most costly being code updates after sale. Code "bugs", or the desire to augment system func- tionality, prompt after-sale code updates. Field revisions to EPROM-based code require the removal of EPROM components or entire boards. The service technician performs the twenty-minute ultraviolet erasure and reprogramming on-site, or returns boards to the factory for rework. An alternate approach is to use one-time-programmable EPROMs. The service technician removes the "old" devices and replaces them with updated versions. The used components are discarded. Designing with the in-circuit alterable 27F256 eliminates socketed memories, reduces overall material costs, and drastically cuts the labor costs associated with code updates. With the 27F256, code updates are implemented locally via an edge-connector, or remotely over a serial communication link. A high degree of on-chip feature integration simplifies memory-to-processor interfacing. Figure 3 illustrates the interface between the MCS-51 microcontroller and one 27F256 flash-memory in a minimum chip-count system. Figure 4 depicts two 27F256s tied to the 80C186 system bus. In both instances, the 27F256's architecture minimizes interface circuitry needed for complete in-circuit updates of memory contents. With cost-effective electrical erasure and reprogramming, the 27F256 fills the functionality gap between traditional EPROMs and EEPROMS. EPROM-compatible specifications, straightforward interfacing, and in-circuit alterability allows designers to easily augment memory flexibility and satisfy the need for updatable-code-storage in today's designs. Figure 3. 27F256 in an MCS-51 System Figure 4. 27F256 in an 80C186 System ## PRINCIPLES OF OPERATION Flash-memory augments EPROM functionality with in-circuit electrical erasure and reprogramming. The 27F256 introduces a command register to manage this new functionality. The command register allows for: 100% TTL-level control inputs; fixed power supplies during erasure and programming; and maximum EPROM compatibility. In the absence of high voltage on the V<sub>PP</sub> pin, the 27F256 is a read-only memory. The 27F256 is completely read-compatible with the industry-standard 27256 and 27C256 EPROMs. Manipulation of the external memory-control pins yields the standard EPROM read, standby, output disable, and inteligent IdentifierTM operations. The same EPROM read, standby, and output disable operations are available when high voltage is applied to the VPP pin. In addition, high voltage on VPP enables erasure and programming of the device. All functions associated with altering memory contents—inteligent Identifier, erase, erase verify, program, and program verify—are accessed via the command register. Commands are written to the register using standard microprocessor write timings. Register contents serve as input to an internal state-machine which controls the erase and programming circuitry. Write cycles also internally latch addresses and data needed for programming or erase operations. With the appropriate command written to the register, standard microprocessor read timings output array data, access the inteligent Identifier codes, or output data for erase and program verification. | Table 2. | 27F256 | <b>Bus O</b> | perations | |----------|--------|--------------|-----------| |----------|--------|--------------|-----------| | | | Pins | | | l | | A14/ | | |----------------|---------------------------------|---------------------|----------------|---------------------|-----------------|-----------------|-----------------|----------------------------------| | | Operation | V <sub>PP</sub> (1) | A <sub>0</sub> | A9 | CE | ŌĒ | WE | DQ <sub>0</sub> -DQ <sub>7</sub> | | _ | Read | V <sub>PPL</sub> | Ao | Ag | V <sub>IL</sub> | V <sub>IL</sub> | A <sub>14</sub> | Data Out | | READ-ONLY | Output Disable | V <sub>PPL</sub> | Х | x | VIL | V <sub>IH</sub> | V <sub>IH</sub> | Tri-state | | Q | Standby | V <sub>PPL</sub> | Х | х | V <sub>IH</sub> | Х | Х | Tri-state | | REA | inteligent ID™ Manufacturer (2) | V <sub>PPL</sub> | VIL | Λ <sup>ID</sup> (3) | VIL | VIL | V <sub>IL</sub> | Data = 89H | | | inteligent ID™ Device (2) | V <sub>PPL</sub> | VIH | V <sub>ID</sub> (3) | V <sub>IL</sub> | ٧ <sub>L</sub> | V <sub>IL</sub> | Data = 91H | | | Read | V <sub>PPH</sub> | A <sub>0</sub> | Ag | VIL | V <sub>IL</sub> | V <sub>IH</sub> | Data Out (4) | | READ/<br>WRITE | Output Disable | V <sub>PPH</sub> | . <b>X</b> | x | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IH</sub> | Tri-state | | AE. | Standby (5) | V <sub>PPH</sub> | Х | × | V <sub>IH</sub> | Х | Х | Tri-state | | | Write | V <sub>PPH</sub> | A <sub>0</sub> | A <sub>9</sub> | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Data In (6) | #### NOTES - V<sub>PL</sub> may be ground, a no-connect with a resistor tied to ground, or ≤V<sub>CC</sub> +2.0V. V<sub>PPH</sub> is the programming voltage specified for the device. Refer to D.C. Characteristics. When V<sub>PP</sub> = V<sub>PPL</sub>, memory contents can be read but not written or erased. - 2. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 3. - 3. $11.5V \le V_{ID} \le 13.0V$ - 4. Read operations with V<sub>PP</sub> = V<sub>PPH</sub> may access array data or the int<sub>e</sub>ligent IDTM. - 5. With Vpp at high voltage, the standby current equals Icc + Ipp (standby). - 6. Refer to Table 3 for valid Data-In during a write operation. - 7. X can be VIL or VIH. The command register is only alterable when V<sub>PP</sub> is at high voltage. Depending upon the application, the system designer may choose to make the V<sub>PP</sub> power supply switchable—available only when memory updates are desired. When high voltage is removed, the contents of the register default to the read command, making the 27F256 a read-only memory. Memory contents cannot be altered. Write-Enable control is multiplexed with A14 to preserve compatibility with EPROM footprints. When Vpp equals VppH, A14/Write-Enable functions as the Write-Enable pin. When Vpp equals VppL, A14/Write-Enable is an address input line. The lowest order register bit contains the A14 information. In this manner, the 27F256 operates in a page-addressed fashion when Vpp equals VppH. The system designer may choose to "hard-wire" Vpp, making the high voltage supply constantly available. In this instance, all operations are performed in conjunction with the command register. The 27F256 is designed to accomodate either design practice, and to encourage optimization of the processor-memory interface. ### **BUS OPERATIONS** #### Read The 27F256 has two control functions, both of which much be logically active, to obtain data at the outputs. Chip-Enable ( $\overline{OE}$ ) is the power control and should be used for device selection. Output-Enable ( $\overline{OE}$ ) is the output control and should be used to gate data from the output pins, independent of device selection. Figure 7 illustrates read timing waveforms. The read operation only accesses array data when Vpp is low (VppL). When Vpp is high (VppH), the read operation can be used to access array data, to output the inteligent Identifier™ codes, and to access data for program/erase verification. ### **Output Disable** With Output-Enable at a logic-high level ( $V_{IH}$ ), output from the device is disabled. Output pins are placed in a high-impedance state. ## Standby With Chip-Enable at a logic-high level, the standby operation disables most of the 27F256's circuitry and substantially reduces device power consumption. The outputs are placed in a high-impedence state, independent of the Output-Enable signal. If the 27F256 is deselected during erasure, programming, or program/erase verification, the device draws active current until the operation is terminated. # inteligent Identifier™ The inteligent Identifier operation outputs the manufacturer code (89H) and device code (91H). Programming equipment automatically matches the device with its proper erase and programming algorithms. With Chip-Enable and Output-Enable at a logic low level, raising A9 to high voltage (11.5V-13.0V) activates the operation. Data read from locations 0000H and 0001H represent the manufacturer's code and the device code, respectively. The manufacturer- and device-codes can also be read via the command register, for instances where the 27F256 is erased and reprogrammed in the target system. Following a write of 80H to the command register, a read from address location 0000H outputs the manufacturer code (89H). A read from address 0001H outputs the device code (91H). ### Write Device erasure and programming are accomplished via the command register, when high voltage is applied to the V<sub>PP</sub> pin. The contents of the register serve as input to the internal state-machine. The state-machine outputs dictate the function of the device. The command register itself does not occupy an addressable memory location. The register is a latch used to store the command, along with address and data information needed to execute the command. The command register is written by bringing Write-Enable to logic-low level (V<sub>IL</sub>), while Chip-Enable is low. Addresses are latched on the falling edge of Write-Enable, while data is latched on the rising edge of the Write-Enable pulse. Standard microprocessor write timings are used. The three high-order register bits (R7, R6, R5) encode the control functions. The lowest-order register bit (R0) contains the A14 information. All other regis- ter bits, R4 to R1, must be zero. The only exception is the reset command, when FFH is written to the register. Register bits R7-R0 correspond to data inputs D7-D0. Refer to AC Write Characteristics and the Erase/ Programming Waveforms for specific timing parameters. ## **COMMAND DEFINITIONS** When low voltage is applied to the V<sub>PP</sub> pin, the contents of the command register default to 00H, enabling read-only operations. Placing high voltage on the V<sub>PP</sub> pin enables read/write operations. Device operations are selected by writing specific data patterns into the command register. Table 3 defines these 27F256 register commands. # Read Command (Page 0/Page 1) While V<sub>PP</sub> is high, for erasure and programming, memory contents can be accessed via the read command. When accessing array data with the read command, the A14 address information is written into bit zero (R0) of the command register. In effect, this divides the device into 16-kilobyte pages (page 0 and page 1). The read operation (page 0) is initiated by writing 00H into the command register. Microprocessor read cycles retrieve array data from the lower 16-kilobyte page of memory. The device remains enabled for reads (page 0) until the command register contents are altered. By writing 01H to the command register, read cycles access data from the upper 16-kilobyte page (page 1) of memory. The default contents of the register upon V<sub>PP</sub> power-up is 00H. This default value ensures that no spurious alteration of memory contents occurs during the V<sub>PP</sub> power transition. Where the V<sub>PP</sub> supply is hard-wired to the 27F256, the device powers-up and remains enabled for reads (page 0) until the command-register contents are changed. Refer to the AC Read Characteristics and Waveforms for specific timing parameters. # int<sub>e</sub>ligent Identifier™ Command Flash-memories are intended for use in applications where the local CPU alters memory contents. As such, manufacturer and device-codes must be accessible while the device resides in the target system. PROM programmers typically access signature codes by raising A9 to a high voltage. However, multiplexing high voltage onto address lines is not desired system-design practice. | Table | 3 C | ommano | Definit | ione | |-------|-----|--------|---------|------| | | | | | | | | Bus | | Bus Cycle | | Second Bus Cycle | | | | | |-------------------------------|-----------------|--------------------------|------------|---------|--------------------------|------------|---------|--|--| | Command | Cycles<br>Req'd | Operation <sup>(1)</sup> | Address(2) | Data(3) | Operation <sup>(1)</sup> | Address(2) | Data(3) | | | | Read Memory | | | | | | | | | | | a. Page 0 | 1 | Write | Х | 00H | | | | | | | b. Page 1 | 1 | Write | × | 01H | | | | | | | Read inteligent IDTM(4) | 1 | Write | Х | 80H | Read | IA | D | | | | Set-up Erase/Erase(5) | 2 | Write | Х | 20H | Write | X | 20H | | | | Erase Verify <sup>(5)</sup> | | | | | | | | | | | a. Page 0 | 2 | Write | EA | A0H | Read | Х | EVD | | | | b. Page 1 | 2 | Write | EA | A1H | Read | Х | EVD | | | | Set-up Program/Program(6) | | | | | | | | | | | a. Page 0 | 2 | Write | Х | 40H | Write | PA | PD | | | | b. Page 1 | 2 | Write | Х | 41H | Write | PA | PD | | | | Program Verify <sup>(6)</sup> | | | | | | | | | | | a. Page 0 | 2 | Write | Х | COH | Read | Х | PVD | | | | b. Page 1 | 2 | Write | Х | C1H | Read | Х | PVD | | | | Reset <sup>(7)</sup> | 2 | Write | Х | FFH | Write | Х | FFH | | | #### NOTES: - 1. Bus operations are defined in Table 2. - 2. IA = Identifier Address: 00H for manufacturer code; 01H for device code. - EA = Address of memory location to be read during erase verify. - PA = Address of memory location to be programmed. - Addresses are latched on the falling edge of the Write-Enable pulse. - 3. ID = Data read from location IA during device indentification (Mfr = 89H, Device = 91H). - EVD = Data read from location EA during erase verify. - PD = Data to be programmed at location PA. Data is latched on the rising edge of Write-Enable. - PVD = Data read from location PA during program verify. PA is latched on the Program command. - 4. Following the Read inteligent ID command, two read operations access manufacturer and device codes. - Figure 6 illustrates the Quick-Erase™ Algorithm. - 6. Figure 5 illustrates the Quick-Pulse Programming™ Algorithm. - 7. The second bus cycle must be followed by the desired command register write. The 27F256 contains an int<sub>el</sub>ligent Identifier™ operation to supplement traditional PROM-programming methodology. The operation is initiated by writing 80H into the command register. Following the command write, a read cycle from address 0000H retrieves the manufacturer code of 89H. A read cycle from address 0001H returns the device code of 91H. To terminate the operation, it is necessary to write another valid command into the register. ## Set-up Erase/Erase Commands Set-up Erase is a command-only operation that stages the device for electrical erasure of all bytes in the array. The set-up erase operation is performed by writing 20H to the command register. To commence chip-erasure, the erase command (20H) must again be written to the register. The erase operation begins with the rising edge of the Write-Enable pulse and terminates with the rising edge of the next Write-Enable pulse (i.e. Erase-Verify Command). This two-step sequence of set-up followed by execution ensures that memory contents are not accidentally erased. Also, chip-erasure can only occur when high voltage is applied to the V<sub>PP</sub> pin. In the absence of this high voltage, memory contents are protected against erasure. Refer to AC Erase Characteristics and Waveforms for specific timing parameters. # Erase-Verify Command (Page 0/Page 1) The erase command erases all bytes of the array in parallel. After each erase operation, all bytes must be verified. The erase verify operation (page 0) is initiated by writing A0H into the command register. Erase verify (page 1) is started by writing A1H into the register. The address for the byte to be verified must be supplied as it is latched on the falling edge of the Write-Enable pulse. The register write terminates the erase operation with the rising edge of its Write-Enable pulse. The 27F256 applies an internally-generated margin voltage to the addressed byte. Reading FFH from the addressed byte indicates that all bits in the byte are erased. The erase-verify command must be written to the command register prior to each byte verification to latch its address. The process continues for each byte in the 16-kilobyte page until a byte does not return FFH data, or the last address in the page is accessed. The erase-verify (page 1) command must be written to the register to cross the page boundary. In the case where FFH data is not read, another erase operation is performed. (Refer to Set-up Erase/Erase). Verification then resumes from the address of the last-verified byte. Once all bytes in the array have been verified, the erase step is complete. The device can be programmed. At this point, the verify operation is terminated by writing a valid command (e.g. Program Set-up) to the command register. Figure 6, the Flash-Erase™ Algorithm illustrates how commands and bus operations are combined to perform electrical erasure of the 27F256. Refer to AC Erase Characteristics and Waveforms for specific timing parameters. # Set-up Program/Program Commands (Page 0/Page 1) Set-up program is a command-only operation that stages the device for byte programming. Writing 40H (page 0) or 41H (page 1) into the command register performs the set-up operation. The register write latches the A14 information into bit zero (R0) of the register to select the desired 16-kilobyte page. Once the program set-up operation is performed, the next Write-Enable pulse causes a transition to an active programming operation. Addresses are internally latched on the falling edge of the Write-Enable pulse. Data is internally latched on the rising edge of the Write-Enable pulse. The rising edge of Write-Enable also begins the programming operation. The programming operation terminates with the next rising edge of Write-Enable, used to write the program-verify command. Refer to AC Programming Characteristics and Waveforms for specific timing parameters. # Program-Verify Command (Page 0/Page 1) The 27F256 is programmed on a byte-by-byte basis. Byte programming may occur sequentially or at random. Following each programming operation, the byte just programmed must be verified. The program-verify operation (page 0) is initiated by writing C0H into the command register. Program verify (page 1) is entered by writing C1H into the register. Bit zero (R0) of the register represents A14, selecting one of the two 16-kilobyte pages. The register write terminates the programming operation with the rising edge of its Write-Enable pulse. The program-verify operation stages the device for verification of the byte last programmed. No new address information is latched. The 27F256 applies an internally-generated margin voltage to the byte. A microprocessor read cycle outputs the data. A successful comparison between the programmed byte and true data means that the byte is successfully programmed. Programming then proceeds to the next desired byte location. Figure 5, the 27F256 Quick-Pulse Programming™ Algorithm, illustrates how commands are combined with bus operations to perform byte programming. Refer to AC Programming Characteristics and Waveforms for specific timing parameters. #### **Reset Command** A reset command is provided as a means to safely abort the erase- or program-command sequences. Following either set-up command (erase or program) with two consecutive writes of FFH will safely abort the operation. Memory contents will not be altered. A valid command must then be written to place the device in the desired state. ## QUICK-PULSE PROGRAMMINGTM ALGORITHM The Quick-Pulse Programming™ algorithm uses programming operations of 100 microsecond duration. Each operation is followed by a byte verification to determine when the addressed byte has been successfully programmed. The algorithm allows for up to 25 programming operations per byte, although most bytes verify on the first or second operation. The entire sequence of programming and byte verification is performed with V<sub>PP</sub> at high voltage. Figure 5 illustrates the Quick-Pulse Programming algorithm. Figure 5. 27F256 Quick-Pulse Programming™ Algorithm ## QUICK-ERASETM ALGORITHM Intel's Quick-Erase algorithm yields fast and reliable electrical erasure of memory contents. The algorithm employs a closed-loop flow, similar to the Quick-Pulse Programming<sup>TM</sup> algorithm, to simultaneously remove charge from all bits in the array. Erasure begins with a read of memory contents. The 27F256 is erased when shipped from the factory. Reading FFH data from the device would immediately be followed by device programming. Uniform and reliable erasure is ensured by first programming all bits in the device to their charged state (Data = 00H). This is accomplished, using the Quick-Pulse Programming algorithm, in approximately four seconds. Erase execution then continues with an initial erase operation. Erase verification (data = FFH) begins at address 0000H and continues through the array to the last address, or until data other than FFH is encountered. With each erase operation, an increasing number of bytes verify to the erased state. Erase efficiency may be improved by storing the address of the last byte verified in a register. Following the next erase operation, verification starts at that stored address location. A total of sixty-four erase operations are allowed, which corresponds to approximately ten seconds of cumulative erase time. Erasure typically occurs in one second. Figure 6 illustrates the Quick-Erase Algorithm. ## **DESIGN CONSIDERATIONS** ## **Two-Line Output Control** Flash-memories are often used in larger memory arrays. Intel provides two read-control inputs to accomodate multiple memory connections. Two-line control provides for: - a) the lowest possible memory power dissipation, and - complete assurance that output bus contention will not occur. To efficiently use these two control inputs, an address-decoder output should drive chip-enable, while the system's read signal controls all flashmemories and other parallel memories. This assures that only enabled memory devices have active outputs, while deselected devices maintain the low power standby condition. ## **Power Supply Decoupling** Flash-memory power-switching characteristics require careful device decoupling. System designers are interested in three supply current (I<sub>CC</sub>) issues- standby, active and transient current peaks produced by falling and rising edges of Chip-Enable. The capacitive and inductive loads on the device outputs determine the magnitudes of these peaks. Two-line control and proper decoupling capacitor selection will supress transient voltage peaks. Each device should have a 0.1 $\mu F$ ceramic capacitor connected between $V_{CC}$ and $V_{SS}$ , and between $V_{PP}$ and $V_{SS}$ . Place the high-frequency, low-inherent-inductance capacitors as close as possible to the devices. Also, for every eight devices, a 4.7μF electrolytic capacitor should be placed at the array's power supply connection, between V<sub>CC</sub> and V<sub>SS</sub>. The bulk capacitor will overcome voltage slumps caused by printed-circuit-board trace inductance, and will supply charge to the smaller capacitors as needed. # **VPP Trace on Printed Circuit Boards** Programming flash-memories, while they reside in the target system, requires that the printed circuit board designer pay attention to the Vpp power supply trace. The Vpp pin supplies the memory cell current for programming. Use similar trace width and layout considerations given the V<sub>CC</sub> power bus. Adequate Vpp supply traces and decoupling will decrease Vpp voltage spikes and overshoots. ## Power Up/Down Sequencing The 27F256 is designed to offer protection against accidental erasure or programming, caused by spurious system-level signals that may exist during power transitions. The 27F256 powers-up in its read-only state. Also, with its control register architecture, alteration of memory contents only occurs after successful completion of the two-step command sequences. While these precautions are sufficient for most applications, it is recommended that $V_{\rm CC}$ reach its steady-state value before raising $V_{\rm PP}$ above $V_{\rm CC}+2.0V$ . In addition, upon powering-down, $V_{\rm PP}$ should be below $V_{\rm CC}+2.0V$ , before lowering $V_{\rm CC}$ | SUGNICIDE DEIOM ACC 5'04' pero | io lowering roo. | |----------------------------------|------------------| | Additional Information | Order Number | | 28F256 Data Sheet | 290158 | | 27F64 Data Sheet | 290153 | | AP-314 "The 27F64 Flash | 292043 | | Memory—Your Solution for | | | On-Board Programming" | | | AP-316 "Using the 28F256 Flash | 292046 | | Memory for In-System Repro- | | | grammable Nonvolatile Storage" | | | ER-21 "Intel's 27F256 and 28F256 | 294004 | | Flash Memories" | | | ER-20 "ETOX™ Flash Memory | 294005 | | Technology" | | | RR-60 "ETOX™ Flash Memory | 293002 | | Reliability Data Summary" | | Figure 6. 27F256 Quick-Erase™ Algorithm # **ABSOLUTE MAXIMUM RATINGS** | Operating Temperature During Read0°C to +70°C(1) During Erase/Program0°C to +70°C | |------------------------------------------------------------------------------------------------------------------| | Temperature Under Bias 10°C to +80°C | | Storage Temperature65°C to + 125°C | | Voltage on Any Pin with Respect to Ground2.0V to +7.0V(2) | | Voltage on Pin A <sub>9</sub> with<br>Respect to Ground2.0V to +13 5V(2,3) | | V <sub>PP</sub> Supply Voltage with<br>Respect to Ground<br>During Erase/Program 2.0V to +14.0V <sup>(2,3)</sup> | | V <sub>CC</sub> Supply Voltage with Respect to Ground2.0V to +7.0V <sup>(2)</sup> | | Output Short Circuit Current100 mA(4) | \*Notice: Stresses above 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 device reliability. NOTICE: Specifications contained within the following tables are subject to change. #### NOTES: 1. Operating temperature is for commercial product defined by this specification. - 2. Minimum D.C. input voltage is -0.5V. During transitions, inputs may undershoot to -2.0V for periods less than 20ns. Maximum D.C. voltage on output pins is $V_{CC} + 0.5$ V, which may overshoot to $V_{CC} + 2.0$ V for periods less than 20ns. - 3. Maximum D.C. voltage on Aq or $V_{PP}$ may overshoot to +14.0V for periods less than 20 ns. 4. Output shorted for no more than one second. No more than one output shorted at a time. ### OPERATING CONDITIONS | Symbol | Davamatar | Limits | | Unit | Comments | |--------|--------------------------------|--------|------|------|--------------------------------------------| | | Parameter | Min | Max | | | | TA | Operating Temperature | 0 | 70 | °C | For Read-Only and<br>Read/Write Operations | | Vcc | V <sub>CC</sub> Supply Voltage | 4.50 | 5.50 | V | | # D.C. CHARACTERISTICS-TTL/NMOS COMPATIBLE | | Barrantal | Lir | nits | Unit | Test Conditions | | |-----------------|-------------------------------------|-----|------|------|------------------------------------------------------------------------------------------------|--| | Symbol | Parameter | Min | Max | | | | | ILI | Input Leakage Current | | ±1.0 | μΑ | $V_{CC} = V_{CC} \text{ max}$ $V_{IN} = V_{CC} \text{ or } V_{SS}$ | | | l <sub>LO</sub> | Output Leakage Current | | ±1.0 | μΑ | V <sub>CC</sub> = V <sub>CC</sub> max<br>V <sub>OUT</sub> = V <sub>CC</sub> or V <sub>SS</sub> | | | Iccs | V <sub>CC</sub> Standby Current | | 1.0 | mA | $V_{CC} = V_{CC} \max$ $\overline{CE} = V_{IH}$ | | | ICC1 | V <sub>CC</sub> Active Read Current | | 30 | mA | $V_{CC} = V_{CC} \max \overline{CE} = V_{IL}$<br>$f = 6MHz, I_{OUT} = 0 mA$ | | | ICC2 | V <sub>CC</sub> Programming Current | | 30 | mA | CE = V <sub>IL</sub><br>Programming in progress | | # D.C. CHARACTERISTICS—TTL/NMOS COMPATIBLE (Continued) | Symbol | Parameter | | Limits | Unit | Test Conditions | |------------------|---------------------------------------------------------------|-------|------------------------|------|---------------------------------------------------------------------------------| | | V availiteter | Min | Max | J | i est Conditions | | I <sub>CC3</sub> | V <sub>CC</sub> Erase Current | | 30 | mA | CE = V <sub>IL</sub><br>Erasure in progress | | IPPS | V <sub>PP</sub> Leakage Current | | 1.0 | μΑ | V <sub>PP</sub> = V <sub>PPL</sub> | | IPP1 | V <sub>PP</sub> Read Current | | 200 | μΑ | V <sub>PP</sub> = V <sub>PPH</sub> | | I <sub>PP2</sub> | V <sub>PP</sub> Programming Current | | 30 | mA | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in progress | | I <sub>PP3</sub> | V <sub>PP</sub> Erase Current | | 30 | mA | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in progress | | V <sub>IL</sub> | Input Low Voltage | -0.5 | 0.8 | V | | | V <sub>IH</sub> | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.5 | V | | | V <sub>OL</sub> | Output Low Voltage | | 0.45 | ٧ | I <sub>OL</sub> = 2.1 mA<br>V <sub>CC</sub> = V <sub>CC</sub> min | | V <sub>OH1</sub> | Output High Voltage | 2.4 | | ٧ | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ min}$ | | V <sub>ID</sub> | A <sub>9</sub> int <sub>e</sub> ligent Identifier™<br>Voltage | 11.50 | 13.00 | ٧ | $A_9 = V_{ID}$ | | al | A <sub>9</sub> int <sub>e</sub> ligent Identifier™<br>Current | | 500 | μΑ | $A_9 = V_{ID}$ | | V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations | 0.00 | V <sub>CC</sub> + 2.0V | ٧ | Note: Erase/Program<br>are Inhibited when<br>V <sub>PP</sub> = V <sub>PPL</sub> | | V <sub>PPH</sub> | V <sub>PP</sub> during Read/Write<br>Operations | 12.50 | 13.00 | ٧ | | # D.C. CHARACTERISTICS—CMOS COMPATIBLE | Symbol | Parameter | Limits | | Unit | Test Conditions | |--------|---------------------------------|--------|-------|------|---------------------------------------------------------------| | | T di dillotoi | Min | Max | | rest Conditions | | lu | Input Leakage Current | | ± 1.0 | μΑ | $V_{CC} = V_{CC} \max$ $V_{IN} = V_{CC} \text{ or } V_{SS}$ | | ILO | Output Leakage Current | | ± 1.0 | μА | $V_{CC} = V_{CC} \max$ $V_{OUT} = V_{CC} \text{ or } V_{SS}$ | | Iccs | V <sub>CC</sub> Standby Current | | 100 | μΑ | V <sub>CC</sub> = V <sub>CC</sub> max<br>CE = V <sub>IH</sub> | # D.C. CHARACTERISTICS—CMOS COMPATIBLE (Continued) | Symbol | Parameter | Limits | | Unit | Test Conditions | | | |------------------|---------------------------------------------------------------|-----------------------|-----------------------|------|---------------------------------------------------------------------------------------------|--|--| | | | Min | Max | | | | | | I <sub>CC1</sub> | V <sub>CC</sub> Active Read Current | | 30 | mA | $V_{CC} = V_{CC} \text{ max } \overline{CE} = V_{IL}$<br>$f = 6MHz, I_{OUT} = 0 \text{ mA}$ | | | | lcc2 | V <sub>CC</sub> Programming Current | | 30 | mA | CE = V <sub>IL</sub><br>Programming in progress | | | | Іссз | V <sub>CC</sub> Erase Current | | 30 | mA | CE = V <sub>IL</sub><br>Erasure in progress | | | | IPPS | V <sub>PP</sub> Leakage Current | | 1.0 | μΑ | V <sub>PP</sub> = V <sub>PPL</sub> | | | | I <sub>PP1</sub> | V <sub>PP</sub> Read Current | | 200 | μΑ | V <sub>PP</sub> = V <sub>PPH</sub> | | | | lpp2 | V <sub>PP</sub> Programming Current | | 30 | mA | V <sub>PP</sub> = V <sub>PPH</sub><br>Programming in progress | | | | I <sub>PP3</sub> | V <sub>PP</sub> Erase Current | | 30 | mA | V <sub>PP</sub> = V <sub>PPH</sub><br>Erasure in progress | | | | VIL | Input Low Voltage | - 0.5 | 0.8 | ٧ | | | | | V <sub>iH</sub> | Input High Voltage | 0.7 V <sub>CC</sub> | V <sub>CC</sub> + 0.5 | V | | | | | V <sub>OL</sub> | Output Low Voltage | | 0.45 | ٧ | I <sub>OL</sub> = 2.1 mA<br>V <sub>CC</sub> = V <sub>CC</sub> min | | | | Vaus | | 0.85 V <sub>CC</sub> | | V | $I_{OH} = -2.5 \text{ mA}$ $V_{CC} = V_{CC} \text{ min}$ | | | | V <sub>OH1</sub> | Output High Voltage | V <sub>CC</sub> - 0.4 | 1 | ' | $I_{OH} = -100 \mu\text{A} V_{CC} = V_{CC} \text{m}$ | | | | V <sub>OH2</sub> | A <sub>9</sub> int <sub>e</sub> ligent Identifier™<br>Voltage | 11.50 | 13.00 | ٧ | $A_{\theta} = V_{ID}$ | | | | Ι <sub>Ι</sub> D | A <sub>9</sub> inteligent Identifier™ Current | | 500 | μА | $A_9 = V_{ID}$ | | | | V <sub>PPL</sub> | V <sub>PP</sub> during Read-Only<br>Operations | 0.00 | V <sub>CC</sub> + 2.0 | V | Note: Erase/Program<br>are inhibited when<br>V <sub>PP</sub> = V <sub>PPL</sub> | | | | V <sub>РРН</sub> | V <sub>PP</sub> during Read/Write<br>Operations | 12.50 | 13.00 | V | | | | ## CAPACITANCE(1) TA = 25°C, f = 1.0 MHz | APACITANCE | (1) A = 25°C, f = 1.0 WHZ | Lir | nits | Unit | Conditions | | |-----------------|-----------------------------|-----|------|------|-----------------------|--| | Symbol | Parameter | Min | Max | | | | | | Address/Control Capacitance | | 6 | pF | $V_{IN} = 0V$ | | | C <sub>IN</sub> | Output Capacitance | | 12 | pF | V <sub>OUT</sub> = 0V | | NOTE: 1. Sampled, not 100% tested. ### A.C. TEST CONDITIONS Input Rise and Fall Times (10% to 90%) . . . . . 10 ns Inpulse Pulse Levels . . . . . . . $V_{OL}$ and $V_{OH1}$ Input Timing Reference Level . . . . . . $V_{IL}$ and $V_{IH}$ Output Timing Reference Level . . . . . . . $V_{IL}$ and $V_{IH}$ ### A.C. TESTING LOAD CIRCUIT ### A.C. TESTING INPUT/OUTPUT WAVEFORM A.C Testing: inputs are driven at $V_{OH1}$ for a logic "1" and $V_{OL}$ for a logic "0". Testing measurements are made at $V_{IH}$ for a logic "1" and $V_{IL}$ for a logic "0". Rise/Fall time $\leq$ 10 ns. ### A.C. CHARACTERISTICS-READ-ONLY OPERATIONS | Versions | | 27F256-170P2C2 | | 27F256-200P2C2 | | 27F256-250P2C2 | | Unit | |------------------------------------|------------------------------------------------|----------------|-----|----------------|-----|----------------|-----|-------| | Symbol | Characteristics | Min | Max | Min | Max | Min | Max | Oiiit | | t <sub>AVAV</sub> /t <sub>RC</sub> | Read Cycle Time | 170 | | 200 | | 250 | | ns | | t <sub>ELQV</sub> /t <sub>CE</sub> | Chip Enable Access Time | | 170 | | 200 | | 250 | ns | | tavqv/tacc | Address Access Time | | 170 | | 200 | | 250 | ns | | t <sub>GLQV</sub> /t <sub>OE</sub> | Output Enable<br>Access Time | | 70 | | 75 | | 80 | ns | | t <sub>ELQX</sub> /t <sub>LZ</sub> | Chip Enable to Output in Low Z | 0 | | 0 | | 0 | | ns | | tEHQZ | Chip Enable to Output in High Z | | 55 | | 60 | | 65 | ns | | tGLQX/tOLZ | Output Enable to Output in Low Z | 0 | | 0 | | 0 | | ns | | t <sub>GHQZ</sub> /t <sub>DF</sub> | Output Disable to Output in High Z | | 35 | | 45 | | 55 | ns | | tон | Output Hold from Address, CE, or OE Change (1) | 0 | | 0 | | 0 | | ns | | <sup>t</sup> WHGL | Write Recovery Time<br>Before Read | 6 | | 6 | | 6 | | ns | #### NOTES: - 1. Whichever occurs first. - 2. Rise/Fall times ≤ 10 ns. Figure 7. AC Waveforms for Read Operations 5-52 # A.C. CHARACTERISTICS—For Write/Erase/Program Operations(1) | Versions | | 27F256-170P2C2 | | 27F256-200P2C2 | | 27F256-250P2C2 | | Unit | |-------------------------------------|----------------------------------------------------|----------------|----------|----------------|----------|----------------|----------|-------| | Symbol | Characteristics | Min | Max | Min | Max | Min | Max | Oiiii | | t <sub>AVAV</sub> /t <sub>WC</sub> | Write Cycle Time | 170 | | 200 | | 250 | | ns | | tAVWL/tAS | Address Set-up Time | 0 | | 0 | | 0 | | ns | | t <sub>WLAX</sub> /t <sub>AH</sub> | Address Hold Time | 60 | | 75 | | 90 | | ns | | t <sub>DVWH</sub> /t <sub>DS</sub> | Data Set-up Time | 50 | | 50 | | 50 | | ns | | t <sub>WHDX</sub> /t <sub>DH</sub> | Data Hold Time | 10 | | 10 | | 10 | | ns | | twhGL | Write Recovery Time<br>Before Read | 6 | | 6 | | 6 | | μs | | <sup>t</sup> GHWL | Read Recovery Time<br>Before Write | 0 | | 0 | | 0 | | μs | | t <sub>ELWL</sub> /t <sub>CS</sub> | Chip Enable Set-up Time | 0 | | 0 | | 0 | | ns | | twhen/tch | Chip Enable Hold Time | 0 | | 0 | | 0 | | ns | | twLWH/twp | Write Pulse Width | 50 | | 60 | | 75 | | ns | | t <sub>WHWL</sub> /t <sub>WPH</sub> | Write Pulse Width High | 50 | | 60 | | 75 | | ns | | twHwH1 | Programming Operation | 95 | 150 | 95 | 150 | 95 | 150 | μs | | t <sub>WHWH2</sub> | Erase Operation | (2) | (2) + 5% | (2) | (2) + 5% | (2) | (2) + 5% | | | t <sub>EHVP</sub> | Chip Enable Set-up Time<br>to V <sub>PP</sub> Ramp | 100 | | 100 | | 100 | | ns | | tVPEL | V <sub>PP</sub> Set-up Time to<br>Chip Enable Low | 100 | | 100 | | 100 | | ns | #### NOTES: TEW = Truncated Integer Divide (CUMTEW/8) The duration of the erase operation actually applied can exceed the calculated value by a maximum tolerance of 5%. Refer to Figure 6 for additional details. Read timing characteristics during read/write operations are the same as during read-only operations. Refer to A.C. Characteristics for Read-Only Operations. <sup>2.</sup> The duration of each erase operation is variable and is calculated in the Quick-Erase™ Algorithm. The duration of the current erase operation is equal to the truncated value of cumulative erase time divided by eight (integer divide). Figure 8. A.C. Waveforms for Programming Operations 5-54 Figure 9. A.C. Waveforms for Erase Operations 5-55 # ORDERING INFORMATION VALID COMBINATIONS: D27F256-170P2C2 D27F256-200P2C2 D27F256-250P2C2