Inc. 4,194,304 bit CMOS FLASH Memory Module #### **Features** Fast access times of 150/200/250 ns. User Configurable as 32 / 16 / 8 bit wide. Operating Power @ 1MHz 120 / 70 / 45 mW (typical). Low Power Standby 400 µW (maximum). Single High Voltage for Erase/Write : $V_{pp}$ =12.0V ± 0.6. Byte Write Time of 25 µs (typical). Automatic On-Chip Erase Function with Status Polling. Flash Electrical Erase of Module, 1 second (typical). 104 Erase/Write Cycle Endurance minimum. On board decoupling capacitors. Module Components may be processed to MIL-STD-883, non-compliant. ### **Block Diagram** ## 128K x 32 FLASH MODULE ## PUMA 2F4000-15/20/25 Issue 2.0: May 1994 ### PRELIMINARY # Pin Definition 45 56 12 0808080404040408080800008 **VIEW FROM ABOVE** #### P | Pin Functions | | |-----------------|---------------------------| | A0-A16 | Address Inputs | | D0-D31 | Data Input/Output | | CS1-4 | Chip Selects | | ŌĒ | Output Enable | | <b>WE1-4</b> | Write Enables | | $V_{pp}$ | Write/Erase Input Voltage | | V <sub>cc</sub> | Power (+5V) | | GND | Ground | | | | 55 PUMA 2F4000-15/20/25 ISSUE 2.0 : MAY 1994 ### **GENERAL DESCRIPTION** The PUMA 2F4000 is a 4,194,304 bit CMOS FLASH Memory which is configurable as 8, 16 or 32 bit wide output using CS1-4, allowing flexibility in a wide range of applications. FLASH memory combines the functionality of EPROM with on-board electrical Write/Erasure. The PUMA 2F4000 utilises devices which use a Command Register to manage these functions, allowing fixed power supply during Write/Erase and maximum EPROM compatibility. During Write cycles, the command register internally latches address and data needed for the Write and Erase operations, thus simplifying the external control circuitry. When normal TTL/CMOS logic levels are applied to the $V_{pp}$ pin, the module displays normal EPROM Read, Standby and Output Disable. However, when high voltage ( $V_{ppH}$ ) is applied to $V_{pp}$ the Write /Erase options are available as well as the Read. FLASH technology reliably stores data even after 10,000 Write/Erase cycles and utilises a single program supply of 12V±5%. Additionally, the interactive program algorithm allows a typical room temperature program time of less than 4 seconds for the entire module (in 32 bit mode). The typical module erasure time is less than 1 second. ## Absolute Maximum Ratings (1) | Tops | -55 to +125 °C | |------------------|-----------------------------------------------------| | T <sub>stG</sub> | -65 to +150 °C | | | -0.3 to +6.5 V | | V <sub>ID</sub> | -0.3 to 13.5 V | | V <sub>PP</sub> | -0.3 to +14.0 V | | V <sub>cc</sub> | -0.3 to +6.5 V | | | V <sub>IN,OUT</sub> V <sub>ID</sub> V <sub>PP</sub> | Notes: (1) Stresses above those listed may cause permanent damage to the device. These are stress ratings 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. (2) V<sub>IN</sub>, V<sub>OUT</sub>, V<sub>ID</sub> minimum = -2.0V for pulse width of less than 20 ns. # **Recommended Operating Conditions** | | | | min | typ | max | | |-----------------------|------|------------------|----------------------|------|---------------------|--------------------| | Supply Voltage | | V <sub>cc</sub> | 4.5 | 5.0 | 5.5 | V | | Programming Voltage | Read | Vooi | V <sub>cc</sub> -1.0 | - | $V_{\infty}$ | V | | Write/Erase | | V <sub>PPH</sub> | 11.4 | 12.0 | 12.6 | V | | Identifier Voltage | • | V <sub>ID</sub> | 11.4 | 12.0 | 12.6 | V | | Input High Voltage | ΠL | V | 2.2 | - | V <sub>∞</sub> +1.0 | V | | Input Low Voltage | TTL | | -0.3 | - | 0.8 | V | | Operating Temperature | | T | 0 | - | 70 | <b>°C</b> | | | | T, | -40 | - | 85 | °C (-I suffix) | | | | T | -55 | - | 125 | °C (-M,-MB suffix) | ## Capacitance (T<sub>4</sub>=25°C,f=1MHz) | Capacitatice (14-20 0) | | | | | | | | |----------------------------|---------------|--------------------|----------------------|-----|-----|------|--| | Parameter | | Symbol | Test Condition | typ | max | Unit | | | Input Capacitance CS1 | 4 WE1~4 | C | V <sub>m</sub> =0V | - | 16 | рF | | | | Other pins | C <sub>IN2</sub> | V <sub>IN</sub> =0V | • | 34 | pF | | | Output Capacitance | 32 bit | C <sup>OU132</sup> | V <sub>OUT</sub> =0V | - | 22 | pF | | | Alata Than a managed or of | ro coloulated | not measure | ď | | | | | Note: These parameters are calculated, not measured. DC Electrical Characteristics ( $T_A$ =-55°C to +125°C, $V_{cc}$ =5V ± 10%) | | <u> </u> | | | | | | | |------------------------------------|-------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------|--------|------| | Parameter | S | ymbol | Test Condition | min | typ(2) | max | Unit | | I/P Leakage Current A | Address, OE | l <sub>ut</sub> | $V_{IN}$ =0V to $V_{CC}$ , $V_{PP}$ = $V_{PPL}$ or $V_{PPH}$ | - | - | 8 | • | | WE | 1~4, CS1~4 | l <sub>Li2</sub> | As above | - | - | 2 | μΑ | | Output Leakage Currer | nt 32 bit | ILO | $V_{\text{OUT}} = 0V$ to $V_{\text{CC}}$ , $V_{\text{PP}} = V_{\text{PPL}}$ or $V_{\text{PPH}}$ , 8 bit | - | - | 2 | μΑ | | V <sub>pp</sub> Current | | l <sub>pp1</sub> | V <sub>pp</sub> =5.5V | - | - | 2 | mΑ | | (r | | I <sub>PP2</sub> | V <sub>PP</sub> =12.6V | - | - | 4 | mA | | V <sub>∞</sub> Read Current | 32 bit | I <sub>CCR132</sub> | $\overline{\text{CS}}_{\text{H}}^{(1)}$ , $\overline{\text{OE}}_{\text{H}}^{(1)}$ , $\overline{\text{OE}}_{\text{H}}^{(1)}$ , $\overline{\text{OU}}_{\text{H}}^{\text{OUT}}$ =0mA, $f$ =1MHz | - | 24 | 80 | mA | | W | 16 bit | CCR116 | | - | 14 | 46 | mA | | | 8 bit | CCR18 | As above | - | 9 | 29 | mA | | | 32 bit | I <sub>CCR832</sub> | $\overline{\text{CS}}=V_{\text{H}}^{(1)}, \overline{\text{OE}}=V_{\text{H}}, I_{\text{OUT}}=0\text{mA}, f=6.67\text{MHz}$ | - | 100 | 240 | mA | | | 16 bit | CCR816 | | - | 52 | 126 | mA | | | 8 bit | CCR88 | As above | - | 28 | 69 | mA | | V <sub>∞</sub> Write/Erase Curren | nt 32 bit | I <sub>CCE32</sub> | CS=V <sub>IL</sub> (1),V <sub>PP</sub> =V <sub>PPH</sub> ,Write/Erase in progress | ; - | 20 | 80 | mA | | w | 16 bit | I <sub>CCE16</sub> | As above | - | 12 | 46 | mA | | | 8 bit | ICCES | As above | - | 8 | 29 | mA | | V <sub>cc</sub> Auto Erase Current | t 32 bit | I <sub>CCA32</sub> | CS=V <sub>a</sub> (1),V <sub>pp</sub> =V <sub>ppH</sub> , Auto Erase in progress | - | 40 | 200 | mA | | <b>w</b> | 16 bit | CCA16 | As above | - | 22 | 106 | mA | | | 8 bit | ICCAB | As above | - | 13 | 59 | mΑ | | V <sub>oo</sub> Write/Erase Curren | nt 32 bit | l <sub>PPE32</sub> | CS=V <sub>E</sub> (1),V <sub>PP</sub> =V <sub>PPH</sub> , Write/Erase in progres | s - | 40 | 160 | mA | | rr | 16 bit | PPE16 | As above | - | 22 | 86 | mA | | | 8 bit | I <sub>PPE8</sub> | As above | - | 13 | 49 | mA | | V <sub>PP</sub> Auto Erase Current | t 32 bit | PPA32 | · CS=V <sub>a</sub> (1),V <sub>pp</sub> =V <sub>pppt</sub> Auto Erase in progress | 3 - | 140 | 400 | mA | | . РР | 16 bit | I <sub>PPA16</sub> | As above | - | 72 | 206 | mA | | | 8 bit | I <sub>PPA8</sub> | As above | - | 38 | 109 | mA | | Standby Supply Currer | nt TTL | l <sub>SB1</sub> | $V_{cc} = V_{cc} \max_{i} \overline{CS} = V_{H}^{(1)}$ | - | - | 3 | mA | | | CMOS | SB1<br>SB2 | V <sub>cc</sub> =V <sub>cc</sub> max, CS=V <sub>cc</sub> <sup>(1)</sup> | - | - | 500 | μΑ | | Output Low Voltage | | Val | l <sub>ot</sub> =2.1mA. | - | - | _ 0.45 | V | | Output High Voltage | TTL loading | V <sub>OH</sub> | ι <sub>οн</sub> =-400μΑ. | 2.4 | - | | · V | Notes (1) CS above are accessed through CS1-4. These inputs must be operated simultaneously for 32 bit operation, in pairs in 16 bit mode and singly for 8 bit mode. - (2) Typical figures are measured at 25°C and nominal $\rm V_{\rm cc}$ - (3) Maximum active current is the sum of $I_{cc}$ and $I_{pp}$ . - (4) CAUTION: the PUMA 2F4000 must not be removed from or inserted into a socket when V<sub>cc</sub> or V<sub>PP</sub> is applied. | AC Test Conditions | Output Load | |----------------------------------------------------------------------------------------------------------------------------|---------------------------------| | * Input pulse levels: 0.45V to 2.4V. * Input rise and fall times: ≤ 10ns. * Input and Output timing reference levels: 1.5V | VO Pin 645 Ω 1.76 V | | * Output load : see diagram. * Module is tested in 32 bit mode. | 100 pF* Including scope and jig | ## **AC Read Characteristics** | AC Read Characteristics | | | 15 | | 20 | -25 | | | |------------------------------------|---------------------|-----|------------|-----|-----|-----|-----|------| | Parameter | Symbol | min | max | min | max | min | max | Unit | | | | | 450 | | 200 | _ | 250 | ns | | Chip Select Access Time | t <sub>cs</sub> | - | 150<br>150 | - | 200 | _ | 250 | ns | | Address Access Time | TACC | - | 70 | • | 80 | _ | 90 | ns | | Output Enable Access Time | (1) toE | 0 | 70<br>50 | 0 | 60 | 0 | 70 | ns | | Output Disable to Output in High Z | (1) t <sub>DF</sub> | 5 | 30 | 5 | - | 5 | - | ns | | Output Hold Time | ГОН | 5 | | • | | | | | Notes: (1) t<sub>pr</sub> is defined as the time at which the outputs achieve the open circuit conditions and are not referenced to output voltage levels. This parameter is not 100% tested. # Read Cycle Timing Waveform | | ~~ ^^^ | . 7000 V EV L 100/\ | |----------------------------------------|----------------|---------------------------------| | | $I = I \cap I$ | $t0 \pm 70\%$ $V = 5V \pm 10\%$ | | AC Write/Erase/Program Characteristics | 11. = 0 0 | 10 +10 O, 1 ~ - O 1 ~ 10 10) | | | | | | | | - | -15 | - | -20 | -2 | 25 | | |------------------------------------------|------------------|-----|-----|-----|-----|-----|-----|------| | Parameter S | ymbol | min | max | min | max | min | max | Unit | | Command Programming Cycle Time | t <sub>cwc</sub> | 150 | - | 200 | _ | 250 | - | ns | | Address Setup Time | tas | 0 | - | 0 | - | 0 | - | ns | | Address Hold Time | t | 60 | - | 60 | - | 60 | - | ns | | Data Setup Time | t <sub>DS</sub> | 50 | - | 50 | - | 50 | - | ns | | Data Hold Time | t <sub>DH</sub> | 10 | - | 10 | - | 10 | - | ns | | Chip Select Setup Time | t <sub>ces</sub> | 0 | - | 0 | - | 0 | - | ns | | Chip Select Hold Time | t <sub>CEH</sub> | 0 | - | 0 | - | 0 | - | ns | | V <sub>∞</sub> Setup Time | t <sub>vps</sub> | 100 | - | 100 | - | 100 | - | ns | | V <sub>PP</sub> Hold Time | t <sub>vpH</sub> | 100 | - | 100 | - | 100 | - | ns | | Write Programming Pulse Width | twee | 90 | - | 90 | - | 90 | - | ns | | Write Programming Pulse Width High | t <sub>wen</sub> | 20 | - | 20 | - | 20 | - | ns | | Output Enable Setup Before Command | toews | 0 | - | 0 | - | 0 | - | ns | | Output Enable Setup before Verify | toens | 6 | - | 6 | - | 6 | - | μs | | Verify Access Time | t <sub>va</sub> | - | 150 | - | 200 | - | 250 | ns | | Output Enable Setup before Status Pollin | | 20 | - | 20 | - | 20 | | ns | | Status Polling Access Time | t <sub>SPA</sub> | - | 150 | - | 200 | - | 250 | ns | | Standby Time before Programming | t <sub>PPW</sub> | 25 | - | 25 | - | 25 | - | μs | | Standby Time in Erase | t <sub>et</sub> | 9 | 11 | 9 | 11 | 9 | 11 | ms | | Output Disable Time (3) | t <sub>of</sub> | 0 | 50 | 0 | 60 | 0 | 70 | ns | | Automatic Erase Time | t <sub>AET</sub> | 0.5 | 30 | 0.5 | 30 | 0.5 | 30 | s | Notes (1) $\overline{\text{CS1-4}}$ , $\overline{\text{OE}}$ and $\overline{\text{WE1-4}}$ must be fixed High during $V_{pp}$ transition from $V_{ppL}$ to $V_{ppH}$ or from $V_{ppH}$ to $V_{ppL}$ . - (2) Refer to Read Operation when $V_{pp} = V_{ppl}$ . - (3) t<sub>DF</sub> is defined as the time at which the outputs achieve the open circuit conditions and are not referenced to output voltage levels. This parameter is not 100% tested. ## **Programming Timing Waveform** PUMA 2F4000-15/20/25 ## **Erase Timing Waveform** ## **Automatic Erase Timing Waveform** #### **BUS OPERATIONS** Read Two control functions are provided, both of which must be logically active to obtain data at the outputs. Chip Select selects the module and controls the power, while Output Enable gates data from the output pins - see the Read Cycle Timing Waveform for details. *Write* Module Write/Erasure are accessed via the command register while $V_{pp}$ is at $V_{ppH}$ . Note that the register itself does not occupy an addressable memory location, but is simply a latch used to store the command and address/data information required to execute the command. With Chip Select and Write Enable at V<sub>L</sub> the command registers are accessed; addresses are latched on the falling edge of Write Enable and data latched on the rising edge of Write Enable. The three most significant bits of each register (D7- D5) encode the command function while the other bits (D4-D0) must be zero. The exception to this is the Reset command when data $FF_H$ is written to the registers and Identifier mode when $90_H$ is written to the registers. Output Disable When Output Enable is at $V_{\rm H}$ the output pins are placed in a high impedance state and output from the module is disabled. **Standby** If Chip Select is held at $V_{\rm H}$ the power consumption of the PUMA 2F4000 is substantially reduced because most of the on-board circuitry is disabled. The outputs are placed in a high impedance state (independent of Output Enable). If the PUMA 2F4000 module is deselected and placed in Standby mode during Write/Erase and Verify cycles, the module will continue to draw normal active current until the operation is terminated. ## **PUMA 2F4000 Operating Modes** | OI | PERATION | Vpp | AO | A9 | <del>cs</del> | ŌĒ | WE | D0 - D7 | |------------|----------------------------|------------------|-----------------|--------------------------------|-----------------|-----------------|-----------------|--------------| | | Read | $V_{PPL}$ | A0 | A9 | V <sub>IL</sub> | VIL | V <sub>IH</sub> | Data out | | | Output Disable | $V_{PPL}$ | X | Х | VIL | V <sub>IH</sub> | VIH | Tri-State | | READ ONLY | Standby | $V_{PPL}$ | X | Х | V <sub>IH</sub> | Х | X | Tri-State | | | Manufacturer Identifier(1) | | V <sub>IL</sub> | V <sub>ID</sub> <sup>(2)</sup> | V <sub>IL</sub> | $V_{IL}$ | V <sub>IH</sub> | Data = 07н | | | Device Identifier(1) | V <sub>PPL</sub> | V <sub>IH</sub> | V <sub>ID</sub> <sup>(2)</sup> | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data = 19н | | | Read <sup>(3)</sup> | $V_{PPH}$ | A0 | A9 | V <sub>IL</sub> | V <sub>IL</sub> | V <sub>IH</sub> | Data Out (5) | | READ/WRITE | Output Disable | V <sub>PPH</sub> | Х | Х | V <sub>IL</sub> | VIH | V <sub>IH</sub> | Tri-State | | | Standby | V <sub>PPH</sub> | Х | Х | V <sub>IH</sub> | Х | Х | Tri-State | | | Write | V <sub>PPH</sub> | A0 | A9 | V <sub>IL</sub> | V <sub>IH</sub> | V <sub>IL</sub> | Datā In (4) | Notes (1) Device Identifier codes can be output in command programming mode. Refer to the Command Definition Table. - (2) $11.4V \le V_{10} \le 12.6V$ - (3) Read operations with V<sub>PP</sub>=V<sub>PPH</sub> may access array data or identifier codes. - (4) Refer to Command Definition table for valid Data In during a Write operation. Data is Programmed, Erased or Verified after mode setting by command inputs. - (5) Status of AutoErase can be verified in this mode. Status output appears on D7, with D0-D6 in the high impedance state. - (6) X can be V<sub>u</sub> or V<sub>ur</sub> - (7) If Vpp is lowered from 12V to 5V in Erase or Program operation, the erasure or programmimg will stop. - (8) $V_{cc}$ must be applied before $V_{pp}$ and removed after $V_{pp}$ is removed. PUMA 2F4000-15/20/25 ## **COMMAND DEFINITIONS** With the V<sub>pp</sub> pin at a low voltage the Command Register contents default to 00<sub>H</sub>, enabling Read-only operations. A high voltage on V<sub>PP</sub> enables Read/Write modes with device operation selected by writing data into the Register - see the Command Definition table for details. Read While Vpp is high the memory contents can be Read by first writing 00, into the Command Register and thereafter obeying the timings shown on the Read Cycle Waveform. This mode remains enabled until the Command Register contents are altered. On power up the Register contents will be 00<sub>H</sub>, ensuring that the memory contents are not changed during the V<sub>cc</sub> power transition. When reading the PUMA 2F4000, $V_{pp}$ must be set within $V_{ss}$ to $V_{cc}$ (except during a Command Read). In order to use the correct Intelligent Identifier programming and erase algorithms on PROM devices, these parts usually have built in codes to identify manufacturer and specific device. However, to access these codes address line A9 normally has to be placed at a high voltage, which is not considered good practice and leads to complications in PCB design. The PUMA 2F4000 allows the identifiers to be accessed through the Command Register without placing a high voltage on A9. Writing $90_{_{ m H}}$ into the Registers starts this process with a subsequent Read from 00000, retrieving the manufacturer codes of 07, and a Read from 00001, giving the device codes 19, To terminate this sequence another valid command must be written to the Register. ## **PUMA 2F4000 Command Definitions** | | Bus | First E | Bus Cycle | e | Second Bus Cycle | | | | |-------------------------------------------|--------------------------------------------------|---------------|-----------|-----------------|------------------|----------|-----------------|--| | COMMAND | Cycles<br>Req'd | Operation (1) | Addr (2) | Data (3) | Operation (1) | Addr (2) | Data (3) | | | Read Memory <sup>(4)</sup> | 1 | Write | Х | 00 <sub>H</sub> | Read | RA | RD | | | Read Identifier Codes | 2 | Write | Х | 90 <sub>H</sub> | Read | IA | ID | | | Set-up Erase/Erase <sup>(5)</sup> | 2 | Write | X | 20 <sub>H</sub> | Write | X | 20 <sub>H</sub> | | | Erase Verify (5) | 2 | Write | EA | A0 <sub>H</sub> | Read | X | EVD | | | Set-up AutoErase/AutoErase <sup>(6)</sup> | <del> </del> | Write | X | 30 <sub>H</sub> | Write | Х | 30 <sub>H</sub> | | | Set-up Program/Program <sup>(7)</sup> | 2 | Write | X | 40 <sub>H</sub> | Write | PA | PD | | | Program Verify (7) | 2 | Write | X | C0 <sub>H</sub> | Read | Х | PVD | | | Reset | 2 | Write | X | FГH | Write | Х | FFH | | ## Notes (1) See Operating Modes Table. - Identifier address. 00000<sub>H</sub> for Manufacturers code and 00001<sub>H</sub> for device code. - EA = Address of memory location to be read during Erase Verify. - PA Address of memory location to be programmed. - RA Address of memory location to be Read. Addresses are latched on the falling edge of Write Enable pulse. - (3) ID = Data read from location IA during device identification. (Manufacturer = 07<sub>H</sub>, Device = 19<sub>H</sub>) - 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. - RD = Data to be read from location RA during Read operation. - PVD = Data to be read from location PA during Program Verify. PA is latched on the Program command. - (4) Command latch default value when applying 12.0V to V<sub>PP</sub> is 00<sub>H</sub>. Device is in Read mode after VP<sub>P</sub> is set to 12.0V. - (5) All data in the chip is erased. Erasure occurs according to the fast High Reliablility Erase Flowchart - (6) All data in the chip is erased. The data is erased automatically by the internal logic circuitry, with external verification of the erase not required. Termination of erasure is verified by Status Polling after AutoErase begins. - (7) Data is programmed according to the Fast High Reliability Programming Flowchart. The completetion of programming after the program pulse must be verified by Status Polling once programming has begun. **Set-up Program/Program** Set-up program is a command only operation which prepares the memories for byte programming, initiated by writing 40<sub>H</sub> into the command register. Once Set-up program has been performed, the next Write Enable pulse causes data to be latched on the rising edge and the address is latched on the falling edge of this pulse. Internal programming begins on the rising edge and is terminated with the next rising edge of Write Enable used to write the program-verify command. **Program-Verify** This module is programmed byte by byte, which can occur sequentially or at random, but the byte just written must be verified. Writing CO<sub>H</sub> to the command registers begins this operation, which also terminates the programming operation. The last byte written will be verified; no new address information is required as the previous address is latched. A Read Cycle can now be performed in order to compare the data just written with the byte contents. This process is shown by the Programming Algorithm. Set-up Erase/Erase Set-up erase is a command only operation which prepares the memory for electrical erasure of all contents, initiated by writing 20<sub>H</sub> to the Command Registers. In order to start erasure $20_{\rm H}$ must again be written to the registers; this two-step sequence ensures that accidental erasure will not occur. Additionally, if the $V_{\rm pp}$ pin is not at a high voltage the memory contents are protected against erasure. Erase-Verify The Erase command erases all the contents of the memory, but after this operation all bytes must be verified. This is accomplished by writing $A0_H$ to the Command Registers, with the address of the byte to be verified supplied as it is latched on the falling edge of the Write-Enable pulse. Reading $FF_H$ from the addressed bytes indicates that they are erased. This command must be issued prior to each byte verification to latch its address. If the data read is not $FF_H$ another erase operation must be performed. Verification can then continue from the address of the last verified byte, and once all bytes have been verified the erase procedure is complete. This process is shown by the Erase algorithm. The verify operation is halted by writing another valid command e.g. Set-up Program, into the command register. Automatic Erase The Erase and Erase Verify processes can be performed automatically by writing $30_{\rm H}$ into the Command register, followed by a second write of $30_{\rm H}$ to initiate the AutoErase. Once initiated all of the locations in the PUMA 2F4000 will be set to FF<sub>H</sub> automatically, without the need to verify each byte. Typically the whole device will be erased in 1 second, with the end of erasure being indicated by Status Polling. Status Polling Status Polling allows the status of the FLASH memory to be determined. If the PUMA 2F4000 is set to the Status Polling mode during the Erase Cycle, D7 is lowered to $V_{\rm OL}$ to indicate that the PUMA 2F4000 is performing an Erase operation. When the Erase has terminated, D7 is set to $V_{\rm OH}$ . During Status Polling only D7 outputs data. D0 to D6 are in high impedance state (High Z). The Status Polling feature is only active during the automatic erase algorithm. Reset This command, which consists of two consecutive writes of $FF_H$ , will safely abort either Erase or Program operations after the Set-up commands. Memory contents will not be altered, and a valid command must then be written to place the device in the desired state. ### **ALGORITHM NOTES** These algorithms **MUST BE FOLLOWED** to ensure correct and reliable device operation. Fast Pulse Programming Algorithm This programming algorithm uses pulses of 25 $\mu$ s duration in order to improve programming time. Each operation is followed by byte verification in order to check when the specified byte has been successfully programmed. The algorithm allows up to 20 such pulses per byte, even though most bytes will verify on the first or second pulse. Both the Write and Verify sequences take place with $V_{pp} = V_{pph}$ . See the Programming Algorithm for a full description. Fast Erase Algorithm The Fast Erase algorithm uses a closed loop flow similar to that of the Programming Algorithm to reliably and quickly erase\_all memory contents. Uniform and reliable erasure is guaranteed by first writing $00_{\rm H}$ to all memory locations. This can be accomplished using the Fast Pulse Programming algorithm. Erase execution then proceeds with an initial Erase operation, after which Erase Verification (data = $FF_{\rm H}$ ) begins at address $00_{\rm H}$ . This continues through the devices until the last address is reached or any data other than $FF_{\rm H}$ is found. With each subsequent Erase operation a greater number of bytes will verify to the erased state. The erase time may be minimised by storing the address of the last byte verified; after the next Erase operation verification can begin at this address, circumventing the need to re-verify previously erased locations. Erasure occurs typically in 1 second. **Timing Delays** Four timing delays are associated with the Program and Erase algorithms described: - (1) When V<sub>pp</sub> first turns on the capacitors on the V<sub>pp</sub> line cause an RC ramp, the rise time of which is proportional to the number of devices being erased and the capacitance per device. V<sub>pp</sub> must reach its final value 100ns before any commands are executed. - (2) The second timing delay is the erase time pulse width of 10ms, which should be timed by a microprocessor routine. This operation is terminated by writing the Erase/Verify Command; if this command is not issued the memory cell will be driven into depletion (no internal times). - (3) Each programming operation lasts 25µs, and since the algorithm is interactive each byte is verified after a Write pulse; the program operation must be terminated at the conclusion of the timing routine. - (4) In order to improve memory cell operation, an internally generated margin voltage is applied to the addressed cell during Write/Erase Verify. It is during this 6µs delay that the internal circuitry is changing voltage levels between the Erase/Write level and those used for Verify and Read operations. Any attempt to Read the device(s) during this period will result in possible false data appearing on the outputs. # DESIGN CONSIDERATIONS Two Line Control Two Read signals are provided for output control to accommodate large memory arrays, giving the lowest possible memory power dissipation and ensuring bus contention does not occur. Supply Decoupling Flash memory power-switching characteristics require careful decoupling. Three supply current issues have to be considered - Standby, Active and transient current peaks caused by rising and falling edges of Chip Select. Two line control and correct decoupling capacitor selection will help to suppress these transient voltage peaks. Each PUMA 2F4000 device should have a 0.1 $\mu$ F ceramic capacitor between V $_{\infty}$ and GND and between V $_{pp}$ and GND. These high frequency, low inductance capacitors should be placed as close as possible to the PUMA 2F4000. Additionally, it is recommended that a 4.7 $\mu$ F electrolytic capacitor should be placed between V<sub>cc</sub> and GND every eight PUMA 2F4000 devices. This capacitor will smooth out voltage dips in the supply caused by PCB track inductance and will supply charge to the on-board capacitors as needed. $V_{pp}$ Trace Because Flash memories are designed to be programmed in situ, the PCB designer must be made aware of the $V_{pp}$ supply trace. This should be made similar to the $V_{cc}$ bus as the $V_{pp}$ pin supplies the memory cell current for Programming and Erase. **Power Up/Down** When lowering $V_{pp}$ to $V_{cc}$ or less, $V_{cc}$ must be set to 5V. $V_{cc}$ must be applied before $V_{pp}$ and removed after $V_{pp}$ is removed. #### PROGRAMMING ALGORITHM These algorithms MUST BE FOLLOWED to ensure proper and reliable operation, and are shown for a single device only. ## ERASE ALGORITHM #### **Notes** (1) See DC Characteristics for the value of $V_{pph}$ . The $V_{pp}$ supply can be hard wired to the device or switchable. When $V_{pp}$ is switched, $V_{ppt}$ may be GND, NC with a resistor tied to GND or less than $V_{cc}$ +2.0V 11 ## **Ordering Information** #### PUMA 2F4000MB-15 = 150 nsSpeed 20 = 200 ns= 250 ns25 Blank = Commercial Temperature Temp. range/screening = Industrial Temperature = Military Temperature M = Processed to MIL-STD 883 MB Method 5004, non-compliant. 4000 = 4Mbit array, configurable as Organization 128K x 32, 256K x 16 or 512K x 8 bit F = FLASH MEMORY Technology The policy of the company is one of continuous development and while the information presented in this data sheet is believed to be accurate, no liability is assumed for any data contained within. The company reserves the right to make changes without notice at any time. © 1988 This design is the property of Mosaic Semiconductor, Inc. 17 7420 Carroll Road San Diego, CA 92121 Tel: (619) 271 4565 FAX: (619) 271 6058