# **Document Title** # 1M x 8 bit NAND Flash Memory # **Revision History** | Revision No. | <u>History</u> | | | | | | | <u>Draft Date</u> | <u>Remark</u> | |--------------|------------------------|-------------------------------------------|--------------------|-----------------------|-----------|----------|------|-------------------|---------------| | 0.0 | Data Shee | 1997 | | | | | | April 10th 1997 | Advance | | 1.0 | | t 1998<br>d tbers parame<br>d tprog param | 10ms | $s(Max.) \rightarrow$ | 4ms(Max.) | • | | April 10th 1998 | Preliminary | | 1.1 | Data sheet 1. Cjanged | 1998<br>DC and Oper | ating Chai | racteristics | | | | July 14th 1998 | Final | | | D | | Vcc=2.7 | 7V~3.6V | Vcc=3.6 | 6V~5.5V | 1114 | | | | | Par | ameter | Тур | Max | Тур | Max | Unit | | | | | | Burst Read | $10 \rightarrow 5$ | 20 → 10 | 15 → 10 | 30 → 20 | | | | | | Operating<br>Current | Program | 10 → 5 | 20 → 10 | 15 → 10 | 30 → 20 | mA | | | | | | Eraase | 10 → 5 | 20 → 10 | 15 → 10 | 30 → 20 | | | | | | Stand-by C | urrent (CMOS) | 5 → 10 | 50 | 10 | 100 → 50 | | | | | | Input Leaka | ge Current | - | 10 → ±10 | - | 10 → ±10 | μΑ | | | | | Output Leal | age Current | - | 10 → ±10 | - | 10 → ±10 | | | | | 1.2 | Data Sheet 1999 1) Added $\overline{\text{CE}}$ dont care mode during the data-loading and reading | April 10th 1999 | Final | |-----|-----------------------------------------------------------------------------------------------------|-----------------|-------| | 1.3 | 1) Revised real-time map-out algorithm(refer to technical notes) | July 23th 1999 | Final | | 1.4 | Changed device name - KM29W8000T -> K9F8008W0M-TCB0 - KM29W8000IT -> K9F8008W0M-TIB0 | Sep. 15th 1999 | Final | The attached datasheets are prepared and approved by SAMSUNG Electronics. SAMSUNG Electronics CO., LTD. reserve the right to change the specifications. SAMSUNG Electronics will evaluate and reply to your requests and questions about device. If you have any questions, please contact the SAMSUNG branch office near you. # 1M x 8 Bit NAND Flash Memory #### **FEATURES** • Voltage supply: 2.7V ~ 5.5V Organization Memory Cell Array: (1M + 32K)bit x 8bit Data Register : (256 + 8)bit x8bit Automatic Program and Erase(Typical) Page Program: (256 + 8)Byte in 250µs Block Erase : (4K + 128)Byte in 2ms - Status Register 264-Byte Page Read Operation Random Access : 10µs(Max.) Serial Page Access : 80ns(Min.) System Performance Enhancement System Performance Ennancement - Ready/ Busy Status Output • Command/Address/Data Multiplexed I/O port • Hardware Data Protection - Program/Erase Lockout During Power Transitions • Reliable CMOS Floating-Gate Technology - Endurance : 1M Program/Erase Cycles Data Retention : 10 yearsCommand Register Operation • 44(40) - Lead TSOP Type II (400mil / 0.8 mm pitch) ### **GENERAL DESCRIPTION** The K9F8008W0M is a 1M(1,048,576)x8bit NAND Flash Memory with a spare 32K(32,768)x8bit. Its NAND cell provides the most cost-effective solution for the solid state mass storage market. A program operation programs the 264-byte page in typically $250\mu s$ and an erase operation can be performed in typically 2ms on a 4K-byte block. Data in the page can be read out at 80ns cycle time per byte. The I/O pins serve as the ports for address and data input/output as well as command inputs. The on-chip write controller automates all program and erase system functions, including pulse repetition, where required, and internal verify and margining of data. Even the write-intensive systems can take advantage of the K9F8008W0M extended reliability of 1,000,000 program/erase cycles by providing either ECC(Error Correction Code) or real time mapping-out algorithm. These algorithms have been implemented in many mass storage applications and also the spare 8bytes of a page combined with the other 256 bytes can be utilized by system-level ECC. The K9F8008W0M is an optimum solution for large nonvolatile storage application such as solid state storage, digital voice recorder, digital still camera and other portable applications requiring nonvolatility. ### **PIN CONFIGURATION** ### **PIN DESCRIPTION** | Pin Name | Pin Function | |------------------------------------|----------------------| | I/O <sub>0</sub> ~I/O <sub>7</sub> | Data Inputs/Outputs | | CLE | Command Latch Enable | | ALE | Address Latch Enable | | CE | Chip Enable | | RE | Read Enable | | WE | Write Enable | | WP | Write Protect | | GND | Ground Input | | R/B | Ready/Busy output | | Vcc | Power(2.7V ~ 5.5V) | | Vss | Ground | | N.C | No Connection | NOTE: Connect all Vcc and Vss pins of each device to power supply outputs. Do NOT leave Vcc or Vss disconnected Figure 1. FUNCTIONAL BLOCK DIAGRAM Figure 2. ARRAY ORGANIZATION | | I/Oo | <b>I/O</b> 1 | I/O <sub>2</sub> | I/O <sub>3</sub> | I/O <sub>4</sub> | I/O <sub>5</sub> | I/O <sub>6</sub> | <b>I/O</b> 7 | | |-----------|------|--------------|------------------|------------------|------------------|------------------|------------------|--------------|-------------------------------| | 1st Cycle | Ao | A1 | A <sub>2</sub> | Аз | A4 | <b>A</b> 5 | A <sub>6</sub> | A7 | Column Address | | 2nd Cycle | A8 | <b>A</b> 9 | A10 | A11 | A12 | A13 | A14 | A15 | Row Address<br>(Page Address) | | 3rd Cycle | A16 | A17 | A18 | <b>A</b> 19 | *X | *X | *X | *X | (i age Address) | $\textbf{NOTE}: \ A_{12} \ to \ A_{19}: Block \ Address$ $^{\star}:X\;\;can\;be\;V_{IL}\;or\;V_{IH}.$ #### PRODUCT INTRODUCTION The K9F8008W0M is an 8.6Mbit(8,650,752 bit) memory organized as 4096 rows by 264 columns. Spare eight columns are located from column address of 256 to 263. A 264-byte data register is connected to memory cell arrays accommodating data transfer between the I/O buffers and memory during page read and page program operations. The memory array is made up of 16 cells that are serially connected to form a NAND structure. Each of the 16 cells resides in a different page. A block consists of the 16 pages formed by one NAND structures, totaling 2,112 NAND structures of 16 cells. The array organization is shown in Figure 2. The program and read operations are executed on a page basis, while the erase operation is executed on block basis. The memory array consists of 256 separately or grouped erasable 4K-byte blocks. It indicates that the bit by bit erase operation is prohibited on the K9F8008W0M. The K9F8008W0M has addresses multiplexed into 8 I/O's. This scheme dramatically reduces pin counts and allows systems upgrades to future densities by maintaining consistency in system board design. Command, address and data are all written through I/O's by bringing WE to low while CE is low. Data is latched on the rising edge of WE. Command Latch Enable(CLE) and Address Latch Enable(ALE) are used to multiplex command and address respectively, via the I/O pins. All commands require one bus cycle except for Block Erase command which requires two cycles: a cycle for erase-setup and another for erase-execution after block address loading. The 2M byte physical space requires 21 addresses, thereby requiring three cycles for byte-level addressing: column address, low row address and high row address, in that order. Page Read and Page Program need the same three address cycles following the required command input. In Block Erase operation, however, only the two row address cycles are used. Device operations are selected by writing specific commands into the command register. Table 1 defines the specific commands of the K9F8008W0M. **Table 1. COMMAND SETS** | Function | 1st. Cycle | 2nd. Cycle | Acceptable Command during Busy | |-----------------------|------------|------------|--------------------------------| | Sequential Data Input | 80h | - | | | Read 1 | 00h | - | | | Read 2 | 50h | - | | | Read ID | 90h | - | | | Reset | FFh | - | 0 | | Page Program | 10h | - | | | Block Erase | 60h | D0h | | | Read Status | 70h | - | 0 | #### PIN DESCRIPTION #### Command Latch Enable(CLE) The CLE input controls the path activation for commands sent to the command register. When active high, commands are latched into the command register through the I/O ports on the rising edge of the $\overline{\text{WE}}$ signal. #### Address Latch Enable(ALE) The ALE input controls the path activation for address and input data to the internal address/data register. Addresses are latched on the rising edge of $\overline{\text{WE}}$ with ALE high, and input data is latched when ALE is low. ### Chip Enable(CE) The $\overline{\text{CE}}$ input is the device selection control. When $\overline{\text{CE}}$ goes high during a read operation the device is returned to standby mode. However, when the devices is in the busy state during program or erase, $\overline{\text{CE}}$ high is ignored, and does not return the device to standby mode. ### Write Enable(WE) The WE input controls writes to the I/O port. Commands, address and data are latched on the rising edge of the WE pulse. # Read Enable(RE) The RE input is the serial data-out control, and when active drives the data onto the I/O bus. Data is valid trea after the falling edge of RE which also increments the internal column address counter by one. #### I/O Port: I/O<sub>0</sub> ~ I/O<sub>7</sub> The I/O pins are used to input command, address and data, and to output data during read operations. The I/O pins float to high-z when the chip is deselected or when the outputs are disabled. #### Write Protect(WP) The $\overline{\text{WP}}$ pin provides inadvertent write/erase protection during power transitions. The internal high voltage generator is reset when the $\overline{\text{WP}}$ pin is active low. ### Ready/Busy(R/B) The R/B output indicates the status of the device operation. When low, it indicates that a program, erase or random read operation is in process and returns to high state upon completion. It is an open drain output and does not float to high-z condition when the chip is deselected or when outputs are disabled. # **ABSOLUTE MAXIMUM RATINGS** | Parameter | | Symbol | Rating | Unit | |------------------------------------|-----------------|--------|--------------|------| | Voltage on any pin relative to Vss | | Vin | -0.6 to +7.0 | V | | Tomporatura Under Pice | K9F8008W0M-TCB0 | TBIAS | -10 to +125 | °C | | Temperature Under Bias | K9F8008W0M-TIB0 | I BIAS | -40 to +125 | C | | Storage Temperature | | Тѕтс | -65 to +150 | °C | | Short Circuit Output Current | | los | 5 | mA | #### NOTE: ### RECOMMENDED OPERATING CONDITIONS (Voltage reference to GND, K9F8008W0M-TCB0:Ta=0 to $70^{\circ}$ C, K9F8008W0M-TIB0:Ta=-40 to $85^{\circ}$ C) | Parameter | Symbol | Min | Тур. | Max | Unit | |----------------|--------|-----|------|-----|------| | Supply Voltage | Vcc | 2.7 | - | 5.5 | V | | Supply Voltage | Vss | 0 | 0 | 0 | V | # DC AND OPERATING CHARACTERISTICS (Recommended operating conditions otherwise noted.) | Doromotor | | Comple ed | Took Conditions | Vcc = 2.7V ~ 3.6V | | | Vcc | = 3.6V | ~ 5.5V | Unit | |--------------------------------|----------------------------------------|-----------|-------------------------------|-------------------|-----|---------|------|--------|---------|------| | | Parameter | | | Тур | Max | Min | Тур | Max | Unit | | | | Burst Read Cycle | ICC1 | tcycle=80ns, CE=VIL, IOUT=0mA | - | 5 | 10 | - | 10 | 20 | | | Operat-<br>ing | Program | ICC2 | - | - | 5 | 10 | - | 10 | 10 | 4 | | Current | Erase | Іссз | - | - | 5 | 10 | - | 10 | 20 | mA | | Stand-by | Current(TTL) | ISB1 | CE=VIH, WP=0V/Vcc | - | - | 1 | - | - | 1 | | | Stand-by | Current(CMOS) | ISB2 | CE=Vcc-0.2, WP=0V/Vcc | - | 10 | 50 | - | 10 | 50 | | | Input Lea | akage Current | ILI | VIN=0 to 5.5V | - | - | ±10 | • | ı | ±10 | μΑ | | Output Lo | eakage Current | ILO | Vout=0 to 5.5V | - | - | ±10 | • | ı | ±10 | | | Input Hig | h Voltage, All inputs | VIH | - | 2.4 | - | Vcc+0.3 | 2.4 | - | Vcc+0.5 | | | Input Lov | v Voltage, All inputs | VIL | - | -0.3 | - | 0.6 | -0.3 | - | 0.8 | | | Output High Voltage Level Vol- | | Vон | Іон=-400μА | 2.4 | - | - | 2.4 | ı | - | V | | Output Lo | Output Low Voltage Level VoL IoL=2.1mA | | - | - | 0.4 | - | - | 0.4 | | | | Output Lo | ow Current(R/B) | IoL(R/B) | VoL=0.4V | 8 | 10 | - | 8 | 10 | - | mA | Minimum DC voltage is -0.3V on input/output pins. During transitions, this level may undershoot to -2.0V for periods <30ns. <p>Maximum DC voltage on input/output pins is Vcc+0.3V which, during transitions, may overshoot to Vcc+2.0V for periods <20ns.</p> <sup>2.</sup> Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to the conditions as detailed in the operational sections of this data sheet. Exposure to absolute maximum rating conditions for extended periods may affect reliability. # K9F8008W0M-TCB0, K9F8008W0M-TIB0 # **FLASH MEMORY** ### **VALID BLOCK** | Parameter | Symbol | Min | Тур. | Max | Unit | |--------------------|--------|-----|------|-----|--------| | Valid Block Number | Nvb | 251 | - | 256 | Blocks | - 1. The KK9F8008W0M may include invalid blocks. Invalid blocks are defined as blocks that contain one or more bad bits. Do not try to access these invalid blocks for program and erase. During its lifetime of 10 years and/or 1million program/erase cycles,the minimum number of valid blocks are guaranteed though its initial number could be reduced. (Refer to the attached technical notes) 2. The 1st block, which is placed on 00h block address, is guaranteed to be a valid block #### **AC TEST CONDITION** (K9F8008W0M-TCB0:TA=0 to 70°C, K9F8008W0M-TIB0:TA=-40 to 85°C, Vcc=2.7V ~ 5.5V unless otherwise noted) | Parameter | Value | | | | | |--------------------------------|----------------------------------|-------------------------|--|--|--| | Parameter | Vcc = 2.7V ~ 3.6V | Vcc = 3.6V ~ 5.5V | | | | | Input Pulse Levels | 0.4V to 2.6V | 0.4V to 2.6V | | | | | Input Rise and Fall Times | 5ns | | | | | | Input and Output Timing Levels | 0.8V a | nd 2.0V | | | | | Output Lood | 1TTL GATE & CL=50pF(3.0V+/-10%) | 4 TTL CATE and CL 400nE | | | | | Output Load | 1 TTL GATE & CL=100pF(3.0V~3.6V) | | | | | ### CAPACITANCE(TA=25°C, VCC=5.0V, f=1.0MHz) | Item | Symbol | Test Condition | Min | Max | Unit | |--------------------------|--------|----------------|-----|-----|------| | Input/Output Capacitance | CI/O | VIL=0V | - | 10 | pF | | Input Capacitance | Cin | VIN=0V | - | 10 | pF | NOTE: Capacitance is periodically sampled and not 100% tested. #### **MODE SELECTION** | CLE | ALE | CE | WE | RE | WP | N | lode | | |-----|------------------|----|----------|----|-----------------------|----------------------|-----------------------|--| | Н | L | L | | Н | Х | Read Mode | Command Input | | | L | Н | L | <b>□</b> | Н | Х | Read Mode | Address Input(3clock) | | | Н | L | L | F | Н | Н | Write Mode | Command Input | | | L | Н | L | 7₹ | Н | Н | - write wide | Address Input(3clock) | | | L | L | L | | Н | Н | Data Input | | | | L | L | L | Н | 7 | Х | Sequential Read & Da | ta Output | | | L | L | L | Н | Н | Х | During Read(Busy) | | | | Х | Х | Х | Х | Х | Н | During Program(Busy) | | | | Х | Х | Х | Х | Х | Н | During Erase(Busy) | | | | Х | X <sup>(1)</sup> | Х | Х | Х | L | Write Protect | | | | Х | Х | Н | Х | Х | 0V/Vcc <sup>(2)</sup> | Stand-by | | | $\textbf{NOTE}: \textbf{1.} \ \underline{\textbf{X}} \ \underline{\textbf{can}} \ \textbf{be} \ \textbf{V}\text{\tiny{IL}} \ \textbf{or} \ \textbf{V}\text{\tiny{IH}}$ ### **Program/Erase Characteristics** | Parameter | Symbol | Min | Тур | Max | Unit | |---------------------------------------------------|--------|-----|------|-----|--------| | Program Time | tprog | - | 0.25 | 1.0 | ms | | Number of Partial Program Cycles in the Same Page | Nop | - | - | 10 | cycles | | Block Erase Time | tBERS | - | 2 | 4 | ms | <sup>2.</sup> WP should be biased to CMOS high or CMOS low for standby. # AC Timing Characteristics for Command / Address / Data Input | Parameter | Symbol | Min | Max | Unit | |-------------------|--------|-----|-----|------| | CLE Set-up Time | tcls | 20 | - | ns | | CLE Hold Time | tclH | 40 | - | ns | | CE Setup Time | tcs | 20 | - | ns | | CE Hold Time | tch | 40 | - | ns | | WE Pulse Width | twp | 40 | - | ns | | ALE Setup Time | tals | 20 | - | ns | | ALE Hold Time | talh | 40 | - | ns | | Data Setup Time | tos | 30 | - | ns | | Data Hold Time | tDH | 20 | - | ns | | Write Cycle Time | twc | 80 | - | ns | | WE High Hold Time | twH | 20 | - | ns | # **AC Characteristics for Operation** | Parameter | Symbol | Min | Max | Unit | |---------------------------------------------------------|--------|-----|----------------|------| | Data Transfer from Cell to Register | tr | - | 10 | μs | | ALE to RE Delay | tar | 150 | - | ns | | ALE to RE Delay( ID Read ) | tAR1 | 200 | - | ns | | CE to RE Delay( ID Read ) | tcr | 200 | - | ns | | Ready to RE Low | trr | 20 | - | ns | | WE High to Busy | twB | - | 200 | ns | | Read Cycle Time | trc | 80 | - | ns | | RE Access Time | trea | - | 45 | ns | | RE High to Output Hi-Z | trhz | 5 | 20 | ns | | CE High to Output Hi-Z | tcHZ | - | 30 | ns | | RE High Hold Time | treh | 20 | - | ns | | Output Hi-Z to RE Low | tır | 0 | - | ns | | Last RE High to Busy(at sequential read) | trB | - | 200 | ns | | CE High to Ready(in case of interception by at read)(1) | tcry | - | 100+tr(R/B)(2) | ns | | CE High Hold Time(at the last serial read)(3) | tceh | 250 | - | ns | | RE Low to Status Output | trsto | - | 45 | ns | | CE Low to Status Output | tcsто | - | 55 | ns | | WE High to RE Low | twhr | 50 | - | ns | | Device Resetting Time(Read/Program/Erase) | trst | - | 5/10/500 | μs | NOTE: 1. If $\overline{CE}$ goes high within 30ns after the rising edge of the last $\overline{RE}$ , $R/\overline{B}$ will not return to Vol. 2. The time to Ready depends on the <u>value</u> of the pull-up resistor tied $R/\overline{B}$ pin. 3. To break the sequential read cycle, $\overline{CE}$ must be held high for longer time than tCEH. #### NAND Flash Technical Notes #### Invalid Block(s) Invalid blocks are defined as blocks that contain one or more invalid bits whose reliability is not guaranteed by Samsung. Typically, an invalid block will contain a single bad bit. The information regarding the invalid block(s) is called as the invalid block information. The invalid block information is written to the 1st or the 2nd page of the invalid block(s) with 00h data. Devices with invalid block(s) have the same quality level or as devices with all valid blocks and have the same AC and DC characteristics. An invalid block(s) does not affect the performance of valid block(s) because it is isolated from the bit line and the common source line by a select transistor. The system design must be able to mask out the invalid block(s) via address mapping. The 1st block of the NAND Flash, however, is fully guaranteed to be a valid block. #### Identifying Invalid Block(s) All device locations are erased(FFh) except locations where the invalid block information is written prior to shipping. Since the invalid block information is also erasable in most cases, it is impossible to recover the information once it has been erased. Therefore, the system must be able to recognize the invalid block(s) based on the original invalid block information and create the invalid block table via the following suggested flow chart(Figure 1). Any intentional erasure of the original invalid block information is prohibited. Figure 1. Flow chart to create invalid block table. # NAND Flash Technical Notes (Continued) #### Error in write or read operation Over its life time, the additional invalid blocks may occur. Through the tight process control and intensive testing, Samsung minimizes the additional block failure rate, which is projected below 0.1% up until 1 million program/erase cycles. Refer to the qualification report for the actual data. The following possible failure modes should be considered to implement a highly reliable system. In the case of status read failure after erase or program, block replacement should be done. To improve the efficiency of memory space, it is recommended that the read or verification failure due to single bit error be reclaimed by ECC without any block replacement. The said additional block failure rate does not include those reclaimed blocks. | Failure Mode | | Detection and Countermeasure sequence | | |--------------|--------------------|---------------------------------------------------------------------------------------------------------------------|--| | | Erase Failure | Status Read after Erase> Block Replacement | | | Write | Program Failure | Status Read after Program> Block Replacement Read back ( Verify after Program)> Block Replacement or ECC Correction | | | Read | Single Bit Failure | Verify ECC -> ECC Correction | | **ECC** : Error Correcting Code --> Hamming Code etc. Example) 1bit correction & 2bit detection ## **Program Flow Chart** (\*) : If program operation results in an error, map out the block including the page in error and copy the target data to another block. # NAND Flash Technical Notes (Continued) ### **Erase Flow Chart** # **Read Flow Chart** (\*): If erase operation results in an error, map out the failing block and replace it with another block. # **Block Replacement** When the error happens in Block "A", try to write the data into another Block "B" by reloading from an external buffer. Then, prevent further system access to Block "A"(by creating a "invalid block" table or other appropriate scheme.) ### System Interface Using CE dont-care. For a easier system interface, $\overline{\text{CE}}$ may be inactive during the data-loading or sequential data-reading as shown below. The internal 256byte page registers are utilized as seperate buffers for this operation and the system design gets more flexible. In addition, for voice or audio applications which use slow cycle time on the order of u-seconds, de-activating $\overline{\text{CE}}$ during the data-loading and reading would provide significant savings in power consumption. Figure 3. Program Operation with $\overline{\text{CE}}$ dont-care. Timing requirements : If $\overline{\text{CE}}$ is is exerted high during sequential data-reading, the falling edge of $\overline{\text{CE}}$ to valid data(tCEA) must be kept greater than 55ns. # \* Command Latch Cycle # \* Address Latch Cycle # \* Input Data Latch Cycle # \* Sequential Out Cycle after Read(CLE=L, $\overline{\text{WE}}$ =H, ALE=L) NOTES: Transition is measured $\pm 200$ mV from steady state voltage with load. This parameter is sampled and not 100% tested. # \* Status Read Cycle # **READ1 OPERATION**(READ ONE PAGE) # READ1 OPERATION(INTERCEPTED BY CE) # **READ2 OPERATION**(READ ONE PAGE) # **SEQUENTIAL ROW READ OPERATION** # **PAGE PROGRAM OPERATION** # **BLOCK ERASE OPERATION**(ERASE ONE BLOCK) #### **DEVICE OPERATION** #### **PAGE READ** Upon initial device power up, the device defaults to Read1 mode. This operation is also initiated by writing 00H to the command register along with three address cycles. Once the command is latched, it does not need to be written for the following page read operation. Three types of operations are available: random read, sequential page read and sequential row read. The random read mode is enabled when the page address is changed. The 264 bytes of data within the selected page are transferred to the data registers in less than $10\mu s(tR)$ . The CPU can detect the completion of this data transfer(tR) by analyzing the output of $R/\overline{B}$ pin. Once the data in a page is loaded into the registers, they may be read out in 80ns cycle time by sequentially pulsing RE with $\overline{CE}$ staying low. High to low transitions of the RE clock output the data starting from the selected column address up to the last column address(column 264). After the data of last column address is clocked out, the next page is automatically selected for sequential read. Waiting $10\mu s$ again allows for reading of the page. The sequential row read operation is terminated by bringing $\overline{CE}$ to high. The way the Read1 and Read2 commands work is like a pointer set to either the main area or the spare area. The spare area of bytes 256 to 263 may be selectively accessed by writing the Read2 command. Addresses $A_0$ to $A_2$ set the starting address of the spare area while addresses $A_3$ to $A_7$ are ignored. Unless the operation is aborted, the page address is automatically incremented for sequential row read as in Read1 operation and spare eight bytes of each page may be sequentially read. The Read1 command(00H) is needed to move the pointer back to the main area. Figures 3 thru 6 show typical sequence and timings for each read operation. Figure 3. Read1 Operation Figure 4. Read2 Operation CLE CE WE ALE R/B Busy(Seek Time) RE 50H Data Output(Sequential) I/O<sub>0~7</sub> Start Add.(3Cycle) A0 ~ A2 & A8 ~ A19 Spare Field (A<sub>3</sub> ~ A<sub>7</sub>: Don't Care) Spare Field Data Field Figure 5. Sequential Row Read1 Operation Figure 6. Sequential Row Read2 Operation ### **PAGE PROGRAM** The device is programmed basically on a page basis. But it also allows multiple partial page programming of a byte or consecutive bytes up to 264 may be programmed in a single page program cycle. The number of partial page programming operation in the same page without an intervening erase operation must not exceed ten. The addressing may be done in any random order in a block. A page program cycle consist of a serial data loading period in which up to 264 bytes of data must be loaded into the device, and non-volatile programming period in which the loaded data is programmed into the appropriate cell. The sequential data loading period begins by inputting the Serial Data Input command(80H), followed by the three cycle address input and then serial data loading. The bytes other than those to be programmed do not need to be loaded. In order to program the bytes in the spare columns of 256 to 263, the pointer should be set to the spare area by writing the Read 2 command(50H) to the command register. The pointer remains in the spare area unless the Read 1 command(00H) is entered to return to the main area. The Page Program confirm command(10H) initiates the programming process. Writing 10H alone without previously entering the serial data will not initiate the programming process. The internal write controller automatically executes the algorithms and timings necessary for program and verify, thereby freeing the CPU for other tasks. Once the program process starts, the Status Register may be read RE and CE low after the Read Status command(70H) is written to it. The CPU can detect the completion of program cycle by monitoring the R/B output, or the Status bit(I/O6) of the Status Register. Only the Read Status command and Reset command are valid while programming is in progress. When the Page Program is complete, the Write Status Bit(I/O0) may be checked(Figure 7). The internal write verify detects only errors for "1"s that are not successfully programmed to "0"s. The command register remains in Read Status command mode until another valid command is written to the command register. Figure 7. Program & Read Status Operation #### **BLOCK ERASE** The Erase operation is done on a block(4K Byte) basis. Block address loading is accomplished in two cycles initiated by an Erase Setup command(60H). Only address $A_{12}$ to $A_{19}$ is valid while $A_8$ to $A_{11}$ is ignored. The Erase Confirm command(D0H) following the block address loading initiates the internal erasing process. This two-step sequence of setup followed by execution command ensures that memory contents are not accidentally erased due to external noises conditions. At the rising edge of $\overline{\text{WE}}$ after the erase confirm command input, the internal write controller handles erase, erase-verify and pulse repetition where required. If an erase operation error is detected, the internal verify is halted and erase operation is terminated. When the erase operation is complete, the Write Status Bit(I/O0) may be checked. Figure 8 details the sequence. Figure 8. Block Erase Operation #### **READ STATUS** The device contains a Status Register which may be read to find out whether program or erase operation is complete, and whether the program or erase operation is completed successfully. After writing 70H command to the command register, a read cycle outputs the contents of the Status Register to the I/O pins on the falling edge of $\overline{CE}$ or $\overline{RE}$ , whichever occurs last. This two line control allows the system to poll the progress of each device in multiple memory connections even when $R/\overline{B}$ pins are common-wired. $\overline{RE}$ or $\overline{CE}$ does not need to be toggled for updated status. Refer to table 2 for specific Status Register definitions. The command register remains in Status Read mode until further commands are issued to it. Therefore, if the status register is read during a random read cycle, a read command(00H or 50H) should be given before sequential page read cycle. Table2. Status Register Definition | SR | Status | Definition | | |------------------|-------------------------|-------------------------------------|--| | I/Oo | Program / Erase | "0" : Successful Program / Erase | | | 1700 | Trogram / Erase | "1" : Error in Program / Erase | | | I/O1 | | "0" | | | I/O2 | D | "0" | | | I/O3 | Reserved for Future Use | "0" | | | I/O4 | | "0" | | | I/O5 | | "0" | | | I/O6 | Device Operation | "0" : Busy "1" : Ready | | | I/O <sub>7</sub> | Write Protect | "0" : Protected "1" : Not Protected | | #### **READ ID** The device contains a product identification mode, initiated by writing 90H to the command register, followed by an address input of 00H. Two read cycles sequentially output the manufacture code(ECH), and the device code (6EH) respectively. The command register remains in Read ID mode until further commands are issued to it. Figure 9 shows the operation sequence. Figure 9. Read ID Operation #### **RESET** The device offers a reset feature, executed by writing FFH to the command register. When the device is in Busy state during random read, program or erase mode, the reset operation will abort these operations. The contents of memory cells being altered are no longer valid, as the data will be partially programmed or erased. The command register is cleared to wait for the next command, and the Status Register is cleared to value C0H when $\overline{\text{WP}}$ is high. Refer to table 3 for device status after reset operation. If the device is already in reset state a new reset command will not be accepted by the command register. The R/B pin transitions to low for trest after the Reset command is written. Reset command is not necessary for normal operation. Refer to Figure 10 below. ### Figure 10. RESET Operation Table3. Device Status | | After Power-up | After Reset | |----------------|----------------|--------------------------| | Operation Mode | Read 1 | Waiting for next command | ### READY/BUSY The device has a $R/\overline{B}$ output that provides a hardware method of indicating the completion of a page program, erase and random read completion. The $R/\overline{B}$ pin is normally high but transitions to low after program or erase command is written to the command register or random read is started after address loading. It returns to high when the internal controller has finished the operation. The pin is an open-drain driver thereby allowing two or more $R/\overline{B}$ outputs to be Or-tied. An appropriate pull-up resister is required for proper operation and the value may be calculated by the following equation. $$Rp = \frac{Vcc(Max.) - VoL(Max.)}{IoL + \Sigma IL} = \frac{Note^*}{8mA + \Sigma IL}$$ where IL is the sum of the input currents of all devices tied to the $R/\overline{B}$ pin. Note\* : 5.1V when Vcc=3.6V~5.5V 3.2V when Vcc=2.7V~3.6V ### **DATA PROTECTION** The device is designed to offer protection from any involuntary program/erase during power-transitions. An internal voltage detector disables all functions whenever Vcc is below about 2V. $\overline{\text{WP}}$ pin provides hardware protection and is recommended to be kept at Vil during power-up and power-down as shown in Figure 11. The two step command sequence for program/erase provides additional software protection. Figure 11. AC Waveforms for Power Transition # **PACKAGE DIMENSIONS** # 44(40) LEAD PLASTIC THIN SMALL OUT-LINE PACKAGE TYPE(II)