Bus # NM25C020 2K-Bit Serial CMOS EEPROM (Serial Peripheral Interface (SPI) Synchronous Bus) ## **General Description** The NM25C020 is a 2048-bit CMOS EEPROM with an SPI compatible serial interface. The NM25C020 is designed for data storage in applications requiring both non-volatile memory and insystem data updates. This EEPROM is well suited for applications using the 68HC11 series of microcontrollers that support the SPI interface for high speed communication with peripheral devices via a serial bus to reduce pin count. The NM25C020 is implemented in Fairchild Semiconductor's floating gate CMOS process that provides superior endurance and data retention. The serial data transmission of this device requires <u>four</u> signal lines to control the device operation: Chip Select $(\overline{CS})$ , Clock (SCK), Data In (SI), and Serial Data Out (SO). All programming cycles are completely self-timed and do not require an erase before WRITE. BLOCK WRITE protection is provided by programming the STATUS REGISTER with one of four levels of write protection. Additionally, separate WRITE enable and WRITE disable instructions are provided for data protection. Hardware data protection is provided by the WP pin to protect against inadvertent programming. The HOLD pin allows the serial communication to be suspended without resetting the serial sequence. #### **Features** - 2.1 MHz clock rate @ 2.7V to 5.5V - 2048 bits organized as 256 x 8 - Multiple chips on the same 3-wire bus with separate chip select lines - Self-timed programming cycle - Simultaneous programming of 1 to 4 bytes at a time - Status register can be polled during programming to monitor READY/BUSY - Write Protect (WP) pin and write disable instruction for both hardware and software write protection - Block write protect feature to protect against accidental writes - Endurance: 1,000,000 data changes - Data retention greater than 40 years - Packages available: 8-pin DIP, 8-pin SO, or 8-pin TSSOP ## **Block Diagram** DS012400-1 ### **Connection Diagram** ### Dual-In-Line Package (N), SO Package (M8), and TSSOP Package (MT8) **Top View** See Package Number N08E (N), M08A (M8), and MTC08 (MT8) #### **Pin Names** | CS | Chip Select Input | | |-----------------|----------------------|--| | so | Serial Data Output | | | WP | Write Protect | | | V <sub>SS</sub> | Ground | | | SI | Serial Data Input | | | SCK | Serial Clock Input | | | HOLD | Suspends Serial Data | | | V <sub>CC</sub> | Power Supply | | ## **Ordering Information** **Memory Prefix** 0°C to +70°C -40°C to +85°C -40°C to +125°C ## Standard Voltage $4.5 \le V_{CC} \le 5.5V$ Specifications ### **Absolute Maximum Ratings** (Note 1) ## **Operating Conditions** Ambient Storage Temperature -65°C to +150°C All Input or Output Voltage with Lead Temp. (Soldering, 10 sec.) Respect to Ground +6.5V to -0.3V +300°C **Ambient Operating Temperature** NM25C020 NM25C020E NM25C020V Power Supply (V<sub>CC</sub>) 4.5V to 5.5V **ESD Rating** 2000V ## DC and AC Electrical Characteristics $4.5V \le V_{CC} \le 5.5V$ (unless otherwise specified) | Symbol | Parameter | Conditions | Min | Max | Units | |-------------------|-------------------------|----------------------------------------|-----------------------|-----------------------|-------| | I <sub>CC</sub> | Operating Current | CS = V <sub>IL</sub> | | 3 | mA | | I <sub>CCSB</sub> | Standby Current | $\overline{\text{CS}} = V_{\text{CC}}$ | | 50 | μА | | I <sub>IL</sub> | Input Leakage | V <sub>IN</sub> = 0 to V <sub>CC</sub> | -1 | +1 | μА | | I <sub>OL</sub> | Output Leakage | $V_{OUT} = GND \text{ to } V_{CC}$ | -1 | +1 | μΑ | | $V_{IL}$ | CMOS Input Low Voltage | | -0.3 | V <sub>CC</sub> * 0.3 | V | | $V_{IH}$ | CMOS Input High Voltage | | 0.7 * V <sub>CC</sub> | V <sub>CC</sub> + 0.3 | V | | $V_{OL}$ | Output Low Voltage | I <sub>OL</sub> = 1.6 mA | | 0.4 | V | | $V_{OH}$ | Output High Voltage | $I_{OH} = -0.8 \text{ mA}$ | V <sub>CC</sub> - 0.8 | | V | | $f_{OP}$ | SCK Frequency | | | 2.1 | MHz | | t <sub>RI</sub> | Input Rise Time | | | 2.0 | μs | | t <sub>FI</sub> | Input Fall Time | | | 2.0 | μs | | t <sub>CLH</sub> | Clock High Time | (Note 2) | 190 | | ns | | t <sub>CLL</sub> | Clock Low Time | (Note 2) | 190 | | ns | | t <sub>CSH</sub> | Min CS High Time | (Note 3) | 240 | | ns | | t <sub>CSS</sub> | CS Setup Time | | 240 | | ns | | t <sub>DIS</sub> | Data Setup Time | | 100 | | ns | | t <sub>HDS</sub> | HOLD Setup Time | | 90 | | ns | | t <sub>CSN</sub> | CS Hold Time | | 240 | | ns | | t <sub>DIN</sub> | Data Hold Time | | 100 | | ns | | t <sub>HDN</sub> | HOLD Hold Time | | 90 | | ns | | t <sub>PD</sub> | Output Delay | C <sub>L</sub> = 200 pF | | 240 | ns | | t <sub>DH</sub> | Output Hold Time | | 0 | | ns | | $t_{LZ}$ | HOLD to Output Low Z | | | 100 | ns | | t <sub>DF</sub> | Output Disable Time | C <sub>L</sub> = 200 pF | | 240 | ns | | t <sub>HZ</sub> | HOLD to Output High Z | | | 100 | ns | | t <sub>WP</sub> | Write Cycle Time | 1–4 Bytes | | 10 | ms | ## **Capacitance** $T_A = 25^{\circ}C$ , f = 2.1/1 MHz (Note 4) | Symbol | Test | Тур | Max | Units | |------------------|--------------------|-----|-----|-------| | C <sub>OUT</sub> | Output Capacitance | 3 | 8 | pF | | C <sub>IN</sub> | Input Capacitance | 2 | 6 | pF | #### **AC Test Conditions** $C_{L} = 200 \text{ pF}$ **Output Load** Input Pulse Levels $0.1 * V_{CC} - 0.9 * V_{CC}$ Timing Measurement Reference Level 0.3 \* V<sub>CC</sub> - .07 \* V<sub>CC</sub> Note 1: Stress 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 the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Note 2: The $f_{OP}$ frequency specification specifies a minimum clock period of $1/f_{OP}$ . Therefore, for every $f_{OP}$ clock cycle, $t_{CLH} + t_{CLL}$ must be equal to or greater than $1/f_{OP}$ . For example, if the 2.1MHz period = 476ns and $t_{CLH} = 190$ ns, $t_{CLL}$ must be 286ns. Note 3: $\overline{\text{CS}}$ must be brought high for a minimum of $t_{\text{CSH}}$ between consecutive instruction cycles. Note 4: This parameter is periodically sampled and not 100% tested. ## **Low Voltage 2.7V ≤ V<sub>CC</sub> ≤ 4.5V Specifications** ### **Absolute Maximum Ratings** (Note 5) ## **Operating Conditions** Ambient Storage Temperature -65°C to +150°C Ambient Operating Temperature NM25C020L/LZ All Input or Output Voltage with Respect to Ground **ESD Rating** NM25C020LF/LZE NM25C020LV 0°C to +70°C -40°C to +85°C -40°C to +125°C Lead Temp. (Soldering, 10 sec.) +6.5V to -0.3V +300°C 2000V Power Supply (V<sub>CC</sub>) 2.7V-4.5V ## DC and AC Electrical Characteristics 2.7V ≤ V<sub>CC</sub> ≤ 4.5V (unless otherwise specified) | | | | | | 20L/LE<br>)LZ/LZE | 25C0 | )20LV | | |-------------------|---------------------|---------|----------------------------------------|-----------------------|-----------------------|-----------------------|-----------------------|----------| | Symbol | Parameter | Part | Conditions | Min. | Max. | Min | Max | Units | | I <sub>cc</sub> | Operating Current | | CS = V <sub>IL</sub> | | 3 | | 3 | mA | | I <sub>CCSB</sub> | Standby Current | L<br>LZ | $\overline{\text{CS}} = V_{\text{CC}}$ | | 10<br>1 | | 10<br>N/A | μA<br>μA | | I <sub>IL</sub> | Input Leakage | | $V_{IN} = 0$ to $V_{CC}$ | -1 | 1 | -1 | 1 | μА | | I <sub>OL</sub> | Output Leakage | | $V_{OUT} = GND \text{ to } V_{CC}$ | -1 | 1 | -1 | 1 | μА | | V <sub>IL</sub> | Input Low Voltage | | | -0.3 | V <sub>CC</sub> * 0.3 | -0.3 | V <sub>CC</sub> * 0.3 | V | | V <sub>IH</sub> | Input High Voltage | | | 0.7 * V <sub>CC</sub> | $V_{CC} + 0.3$ | 0.7 * V <sub>CC</sub> | $V_{CC} + 0.3$ | V | | V <sub>OL</sub> | Output Low Voltage | | $I_{OL} = 0.8 \text{ mA}$ | | 0.4 | | 0.4 | V | | V <sub>OH</sub> | Output High Voltage | | $I_{OH} = -0.8 \text{ mA}$ | V <sub>CC</sub> - 0.8 | | V <sub>CC</sub> - 0.8 | | V | | f <sub>OP</sub> | SCK Frequency | | | | 1.0 | | 1.0 | MHz | | t <sub>RI</sub> | Input Rise Time | | | | 2.0 | | 2.0 | μѕ | | t <sub>FI</sub> | Input Fall Time | | | | 2.0 | | 2.0 | μs | | t <sub>CLH</sub> | Clock High Time | | (Note 6) | 410 | | 410 | | ns | | t <sub>CLL</sub> | Clock Low Time | | (Note 6) | 410 | | 410 | | ns | | t <sub>CSH</sub> | Min. CS High Time | | (Note 7) | 500 | | 500 | | ns | | t <sub>css</sub> | CS Setup Time | | | 500 | | 500 | | ns | | t <sub>DIS</sub> | Data Setup Time | | | 100 | | 100 | | ns | | t <sub>HDS</sub> | HOLD Setup Time | | | 240 | | 240 | | ns | | t <sub>CSN</sub> | CS Hold Time | | | 500 | | 500 | | ns | | t <sub>DIN</sub> | Data Hold Time | | | 100 | | 100 | | ns | | t <sub>HDN</sub> | HOLD Hold Time | | | 240 | | 240 | | ns | | t <sub>PD</sub> | Output Delay | | C <sub>L</sub> = 200 pF | | 500 | | 500 | ns | | t <sub>DH</sub> | Output Hold Time | | | 0 | | 0 | | ns | | t <sub>LZ</sub> | HOLD Output Low Z | | | | 240 | | 240 | ns | | t <sub>DF</sub> | Output Disable Time | | C <sub>L</sub> = 200 pF | | 500 | | 500 | ns | | t <sub>HZ</sub> | HOLD to Output Hi Z | | | | 240 | | 240 | ns | | t <sub>WP</sub> | Write Cycle Time | | 1-4 Bytes | | 15 | | 15 | ms | ### **Capacitance** $T_A = 25^{\circ}C$ , f = 2.1/1 MHz (Note 8) | Symbol | Test | Тур | Max | Units | |------------------|--------------------|-----|-----|-------| | C <sub>OUT</sub> | Output Capacitance | 3 | 8 | pF | | C <sub>IN</sub> | Input Capacitance | 2 | 6 | pF | #### **AC Test Conditions** Output Load $I_{OL}$ = 10 $\mu$ A, $I_{OH}$ = 10 $\mu$ A Input Pulse Levels 0.3V to 3.5V Timing Measurement Reference Level Input 0.4V and 1.6V Output 0.8V and 1.6V Note 5: Stress 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 the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Note 6: The $f_{OP}$ frequency specification specifies a minimum clock period of $1/f_{OP}$ . Therefore, for every $f_{OP}$ clock cycle, $t_{CLH} + t_{CLL}$ must be equal to or greater than $1/f_{OP}$ . For example, if the 2.1MHz period = 476ns and $t_{CLH}$ = 190ns, $t_{CLL}$ must be 286ns. Note 7: $\overline{\text{CS}}$ must be brought high for a minimum of $t_{\text{CSH}}$ between consecutive instruction cycles Note 8: This parameter is periodically sampled and not 100% tested. ## AC Test Conditions (Continued) ### FIGURE 1. Synchronous Data Timing Diagram DS012400-3 ### **FIGURE 2. HOLD Timing** DS012400-6 #### **FIGURE 3. SPI Serial Interface** DS012400-4 ## **Functional Description** **TABLE 1. Instruction Set** | Instruction<br>Name | Instruction<br>Opcode | Operation | |---------------------|-----------------------|--------------------------------| | WREN | 00000110 | Set Write Enable Latch | | WRDI | 00000100 | Reset Write Enable Latch | | RDSR | 00000101 | Read Status Register | | WRSR | 00000001 | Write Status Register | | READ | 00000011 | Read Data from Memory<br>Array | | WRITE | 00000010 | Write Data to Memory Array | **MASTER**: The device that generates the serial clock is designated as the master. The NM25C020 can never function as a master. ${\bf SLAVE}$ : The NM25C020 always operates as a slave as the serial clock pin is always an input. **TRANSMITTER/RECEIVER**: The NM25C020 has separate pins for data transmission (SO) and reception (SI). MSB: The Most Significant Bit is the first bit transmitted and received. **CHIP SELECT**: The chip is selected when pin $\overline{CS}$ is low. When the chip is *not* selected, data will not be accepted from pin SI, and the output pin SO is in high impedance. **SERIAL OP-CODE**: The first byte transmitted after the chip is selected with CS going low contains the op-code that defines the operation to be performed. **PROTOCOL**: When connected to the SPI port of a 68HC11 microcontroller, the NM25C020 accepts a clock phase of 0 and a clock polarity of 0. The SPI protocol for this device defines the byte transmitted on the SI and SO data lines for proper chip operation. See Figure 4. #### **FIGURE 4. SPI Protocol** Data is clocked in on the positive SCK edge and out on the negative SCK edge. $\label{eq:control} % \begin{subarray}{ll} \end{subarray} \begin$ HOLD: The HOLD pin is used in conjunction with the CS to select the device. Once the device is selected and a serial sequence is underway, HOLD may be forced low to suspend further serial communication with the device without resetting the serial sequence. Note that HOLD must be brought low while the SCK pin is low. The device must remain selected during this sequence. To resume serial communication HOLD is brought high while the SCK pin is low. The SO pin is at a high impedance state during HOLD. **INVALID OP-CODE**: After an invalid code is received, no data is shifted into the NM25C020, and the SO data output pin remains high impedance until a new $\overline{\text{CS}}$ falling edge reinitializes the serial communication. See Figure 5. #### FIGURE 5. Invalid Op-Code www.fairchildsemi.com 6 #### Functional Description (Continued) **READ SEQUENCE:** Reading the memory via the serial SPI link requires the following sequence. The $\overline{CS}$ line is pulled low to select the device. The READ op-code is transmitted on the SI line followed by the byte address (A7–A0) to be read. After this is done, data on the SI line becomes don't care. The data (D7–D0) at the address specified is then shifted out on the SO line. If only one byte is to be read, the $\overline{CS}$ line can be pulled back to the high level. It is possible to continue the READ sequence as the byte adress is automatically incremented and data will continue to be shifted out as clock pulses are continuously applied. When the highest address is reached (FF), the address counter rolls over to lowest address (000) allowing the entire memory to be read in one continuous READ cycle. See Figure 6. #### FIGURE 6. Read Sequence **READ STATUS REGISTER (RDSR)**: The Read Status Register (RDSR) instruction provides access to the status register and is used to interrogate the READY/BUSY and WRITE ENABLE status of the chip. (Two non-volatile status register bits are used to select one of four levels of BLOCK WRITE PROTECTION.) The status register format is shown in Table 2. **TABLE 2. Status Register Format** | Bit<br>7 | Bit<br>6 | Bit<br>5 | Bit<br>4 | Bit<br>3 | Bit<br>2 | Bit<br>1 | Bit<br>0 | | |----------|----------|----------|----------|----------|----------|----------|----------|--| | Χ | Х | Χ | X | BP1 | BP0 | WEN | RDY | | X = Don't Care Status register Bit 0=0 ( $\overline{RDY}$ ) indicates that the device is READY; Bit 0=1 indicates that a program cycle is in progress. Bit 1=0 (WEN) indicates that the device is not WRITE ENABLED; Bit 1=1 indicates that the device is WRITE ENABLED. Non-volatile status register Bits 2 and 3 (BP0 and BP1) indicate the level of BLOCK WRITE PROTECTION selected. The block write protection levels and corresponding status register control bits are shown in Table 3. Note that if a RDSR instruction is executed during a programming cycle only the $\overline{RDY}$ bit is valid. All other bits are 1s. See Figure 7. FIGURE 7. Read Status **TABLE 3. Block Write Protection Levels** | Level | Status Re | gister Bits | Array<br>Address | |-------|-----------|-------------|------------------| | | BP1 | BP0 | Protected | | 0 | 0 | 0 | None | | 1 | 0 | 1 | C0-FF | | 2 | 1 | 0 | 80-FF | | 3 | 1 | 1 | 00-FF | WRITE ENABLE (WREN): When $V_{\rm CC}$ is applied to the chip, it "powers up" in the write disable state. Therefore, all programming modes must be preceded by a WRITE ENABLE (WREN) instruction. At the completion of a WRITE or WRSR cycle the device is automatically returned to the write disable state. Note that a WRITE DISABLE (WRDI) instruction will also return the device to the write disable state. See Figure 8. #### FIGURE 8. Write Enable **WRITE DISABLE (WRDI)**: To protect against accidental data disturbance the WRITE DISABLE (WRDI) instruction disables all programming modes. See Figure 9. #### FIGURE 9. Write Disable WRITE SEQUENCE: To program the device, the WRITE PROTECT (WP) pin must be held high and two separate instructions must be executed. The chip must first be write enabled via the WRITE ENABLE instruction and then a WRITE instruction must be executed. Moreover, the address of the memory location(s) to be programmed must be outside the protected address field selected by the Block Write Protection Level. See Table 3. A WRITE command requires the following sequence. The $\overline{CS}$ line is pulled low to select the device, then the WRITE op-code is transmitted on the SI line followed by the byte address(A7–A0) and the corresponding data (D7-D0) to be written. **Programming will start after the \overline{CS} pin is forced back to a high level.** Note that the LOW to HIGH transition of the $\overline{CS}$ pin must occur during the SCK low time immediately after clocking in the D0 data bit. See Figure 10. 7 ## Functional Description (Continued) #### FIGURE 10. Write Sequence The READY/BUSY status of the device can be determined by executing a READ STATUS REGISTER (RDSR) instruction. Bit 0 = 1 indicates that the WRITE cycle is still in progress and Bit 0 = 0 indicates that the WRITE cycle has ended. During the WRITE programming cycle (Bit 0 = 1) only the READ STATUS REGISTER instruction is enabled. The NM25C020 is capable of a 4 byte PAGE WRITE operation. After receipt of each byte of data the two low order address bits are internally incremented by one. The seven high order bits of the address will remain constant. If the master should transmit more than 4 bytes of data, the address counter will "roll over," and the previously loaded data will be reloaded. See Figure 11. #### FIGURE 11. 4 Byte Page Write At the completion of a WRITE cycle the device is automatically returned to the write disable state. If the device is not WRITE enabled, the device will ignore the WRITE instruction and return to the standby state when $\overline{\text{CS}}$ is forced high. A new $\overline{\text{CS}}$ falling edge is required to re-initialize the serial communication. WRITE STATUS REGISTER (WRSR): The WRITE STATUS REGISTER (WRSR) instruction is used to program the non-volatile status register Bits 2 and 3 (BP0 and BP1). The WRITE PROTECT (WP) pin must be held high and two separate instructions must be executed. The chip must first be write enabled via the WRITE ENABLE instruction and then a WRSR instruction must be executed. The WRSR command requires the following sequence. The $\overline{\text{CS}}$ line is pulled low to select the device and then the WRSR op-code is transmitted on the SI line followed by the data to be programmed. See Figure 12. #### FIGURE 12. Write Status Register Note that the first four bits are don't care bits followed by BP1 and BP0 then two additional don't care bits. Programming will start after the CS pin is forced back to a high level. As in the WRITE instruction the LOW to HIGH transition of the CS pin must occur during the SCK low time immediately after clocking in the last don't care bit. See Figure 13. #### FIGURE 13. Start WRSR Condition The READY/BUSY status of the device can be determined by executing a READ STATUS REGISTER (RDSR) instruction. Bit 0 = 1 indicates that the WRSR cycle is still in progress and Bit 0 = 0 indicates that the WRSR cycle has ended. At the completion of a WRITE cycle the device is automatically returned to the write disable state. ### Physical Dimensions inches (millimeters) unless otherwise noted Molded Small Out-Line Package (M8) Package Number M08A Molded Dual-In-Line Package (N) Package Number N08E Bus ## Physical Dimensions inches (millimeters) unless otherwise noted Notes: Unless otherwise specified 1. Reference JEDEC registration MO153. Variation AA. Dated 7/93 8-Pin Molded TSSOP, JEDEC (MT8) **Package Number MTC08** ### **Life Support Policy** Fairchild's products are not authorized for use as critical components in life support devices or systems without the express written approval of the President of Fairchild Semiconductor Corporation. As used herein: - 1. Life support devices or systems are devices or systems which. (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user. - 2. A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness. | an crinic Serniconductor | |---------------------------------| | Americas | | <b>Customer Response Center</b> | | el. 1-888-522-5372 | | | Fairchild Semiconductor Deutsch +49 (0) 8141-6102-0 +44 (0) 1793-856856 +33 (0) 1-6930-3696 +39 (0) 2-249111-1 English Français Fairchild Semiconductor Hong Kong 8/F, Room 808, Empire Centre 68 Mody Road, Tsimshatsui East Kowloon. Hong Kong Tel; +852-2722-8338 Fax: +852-2722-8383 Fairchild Semiconductor Fairchild Semiconductor Japan Ltd. 4F, Natsume Bldg. 2-18-6, Yushima, Bunkyo-ku Tokyo, 113-0034 Japan Tel: 81-3-3818-8840 Fax: 81-3-3818-8841 Fairchild does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied and Fairchild reserves the right at any time without notice to change said circuitry and specifications