Memory
Databook

# MEMORY DATABOOK 

1992 Edition
CMOS EPROMsCMOS EEPROMs
PROMs
Application Notes
Quality and Reliability
Physical Dimensions

## TRADEMARKS

Following is the most current list of National Semiconductor Corporation's trademarks and registered trademarks.

| ABiC'm | FACT Quiet Series ${ }^{\text {TM }}$ | MICROWIRETM | Script ${ }^{\text {ChekTM }}$ |
| :---: | :---: | :---: | :---: |
| Abuseable ${ }^{\text {TM }}$ | FAIRCADTM | MICROWIRE/PLUSTM | SCXTM |
| AnadigTM | Fairtech ${ }^{\text {TM }}$ | MOLETM | SERIES/800TM |
| ANS-R-TRANTM | FAST ${ }^{\text {® }}$ | MPATM | Series 900тm |
| APPSTM | FASTrTM | MSTTM | Series 3000TM |
| ASPECTTM | 5-Star Service ${ }^{\text {TM }}$ | Naked-8TM | Series 32000 ${ }^{\text {® }}$ |
| Auto-Chem DeflasherTM | Flashtm | National ${ }^{\text {® }}$ | Shelf $\sim$ ChekTM |
| ВСРтм | GENIXTM | National Semiconductor ${ }^{(1)}$ | Simple SwitcherTM |
| BI-FETTM | GNXTM | National Semiconductor | SofChekTM |
| BI-FET IITM | GTOTM | Corp. ${ }^{\text {® }}$ | SONICTM |
| BI-LINETM | HAMRTM | NAX 800 ${ }^{\text {PM }}$ | SPIRETM |
| BIPLAN ${ }^{\text {TM }}$ | HandiScantM | Nitride Plus ${ }^{\text {TM }}$ | Staggered Refresh ${ }^{\text {TM }}$ |
| BLCTM | HEX 3000 ${ }^{\text {TM }}$ | Nitride Plus Oxide ${ }^{\text {TM }}$ | STARTM |
| BLXTM | НРСТм | NMLTM | Starlink ${ }^{\text {TM }}$ |
| BMACTM | НуВalтм | NOBUSTM | STARPLEXTM |
| Brite-Litetm | ${ }^{3} \mathrm{~L}$ (8) | NSC800 ${ }^{\text {m }}$ | ST-NICTM |
| BSITM | ICM ${ }^{\text {TM }}$ | NSCISETM | SuperATTM |
| BSI-2TM | INFOCHEXTM | NSX-16TM | Super-Block ${ }^{\text {TM }}$ |
| CDDTM | Integral ISETM | NS-XC-16TM | SuperChip ${ }^{\text {TM }}$ |
| CheckTrack ${ }^{\text {TM }}$ | Intelisplay ${ }^{\text {TM }}$ | NTERCOM ${ }^{\text {TM }}$ | SuperScript ${ }^{\text {m }}$ |
| CIM ${ }^{\text {TM }}$ | Inter-LERICTM | NURAMTM | SYS32TM |
| CIMBUSTM | Inter-RICTM | OPALTM | TapePak ${ }^{\text {® }}$ |
| CLASICTM | ISETM | OXISSTM | TDSTM |
| Clock $\sim$ Chek ${ }^{\text {TM }}$ | ISE/06TM | $\mathrm{P}^{2} \mathrm{CMOSTM}$ | TeleGate ${ }^{\text {TM }}$ |
| COMBO® | ISE/08TM | PC Master ${ }^{\text {TM }}$ | The National Anthem ${ }^{(1)}$ |
| COMBO ITM | ISE/16TM | Perfect Watch ${ }^{\text {TM }}$ | TimeصChek ${ }^{\text {TM }}$ |
| COMBO IITM | ISE32TM | Pharma-ChekTM | TINATM |
| COPSTM microcontrollers | ISOPLANARTM | PLANTM | TLCTM |
| CRDTM | ISOPLANAR-ZTM | PLANARTM | TrapezoidalTM |
| DA4TM | KeyScantm | PLAYERTM | TRI-CODETM |
| Datachecker® | LERICTM | Plus-2тm | TRI-POLYTM |
| DENSPAKTM | LMCMOSTM | Polycraft ${ }^{\text {TM }}$ | TRI-SAFETM |
| DIBTM | M ${ }^{2} \mathrm{CMOS}$ тм | POSilink ${ }^{\text {TM }}$ | TRI-STATE ${ }^{\text {® }}$ |
| DISCERNTM | Macrobus ${ }^{\text {™ }}$ | POSitalkerTM | TROPICTM |
| DISTILLTM | Macrocomponent ${ }^{\text {TM }}$ | Power + Controlim | TURBOTRANSCEIVERTM |
| DNR ${ }^{\text {® }}$ | MAPLTM | POWERplanarTM | VIPTM |
| DPVM ${ }^{\text {TM }}$ | MAXI-ROM ${ }^{\text {® }}$ | QUAD3000TM | VR32Tm |
| E2CMOSTM | Meat Chek $^{\text {TM }}$ | QUIKLOOKTM | WATCHDOGTM |
| ELSTARTM | MenuMaster ${ }^{\text {TM }}$ | RATTM | ХMOSTM |
| Embedded System | MicrobusTM data bus | RICTM | XPUTM |
| ProcessorTM | MICRO-DACTM | RTX16TM | Z STARTM |
| EPTM | $\mu$ talker ${ }^{\text {TM }}$ | SABRTM | 883B/RETSTM |
| E-Z.LINKTM | Microtalker ${ }^{\text {TM }}$ | SCAN ${ }^{\text {TM }}$ | 883S/RETSTM |

ABELTM is a trademark of Data I/O Corporation.
Ethernet ${ }^{\circledR}$ is a registered trademark of Xerox Corporation.
GAL® is a registered trademark of Lattice Semiconductor Corporation.
PAL® is a registered trademark of and used under license from Advanced Micro Devices, Inc.
PC-AT® is a registered trademark of International Business Machines Corporation.
SPITM is a trademark of Motorola Corporation.
TouchToneTM is a trademark of Western Electric Co., Inc.
Z80 ${ }^{\text {® }}$ is a registered trademark of Zilog Corporation.

## LIFE SUPPORT POLICY

NATIONAL'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 NATIONAL 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 suppor device or system whose failure to perform can be reasc ably expected to cause the failure of the life support , vice or system, or to affect its safety or effectivener

## New Products for 1992

## EPROMs

## 68040 Compatible EPROM

Brief Descriptlon: This device can interface directly with Motorola's 68040 Microprocessor to allow for speed maximization while reducing the number of glue logic devices, thus reducing system cost.

## Low Voltage EPROMs

Brief Description: These devices operate at 3 V for low power consumption, and have JEDEC standard pinouts. These devices are ideal for handheld applications.

## 2 Megabyte EPROM

Brief Description: This device is a high performance device that possesses two megabytes of NV memory, and has JEDEC standard pinout.

## EEPROMs

## 16K MICROWIRETM EEPROM

Brief Description: The NM93C86A can be configured either $x 8$ or $x 16$ and offers 16K of NV memory. This device will be offered in an 8-pin small-outline (SO) package for minimal space usage.

## 16K MICROWIRE EEPROM

Brief Description: The NM59C16 can be configured either x8 or $\times 16$, can be monitored for programming status by monitoring the RDY/BUSY pin and offers 16 K of NV memory. This device will be offered in an 8 -pin small-outline (SO) package for minimal space usage.

2K/4K Extended Low Voltage ${ }^{2} \mathbf{2 C}$ EEPROM
Brief Descriptlon: These devices operate on an 12C 2-wire bus and operate in an extended voltage range of 2.5 V to 5.5 V .

## 4K SPITM EEPROM

Brief Description: These devices are designed for data storage in applications requiring both non-volatile memory and in-system data updates.
Note: For device status and availability, contact your local sales office.

## Memory Databook Introduction

National Semiconductor's Memory Databook is a comprehensive collection of information on advanced memory products intended to meet the needs of virtually every electronic system. We are committed to designing and providing state-of-the-art non-volatile EPROM and EEPROM solutions. National's EPROM families-Standard Products, Processor Oriented ePROMs, 5 V Low Current and Low Voltage (3V), along with our EEPROM families-MICROWIRETM and I ${ }^{2} \mathrm{C}$, are designed to do just that.
National Semiconductor's EPROM families are suited to meet a variety of customer needs. The Standard Product EPROMs are industry compliant JEDEC parts. Yet, a standard EPROM does not meet the needs of every electronic system. To meet these needs, National provides other families such as the Low Current 5 V family which has low Icc for power sensitive applications, Low Voltage EPROMs for newly emerging portable hand-held markets, and Processor Oriented ePROMs (POPTM) which are designed to fully utilize microprocessor features which increase data throughput.
National Semiconductor's EEPROM families are also suited to provide any solution in serial EEPROM. Different microcontrollers provide various serial interfaces. National, the industry leader, is setting the standard again! The MICROWIRE interface is the industry standard. We have expanded our offering to also include the $I^{2} \mathrm{C}$ interface for consumer electronics, and SPITM for automotive and telecommunication.
National Semiconductor is committed to excellence in design, manufacturing, reliability, and service to our customers through the continuing development of new products and technologies. As new information and devices become available, individual new datasheets will be issued. For the most current information, please contact your local National Semiconductor sales office or distributor.
Look to National for long term support for your memory needs!

## Definition of Terms

## Product Status Definitions

| Data Sheet Identification | Product Status | Definition |
| :--- | :--- | :--- |
| Advance Information | Formative or <br> In Design | This data sheet contains the design specifications for product <br> development. Specifications may change in any manner without notice. |
| Prellminary | First <br> Production | This data sheet contains preliminary data, and supplementary data will <br> be published at a later date. National Semiconductor Corporation <br> reserves the right to make changes at any time without notice in order <br> to improve design and supply the best possible product. |
| No  <br> Identification <br> Noted This data sheet contains final specifications. National Semiconductor <br> Corporation reserves the right to make changes at any time without <br> notice in order to improve design and supply the best possible product. | Froduction |  |

National Semiconductor Corporation reserves the right to make changes without further notice to any products herein to improve reliability, function or design. National does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights, nor the rights of others.

## Table of Contents

Alphanumeric Index ..... viii
Section 1 CMOS EPROMS
STANDARD PRODUCT EPROMS
CMOS EPROM Selection Guide ..... 1-3
NMC27C16B 16,384-Bit (2048 x 8) CMOS EPROM ..... 1-4
NMC27C32B 32,768-Bit ( $4096 \times 8$ ) CMOS EPROM ..... 1-13
NMC27C64 65,536-Bit (8192 x 8) CMOS EPROM ..... 1-22
NM27C128 131,072-Bit (16K x 8) High Performance CMOS EPROM ..... 1-31
NM27C256 262,144-Bit (32K x 8) High Performance CMOS EPROM ..... 1-41
NM27C512 524,288-Bit (64K x 8) High Performance CMOS EPROM ..... 1-51
NM27C010 1,048,576-Bit ( $128 \mathrm{~K} \times 8$ ) High Performance CMOS EPROM ..... 1-61
NM27C210 1,048,576-Bit ( $64 \mathrm{~K} \times 16$ ) High Performance CMOS EPROM ..... 1-69
NM27C040 4,194,304-Bit ( $512 \mathrm{~K} \times 8$ ) High Performance CMOS EPROM ..... $1-78$
PROCESSOR ORIENTED EPROMS
Processor Oriented EPROM Selection Guide ..... 1-88
NM27P512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) Processor Oriented CMOS EPROM ..... 1-89
NM27P210 1,048,576-Bit (64K x 16) Processor Oriented CMOS EPROM ..... 1-99
NM27P040 4,194,304-Bit ( $512 \mathrm{~K} \times 8$ ) Processor Oriented CMOS EPROM ..... 1-108
NMC87C257 262,144-Bit (32K x 8) CMOS EPROM with On-Chip Address Latches ..... 1-117
5V LOW CURRENT EPROMS
NM27LC256 262,144-Bit (32K x 8) Low Current CMOS EPROM ..... 1-127
NM27LC512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) Low Current CMOS EPROM ..... 1-136
LOW VOLTAGE EPROMS
NM27LV512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) Low Voltage EPROM ..... 1-146
NM27LV010 1,048,576-Bit ( $128 \mathrm{~K} \times 8$ ) Low Voltage EPROM ..... 1-147
NM27LV210 1,048,576-Bit ( $64 \mathrm{~K} \times 16$ ) Low Voltage EPROM ..... 1-155
Section 2 CMOS EEPROMS
${ }^{2}{ }^{2} \mathrm{C}$ CMOS EEPROM Selection Guide ..... 2-3
MICROWIRE CMOS EEPROM Selection Guide ..... 2-4
Specialty Products CMOS EEPROM Selection Guide ..... 2-5
I2C SYNCHRONOUS 2-WIRE BUS
NM24C02/C04/C08/C16 2K-/4K-/8K-/16K-Bit Serial EEPROM (I2C Synchronous 2-Wire Bus) ..... 2-6
NM24C03/C05/C09/C17 2K-/4K-/8K-/16K-Bit Serial EEPROM with Write Protect ( ${ }^{2} \mathrm{C}$ Synchronous 2 -Wire Bus) ..... 2-17
NM24C02L/C04L 2K-/4K-Bit Serial EEPROM with Extended Voltage (I2C Synchronous 2-Wire Bus) ..... 2-27
NM24C03L/C05L 2K-/4K-Bit Serial EEPROM with Write Protect and Extended Voltage (I2C Synchronous 2-Wire Bus) ..... 2-39
MICROWIRE SERIAL EEPROMS
NM59C11 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable with Programming Status ..... 2-51
NM93C06/C46/C56/C66 256-/1024-/2048-/4096-Bit Serial EEPROM (MICROWIRE) ..... 2-58
NM93CS06/CS46/CS56/CS66 256-/1024-/2048-/4096-Bit Serial EEPROM with Data Protect and Sequential Read ..... 2-66
NM93C06L/C46L/C56L/C66L 256-/1024-/2048-/4096-Bit Serial EEPROM with Extended Voltage ( 2.0 V to 5.5 V ) ..... 2-77
NM93CS06L/CS46L/CS56L/CS66L 256-/1024-/2048-/4096-Bit Serial EEPROM with Extended Voltage ( 2.0 V to 5.5 V ) and Data Protect ..... 2-87
NM93C46A 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable ..... 2-100

## Table of Contents (conimene)

Section 2 CMOS EEPROMS (Continued)
NM93C46AL 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable ..... 2-108
APPLICATION SPECIFIC EEPROM
NM95C12 1K-Bit CMOS EEPROM with Programmable Switches ..... 2-118
Section 3 PROMS
Bipolar PROM Selection Guide ..... 3-3
NON-REGISTERED BIPOLAR PROMS
DM74S188 (32 x 8) 256-Bit TTL PROM ..... 3-4
DM74S288 (32 x 8) 256-Bit TTL PROM ..... 3-8
DM74S287 ( $256 \times 4$ ) 1024-Bit TTL PROM ..... 3-12
DM74S387 (256 x 4) 1024-Bit TTL PROM ..... 3-16
DM74LS471 (256 x 8) 2048-Bit TTL PROM ..... 3-20
DM74S472 ( $512 \times 8$ ) 4096-Bit TTL PROM ..... 3-24
DM74S473 ( $512 \times 8$ ) 4096-Bit TTL PROM ..... 3-28
DM74S570 (512 x 4) 2048-Bit TTL PROM ..... 3-32
DM74S571 (512 x 4) 2048-Bit TTL PROM ..... 3-36
DM74S572 (1024 x 4) 4096-Bit TTL PROM ..... 3-40
DM74S573 (1024 x 4) 4096-Bit TTL PROM ..... 3-44
APPLICATIONS INFORMATION
Bipolar PROM Devices in Plastic Leaded Chip Carriers ..... 3-48
Non-Registered PROM Programming Procedure ..... 3-51
Standard Test Load ..... 3-52
Switching Time Waveforms ..... 3-53
Approved Programmers/Quality Enhancement ..... 3-53
Section 4 Application Notes
AB-15 Protecting Data in Serial EEPROMs ..... 4-3
AB-18 Electronic Compass Calibration Made Easy with EEPROMs ..... 4-5
AN-338 Designing with the NM93C06 A Versatile Simple to Use EEPROM ..... 4-6
AN-423 The NM93C46-An Amazing Device ..... 4-12
AN-507 Using the NM93CSXX Family of Electrically Erasable Programmable Memory ..... 4-15
AN-716 Using the NM93CS EEPROM Family Features ..... 4-29
AN-731 Using National's NMC87C257 256K EPROM with On-Chip Latches ..... 4-31
AN-735 Understanding National's NM95C12 EEPROM with Programmable Switches ..... 4-33
AN-755 NM95C12 Flexibility in Industrial Control Applications ..... 4-39
AN-756 Using the NM95C12 to Solve Common Manufacturing Problems ..... 4-50
AN-758 Using National's MICROWIRE EEPROM ..... 4-62
AN-765 Using the NM95C12 CMOS EEPROM with Programmable Switches for Analog Applications ..... $4-73$
AN-766 Using the NM95C12 in a Stand Alone Metering Device ..... 4-80
AN-767 NM95C12 Memory Mapping Solution for PC® Applications ..... 4-89
AN-789 Integrated Manufacturing Control-NM95C12 ..... 4-93
AN-790 NM95C12 EEPROM Controls Amplifier Gain ..... 4-96
AN-791 Stand Alone Control of MICROWIRE Peripherals Using the NMC87C257 ..... 4-102
AN-792 NM95C12 Applications in a PC-AT Ethernet Adapter ..... 4-123
AN-794 Using an EEPROM-I²C Interface NM24C02/03/04/05/08/09/16/17 ..... 4-127
Section 5 Quality and Reliability
EPROM and EEPROM Reliability Information ..... 5-3
Section 6 Physical Dimensions
Physical Dimensions ..... 6-3BookshelfDistributors

## Alpha-Numeric Index

AB-15 Protecting Data in Serial EEPROMs ..... 4-3
$A B-18$ Electronic Compass Calibration Made Easy with EEPROMs ..... 4-5
AN-338 Designing with the NM93C06 A Versatile Simple to Use EEPROM ..... 4-6
AN-423 The NM93C46-An Amazing Device ..... 4-12
AN-507 Using the NM93CSXX Family of Electrically Erasable Programmable Memory ..... 4-15
AN-716 Using the NM93CS EEPROM Family Features ..... 4-29
AN-731 Using National's NMC87C257 256K EPROM with On-Chip Latches ..... 4-31
AN-735 Understanding National's NM95C12 EEPROM with Programmable Switches ..... 4-33
AN-755 NM95C12 Flexibility in Industrial Control Applications ..... 4-39
AN-756 Using the NM95C12 to Solve Common Manufacturing Problems ..... 4-50
AN-758 Using National's MICROWIRE EEPROM ..... 4-62
AN-765 Using the NM95C12 CMOS EEPROM with Programmable Switches for Analog Applications ..... 4-73
AN-766 Using the NM95C12 in a Stand Alone Metering Device ..... 4-80
AN-767 NM95C12 Memory Mapping Solution for PC ${ }^{\circledR}$ Applications ..... 4-89
AN-789 Integrated Manufacturing Control-NM95C12 ..... 4-93
AN-790 NM95C12 EEPROM Controls Amplifier Gain ..... 4-96
AN-791 Stand Alone Control of MICROWIRE Peripherals Using the NMC87C257 ..... 4-102
AN-792 NM95C12 Applications in a PC-AT Ethernet Adapter ..... 4-123
AN-794 Using an EEPROM-I²C Interface NM24C02/03/04/05/08/09/16/17 ..... 4-127
DM74LS471 ( $256 \times 8$ ) 2048-Bit TTL PROM ..... 3-20
DM74S188 ( $32 \times 8$ ) 256-Bit TTL PROM ..... 3-4
DM74S287 (256 x 4) 1024-Bit TTL PROM ..... 3-12
DM74S288 (32 x 8) 256-Bit TTL PROM ..... 3-8
DM74S387 (256 x 4) 1024-Bit TTL PROM ..... 3-16
DM74S472 (512 x 8) 4096-Bit TTL PROM ..... 3-24
DM74S473 (512 x 8) 4096-Bit TTL PROM ..... 3-28
DM74S570 (512 x 4) 2048-Bit TTL PROM ..... 3-32
DM74S571 (512 x 4) 2048-Bit TTL PROM ..... 3-36
DM74S572 (1024 x 4) 4096-Bit TTL PROM ..... 3-40
DM74S573 (1024 x 4) 4096-Bit TTL PROM ..... 3-44
NM24C02 2K-Bit Serial EEPROM (I2C Synchronous 2-Wire Bus) ..... 2-6
NM24C02L 2K-Bit Serial EEPROM with Extended Voltage (I2C Synchronous 2-Wire Bus) ..... 2-27
NM24C03 2K-Bit Serial EEPROM with Write Protect (I2C Synchronous 2-Wire Bus) ..... 2-17
NM24C03L 2K-Bit Serial EEPROM with Write Protect and Extended Voltage (I2C Synchronous 2-Wire Bus) ..... 2-39
NM24C04 4K-Bit Serial EEPROM (I2C Synchronous 2-Wire Bus) ..... 2-6
NM24C04L 4K-Bit Serial EEPROM with Extended Voltage (I2C Synchronous 2-Wire Bus) ..... 2-27
NM24C05 4K-Bit Serial EEPROM with Write Protect (I2C Synchronous 2-Wire Bus) ..... 2-17
NM24C05L 4K-Bit Serial EEPROM with Write Protect and Extended Voltage ( $I^{2} \mathrm{C}$ Synchronous 2-Wire Bus) ..... 2-39
NM24C08 8K-Bit Serial EEPROM (I2C Synchronous 2-Wire Bus) ..... 2-6
NM24C09 8K-Bit Serial EEPROM with Write Protect (I2C Synchronous 2-Wire Bus) ..... 2-17
NM24C16 16K-Bit Serial EEPROM (I²C Synchronous 2-Wire Bus) ..... 2-6
NM24C17 16K-Bit Serial EEPROM with Write Protect (I²C Synchronous 2-Wire Bus) ..... 2-17
NM27C010 1,048,576-Bit (128K x 8) High Performance CMOS EPROM ..... 1-61
NM27C040 4,194,304-Bit (512K x 8) High Performance CMOS EPROM ..... 1-78
NM27C128 131,072-Bit (16K x 8) High Performance CMOS EPROM ..... 1-31
NM27C210 1,048,576-Bit (64K x 16) High Performance CMOS EPROM ..... 1-69
NM27C256 262,144-Bit (32K x 8) High Performance CMOS EPROM ..... 1-41
NM27C512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) High Performance CMOS EPROM ..... 1-51

## Alpha-Numeric Index ${ }_{\text {(Continued) }}$

NM27LC256 262,144-Bit (32K x 8) Low Current CMOS EPROM ..... 1-127
NM27LC512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) Low Current CMOS EPROM ..... 1-136
NM27LV010 1,048,576-Bit (128K x 8) Low Voltage EPROM ..... 1-147
NM27LV210 1,048,576-Bit ( $64 \mathrm{~K} \times 16$ ) Low Voltage EPROM ..... 1-155
NM27LV512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) Low Voltage EPROM ..... 1-146
NM27P040 4,194,304-Bit ( $512 \mathrm{~K} \times 8$ ) Processor Oriented CMOS EPROM ..... 1-108
NM27P210 1,048,576-Bit (64K x 16) Processor Oriented CMOS EPROM ..... 1-99
NM27P512 524,288-Bit (64K x 8) Processor Oriented CMOS EPROM ..... 1-89
NM59C11 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable with Programming Status ..... $2-51$
NM93C06 256-Bit Serial EEPROM (MICROWIRE) ..... 2-58
NM93C06L 256-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5V) ..... 2-77
NM93C46 1024-Bit Serial EEPROM (MICROWIRE) ..... 2-58
NM93C46A 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable ..... 2-100
NM93C46AL 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable ..... 2-108
NM93C46L 1024-Bit Serial EEPROM with Extended Voltage ( 2.0 V to 5.5 V ) ..... 2-77
NM93C56 2048-Bit Serial EEPROM (MICROWIRE) ..... 2-58
NM93C56L 2048-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5V) ..... 2-77
NM93C66 4096-Bit Serial EEPROM (MICROWIRE) ..... 2-58
NM93C66L 4096-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5V) ..... 2-77
NM93CS06 256-Bit Serial EEPROM with Data Protect and Sequential Read ..... 2-66
NM93CS06L 256-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5V) and Data Protect ..... 2-87
NM93CS46 1024-Bit Serial EEPROM with Data Protect and Sequential Read ..... 2-66
NM93CS46L 1024-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5 V ) and Data Protect ..... $2-87$
NM93CS56 2048-Bit Serial EEPROM with Data Protect and Sequential Read ..... 2-66
NM93CS56L 2048-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5 V ) and Data Protect ..... 2-87
NM93CS66 4096-Bit Serial EEPROM with Data Protect and Sequential Read ..... 2-66
NM93CS66L 4096-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5V) and Data Protect ..... 2-87
NM95C12 1K-Bit CMOS EEPROM with Programmable Switches ..... 2-118
NMC27C16B 16,384-Bit ( $2048 \times 8$ ) CMOS EPROM ..... 1-4
NMC27C32B 32,768-Bit ( $4096 \times 8$ ) CMOS EPROM ..... 1-13
NMC27C64 65,536-Bit ( $8192 \times 8$ ) CMOS EPROM ..... 1-22
NMC87C257 262,144-Bit (32K x 8) CMOS EPROM with On-Chip Address Latches ..... 1-117

Section 1 CMOS EPROMs
Section 1 Contents
STANDARD PRODUCT EPROMS
CMOS EPROM Selection Guide ..... 1-3
NMC27C16B 16,384-Bit ( $2048 \times 8$ ) CMOS EPROM ..... 1-4
NMC27C32B 32,768-Bit ( $4096 \times 8$ ) CMOS EPROM ..... 1-13
NMC27C64 65,536-Bit ( $8192 \times 8$ ) CMOS EPROM ..... 1-22
NM27C128 131,072-Bit ( $16 \mathrm{~K} \times 8$ ) High Performance CMOS EPROM ..... 1-31
NM27C256 262,144-Bit (32K x 8) High Performance CMOS EPROM ..... 1-41
NM27C512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) High Performance CMOS EPROM ..... 1-51
NM27C010 1,048,576-Bit (128K x 8) High Performance CMOS EPROM ..... 1-61
NM27C210 1,048,576-Bit ( $64 \mathrm{~K} \times 16$ ) High Performance CMOS EPROM ..... 1-69
NM27C040 4,194,304-Bit (512K x 8) High Performance CMOS EPROM ..... 1-78
PROCESSOR ORIENTED EPROMS
Processor Oriented EPROM Selection Guide ..... 1-88
NM27P512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) Processor Oriented CMOS EPROM ..... 1-89
NM27P210 1,048,576-Bit ( $64 \mathrm{~K} \times 16$ ) Processor Oriented CMOS EPROM ..... 1-99
NM27P040 4,194,304-Bit ( $512 \mathrm{~K} \times 8$ ) Processor Oriented CMOS EPROM ..... 1-108
NMC87C257 262,144-Bit (32K x 8) CMOS EPROM with On-Chip Address Latches ..... 1-117
5V LOW CURRENT EPROMS
NM27LC256 262,144-Bit (32K x 8) Low Current CMOS EPROM ..... 1-127
NM27LC512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) Low Current CMOS EPROM ..... 1-136
LOW VOLTAGE EPROMS
NM27LV512 524,288-Bit ( $64 \mathrm{~K} \times 8$ ) Low Voltage EPROM ..... 1-146
NM27LV010 1,048,576-Bit (128K x 8) Low Voltage EPROM ..... 1-147
NM27LV210 1,048,576-Bit (64K x 16) Low Voltage EPROM ..... 1-155

## General Description

National Semiconductor's family of high performance CMOS EPROMs offer the following shared features: pin compatibility with byte-wide JEDEC EPROMs; "Don't Care" feature during read operations; high speed operation with high performance CPUs such as the 80186, 68020, 80386; single chip solutions for the code storage requirements of 100\% firmware based equipment.
A feature not shared by all family members is found in the NMC87C257-address latches for direct interfacing with address/data multiplexed microprocessors. Other differences are memory size, speed, packaging and operating temperature range.

## Features

- High performance CMOS
-100 ns access time
- Fast programming
- EPI processing
- Latch-up immunity to 200 mA
- ESD protection exceeds 2000 V
- Compatible with JEDEC EPROM configurations
- Simplified upgrade path
- VPP and PGM are "Don't Care" during normal read operation
- Single 5V power supply


## Available Product

|  | Packages | Temperature Ranges | Speed |
| :--- | :---: | :---: | :--- |
| NMC27C16B | $Q$ | C, E | $150 \mathrm{~ns}, 200 \mathrm{~ns}$ |
| NMC27C32B | $Q$ | C, E | 200 ns |
| NMC27C64 | Q, N | C, E, M* | $150 \mathrm{~ns}, 200 \mathrm{~ns}$ |
| NM27C128 | $Q, N$ | C, E | $200 \mathrm{~ns}, 250 \mathrm{~ns}$ |
| NM27C256 | Q, V,N | C, E | $100 \mathrm{~ns}, 120 \mathrm{~ns}, 150 \mathrm{~ns}, 200 \mathrm{~ns}$ |
| NM27C512 | Q,V,N | C, E | $120 \mathrm{~ns}, 150 \mathrm{~ns}, 200 \mathrm{~ns}$ |
| NM27C010 | Q,V,N | C, E | $120 \mathrm{~ns}, 150 \mathrm{~ns}, 200 \mathrm{~ns}$ |
| NM27C210 | Q, V | C, E | $120 \mathrm{~ns}, 150 \mathrm{~ns}, 200 \mathrm{~ns}$ |
| NM27C040 | Q | C, E | $150 \mathrm{~ns}, 170 \mathrm{~ns}, 200 \mathrm{~ns}$ |

*N package available only in commercial temperature range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$.
Note: All products will operate at speeds stower than those listed.

## Ordering Information



## NMC27C16B 16,384-Bit (2048 x 8) CMOS EPROM

## General Description

The NMC27C16B is a high performance 16K UV erasable and electrically reprogrammable CMOS EPROM, ideally suited for applications where fast turnaround, pattern experimentation and low power consumption are important requirements.
The NMC27C16B is packaged in a 24 -pin dual-in-line package with a quartz window. The quartz window allows the user to expose the chip to ultraviolet light to erase the bit pattern. A new pattern can then be written into the device by following the programming procedure.
This EPROM is fabricated with National's proprietary, time proven CMOS double-poly silicon gate technology which combines high performance and high density with low power consumption and excellent reliability.

## Features

- Low CMOS power consumption Active power: 55 mW max Standby power: 0.55 mW max ( $99 \%$ savings)
- Optimal EPROM for total CMOS systems
- Extended temperature range available, $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- Fast and reliable programming ( $100 \mu \mathrm{~s}$ for most bytes)
- TTL compatible inputs/outputs
- TRI-STATE ${ }^{\circledR}$ output
- Manufacturer's identification code for automatic programming equipment
- High current CMOS level output drivers
- Upgrade for NMOS 2716


## Block Diagram


Pin Names

| $\mathrm{A} 0-\mathrm{A} 10$ | Addresses |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{O}_{0}-\mathrm{O}_{7}$ | Outputs |
| PGM | Program |
| NC | No Connect |

## Connection Diagram



Note: Socket compatible EPROM pin configurations are shown in the blocks adjacent to the NMC27C16B pins.
Order Number NMC27C16BQ See NS Package Number J24AQ

Commercial Temp. Range ( $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ ) $\mathrm{V}_{\mathbf{C C}}=\mathbf{5 V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NMC27C16BQ150 | 150 |
| NMC27C16BQ200 | 200 |

Extended Temp. Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ) $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NMC27C16BQE150 | 150 |
| NMC27C16BQE200 | 200 |

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Temperature Under Bias

Commercial Parts
$-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$
Extended Temp. Parts
Storage Temperature
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
+7.0 V to -0.6 V
Respect to Ground
All Input Voltages except A9 with Respect to Ground (Note 10)
+6.5 V to -0.6 V

All Output Voltages with
Respect to Ground (Note 10) $\quad \mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to GND-0.6V
VPp Supply and A9 Voltage

| with Respect to Ground | +14.0 V to -0.6 V |
| :--- | ---: |
| Power Dissipation | 1.0 W |
| Lead Temp. (Soldering, 10 sec.$)$ | $300^{\circ} \mathrm{C}$ |

## Operating Conditions (Note 8)

Temperature Range

NMC27C16BQ150, 200
NMC27C16BQE150, 200
VCC Power Supply
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$+5 \mathrm{~V} \pm 10 \%$

## READ OPERATION

## DC Electrical Characteristics

| Symbol | Parameter | Conditions | Min | Typ <br> (Note 11) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{L}}$ | Input Load Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or GND |  | 0.1 | 1 | $\mu \mathrm{A}$ |
| ILO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \overline{\mathrm{CE}}=\mathrm{V}_{\text {IH }}$ |  | 0.1 | 1 | $\mu \mathrm{A}$ |
| ${ }^{\mathrm{ICCl}}$ <br> (Note 3) | $V_{C C}$ Current (Active) <br> TTL Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}, f=5 \mathrm{MHz} \\ & \text { Inputs }=V_{\mathrm{IH}} \text { or } V_{\mathrm{IL}} \\ & \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \\ & \hline \end{aligned}$ |  | 5 | 20 | mA |
| ICC2 <br> (Note 3) | $V_{C C}$ Current (Active) CMOS Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{GND}, \mathrm{f}=5 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \\ & \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ |  | 3 | 10 | mA |
| ICCSB1 | $V_{\text {cc }}$ Current (Standby) <br> TTL Inputs | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  | 0.1 | 1 | mA |
| ${ }^{\text {I CCSB2 }}$ | $V_{C C}$ Current (Standby) CMOS Inputs | $\overline{C E}=V_{C C}$ |  | 0.5 | 100 | $\mu \mathrm{A}$ |
| IPP | V PP Load Current | $\mathrm{V}_{\mathrm{PP}}=5.5 \mathrm{~V}$ |  |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.2 |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.0 |  | $\mathrm{V}_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |  |  | 0.45 | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage | $\mathrm{l}_{\mathrm{OH}}=-400 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage | $\mathrm{lOL}=10 \mu \mathrm{~A}$ |  |  | 0.1 | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage | $\mathrm{IOH}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}-0.1$ |  |  | V |

## AC Electrical Characteristics

| Symbol | Parameter | Conditions | NMC27C16BQ |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Q150, QE150 |  | Q200, QE200 |  |  |
|  |  |  | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 150 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 150 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{OE}}$ | $\overline{\text { OE to Output Delay }}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |  | 60 |  | 60 | ns |
| $t_{\text {DF }}$ | $\overline{\text { OE High to Output Float }}$ | $\overline{C E}=V_{\text {IL }}$ | 0 | 50 | 0 | 60 | ns |
| ${ }^{\text {t }}$ CF | $\overline{\text { CE High to Output Float }}$ | $\overline{O E}=V_{1 L}$ | 0 | 50 | 0 | 60 | ns |
| ${ }^{\text {toH }}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | $\overline{O E}=\overline{O E}=V_{\text {IL }}$ | 0 |  | 0 |  | ns |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 4)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathbb{N}}$ | Input Capacitance | $\mathrm{V}_{\mathbb{I N}}=0 \mathrm{~V}$ | 6 | 12 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 9 | 12 | pF |

## AC Test Conditions

| Output Load (Note 12) | 1 TTL Gate and $C_{L}=100 \mathrm{pF}$ | Timing Measurement Reference Level |  |
| :--- | ---: | ---: | ---: |
| Input Rise and Fall Times | $\leq 5 \mathrm{~ns}$ | Inputs | 0.8 V and 2 V |
| Input Pulse Levels | 0.45 V to 2.4 V | Outputs | 0.8 V and 2 V |

## AC Waveforms (Notes 2 \& 9)



TL/D/9180-3
Note 1: 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.
Note 2: $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{PP}}$.
Note 3: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming. $\mathrm{I}_{\mathrm{CC} 1} \leq$ the sum of the $\mathrm{I}_{\mathrm{CC}}$ active and $\mathrm{l}_{\mathrm{PP}}$ read currents.
Note 4: This parameter is only sampled and is not $100 \%$ tested.
Note 5: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impact on $t_{A C C}$.
Note 6: The $\mathrm{t}_{\mathrm{DF}}$ and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}(\mathrm{DC})-0.10 \mathrm{~V}$;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL1}}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 7: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 8: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND.
Note 9: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 10: Inputs and outputs can undershoot to -2.0 V for 20 ns maximum.
Note 11: Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
Note 12: 1 TTL Gate: $\mathrm{I}_{\mathrm{DL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ inlcudes fixture capacitance.

Programming Characteristics (Notes 1, 2, 3 \& 4)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{O E}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tves | $V_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {VPS }}$ | $V_{P P}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {DH }}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}} / \mathrm{PGM}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| tPW | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\text {OE }}$ | Data Valid from $\overline{O E}$ | $\overline{\mathrm{CE}} / \mathrm{PGM}=\mathrm{V}_{\text {IL }}$ |  |  | 150 | ns |
| IPP | $\mathrm{V}_{\mathrm{PP}}$ Supply Current During Programming Pulse | $\begin{aligned} & \overline{\mathrm{CE}}=V_{I H} \\ & \overline{\mathrm{OE}}=V_{I H} \end{aligned}$ |  |  | 30 | mA |
| $\mathrm{I}_{\mathrm{C}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  |  |  | 10 | mA |
| $\mathrm{T}_{\text {A }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{C C}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $\mathrm{V}_{\mathrm{PP}}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $t_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 3.0 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{PP}}$ or $\mathrm{V}_{\mathrm{CC}}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{Pp}}, \mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm, at typical power supply voltages and timings. The Min and Max Limit Parameters are Design parameters, not Tested or guaranteed.

## Programming Waveforms



Fast Programming Algorithm Flow Chart (Note 4)


FIGURE 1

Interactive Programming Algorithm Flow Chart (Note 4)


## Functional Description

## DEVICE OPERATION

The six modes of operation of the NMC27C16B are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{PP}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 12.75 V during the three programming modes, and must be at $\mathrm{V}_{\mathrm{CC}}$ in the other modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other modes.

## Read Mode

The NMC27C16B has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{C E}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $t_{A C C}$ ) is equal to the delay from $\overline{C E}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs $\mathrm{t}_{\mathrm{OE}}$ after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.
The sense amps are clocked for fast access time. $V_{C C}$ should therefore be maintained at operating voltage during read and verify. If $\mathrm{V}_{\mathrm{CC}}$ temporarily drops below the spec. voltage (but not to ground) an address transition must be performed after the drop to insure proper output data.

## Standby Mode

The NMC27C16B has a standby mode which reduces the active power dissipation by $99 \%$, from 55 mW to 0.55 mW . The NMC27C16B is placed in the standby mode by applying a CMOS high signal to the $\overline{C E}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output OR-Tying

Because NMC27C16Bs are usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2 -line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that $\overline{C E}$ (pin 18) be decoded and used as the pri-
mary device selecting function, while $\overline{O E}$ (pin 20) be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14V on pin $21\left(V_{\text {PP }}\right)$ will damage the NMC27C16B.
Initially, and after each erasure, all bits of the NMC27C16B are in the " 1 " state. Data is introduced by selectively programming " Os " into the desired bit locations. Although only " $0 s$ " will be programmed, both " 1 s " and " $0 s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The NMC27C16B is in the programming mode when the $V_{\text {PP }}$ power supply is at 12.75 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $V_{P P}, V_{C C}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins.
When the address and data are stable, an active high, TTL program pulse is applied to the $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ input. A program pulse must be applied at each address location to be programmed. The NMC27C16B is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu$ s pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu \mathrm{~s}$ pulse.
Note: Some programmer manufacturers due to equipment limitation may offer interactive program Algorithm (shown in Figure 2)
The NMC27C16B must not be programmed with a DC signal applied to the CE/PGM input.
Programming multiple NMC27C16Bs in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NMC27C16Bs may be connected together when they are programmed with the same data. A high level TTL pulse applied to the $\overline{\mathrm{CE}} / \mathrm{PGM}$ input programs the paralleled NMC27C16Bs.

TABLE I. Mode Selection

| Mode Pins | CE/PGM <br> (18) | $\begin{gathered} \overline{O E} \\ (20) \end{gathered}$ | $V_{\text {PP }}$ <br> (21) | $V_{c c}$ <br> (24) | $\begin{aligned} & \text { Outputs } \\ & \text { (9-11), (13-17) } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{lL}}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}$ | 5 | Dout |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | $V_{C C}$ | 5 | Hi-Z |
| Output Disable | Don't Care | $\mathrm{V}_{\mathrm{H}}$ | $\mathrm{V}_{\mathrm{CC}}$ | 5 | Hi-Z |
| Program | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | 12.75 V | 6.25 | Dout |
| Program Inhibit | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 | Hi-Z |

## Functional Description (Continued)

## Program Inhibit

Programming multiple NMC27C16Bs in parallel with different data is also easily accomplished. Except for CE/PGM all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel NMC27C16Bs may be common. A TTL high level program pulse applied to an NMC27C16B's CE/PGM input with VPP at 12.75 V will program that NMC27C16B. A TTL low level $\overline{C E} / P G M$ input inhibits the other NMC27C16Bs from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V . Except during programming and program verify, $\mathrm{V}_{\mathrm{PP}}$ must be at $\mathrm{V}_{\mathrm{CC}}$.

## MANUFACTURER'S IDENTIFICATION CODE

The NMC27C16B has a manufacturer's identification code to aid in programming. The code, shown in Table III, is two bytes wide and is stored in a ROM configuration on the chip. It identifies the manufacturer and the device type. The code for the NMC27C16B is, " 8 F 80 ", where " 8 F " designates that it is made by National Semiconductor, and " 80 " designates a 16 k part.
The code is accessed by applying $12.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10, $\overline{\mathrm{CE}}$, and $\overline{\mathrm{OE}}$ are held at $\mathrm{V}_{\mathrm{IL}}$. Address AO is held at $V_{\mathrm{IL}}$ for the manufacturer's code, and at $\mathrm{V}_{1 \mathrm{H}}$ for the device code. The code is read out on the 8 data pins. Proper code access is only guaranteed at $25^{\circ} \mathrm{C}$ $\pm 5^{\circ} \mathrm{C}$.
The primary purpose of the manufacturer's identification code is automatic programming control. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.

## ERASURE CHARACTERISTICS

The erasure characteristics of the NMC27C16B are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA$ - $4000 \AA$ range. After programming, opaque labels should be placed
over the NMC27C16B window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.
The recommended erasure procedure for the NMC27C16B is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a mimimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$.
The NMC27C16B should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table II shows the minimum NMC27C16B erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to unit should be maintained at one inch. The erasure time increases as the square of the distance. (If distance is doubled the erasure time increases by a factor of 4.) Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, ICC, has three segments that are of interest to the system de-signer-the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading the device. The associated $V_{C C}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

TABLE II. Minimum NMC27C16B Erasure Time

| Light Intensity <br> (Micro-Watts/cm <br> ) | Erasure Time <br> (Minutes) |
| :---: | :---: |
| 15,000 | 20 |
| 10,000 | 25 |
| 5,000 | 50 |

TABLE III. Manufacturer's Identification Code

| Pins | $\mathbf{A}_{\mathbf{0}}$ <br> $(8)$ | $\mathbf{O}_{7}$ <br> $(17)$ | $\mathbf{O}_{6}$ <br> $(16)$ | $\mathbf{O}_{5}$ <br> $(15)$ | $\mathbf{O}_{4}$ <br> $(14)$ | $\mathbf{O}_{3}$ <br> $(13)$ | $\mathbf{O}_{2}$ <br> $(11)$ | $\mathbf{O}_{1}$ <br> $(10)$ | $\mathbf{O}_{\mathbf{0}}$ <br> $\mathbf{( 9 )}$ | $H$ ex <br> Data |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 80 |

## NMC27C32B

32,768-Bit (4096 x 8) CMOS EPROM

## General Description

The NMC27C32B is a 32 k UV erasable and electrically reprogrammable CMOS EPROM, ideally suited for applications where fast turnaround, pattern experimentation and low power consumption are important requirements.
The NMC27C32B is designed to operate with a single +5 V power supply with $\pm 10 \%$ tolerance.
The NMC27C32B is packaged in a 24 -pin dual-in-line package with a quartz window. The quartz window allows the user to expose the chip to ultraviolet light to erase the bit pattern. A new pattern can then be written electrically into the device by following the programming procedure.
This EPROM is fabricated with National's proprietary, time proven CMOS double-poly silicon gate technology which combines high performance and high density with low power consumption and excellent reliability.

## Features

- Low CMOS power consumption
- Active Power
55 mW Max
- Standby Power 0.55 mW Max
- Extended temperature range, $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$, available
- Fast and reliable programming
- TTL, CMOS compatible inputs/outputs
- TRI-STATE® output
- Manufacturer's identification code for automatic programming control
- High current CMOS level output drivers
- Compatible with NMOS 2732


## Block Diagram



TL/D/8827-1

Connection Diagram


TL/D/8827-2
Note: Socket compatible EPROM pin configurations are shown in the blocks adjacent to the NMC27C32B pins.
Order Number NMC27C32BQ See NS Package Number J24AQ

Commercial Temp Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NMC27C32BQ150 | 150 |
| NMC27C32BQ200 | 200 |
| NMC27C32BQ250 | 250 |

Extended Temp Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ) $\mathrm{V}_{\mathrm{CC}}=\mathbf{5 V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NMC27C32BQE200 | 200 |

```
Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required,
please contact the National Semiconductor Sales
Office/Distributors for availability and specifications.
```

Temperature Under Bias
Storage Temperature
$V_{C C}$ Supply Voltage with Respect to Ground
All Input Voltages except A9 and $\overline{O E} / V_{P P}$ with
Respect to Ground (Note 9)
All Output Voltages with
Respect to Ground (Note 9) $\quad V_{C C}+1.0 \mathrm{~V}$ to GND -0.6 V
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
+7.0 V to -0.6 V
+6.5 V to -0.6 V
$\overline{O E} V_{P P}$ Supply and A9 Voltage with Respect to Ground
+14.0 V to -0.6 V
Power Dissipation
1.0 W

Lead Temperature (Soldering, 10 sec .) $300^{\circ} \mathrm{C}$
Operating Conditions (Note 6)
Temperature Range

$$
\text { NMC27C32BQ150, 200, } 250 \quad 0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}
$$ NMC27C32BQE200

$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$V_{\text {CC }}$ Power Supply
$+5 \mathrm{~V} \pm 10 \%$

## READ OPERATION

## DC Electrical Characteristics

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or GND |  | 0.01 | 1 | $\mu \mathrm{A}$ |
| Ipp | $\overline{O E} / V_{\text {PP }}$ Load Current | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}=V_{C C}$ or GND |  |  | 10 | $\mu \mathrm{A}$ |
| lo | Output Leakage Current | $V_{\text {OUT }}=V_{\text {CC }}$ or $\mathrm{GND}, \overline{\mathrm{CE}}=\mathrm{V}_{\text {IH }}$ |  | 0.01 | 1 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | $\mathrm{V}_{\mathrm{CC}}$ Current (Active) TTL Inputs | $\begin{aligned} & \overline{C E}=V_{I L}, f=5 \mathrm{MHz} \\ & \text { Inputs }=V_{I H} \text { or } V_{\mathrm{IL}}, I / O=0 \mathrm{~mA} \end{aligned}$ |  | 5 | 20 | mA |
| ICC2 | $\mathrm{V}_{\mathrm{CC}}$ Current (Active) CMOS Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{GND}, \mathrm{f}=5 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ |  | 3 | 10 | mA |
| ICCSB1 | $V_{\text {CC }}$ Current (Standby) <br> TTL Inputs | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  | 0.1 | 1 | mA |
| $\mathrm{I}_{\text {ccsb2 }}$ | $V_{C C}$ Current (Standby) CMOS Inputs | $\overline{C E}=V_{C C}$ |  | 0.5 | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.2 |  | 0.8 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage | $\mathrm{IOL}=2.1 \mathrm{~mA}$ |  |  | 0.45 | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage | $\mathrm{IOL}=10 \mu \mathrm{~A}$ |  |  | 0.1 | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage | $\mathrm{IOH}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}-0.1$ |  |  | V |

## AC Electrical Characteristics

| Symbol | Parameter | Conditions | NMC27C32B |  |  |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Q150 |  | Q200, QE200 |  | Q250 |  |  |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ |  | 150 |  | 200 |  | 250 | ns |
| $\mathrm{t}_{\text {CE }}$ | $\overline{\mathrm{CE}}$ to Output Delay | $\overline{O E}=V_{\text {IL }}$ |  | 150 |  | 200 |  | 250 | ns |
| toe | $\overline{\text { OE }}$ to Output Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 60 |  | 60 |  | 70 | ns |
| $t_{\text {dF }}$ | $\overline{\text { OE High to Output Float }}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ | 0 | 50 | 0 | 60 | 0 | 70 | ns |
| $\mathrm{t}_{\mathrm{CF}}$ | $\overline{\mathrm{CE}}$ High to Output Float | $\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ | 0 | 50 | 0 | 60 | 0 | 60 | ns |
| ${ }^{\text {toh }}$ | Output Hold from Addresses, $\overline{C E}$ or $\overline{O E}$, Whichever Occurred First | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ | 0 |  | 0 |  | 0 |  | ns |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathfrak{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN} 1}$ | Input Capacitance except $\overline{\mathrm{OE} / \mathrm{V}_{\mathrm{PP}}}$ | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ | 6 | 12 | pF |
| $\mathrm{C}_{\mathrm{IN} 2}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ | 16 | 20 | pF |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | $\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}$ | 9 | 12 | pF |

## AC Test Conditions

| Output Load | 1 TTL Gate and $C_{L}=100 \mathrm{pF}(\text { Note 8) }$ | Timing Measurement Reference Level Inputs | 0.8 V and 2 V |
| :---: | :---: | :---: | :---: |
| Input Rise and Fall Times | $\leq 5 \mathrm{~ns}$ | Outputs | 0.8 V and 2 V |
| Input Pulse Levels | 0.45 V to 2.4 V |  |  |

## AC Waveforms (Note 7)



TL/D/8827-3
Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{\text {OE }}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The $\mathrm{t}_{\mathrm{DF}}$ and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}(\mathrm{DC})-0.10 \mathrm{~V}$;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL}}$ (DC) +0.10 V .
Note 5: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $V_{C C}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{IOL}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: Inputs and outputs can undershoot to -2.0 V for 20 ns Max , except for $\overline{\mathrm{O}} / \mathrm{V}_{\mathrm{PP}}$ which cannot exceed -0.2 V .
Note 10: Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.

Programming Characteristics (Notes 1, 2, 3\& 4)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A S}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tves | $V_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {dH }}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{CF}}$ | Chip Enable to Output Float Delay | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toen | OE Hold Time |  | 1 |  |  | ns |
| $\mathrm{t}_{\mathrm{DV}}$ | Data Valid from $\overline{\mathrm{CE}}$ | $\overline{O E}=V_{\text {IL }}$ |  |  | 250 | ns |
| $t_{\text {PRT }}$ | $\overline{\text { OE Pulse Rise Time }}$ During Programming |  | 50 |  |  | ns |
| $t_{V R}$ | $V_{\text {PP }}$ Recovery Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| IPP | $V_{\text {Pp }}$ Supply Current During Programming Pulse | $\begin{aligned} & \overline{\mathrm{CE}}=V_{\mathrm{IL}}, \\ & \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{PP}} \\ & \hline \end{aligned}$ |  |  | 30 | mA |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  |  | 10 | mA |
| $\mathrm{T}_{\text {A }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{C C}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $V_{P P}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $\mathrm{t}_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

## Programming Waveforms



TL/D/8827-4
Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $V_{P P}$ or $V_{C C}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $V_{C C}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm, at typical power supply voltages and timings.

Fast Programming Algorithm Flow Chart (Note 4)


FIGURE 1

Interactive Programming Algorithm Flow Chart (Note 4)


FIGURE 2

## Functional Description

## DEVICE OPERATION

The six modes of operation of the NMC27C32B are listed in Table I. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for $\overline{O E} / V_{P P}$ during programming. In the program mode the $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ input is pulsed from a TTL low level to 12.75 V .

## Read Mode

The NMC27C32B has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs $\mathrm{t}_{\mathrm{OE}}$ after the falling edge of $\overline{\mathrm{OE}}$, assuming that $\overline{\mathrm{CE}}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.
The sense amps are clocked for fast access time. $V_{C C}$ should therefore be maintained at operating voltage during read and verify. If $\mathrm{V}_{\mathrm{CC}}$ temporarily drops below the spec. voltage (but not to ground) an address transition must be performed after the drop to ensure proper output data.

## Standby Mode

The NMC27C32B has a standby mode which reduces the active power dissipation by $99 \%$, from 55 mW to 0.55 mW . The NMC27C32B is placed in the standby mode by applying a CMOS high signal to the $\overline{\mathrm{CE}}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output OR-Tying

Because EPROMs are usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connection. The 2-line control function allows for:
a. The lowest possible memory power dissipation, and
b. complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that $\overline{C E}$ (pin 18) be decoded and used as the primary device selecting function, while $\overline{\mathrm{OE}}$ (pin 20) be made a
common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on pin $20 \overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ will damage the NMC27C32B.
Initially, and after each erasure, all bits of the NMC27C32B are in the " 1 " state. Data is introduced by selectively programming " Os " into the desired bit locations. Although only "0s" will be programmed, both " 1 s " and " 0 s " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The NMC27C32B is in the programming mode when $\overline{\mathrm{OE} /}$ $V_{P P}$ is at 12.75 V . It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{CC}}$ and ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{C E}$ input. A program pulse must be applied at each address location to be programmed. The NMC27C32B is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu$ s pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will Program with a single $100 \mu$ s pulse.
Note: Some programmer manufactures due to equipment limitation may offer interactive program Algorithm (Shown in Figure 2).
The NMC27C32B must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}}$ input.
Programming multiple NMC27C32Bs in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NMC27C32B may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\mathrm{CE}}$ input programs the paralleled NMC27C32B.

TABLE I. Mode Selection

| Pins | $\overline{C E}$ <br> (18) | $\overline{O E} / V_{P P}$ <br> (20) | $V_{\text {cc }}$ <br> (24) | $\begin{aligned} & \text { Outputs } \\ & (9-11,13-17) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |
| Read | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | 5 V | Dout |
| Standby | $\mathrm{V}_{\text {IH }}$ | Don't Care | 5 V | $\mathrm{Hi}-\mathrm{Z}$ |
| Program | $\mathrm{V}_{\text {IL }}$ | 12.75 V | 6.25 V | $\mathrm{DIN}_{\text {I }}$ |
| Program Verify | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$ | 6.25 V | Dout |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | $\mathrm{Hi}-\mathrm{Z}$ |
| Output Disable | Don't Care | $\mathrm{V}_{\mathrm{IH}}$ | 5 V | Hi-Z |

## Functional Description (Continued)

## Program Inhibit

Programming multiple NMC27C32B in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}}$ all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel NMC27C32B may be common. A TTL low level program pulse applied to an NMC27C32B's $\overline{C E}$ input with $\overline{O E} / V_{P P}$ at 12.75 V will program that NMC27C32B. A TTL high level $\overline{\mathrm{CE}}$ input inhibits the other NMC27C32B from being programmed.

## Program Verify

A verify should be performed on the programmed bit to determine whether they were correctly programmed. The verify is accomplished with $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ and $\overline{\mathrm{CE}}$ at $\mathrm{V}_{\mathrm{IL}}$. Data should be verified $t_{D V}$ after the falling edge of $\overline{C E}$.

## MANUFACTURER'S IDENTIFICATION CODE

The NMC27C32B has a manufacturer's identification code to aid in programming. The code, shown in Table II, is two bytes wide and is stored in a ROM configuration on the chip. It identifies the manufacturer and the device type. The code for the NMC27C32B is, " $8 F 01$ ", where " 8 F " designates that it is made by National Semiconductor, and " 01 " designates a 32 k part.
The code is accessed by applying $12.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A11, $\overline{\mathrm{CE}}$, and $\overline{\mathrm{OE}}$ are held at $\mathrm{V}_{\mathrm{IL}}$. Address $A 0$ is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and at $V_{I H}$ for the device code. The code is read out on the 8 data pins. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.
The primary purpose of the manufacturer's identification code is automatic programming control. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.

## ERASURE CHARACTERISTICS

The erasure characteristics of the NMC27C32B are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA 1-4000 \AA$ range. After programming, opaque labels should be placed over the NMC27C32B's window to prevent unintentional
erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.
The recommended erasure procedure for the NMC27C32B is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$.
The NMC27C32B should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table III shows the minimum NMC27C32B erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to unit should be maintained at one inch. The erasure time increases as the square of the distance. (If distance is doubled the erasure time increases by a factor of 4.) Lamps lose intensity as they age. When a lamp is changed, the distance has changed or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, Icc, has three segments that are of interest to the system de-signer-the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $\mathrm{V}_{\mathrm{CC}}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

TABLE II. Manufacturer's Identification Code

| Pins | AO <br> (8) | $\begin{gathered} 0_{7} \\ (17) \\ \hline \end{gathered}$ | $\begin{gathered} O_{6} \\ (16) \end{gathered}$ | $\begin{gathered} \mathrm{O}_{5} \\ (15) \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{O}_{4} \\ (14) \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{O}_{3} \\ (13) \end{gathered}$ | $\begin{gathered} \mathrm{O}_{2} \\ (11) \end{gathered}$ | $\begin{gathered} O_{1} \\ (10) \\ \hline \end{gathered}$ | $\mathrm{O}_{0}$ <br> (9) | Hex <br> Data |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\text {IL }}$ | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8F |
| Device Code | $\mathrm{V}_{1 \mathrm{H}}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 01 |

TABLE III. Minimum NMC27C32B Erasure Time

| Light Intensity <br> $\left(\mu \mathbf{W} / \mathrm{cm}^{\mathbf{2}}\right)$ | Erasure Time <br> (Minutes) |
| :---: | :---: |
| 15,000 | 20 |
| 10,000 | 25 |
| 5,000 | 50 |

National
Semiconductor
NMC27C64

## 65,536-Bit (8192 x 8) CMOS EPROM

## General Description

The NMC27C64 is a 64 K UV erasable, electrically reprogrammable and one-time programmable (OTP) CMOS EPROM ideally suited for applications where fast turnaround, pattern experimentation and low power consumption are important requirements.
The NMC27C64 is designed to operate with a single +5 V power supply with $\pm 5 \%$ or $\pm 10 \%$ tolerance. The CMOS design allows the part to operate over extended and military temperature ranges.
The NMC27C64Q is packaged in a 28-pin dual-in-line package with a quartz window. The quartz window allows the user to expose the chip to ultraviolet light to erase the bit pattern. A new pattern can then be written electrically into the device by following the programming procedure.
The NMC27C64N is packaged in a 28 -pin dual-in-line plastic molded package without a transparent lid. This part is ideally suited for high volume production applications where cost is an important factor and programming only needs to be one once.
This family of EPROMs are fabricated with National's proprietary, time proven CMOS double-poly silicon gate technology which combines high performance and high density with low power consumption and excellent reliability.

## Features

- High performance CMOS - 120 ns access time
- High reliability with EPI processing - Latch-up immunity to 200 mA - ESD protection exceeds 2000V
- JEDEC standard pin configuration - 28-pin DIP package
- 32-pin chip carrier
- Drop-in replacement for 27C64 or 2764
- Manufacturers identification code


## Block Diagram



TL/D/8634-1

## Connection Diagram



Note: Socket compatible EPROM pin configurations are shown in the blocks adjacent to the NMC27C64 pins.

Commercial Temperature Range
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NMC27C64Q, N150 | 150 |
| NMC27C64Q, N200 | 200 |
| NMC27C64Q, N250 | 250 |

Extended Temp Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NMC27C64QE150 | 150 |
| NMC27C64QE200 | 200 |

Military Temp Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )
$V_{\text {CC }}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NMC27C64QM200 | 200 |
| NMC27C64QM250 | 250 |

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

Temperature Under Bias
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input Voltages except A9 with
Respect to Ground (Note 10)
+6.5 V to -0.6 V
All Output Voltages with
Respect to Ground (Note 10) $\quad \mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to GND -0.6 V
VPp Supply Voltage and A9 with Respect to Ground During Programming

$$
+14.0 \mathrm{~V} \text { to }-0.6 \mathrm{~V}
$$

| VCC Supply Voltage with |  |
| :--- | ---: |
| $\quad$ Respect to Ground | +7.0 V to -0.6 V |
| Power Dissipation | 1.0 W |
| Lead Temperature (Soldering, 10 sec.) | $300^{\circ} \mathrm{C}$ |
| ESD Rating |  |
| $\quad$(Mil Spec 883C, Method 3015.2) | 2000 V |

## Operating Conditions (Note 7)

Temperature Range

| NMC27C64Q15, Q150, 200, 250 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| NMC27C64N150, 200, 250 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| NMC27C64QE150, 200 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| NMC27C64QM200, M250 | $+5 \mathrm{~V} \pm 10 \%$ |

## READ OPERATION

## DC Electrical Characteristics

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ILI | Input Load Current | $V_{\text {IN }}=V_{C C}$ or GND |  |  | 10 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \overline{\mathrm{CE}}=\mathrm{V}_{\text {IH }}$ |  |  | 10 | $\mu \mathrm{A}$ |
| $I_{C C 1}$ <br> (Note 9) | $V_{C C}$ Current (Active) <br> TTL Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{f}=5 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ |  | 5 | 20 | mA |
| ICC2 (Note 9) | $\mathrm{V}_{\mathrm{CC}}$ Current (Active) CMOS Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{GND}, \mathrm{f}=5 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ |  | 3 | 10 | mA |
| ICCSB 1 | $V_{\text {CC }}$ Current (Standby) TTL Inputs | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  | 0.1 | 1 | mA |
| ICCsB2 | $\mathrm{V}_{\mathrm{CC}}$ Current (Standby) CMOS Inputs | $\overline{C E}=V_{C C}$ |  | 0.5 | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {PP }}$ | Vpp Load Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  | -0.1 |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.0 |  | $\mathrm{V}_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage | $\mathrm{lOL}^{2}=2.1 \mathrm{~mA}$ |  |  | 0.45 | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  |  | V |
| Vol2 | Output Low Voltage | $\mathrm{lOL}=0 \mu \mathrm{~A}$ |  |  | 0.1 | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage | $\mathrm{IOH}=0 \mu \mathrm{~A}$ | $V_{C C}-0.1$ |  |  | V |

## AC Electrical Characteristics

| Symbol | Parameter | Conditions | NMC27C64Q/N |  |  |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 15, 150, E150 |  | 200, E200, M200 |  | 250, M250 |  |  |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\begin{aligned} & \overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IH}} \end{aligned}$ |  | 150 |  | 200 |  | 250 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{C E}$ to Output Delay | $\overline{O E}=V_{1 L}, \overline{\text { PGM }}=V_{I H}$ |  | 150 |  | 200 |  | 250 | ns |
| toe | $\overline{O E}$ to Output Delay | $\overline{C E}=V_{\text {IL }}, \overline{P G M}=V_{I H}$ |  | 60 |  | 60 |  | 70 | ns |
| ${ }_{\text {t }}$ | $\overline{\text { OE High to Output Float }}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{I L}, \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IH}}$ | 0 | 60 | 0 | 60 | 0 | 60 | ns |
| $\mathrm{t}_{\mathrm{CF}}$ | $\overline{\mathrm{CE}}$ High to Output Float | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IH}}$ | 0 | 60 | 0 | 60 | 0 | 60 | ns |
| ${ }^{\text {toH }}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | $\begin{aligned} & \overline{C E}=\overline{O E}=V_{I L} \\ & \overline{P G M}=V_{I H} \end{aligned}$ | 0 |  | 0 |  | 0 |  | ns |

Capacitance $T_{A}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2) NMC27C64Q

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}$ | 6 | 8 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ | 9 | 12 | pF |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2) NMC27C64N

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ | 5 | 10 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ | 8 | 10 | pF |

## AC Test Conditions

Output Load $C_{L}=100 \mathrm{pF}($ Note 8$)$
$\leq 5 \mathrm{~ns}$
0.45 V to 2.4 V

Timing Measurement Reference Level Inputs
0.8 V and 2 V Outputs 0.8 V and 2 V

Input Rise and Fall Times Input Pulse Levels

## AC Waveforms (Notes 6 \& 9)



TL/D/8634-3
Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The $t_{D F}$ and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V ;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL}}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 5: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND.
Note 7: The outputs must be restricted to $\mathrm{V}_{C C}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TLL Gate: $\mathrm{IOL}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.


| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 2 |  |  | $\mu \mathrm{s}$ |
| ${ }^{\text {t CES }}$ | CE Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| tvPS | $V_{\text {PP }}$ Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| tvcs | $\mathrm{V}_{\text {CC }}$ Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DH }}$ | Data Hold Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{C E}=V_{1 L}$ | 0 |  | 130 | ns |
| tpw | Program Pulse Width |  | 0.45 | 0.5 | 0.55 | ms |
| toe | Data Valid from OE | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 150 | ns |
| IpP | VPp Supply Current During Programming Puise | $\begin{aligned} & \overline{C E}=V_{I L} \\ & \overline{P G M}=V_{I L} \end{aligned}$ |  |  | 30 | mA |
| ICC | $V_{\text {CC }}$ Supply Current |  |  |  | 10 | mA |
| $\mathrm{T}_{\text {A }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{\text {cc }}$ | Power Supply Voltage | , | 5.75 | 6.0 | 6.25 | V |
| $V_{\text {Pp }}$ | Programming Supply Voltage |  | 12.2 | 13.0 | 13.3 | V |
| $t_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 | 1.5 | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 | 1.5 | 2.0 | V |

## Programming Waveforms (Note 3)



TL/D/8634-6
Note 1: National's standard product warranty applies to devices programmed to specifications described herein.
Note 2: $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{PP}}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{P}}$ or $\mathrm{V}_{\mathrm{CC}}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $\mathrm{V}_{\mathrm{PP}}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{Pp}}$, $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the interactive Program Algorithm, at typical power supply voltages and timings.

## Interactive Programming Algorithm Flow Chart



## Functional Description

## DEVICE OPERATION

The six modes of operation of the NMC27C64 are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{Pp}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 13.0 V during the three programming modes, and must be at 5 V in the other three modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The NMC27C64 has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. The programming pin ( $\overline{\mathrm{PGM}}$ ) should be at $\mathrm{V}_{I H}$ except during programming. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs toE after the falling edge of $\overline{O E}$, assuming that $\overline{\mathrm{CE}}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.
The sense amps are clocked for fast access time. VCC should therefore be maintained at operating voltage during read and verify. If $\mathrm{V}_{\mathrm{CC}}$ temporarily drops below the spec. voltage (but not to ground) an address transition must be performed after the drop to insure proper output data.

## Standby Mode

The NMC27C64 has a standby mode which reduces the active power dissipation by $99 \%$, from 55 mW to 0.55 mW . The NMC27C64 is placed in the standby mode by applying a CMOS high signal to the $\overline{C E}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output OR-Tying

Because NMC27C64s are usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.

To most efficiently use these two control lines, it is recommended that $\overline{C E}$ (pin 20) be decoded and used as the primary device selecting function, while $\overline{O E}$ (pin 22) be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on pin $1(\mathrm{~V} P$ ) will damage the NMC27C64.
Initially, all bits of the NMC27C64 are in the "1" state. Data is introduced by selectively programming " $0 s$ " into the desired bit locations. Although only "Os" will be programmed, both " 1 s " and " 0 s " can be presented in the data word. A " 0 " cannot be changed to a " 1 " once the bit has been programmed.
The NMC27C64 is in the programming mode when the $\mathrm{V}_{\mathrm{PP}}$ power supply is at 13.0 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $V_{P P}, V_{C C}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
For programming, $\overline{C E}$ should be kept TTL low at all times while $V_{P P}$ is kept at 13.0 V .
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{PGM}}$ input. A program pulse must be applied at each address location to be programmed. The NMC27C64 is designed to be programmed with interactive programming, where each address is programmed with a series of 0.5 ms pulses until it verifies (up to a maximum of 20 pulses or 10 ms ). The NMC27C64 must not be programmed with a DC signal applied to the $\overline{\text { PGM }}$ input.
Programming multiple NMC27C64s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NMC27C64s may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\text { PGM }}$ input programs the paralleled NMC27C64s. If an application requires erasing and reprogramming, the NMC27C64Q UV erasable PROM in a windowed package should be used.

TABLE I. Mode Selection

| Pins <br> Mode | $\begin{aligned} & \overline{C E} \\ & \text { (20) } \end{aligned}$ | $\begin{aligned} & \overline{O E} \\ & (22) \end{aligned}$ | $\overline{\text { PGM }}$ <br> (27) | $V_{\text {PP }}$ <br> (1) | $V_{C C}$ <br> (28) | $\begin{aligned} & \text { Outputs } \\ & (11-13,15-19) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{i}}$ | 5 V | 5 V | Dout |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | Don't Care | 5 V | 5 V | Hi-Z |
| Output Disable | Don't Care | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 5 V | 5 V | Hi-Z |
| Program | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ |  | 13 V | 6 V | $\mathrm{DIN}^{\text {I }}$ |
| Program Verify | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 13 V | 6 V | Dout |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | Don't Care | 13V | 6 V | Hi-Z |

## Functional Description (Continued)

## Program Inhibit

Programming multiple NMC27C64s in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}}$ all like inputs (including $\overline{\mathrm{OE}}$ and $\overline{\mathrm{PGM}}$ ) of the parallel NMC27C64 may be common. A TTL low level program pulse applied to an NMC27C64's PGM input with CE at $V_{I L}$ and $V_{P P}$ at 13.0 V will program that NMC27C64. A TTL high level $\overline{C E}$ input inhibits the other NMC27C64s from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $V_{P P}$ at 13.0 V . $V_{P P}$ must be at $\mathrm{V}_{\mathrm{CC}}$, except during programming and program verify.

## MANUFACTURER'S IDENTIFICATION CODE

The NMC27C64 has a manufacturer's identification code to aid in programming. The code, shown in Table II, is two bytes wide and is stored in a ROM configuration on the chip. It identifies the manufacturer and the device type. The code for the NMC27C64 is "8FC2", where " 8 F " designates that it is made by National Semiconductor, and "C2" designates a 64k part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A12, $\overline{\mathrm{CE}}$, and $\overline{\mathrm{OE}}$ are held at $\mathrm{V}_{\mathrm{IL}}$. Address AO is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read out on the 8 data pins. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.
The primary purpose of the manufacturer's identification code is automatic programming control. When the device is inserted in a EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.

## ERASURE CHARACTERISTICS

The erasure characteristics of the NMC27C64 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.
After programming, opaque labels should be placed over the NMC27C64's window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

The recommended erasure procedure for the NMC27C64 is exposure to short wave ultraviolet light which has a wavelength of 2537 Angstroms ( $\AA$ ). The integrated dose (i.e., UV intensity $x$ exposure time) for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$.
The NMC27C64 should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table III shows the minimum NMC27C64 erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to unit should be maintained at one inch. The erasure time increases as the square of the distance. (If distance is doubled the erasure time increases by a factor of 4.) Lamps lose intensity as they age. When a lamp is changed, the distance has changed or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, I $\mathrm{I}_{\mathrm{C}}$, has three segments that are of interest to the system de-signer-the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{\mathrm{CC}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

TABLE II. Manufacturer's Identification Code

| Pins | $\mathbf{A}_{\mathbf{0}}$ <br> $(10)$ | $\mathbf{O}_{7}$ <br> $(19)$ | $\mathbf{O}_{6}$ <br> $(18)$ | $\mathbf{O}_{5}$ <br> $(17)$ | $\mathbf{O}_{4}$ <br> $(16)$ | $\mathbf{O}_{3}$ <br> $(15)$ | $\mathbf{O}_{\mathbf{2}}$ <br> $(13)$ | $\mathbf{O}_{1}$ <br> $(12)$ | $\mathbf{O}_{\mathbf{0}}$ <br> $(11)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | C 2 |

TABLE III. Minimum NMC27C64 Erasure Time

| Light Intensity <br> (Micro-Watts/cm <br> 2 | Erasure Time <br> (Minutes) |
| :---: | :---: |
| 15,000 | 20 |
| 10,000 | 25 |
| 5,000 | 50 |

## NM27C128

131,072-Bit (16K x 8) High Performance CMOS EPROM

## General Description

The NM27C128 is a high performance 128K UV Erasable Electrically Programmable Read Only Memory. It is manufactured with National's latest CMOS split gate EPROM technology which enables it to operate at speeds as fast as 100 ns access time over the full operating range. (If faster speeds are required, contact your National sales representative.)
The NM27C128 provides microprocessor-based systems extensive storage capacity for large portions of operating system and application software. Its 100 ns access time provides high speed operation with high-performance CPUs. The NM27C128 offers a single chip solution for the code storage requirements of $100 \%$ firmware-based equipment. Frequently-used software routines are quickly executed from EPROM storage, greatly enhancing system utility.
The NM27C128, is configured in the standard EPROM pinout which provides an easy upgrade path for systems which are currently using standard EPROMs.

The NM27C128 is one member of a high density EPROM Family which range in densities up to 4 Mb .

## Features

- High performance CMOS
- 100 ns access time
- Fast turn-off for microprocessor compatibility
- EPI processing
- Latch-up immunity to 200 mA
- ESD protection exceeds 2000 V
- JEDEC standard pin configuration
- 28-pin DIP package
- 32-pin chip carrier
- Drop-in replacement for 27 C 128 or 27128


## Block Diagram



TL/D/11329-1

## Connection Diagrams

| 27C080 | 27C040 | $27 \mathrm{CO20}$ | 27C010 | $27 C 512$ | 27C256 |  |  |  |  | 27C256 | 27 C 512 | 27C010 | 27C020 | 27C040 | 27C080 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A19 | $V_{\text {PP }}$ | $V_{P P}$ | $V_{P P}$ |  |  |  |  |  |  |  |  | $V_{\text {CC }}$ | $V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ |
| A16 | A16 | A16 | A16 |  |  |  |  |  |  |  |  | PGM | $\overline{\text { PGM }}$ | A18 | A18 |
| A15 | A15 | A15 | A15 | A15 | $V_{\text {PP }}$ | - $\mathrm{V}_{\mathrm{PP}}$ | 1 | 28 | $\square \mathrm{v}_{c c}$ - | $\mathrm{V}_{\mathrm{Cc}}$ | $V_{\text {cc }}$ | XX | A17 | A17 | A17 |
| A12 | A12 | A12 | A12 | A12 | A12 | A12 | 2 | 27 | $\overline{\text { PGM }}$ | A14 | A14 | A14 | A14 | A14 | A14 |
| A7 | A7 | A7 | A7 | A7 | A7 | - A7L | 3 | 26 | A13 - | A13 | A13 | A13 | A13 | A13 | A13 |
| A6 | A6 | A6 | A6 | A6 | A6 | A6 | 4 | 25 | A8 | A8 | A8 | A8 | A8 | A8 | A8 |
| A5 | A5 | A5 | A5 | A5 | A5 | - A5 | 5 | 24 | A9 | A9 | A9 | A9 | A9 | A9 | A9 |
| A4 | A4 | A4 | A4 | A4 | A4 | A | 6 | 23 | ]a11 - | A11 | A11 | A11 | A11 | A11 | A11 |
| A3 | A3 | A3 | A3 | A3 | A3 | A3 | 7 | 22 | $\overline{O E}$ | ठE | $\overline{O E /} V_{P P}$ | OE | OE | $\overline{O E}$ | OE/VPP |
| A2 | A2 | A2 | A2 | A2 | A2 | - A2 |  | 21 | A10 | A10 | A10 | A10 | A10 | A10 | A10 |
| A1 | A1 | A1 | A1 | A1 | A1 | - A1L | 9 | 20 | $\overline{\mathrm{CE}}$ | CE | CE/PGM | CE | CE | CE/PGM | CE/PGM |
| A0 | A0 | A0 | A0 | A0 | A0 | A0 | 10 | 19 | $\square 07-$ | 07 | 07 | 07 | 07 | 07 | 07 |
| O0 | O0 | 00 | 00 | O0 | 00 | 00 L | 11 | 18 | 06 | 06 | 06 | 06 | 06 | 06 | 06 |
| 01 | 01 | 01 | 01 | 01 | 01 | 0 | 12 | 17 | 05 | O5 | 05 | 05 | 05 | O5 | 05 |
| 02 | 02 | O2 | O2 | O2 | 02 | 025 | 13 | 16 | 04 | 04 | 04 | 04 | 04 | 04 | 04 |
| GND | GND | GND | GND | GND | GND | - GND | 14 | 15 | 03 | O3 | O3 | 03 | O3 | O3 | O3 |

TL/D/11329-2
Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27C128 pins.

Commercial Temp. Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27C128 Q, N, V 100 | 100 |
| NM27C128 Q, N, V 120 | 120 |
| NM27C128 Q, N, V 150 | 150 |
| NM27C128 Q, N, V 200 | 200 |

Military Temp. Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27C128 QM 120 | 120 |
| NM27C128 QM 150 | 150 |

Pin Names

| Symbol | Description |
| :--- | :--- |
| A0-A13 | Addresses |
| $\overline{\text { CE }}$ | Chip Enable |
| $\overline{\text { OE }}$ | Output Enable |
| O0-O7 | Outputs |
| $\overline{\text { PGM }}$ | Program |
| NC | No Connect |

Extended Temp. Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27C128 QE, NE, VE 120 | 120 |
| NM27C128 QE, NE, VE 150 | 150 |
| NM27C128 QE, NE, VE 200 | 200 |

Note: Surface mount PLCC package available for commercial and extended temperature ranges only.

Package Types: NM27C128 Q, N, V XXX
$Q=$ Quartz-Windowed Ceramic DIP
$\mathrm{N}=$ Plastic OTP DIP
$V=$ Surface-Mount PLCC

- All packages conform to the JEDEC standard.
- All versions are guaranteed to function for slower speeds.


Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for avallability and specifications.
Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input Voltages except A9 with
Respect to Ground
-0.6 V to +7 V
$V_{P P}$ and A9 with Respect
to Ground
$V_{C C}$ Supply Voltage with
Respect to Ground
-0.7 V to +14 V

ESD Protection
All Output Voltages with
Respect to Ground
$V_{C C}+1.0 \mathrm{~V}$ to $\mathrm{GND}-0.6 \mathrm{~V}$

## Read Operation

DC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level |  | -0.5 | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Level |  | 2.0 | $\mathrm{V}_{\mathrm{CC}}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{IOH}=-2.5 \mathrm{~mA}$ | 3.5 |  | V |
| $\mathrm{I}_{\mathrm{CCSB}}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current (CMOS) | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}}=\mathrm{GND} \pm 0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V} \end{aligned}$ |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{Cc}} \mathrm{SB} 2$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current ( $\mathrm{T}^{2} \mathrm{~L}$ ) | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  | 1 | mA |
| $\mathrm{I}_{\mathrm{CCt}}$ | $\mathrm{V}_{C C}$ Active Current, $\mathrm{T}^{2} \mathrm{~L}$ Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{f}=5 \mathrm{MHz} \\ & \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ |  | 40 | mA |
| ${ }^{\text {c CC2 }}$ | $V_{\text {CC }}$ Active Current CMOS Inputs | $\begin{aligned} & \hline \mathrm{CE}=\mathrm{GND}, \mathrm{f}=5 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \\ & \mathrm{C}, \mathrm{I} \text { Temp. Range } \end{aligned}$ |  | 35 | mA |
| $\mathrm{l}_{\mathrm{pp}}$ | VPP Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  | 10 | $\mu \mathrm{A}$ |
| VPP | Vpp Read Voltage |  | $\mathrm{V}_{\mathrm{CC}}-0.7$ | $\mathrm{V}_{\mathrm{CC}}$ | V |
| $\mathrm{l}_{\mathrm{LI}}$ | Input Load Current | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ or GND | -1 | 1 | $\mu \mathrm{A}$ |
| lo | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND | -10 | 10 | $\mu \mathrm{A}$ |

AC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | 120 |  | 150 |  | 200 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 120 |  | 150 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 120 |  | 150 |  | 200 | ns |
| toe | $\overline{\text { OE }}$ to Output Delay |  | 50 |  | 50 |  | 50 | ns |
| tcF <br> (Note 2) | $\overline{\text { CE High to Output Float }}$ |  | 30 |  | 45 |  | 55 | ns |
| $t_{D F}$ <br> (Note 2) | $\overline{\text { OE High to Output Float }}$ |  | 35 |  | 45 |  | 55 | ns |
| ${ }^{\mathrm{t}} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, <br> Whichever Occurred First | 0 |  | 0 |  | 0 |  | ns |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{I N}=\mathrm{OV}$ | 6 | 12 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ | 9 | 12 | pF |

## AC Test Conditions

| Output Load | 1 TTL Gate and <br> $100 \mathrm{pF}($ Note 8$)$ <br>  <br> Input Rise and Fall Times$\quad \leq 5 \mathrm{~ns}$ |
| :--- | ---: |

Input Pulse Levels
Timing Measurement Reference Level
Inputs
Outputs

## AC Waveforms (Notes 6, 7 and 9)



TL/D/11329-4
Note 1: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{\mathrm{OE}}$ may be delayed up to $\mathrm{t}_{\mathrm{ACC}}-\mathrm{t}_{\mathrm{OE}}$ after the falling edge of $\overline{\mathrm{CE}}$ without impacting $\mathrm{t}_{\mathrm{ACC}}$.
Note 4: The tDF and tCF compare level is determined as follows:
High to TRI-STATE ${ }^{*}$, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V ;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL1}}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 5: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.

Note 7: The outputs must be restricted to $V_{C C}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: TTL Gate: $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$C_{L}=100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $\mathrm{V}_{\mathrm{Pp}}$ may be connected to $\mathrm{V}_{\mathrm{Cc}}$ except during programming.
Note 10: Inputs and outputs can undershoot to $\mathbf{- 2 . 0 V}$ for 20 ns Max.

Programming Characteristics (Notes 1, 2, 3, 4 and 5)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| tCES | $\overline{\text { CE Setup Time }}$ | $\overline{\mathrm{OE}}=\mathrm{V}_{1 H}$ | 1 |  |  | $\mu \mathrm{s}$ |
| tvps | $\mathrm{V}_{\text {PP }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tves | $\mathrm{V}_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tDS | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{C E}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toe | Data Valid from $\overline{\text { OE }}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 100 | ns |
| Ipp | Vpp Supply Current during Programming Pulse | $\overline{C E}=V_{\text {IL }}$ |  |  | 30 | mA |
| ICC | $\mathrm{V}_{C C}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\text {A }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{C C}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $\mathrm{V}_{\text {PP }}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $\mathrm{t}_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{I}_{\mathrm{N}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

## Programming Waveforms (Note 3)



TL/D/11329-5
Note 1: National's standard product warranty applies to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $V_{P P}$ or $V_{C C}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{PP}}$, $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verity are tested with the Fast Program Algorithm, at typical power supply voltages and timings.
Note 5: During power up the $\overline{\text { PGM }}$ pin must be brought high $\left(\geq \mathrm{V}_{\mid H}\right)$ either coincident with or before power is applied to $V_{\text {PP }}$.

Fast Programming Algorithm Flow Chart (Note 4)


FIGURE 1

Interactive Programming Algorithm Flow Chart (Note 4)


FIGURE 2

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{Pp}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{C E}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs OE after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from 220 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the $\overline{C E}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the $\overline{O E}$ input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Typing

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that $\overline{C E}$ be decoded and used as the primary device selecting function, while $\overline{\mathrm{OE}}$ be made a common connection to all devices in the array and connected to the

READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on pin $1\left(\mathrm{~V}_{\mathrm{PP}}\right)$ will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 ' $s$ " state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 's" and " 0 's" can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the $V_{P P}$ power supply is at $12.75 \mathrm{~V}, \overline{\mathrm{CE}}$ is $\mathrm{A} 7 \mathrm{~V}_{\mathrm{IL}}$, and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{P} P}, \mathrm{~V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\text { PGM }}$ input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu \mathrm{~s}$ pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu$ s pulse.
The EPROM must not be programmed with a DC signal applied to the $\overline{\mathrm{PGM}}$ input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirments. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\text { PGM }}$ input programs the paralleled EPROM.
Note: Some programmer manufacturers due to equipment limitation may offer interactive program Algorithm (shown in Figure 2).

## Program Inhibit

Programming multiple EPROMs in parallel with different data is also easily accomplished. Except for CE all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel EPROMs may be common. A TTL low level program pulse applied to an EPROM's $\overline{\mathrm{CE}}$ input with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V will program that EPROM. A TTL high level $\overline{C E}$ input inhibits the other EPROMs from being programmed.

## Functional Description (Continued)

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $V_{P P}$ at 12.75 V . $\mathrm{V}_{\mathrm{PP}}$ must be at $\mathrm{V}_{\mathrm{CC}}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacture and device type. The code for NM27C128 is " 8 F 83 ", where " 8 F " designates that it is made by National Semiconductor, and " 83 " designates a 128 K part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A13, and all control pins are held at $V_{I L}$. Address pin $A O$ is held at $V_{I L}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the eight data pins, $\mathrm{O}_{0}-\mathrm{O}_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C}$ to $\pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA$-4000 $\AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wave-
length of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of 15 W - $\mathrm{sec} / \mathrm{cm}^{2}$.
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table III shows the minimum EPROM erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increases as the square of the distance from the lamp (if distance is doubled the erasure time increases by factor of 4). Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, I IC , has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent of the output capacitance loading of the device. The associated VCC transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## Mode Selection

The modes of operation of NM27C128 listed in Table I. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for VPP and A9 for device signature.

TABLE I. Modes Selection

| Mode Pins | $\overline{\mathbf{C E}}$ | $\overline{\mathbf{O E}}$ | $\overline{\text { PGM }}$ | $\mathbf{V}_{\mathbf{P P}}$ | $\mathbf{V}_{\mathrm{CC}}$ | Outputs |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}$ | 5.0 V | $\overline{D_{\mathrm{OUT}}}$ |
| Output Disable | X | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}$ | 5.0 V | High-Z |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | X | $\mathrm{V}_{\mathrm{CC}}$ | 5.0 V | High-Z |
| Programming | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\mathrm{OUT}}$ |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 12.75 V | 6.25 V | High-Z |

Note 1: $X$ can be $V_{\text {IL }}$ or $V_{I H}$.

TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(10)$ | A9 <br> $(24)$ | O7 <br> $(19)$ | O6 <br> $(18)$ | O5 <br> $(17)$ | O4 <br> $(16)$ | O3 <br> $(15)$ | O2 <br> $(13)$ | O1 <br> $(12)$ | O0 <br> $(11)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 83 |

## NM27C256

## 262,144-Bit (32K x 8) High Performance CMOS EPROM

## General Description

The NM27C256 is a 256 K Electrically Programmable Read Only Memory. It is manufactured in National's latest CMOS split gate EPROM technology which enables it to operate at speeds as fast as 120 ns access time over the full operating range.
The NM27C256 provides microprocessor-based systems extensive storage capacity for large portions of operating system and application software. Its 120 ns access time provides high speed operation with high-performance CPUs. The NM27C256 offers a single chip solution for the code storage requirements of $100 \%$ firmware-based equipment. Frequently-used software routines are quickly executed from EPROM storage, greatly enhancing system utility.
The NM27C256, is configured in the standard EPROM pinout which provides an easy upgrade path for systems which are currently using standard EPROMs.

The NM27C256 is one member of a high density EPROM Family which range in densities up to 4 Mb .

## Features

- High performance CMOS
- 100 ns access time
- High reliability with EPI processing
- Latch-up immunity to 200 mA
- ESD protection exceeds 2000V
- JEDEC standard pin configuration
-28-pin DIP package
- 32-pin chip carrier
- Drop-in replacement for 27 C 256 or 27256
- Manufacturer's identification code


## Block Diagram



Connection Diagrams

| 27C080 | 27C040 | 27C020 | 27C010 | 27 C 512 |  |  |  |  | 27 C 512 | 27C010 | $27 \mathrm{CO2O}$ | $27 \mathrm{CO40}$ | 27C080 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A19 | XX/ $V_{\text {PP }}$ | XX/ $\mathrm{V}_{\mathrm{PP}}$ | XX/VPP |  |  |  |  |  |  | $V_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $V_{\text {cc }}$ |
| A16 | A16 | A16 | A16 |  |  |  |  |  |  | $\mathrm{XX} / \overline{\mathrm{PGM}}$ | XX/FGM | A18 | A18 |
| A15 | A15 | A15 | A15 | A15 | - $\mathrm{VPP}^{\text {L }}$ | 1 | 28 | $\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\mathrm{Cc}}$ | XX | A17 | A17 | A17 |
| A12 | A12 | A12 | A12 | A12 | A12 | 2 | 27 | 14 | A14 | A14 | A14 | A14 | A14 |
| A7 | A7 | A7 | A7 | A7 | - A7- | 3 | 26 | 113 | A13 | A13 | A13 | A13 | A13 |
| A6 | A6 | A6 | A6 | A6 | A6[ | 4 | 25 | A8 | A8 | A8 | A8 | A8 | A8 |
| A5 | A5 | A5 | A5 | A5 | A5 | 5 | 24 | A9 | A9 | A9 | A9 | A9 | A9 |
| A4 | A4 | A4 | A4 | A4 | - | 6 | 23 | 1a11 | A11 | A11 | A11 | A11 | A11 |
| A3 | A3 | A3 | A3 | A3 | - A3 $\square$ | 7 | 22 | $\overline{O E}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ | $\overline{\mathrm{OE}}$ | $\overline{O E}$ | OE | OE/VPP |
| A2 | A2 | A2 | A2 | A2 | A2[ | 8 |  | 10 | A10 | A10 | A10 | A10 | A10 |
| A1 | A1 | A1 | A1 | A1 | [ | 9 | 20 | - $\overline{C E} / \overline{\text { PGM }}$ - | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | CE | CE | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | CE/PGM |
| A0 | A0 | A0 | A0 | AO | A0- | 10 | 19 | 07 | 07 | 07 | 07 | 07 | 07 |
| OO | 00 | O0 | O0 | OO | $00 \square$ | 11 | 18 | 06 | 06 | 06 | 06 | 06 | 06 |
| 01 | 01 | 01 | 01 | 01 | 0 | 12 | 17 | 05 | O5 | 05 | 05 | O5 | O5 |
| O2 | 02 | O2 | O2 | O2 | 02밈 | 13 | 16 | 04 | 04 | 04 | 04 | 04 | 04 |
| GND | GND | GND | GND | GND | - GNDE | 14 | 15 | Ø03 | O3 | O3 | O3 | O3 | O3 |

TL/D/10833-2
Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27C256 pins.

| Commercial Temp. Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )$V_{C C}=5 V \pm 10 \%$ |  |
| :---: | :---: |
| Parameter/Order Number | Access Time (ns) |
| NM27C256 Q, N, V 120 | 120 |
| NM27C256 Q, N, V 150 | 150 |
| NM27C256 Q, N, V 200 | 200 |
| Military Temp. Range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$$V_{C C}=5 V \pm 10 \%$ |  |
| Parameter/Order Number | Access Time ( ns ) |
| NM27C256 QM 150 | 150 |
| NM27C256 QM 250 | 250 |

Pin Names

| Symbol | Description |
| :--- | :--- |
| $\mathrm{AO}-\mathrm{A14}$ | Addresses |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{O}--O 7$ | Outputs |
| $\overline{\mathrm{PGM}}$ | Program |
| $X X$ | Don't Care (during Read) |

Extended Temp. Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{\text {cc }}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27C256 QE, NE, VE 120 | 120 |
| NM27C256 QE, NE, VE 150 | 150 |
| NM27C256 QE, NE, VE 200 | 200 |

Note: Surface mount PLCC package available for commercial and extended temperature ranges only.

Package Types: NM27C256 Q, N, V XXX
$\mathrm{Q}=$ Quartz-Windowed Ceramic DIP
$\mathrm{N}=$ Plastic OTP DIP
$V=$ Surface-Mount PLCC

- All packages conform to the JEDEC standard.
- All versions are guaranteed to function for slower speeds.


Top
TL/D/10833-3
Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input Voltages except A9 with Respect to Ground
-0.6 V to +7 V
$V_{\text {Pp }}$ and A9 with Respect

| to Ground | -0.7 V to +14 V |
| :--- | :--- |
| CC Supply Voltage with |  |
| Respect to Ground | -0.6 V to +7 V |

ESD Protection
$>2000 \mathrm{~V}$
All Output Voltages with Respect to Ground
$V_{C C}+1.0 \mathrm{~V}$ to $\mathrm{GND}-0.6 \mathrm{~V}$

## Operating Range

| Range | Temperature | V CC |
| :--- | :---: | :---: |
| Comm' | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $+5 \mathrm{~V} \pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $+5 \mathrm{~V} \pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $+5 \mathrm{~V} \pm 10 \%$ |

## Read Operation

DC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\text {PP }}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Level |  | -0.5 | 0.8 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Level |  | 2.0 | $\mathrm{V}_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{lOL}=2.1 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{lOH}^{\prime}=-400 \mu \mathrm{~A}$ | 3.5 |  | V |
| $I_{\text {SB1 }}$ <br> (Note 11) | $V_{C C}$ Standby Current (CMOS) | $\overline{C E}=V_{C C} \pm 0.3 \mathrm{~V}$ |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {SB2 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current | $\overline{C E}=V_{1 H}$ |  | 1 | mA |
| ICC1 | VCC Active Current TTL Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL},}, f=5 \mathrm{MHz} \\ & \text { Inputs }=V_{\mathrm{IH}} \text { or } V_{\mathrm{IL}} \end{aligned}$ |  | 40 | mA |
| ICC2 | $\mathrm{V}_{\mathrm{CC}}$ Active Current CMOS Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{GND}, \mathrm{f}=5 \mathrm{MHz}, \\ & \text { Inputs }=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \\ & \mathrm{C}, \mathrm{I} \text { Temperature Ranges } \end{aligned}$ |  | 35 | mA |
| IPP | Vpp Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{PP}}$ | VPp Read Voltage |  | $V_{C C}-0.7$ | $\mathrm{V}_{\mathrm{CC}}$ | V |
| ILI | Input Load Current | $\mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ or GND | -1 | 1 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND | -10 | 10 | $\mu \mathrm{A}$ |

AC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{v}_{\mathrm{CC}}$

| Symbol | Parameter | 100 |  | 120 |  | 150 |  | 200 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 100 |  | 120 |  | 150 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 100 |  | 120 |  | 150 |  | 200 |  |
| $\mathrm{t}_{\text {OE }}$ | $\overline{\mathrm{OE}}$ to Output Delay |  | 50 |  | 50 |  | 50 |  | 50 |  |
| tDF (Note 2) | Output Disable to Output Float |  | 30 |  | 35 |  | 45 |  | 55 |  |
| ${ }^{\mathrm{t}} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | 0 |  | 0 |  | 0 |  | 0 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ | 6 | 12 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}$ | 9 | 12 | pF |

## AC Test Conditions

Output Load
Input Rise and Fall Times

$$
C_{\mathrm{L}}=\begin{aligned}
& 1 \mathrm{TTL} \text { Gate and } \\
& 100 \mathrm{pF}(\text { Note } 8)
\end{aligned}
$$

$\leq 5 \mathrm{~ns}$

Input Pulse Levels
Timing Measurement Reference Level
Inputs
Outputs
0.45 to 2.4 V
(Note 10)
0.8 V and 2.0 V 0.8 V and 2.0 V

AC Waveforms (Notes 6, 7 and 9)


TL/D/10833-4
Note 1: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The $\mathrm{t}_{\mathrm{DF}}$ and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE ${ }^{\otimes}$, the measured $\mathrm{V}_{\mathrm{OH} 1}(\mathrm{DC})-0.10 \mathrm{~V}$;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} 1}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 5: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $V_{C C}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: TTL Gate: $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$C_{L}=100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.
Note 10: Inputs and outputs can undershoot to -2.0 V for 20 ns Max.
Note 11: CMOS inputs: $V_{I L}=G N D \pm 0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$.

Programming Characteristics (Notes 1, 2, 3, 4 and 5)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvPS | $V_{\text {PP }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvCs | $V_{C C}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ DF | Output Enable to Output Float Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toe | Data Valid from $\overline{O E}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |  |  | 100 | ns |
| IPP | Vpp Supply Current during Programming Pulse | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 30 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | $V_{\text {CC }}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\text {A }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{C C}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $\mathrm{V}_{\mathrm{PP}}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $\mathrm{t}_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

## Programming Waveforms (Note 3)



TL/D/10833-5
Note 1: National's standard product warranty applies to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{PP}}$ or $\mathrm{V}_{\mathrm{CC}}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{PP}}$, $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the interactive Program Algorithm, at typical power supply voltages and timings.
Note 5: During power up the $\overline{\mathrm{PGM}}$ pin must be brought high $\left(\geq \mathrm{V}_{I H}\right)$ either coincident with or before power is applied to $\mathrm{V}_{\mathrm{PP}}$.

Fast Programming Algorithm Flow Chart (Same as NMC27C256B)


FIGURE 1

## Interactive Programming Algorithm Flow Chart (Note 4)



FIGURE 2

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $V_{P P}$. The $V_{P P}$ power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $V_{C C}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable (CE/PGM) is the power control and should be used for device selection. Output Enable (OE) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from CE to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs toE after the falling edge of OE, assuming that CE/PGM has been low and addresses have been stable for at least $t_{A C C}-$ toe.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from 385 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the CE/PGM input. When in standby mode, the outputs are in a high impedance state, independent of the OE input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the OE input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Typing

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that CE/PGM be decoded and used as the primary device selecting function, while $O E$ be made a common connection to all devices in the array and connected to the

READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on pin $1\left(\mathrm{~V}_{\mathrm{PP}}\right)$ will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 's" state. Data is introduced by selectively programming " 0 ' $s$ " into the desired bit locations. Although only " 0 ' $s$ " will be programmed, both " 1 's" and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the $V_{P P}$ power supply is at 12.75 V and OE is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the CE/PGM input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu \mathrm{~s}$ pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu \mathrm{~s}$ pulse.
The EPROM must not be programmed with a DC signal applied to the CE/PGM input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirments. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the CE/PGM input programs the paralleled EPROM.
Note: Some programmer manufacturers, due to equipment limitation, may offer interactive program Algorithm (shown in Figure 2).

## Program Inhibit

Programming multiple EPROMs in parallel with different data is also easily accomplished. Except for CE/PGM, all like inputs (including OE) of the parallel EPROMs may be common. A TTL low level program pulse applied to an EP. ROM's CE/PGM input with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V will program that EPROM. A TTL high level CE/PGM input inhibits the other EPROMs from being programmed.

## Functional Description (Continued)

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V . $\mathrm{V}_{\mathrm{PP}}$ must be at $\mathrm{V}_{\mathrm{CC}}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for NM27C256 is " 8 F 04 ", where " 8 F " designates that it is made by National Semiconductor, and "04" designates a 256 K part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A16, and all control pins are held at $\mathrm{V}_{\text {IL }}$. Address pin $A 0$ is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $V_{I H}$ for the device code. The code is read on the eight data pins, $\mathrm{O}_{0}-\mathrm{O}_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C}$ to $\pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wave-
length of $2537 \AA$ A. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$.
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table III shows the minimum EPROM erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increases as the square of the distance from the lamp (if distance is doubled the erasure time increases by factor of 4). Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, Icc, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent of the output capacitance loading of the device. The associated $V_{C C}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $\mathrm{V}_{\mathrm{CC}}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## Mode Selection

The modes of operation of NM27C256 listed in Table I. A single 5 V power supply is required in the read mode. All inputs are TTL evels except for VPP and A9 for device signature.

TABLE I. Modes Selection

| Mode Pins | $\overline{C E} / \overline{\mathrm{PGM}}$ | $\overline{\mathrm{OE}}$ | $\mathbf{V}_{\mathbf{P P}}$ | $\mathbf{V}_{\mathrm{CC}}$ | Outputs |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}$ | 5.0 V | D |
| Output Disable | X <br> $($ Note 1$)$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}$ | 5.0 V | High-Z |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | $\mathrm{V}_{\mathrm{CC}}$ | 5.0 V | High-Z |
| Programming | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}} \mathrm{X}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | X | $\mathrm{V}_{\mathrm{IL}}$ | 12.75 V | 12.75 V | $\mathrm{D}_{\mathrm{OUT}}$ |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | High-Z |

Note 1: X can be $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$.
TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(10)$ | A9 <br> $(24)$ | O7 <br> $(19)$ | O6 <br> $(18)$ | O5 <br> $(17)$ | O4 <br> $(16)$ | O3 <br> $(15)$ | O2 <br> $(13)$ | O1 <br> $(12)$ | O0 <br> $(11)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 04 |

NM27C512
524,288-Bit (64K x 8) High Performance CMOS EPROM

## General Description

The NM27C512 is a high performance 512K UV Erasable Electrically Programmable Read Only Memory. It is manufactured in National's latest CMOS split gate EPROM technology, which enables it to operate at speeds as fast as 120 ns access time over the full operating range.
The NM27C512 provides microprocessor-based systems storage capacity for portions of operating system and application software. Its 120 ns access time provides no-wait-state operation with high-performance CPUs. The NM27C512 offers a single chip solution for the code storage requirements of $100 \%$ firmware-based equipment. Fre-quently-used software routines are quickly executed from EPROM storage, greatly enhancing system utility.
The NM27C512 is configured in the standard JEDEC EPROM pinout which provides an easy upgrade path for systems which are currently using standard EPROMs.

The NM27C512 is one member of a high density EPROM Family which range in densities up to 4 Megabit.

## Features

- High performance CMOS -120 ns access time
- Fast turn-off for microprocessor compatibility
- High reliability with EPI processing
- Latch-up immunity to 200 mA
- ESD protection exceeds 2000 V
- JEDEC standard pin configuration
- 28-pin DIP package
-32-pin chip carrier
- Manufacturers identification code


## Block Diagram



Connection Diagrams


TL/D/10834-2
Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27C512 pins.
Commercial Temp Range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+\mathbf{7 0}{ }^{\circ} \mathrm{C}\right)$

| Parameter/Order Number | Access Time (ns) ${ }^{*}$ |
| :--- | :---: |
| NM27C512 Q, N, V 120 | 120 |
| NM27C512 Q, N, V 150 | 150 |
| NM27C512 Q, N, V 200 | 200 |
| Military Temp Range ( $-\mathbf{5 5 ^ { \circ }} \mathbf{C}$ to $\left.+\mathbf{1 2 5}{ }^{\circ} \mathrm{C}\right)$ |  |
| Parameter/Order Number | Access Time (ns) ${ }^{*}$ |
| NM27C512 QM 200 | 200 |

Extended Temp Range ( $-\mathbf{4 0 ^ { \circ }}{ }^{\circ}$ to $+\mathbf{8 5}{ }^{\circ} \mathbf{C}$ )

| Parameter/Order Number | Access Time (ns) ${ }^{*}$ |
| :---: | :---: |
| NM27C512 QE, NE, VE 120 | 120 |
| NM27C512 QE, NE, VE 150 | 150 |
| NM27C512 QE, NE, VE 200 | 200 |

Note: Surface mount PLCC package available for commercial and extended temperature ranges only.
*All versions are guaranteed to function for slower speeds.
Package Types: NM27C512 Q, N, V XXX
$\mathrm{Q}=$ Quartz-Windowed Ceramic DIP Package
$N=$ Plastic OTP DIP Package
$V=$ PLCC Package

- All packages conform to the JEDEC standard.

| Pin Names |  |
| :--- | :--- |
| A0-A15 | Addresses |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{OO}-07$ | Outputs |
| $\overline{\text { PGM }}$ | Program |
| XX | Don't Care (During Read) |

```
Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required,
please contact the Natlonal Semiconductor Sales
Office/Distributers for availability and specifications.
```

Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input Voltages Except A9 with Respect to Ground
$V_{\text {Pp }}$ and A9 with Respect to Ground
$V_{C C}$ Supply Voltage with Respect to Ground
-0.6 V to +7 V
ESD Protection
(MIL Std. 883, Method 3015.2) >2000V
All Output Voltages with
Respect to Ground
$V_{C C}+1.0 \mathrm{~V}$ to $\mathrm{GND}-0.6 \mathrm{~V}$

## Operating Range

| Range | Temperature | $\mathbf{V}_{\mathbf{C C}}$ | Tolerance |
| :--- | :---: | :---: | :---: |
| Comm' | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |

## Read Operation

## DC Electrical Characteristics

| Symbol | Parameter | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Level |  | -0.5 | 08 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Level |  | 2.0 | $V_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{IOL}=2.1 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ | 3.5 |  | $V$ |
| $\mathrm{I}_{\text {SB1 }}$ | $\mathrm{V}_{\text {CC }}$ Standby Current (CMOS) | $\overline{C E}=V_{C C} \pm 0.3 \mathrm{~V}$ |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {SB2 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  | 1 | mA |
| $\mathrm{ICC1}$ | $V_{C C}$ Active Current | $\overline{C E}=\overline{O E}=V_{\text {IL }} \quad 1 \quad f=5 \mathrm{MHz}$ |  | 40 | mA |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current CMOS Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{GND}, \mathrm{f}=5 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \\ & \mathrm{C}, \mathrm{I} \text { Temp Ranges } \end{aligned}$ |  | 35 | mA |
| Ipp | $V_{\text {PP }}$ Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{PP}}$ | Vpp Read Voltage |  | $\mathrm{V}_{\mathrm{C}}-0.7$ | $\mathrm{V}_{\mathrm{CC}}$ | V |
| lı | Input Load Current | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ or GND | -1 | 1 | $\mu \mathrm{A}$ |
| ILO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND | -10 | 10 | $\mu \mathrm{A}$ |

## AC Electrical Characteristics

| Symbol | Parameter | 120 |  | 150 |  | 200 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 120 |  | 150 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 120 |  | 150 |  | 200 |  |
| toe | $\overline{\text { OE }}$ to Output Delay |  | 50 |  | 50 |  | 50 |  |
| $t_{\text {DF }}$ | Output Disable to Output Float |  | 25 |  | 45 |  | 55 |  |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold from <br> Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, <br> Whichever Occurred First | 0 |  | 0 |  | 0 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN} 1}$ | Input Capacitance <br> except $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}$ | 6 | 12 | pF |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | $\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}$ | 9 | 12 | pF |
| $\mathrm{C}_{\mathrm{IN} 2}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ Input <br> Capacitance | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ | 20 | 25 | pF |

## AC Test Conditions

Output Load

Input Rise and Fall Times
Input Pulse Levels
1 TTL Gate and

$C_{L}=$| $100 \mathrm{pF}($ Note 8$)$ |
| ---: |
| $\leq 5 \mathrm{~ns}$ |
| 0.45 V to 2.4 V |$~$

Timing Measurement Reference Level (Note 9) Inputs
0.8 V and 2 V 0.8 V and 2 V

## AC Waveforms (Notes 6,7)



TL/D/10834-4
Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The tDF and $t_{C F}$ compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}(\mathrm{DC})-0.10 \mathrm{~V}$;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} 1}$ (DC) +0.10 V .
Note 5: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND.
Note 7: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{IOL}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: Inputs and outputs can undershoot to -2.0 V for 20 ns Max.

## Programming Characteristics (Notes 1 and 2)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| tos | Data Setup Time |  | 1 |  |  | $\mu \mathrm{S}$ |
| tves | $V_{C C}$ Setup Time |  | 1 |  |  | $\mu \mathrm{S}$ |
| $t_{A H}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {DH }}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{CF}}$ | Chip Enable to Output Float Delay | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toen | $\overline{\text { OE Hold Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {dV }}$ | Data Valid from $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 250 | ns |
| tPRT | $\overline{O E}$ Pulse Rise Time during Programming |  | 50 |  |  | ns |
| tVR | $V_{\text {PP }}$ Recovery Time |  | 1 |  |  | $\mu \mathrm{S}$ |
| ${ }^{\text {IPP }}$ | $V_{\text {Pp }}$ Supply Current during Programming Pulse | $\begin{aligned} & \overline{\mathrm{CE}}=V_{\mathrm{IL}} \\ & \overline{\mathrm{OE}}=V_{\mathrm{PP}} \end{aligned}$ |  |  | 30 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\mathrm{R}}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{C C}$ | Power Supply Voltage |  | 6 | 6.25 | 6.5 | V |
| Vpp | Programming Supply Voltage |  | 12.5 | 12.75 | 13 | V |
| $t_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4 |  | V |
| ${ }_{\text {tin }}$ | Input Timing Reference Voltage |  | 0.8 |  | 2 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2 | V |

## Programming Waveforms



Note 1: National's standard product warranty applies to devices programmed to specifications described herein.
Note 2: $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{Pp}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{PP}}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{Pp}}$ or $\mathrm{V}_{\mathrm{C}}$.

Note 3: The maximum absolute allowable voltage which may be applied to the $\mathrm{V}_{\mathrm{PP}}$ pin during programming is 14 V . Care must be taken when switching the $\mathrm{V}_{\mathrm{PP}}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm at typical power supply voltages and timings.

Fast Programming Algorithm Flow Chart (Same as NMC27C512A)


TL/D/10834-6
FIGURE 1

## Interactive Programming Algorithm Flow Chart



DEVICE PASSED

FIGURE 2

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and OE/VPp. The OE/VPp power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable (CE/PGM) is the power control and should be used for device selection. Output Enable ( $O E / V_{P P}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $t_{A C C}$ ) is equal to the delay from CE to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs toE after the falling edge of OE, assuming that CE has been low and addresses have been stable for at least $t_{A C C}{ }^{-t_{O E}}$.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from 385 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the CE/PGM input. When in standby mode, the outputs are in a high impedance state, independent of the OE input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the OE input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Typing

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2 -line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that CE/PGM be decoded and used as the primary device selecting function, while $O E / V_{P P}$ be made a common connection to all devices in the array and connected to the READ line from the system control bus.

This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14V on pin 22 ( $O E / V_{P P}$ ) will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 's" state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 's" and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the OE/VPP is at 12.75 V . It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $V_{C C}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.

When the address and data are stable, an active low, TTL program pulse is applied to the CE/PGM input. A program pulse must be applied at each address location to be programmed.
The EPROM is programmed with the Fast Programming AIgorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu \mathrm{~s}$ pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu$ s pulse.
The EPROM must not be programmed with a DC signal applied to the CE/PGM input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the CE/PGM input programs the paralleled EPROM.
Note: Some programmer manufacturers, due to equipment limitation, may offer interactive program Algorithm (shown in Figure 2).

## Program Inhibit

Programming multiple EPROMs in parallel with different data is also easily accomplished. Except for CE/PGM all like inputs (including OE/VPP) of the parallel EPROMs may be common. A TTL low level program pulse applied to an EPROM's CE/PGM input with OE/VPP at 12.75 V will program that EPROM. A TTL high level CE/PGM input inhibits the other EPROMs from being programmed.

## Functional Description (Continued)

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify is accomplished with OE/VPP and CE at $V_{\text {IL }}$. Data should be verified $T_{D V}$ after the falling edge of $C E$.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for NM27C512 is " $8 F 85$ ", where " $8 F$ " designates that it is made by National Semiconductor, and " 85 " designates a 512 K part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A16, and all control pins are held at $\mathrm{V}_{\mathrm{IL}}$. Address pin $A 0$ is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{I H}$ for the device code. The code is read on the eight data pins, $\mathrm{O}_{0}-\mathrm{O}_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA$-4000 $\AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wave-
length of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$.
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table III shows the minimum EPROM erasure time for various light intensities.

An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increase as the square of the distance from the lamp (if distance is doubled the erasure time increases by factor of 4). Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, ICc, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent of the output capacitance loading of the device. The associated $V_{C C}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between VCc and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## Mode Selection

The modes of operation of the NM27C512 are listed in Table I. A single 5V power supply is required in the read mode. All inputs are TTL levels excepts for $\mathrm{V}_{\mathrm{PP}}$ and A 9 for device signature.

TABLE I. Mode Selection

| Mode Pins | $\overline{\text { CE/PGM }}$ | $\overline{O E /} / V_{P P}$ | Vcc | Outputs |
| :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | 5.0 V | Dout |
| Output Disable | (Note 1) | $\mathrm{V}_{\mathrm{IH}}$ | 5.0 V | High Z |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | 5.0 V | High 2 |
| Programming | $\mathrm{V}_{\text {IL }}$ | $\mathrm{VPP}^{(2)}$ | 6.25 V | $\mathrm{DIN}^{\text {I }}$ |
| Program Verity | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$ | 6.25 V | Dout |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{PP}}{ }^{(2)}$ | 6.25 V | High Z |

Note 1: $X$ can be $V_{I L}$ or $V_{I H}$.
TABLE II. Manufacturer's Identlfication Code

| Pins | A0 <br> $(10)$ | A9 <br> $(24)$ | 07 <br> $(19)$ | 06 <br> $(18)$ | 05 <br> $(17)$ | 04 <br> $(16)$ | 03 <br> $(15)$ | 02 <br> $(13)$ | 01 <br> $(12)$ | 00 <br> $(11)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 85 |

NM27C010

## 1,048,576-Bit (128K x 8) High Performance CMOS EPROM

## General Description

The NM27C010 is a high performance, 1,048,576-bit Electrically Programmable UV Erasable Read Only Memory. It is organized as 128 K -words of 8 bits each. Its pin-compatibility with byte-wide JEDEC EPROMs enables upgrades through 8 Mbit EPROMs. The "Don't Care" feature during read operations allows memory expansions from 1M to 8M bits with no printed circuit board changes.
The NM27C010 can directly replace lower density 28 -pin EPROMs by adding an A 16 address line and $\mathrm{V}_{\mathrm{CC}}$ jumper. During the normal read operation PGM and VPP are in a "Don't Care" state which allows higher order addresses, such as A17, A18, and A19 to be connected without affecting the normal read operation. This allows memory upgrades to 8 M bits without hardware changes. The NM27C010 is also offered in a 32 -pin plastic DIP with the same upgrade path.
The NM27C010 provides microprocessor-based systems extensive storage capacity for large portions of operating system and application software. Its 100 ns access time provides no-wait-state operation with high-performance CPUs. The NM27C010 offers a single chip solution for the code storage requirements of $100 \%$ firmware-based equipment. Frequently-used software routines are quickly executed from EPROM storage, greatly enhancing system utility.

The NM27C010 is manufactured using National's advanced CMOS SVG EPROM technology.
The NM27C010 is one member of a high density EPROM Family which range in densities up to 4 Megabit.

## Features

- High performance CMOS
- 100 ns access time
- Fast turn-off for microprocessor compatibility
- High reliability with EPI processing
- Latch-up immunity
- ESD protection
- Simplified upgrade path
- VPP and PGM are "Don't Care" during normal read operation
■ Compatible with 27010 and 27C010 EPROMs
- JEDEC standard pin configurations
- 32-pin DIP package
- 32-pin chip carrier
- Manufacturers identification code

Fast programming

## Block Diagram



TL/D/t0798-1

## Connection Diagrams

DIP PIN CONFIGURATIONS

| 27C080 | 27C040 | 27C020 | 27C512 | 27C256 |
| :---: | :---: | :---: | :---: | :---: |
| A19 | $\mathrm{XX} / \mathrm{V}_{\mathrm{PP}}$ | $\mathrm{XX} / \mathrm{V}_{\mathrm{PP}}$ |  |  |
| A 16 | A 16 | A 16 |  |  |
| A 15 | A 15 | A 15 | A 15 | $\mathrm{~V}_{\mathrm{PP}}$ |
| A 12 | A 12 | A 12 | A 12 | A 12 |
| A 7 | A 7 | A 7 | A 7 | A 7 |
| A 6 | A 6 | A 6 | A 6 | A 6 |
| A 5 | A 5 | A 5 | A 5 | A 5 |
| A 4 | A 4 | A 4 | A 4 | A 4 |
| A 3 | A 3 | A 3 | A 3 | A 3 |
| A 2 | A 2 | A 2 | A 2 | A 2 |
| A 1 | A 1 | A 1 | A 1 | A 1 |
| A 0 | A 0 | A 0 | A 0 | A 0 |
| $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ |
| $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ |
| GND | GND | GND | GND | GND |

DIP NM27C010


| 27C256 | 27 C 512 | 27C020 | 27C040 | 27C080 |
| :---: | :---: | :---: | :---: | :---: |
|  |  | $\left\|\begin{array}{c} v_{C C} \\ \mathrm{xX} / \mathrm{PGM} \end{array}\right\|$ | $\begin{aligned} & V_{\mathrm{CC}} \\ & \mathrm{~A} 18 \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~A} 18 \end{aligned}$ |
| $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{C C}$ | A17 | A17 | A17 |
| A14 | A14 | A14 | A14 | A14 |
| A13 | A13 | A13 | A13 | A13 |
| A8 | A8 | A8 | A8 | A8 |
| A9 | A9 | A9 | A9 | A9 |
| A11 | A11 | A11 | A11 | A11 |
| OE | $\overline{O E /} \mathrm{V}_{P P}$ | OE | OE | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ |
| A10 | A10 | A10 | A10 | A10 |
| $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | $\overline{C E} / \overline{\text { PGM }}$ | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ |
| $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ |
| $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ |
| $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ |
| $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ |
| $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ |

TL/D/10798-2
Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27C010 pins.

Commercial Temperature Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27C010 Q, V, N 100 | 100 |
| NM27C010 Q, V, N 120 | 120 |
| NM27C010 Q, V, N 150 | 150 |
| NM27C010 Q, V, N 200 | 200 |

Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{\text {CC }}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27C010 QE, VE, NE 120 | 120 |
| NM27C010 QE, VE, NE 150 | 150 |
| NM27C010 QE, VE, NE 200 | 200 |

Military Temperature Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )
$V_{\text {cc }}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27C010 QM 200 | 200 |

Note: Surface mount PLCC package available for commercial and extended temperature ranges only.
Package Types: NM27C010 Q, N, V XXX
Q = Quartz-Windowed Ceramic DIP package $V=$ PLCC package

- All packages conform to JEDEC standard.
- All versions are guaranteed to function at slower speeds.

Pin Names

| Pin Names |  |
| :--- | :--- |
| $A 0-A 16$ | Addresses |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{O E}$ | Output Enable |
| $O 0-O 7$ | Outputs |
| $\overline{\text { PGM }}$ | Program |
| $X X$ | Don't Care (During Read) |

PLCC Pin Configuration


Top View

| Absolute Maximum Ratings (Note 1) |  |
| :---: | :---: |
| If Military/Aerospace specified devices are required please contact the National Semiconductor Sales Office/Distributors for availability and specifications. |  |
|  |  |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input Voltages Except $A_{g}$ with Respect to Ground (Note 10) | -0.6 V to +7 V |
| $V_{\text {PP }}$ and $\mathrm{A}_{9}$ with Respect to Ground | -0.6 V to +14 V |
| $V_{C C}$ Supply Voltage with |  |
| Respect to Ground | -0.6 V to +7 V |
| ESD Protection | $>2000 \mathrm{~V}$ |
| Respect to Ground (Note 10) $\mathrm{V}_{\text {CC }}+1.0 \mathrm{~V}$ to GND -0.6 V |  |
|  |  |

Absolute Maximum Ratings (Note 1)
If Millary/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

All Input Voltages Except $\mathrm{A}_{9}$ with Respect to Ground (Note 10)
$V_{\text {PP }}$ and $A_{g}$ with Respect to Ground
$V_{C C}$ Supply Voltage with
Respect to Ground

Respect to Ground (Note 10) $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to $\mathrm{GND}-0.6 \mathrm{~V}$

$$
-0.6 \mathrm{~V} \text { to }+7 \mathrm{~V}
$$

$$
-0.6 \mathrm{~V} \text { to }+14 \mathrm{~V}
$$

$$
-0.6 \mathrm{~V} \text { to }+7 \mathrm{~V}
$$

$$
>2000 \mathrm{~V}
$$

All Output Voltages with

## Operating Range

| Range | Temperature | $V_{\text {CC }}$ | Tolerance |
| :--- | :--- | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |

DC Read Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level |  | -0.5 | 0.8 | V |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Level |  | 2.0 | $V_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ | 3.5 |  | V |
| ${ }^{\text {ISB1 }}$ | $V_{C C}$ Standby Current (CMOS) | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$ |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {SB2 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  | 1 | mA |
| 1 CC | $\mathrm{V}_{\text {CC }}$ Active Current | $\overline{C E}=\overline{O E}=V_{\text {IL }} \quad 1 \quad f=5 \mathrm{MHz}$ |  | 50 | mA |
| IPP | $V_{\text {Pp }}$ Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  | 10 | $\mu \mathrm{A}$ |
| $V_{P P}$ | VPp Read Voltage |  | $\mathrm{V}_{\mathrm{CC}}-0.7$ | $\mathrm{V}_{\mathrm{CC}}$ | V |
| $\mathrm{l}_{\mathrm{LI}}$ | Input Load Current | $\mathrm{V}_{\mathrm{IN}}=5.5$ or GND | -1 | 1 | $\mu \mathrm{A}$ |
| lo | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND | -10 | 10 | $\mu \mathrm{A}$ |

AC Read Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | 100 |  | 120 |  | 150 |  | 200 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 100 |  | 120 |  | 150 |  | 200 | ns |
| ${ }^{\text {t }}$ ce | $\overline{C E}$ to Output Delay |  | 100 |  | 120 |  | 150 |  | 200 |  |
| toe | $\overline{\mathrm{OE}}$ to Output Delay |  | 45 |  | 50 |  | 50 |  | 50 |  |
| ${ }^{t}{ }_{D F}$ (Note 2) | Output Disable to Output Float |  | 35 |  | 35 |  | 45 |  | 55 |  |
| ${ }^{\mathrm{t}} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{C E}$ or $\overline{O E}$, Whichever Occurred First | 0 |  | 0 |  | 0 |  | 0 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ | 9 | 15 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 12 | 15 | pF |

## AC Test Conditions

| Output Load | 1 TTL Gate and $C_{L}=100 \mathrm{pF}(\text { Note } 8)$ | Timing Measurement Reference Level Inputs | 0.8 V and 2 V |
| :---: | :---: | :---: | :---: |
| input Rise and Fall Times | $\leq 5 \mathrm{~ns}$ | Outputs | 0.8 V and 2 V |
| Input Pulse Levels | 0.45 V to 2.4 V |  |  |

## AC Waveforms (Notes 6, 7, \&9)



TL/D/10798-4
Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{\mathrm{OE}}$ may be delayed up to $\mathrm{t}_{\mathrm{ACC}}-\mathrm{t}_{\mathrm{OE}}$ after the falling edge of CE without impacting $\mathrm{t}_{\mathrm{ACC}}$.
Note 4: The tDF and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE ${ }^{\oplus}$, the measured $\mathrm{V}_{\mathrm{OH} 1}(\mathrm{DC})-0.10 \mathrm{~V}$;
Low to TRI-STATE, the measured $V_{\text {OL1 }}$ (DC) +0.10 V .
Note 5: TRI-STATE may be attained using $\overline{\text { OE or CE. }}$
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND.
Note 7: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{IOL}^{=} 1.6 \mathrm{~mA}, \mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$C_{L}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.


Programming Characteristics (Notes 1, 2, 3, 4, \& 5)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| tees | $\overline{C E}$ Setup Time | $\overline{O E}=\mathrm{V}_{1 H}$ | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tVPS | $V_{\text {pp }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tves | $V_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{OE}}$ | Data Valid from $\overline{O E}$ | $\overline{C E}=V_{\text {IL }}$ |  |  | 100 | ns |
| IPP | VPp Supply Current during Programming Pulse | $\begin{aligned} & \overline{\overline{C E}}=V_{\mathrm{IL}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}} \end{aligned}$ |  |  | 30 | mA |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\mathrm{A}}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| VPP | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $\mathrm{t}_{\mathrm{FR}}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{N}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

## Programming Waveforms (Note 3)



TL/D/10798-5
Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $V_{p p}$ or $V_{C C}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{Pp}}$, $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verity are tested with the fast Program Algorithm, at typical power supply voltages and timings.
Note 5: During power up the $\overline{\mathrm{PGM}}$ pin must be brought high $\left(\geq \mathrm{V}_{\mathrm{IH}}\right)$ either coincident with or before power is applied to $\mathrm{V}_{\mathrm{Pp}}$.

Fast Programming Algorithm Flow Chart (Same as NMC27C010)


FIGURE 1

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{Pp}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $V_{C C}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}})$ is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that the addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs toE after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{A C C}-\mathrm{t}_{\mathrm{O}}$.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from 275 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the $\overline{\mathrm{CE}}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the OE input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Tying

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that CE be decoded and used as the primary device selecting function, while OE be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on the $\mathrm{V}_{\mathrm{PP}}$ or A 9 pin will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 's" state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 ' $s$ " will be programmed, both " 1 ' $s$ " and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a "1" is by ultraviolet light erasure.

The EPROM is in the programming mode when the $\mathrm{V}_{\mathrm{PP}}$ power supply is at 12.75 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $V_{P P}, V_{C C}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{PGM}}$ input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu$ s pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu \mathrm{~s}$ pulse.
The EPROM must not be programmed with a DC signal applied to the $\overline{\mathrm{PGM}}$ input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\text { PGM }}$ input programs the paralleled EPROM.

## Program Inhibit

Programming multiple EPROM's in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}}$ all like inputs (including $\overline{O E}$ and $\overline{P G M}$ ) of the parallel EPROM may be common. A TTL low level program pulse applied to an EPROM's $\overline{\text { PGM }}$ input with $\overline{\mathrm{CE}}$ at $\mathrm{V}_{\mathrm{IL}}$ and $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V will program that EPROM. A TTL high level $\overline{C E}$ input inhibits the other EPROM's from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V . $\mathrm{V}_{\mathrm{PP}}$ must be at $\mathrm{V}_{\mathrm{CC}}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's indentification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for the NM27C010 is " 8 F 86 ", where " 8 F " designates that it is made by National Semiconductor, and " 86 " designates a 1 Megabit ( $128 \mathrm{~K} \times 8$ ) part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A16, and all control pins are held at $\mathrm{V}_{\mathrm{IL}}$. Address pin AO is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the eight data pins, $00-07$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.

## Functional Description (Continued) ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $X$ exposure time) for erasure should be a minimum of 15 W $\mathrm{sec} / \mathrm{cm}^{2}$.
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increases as the square of the distance from the lamp. (if distance is doubled the erasure time increases by factor of 4). Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause
symptoms that can be misleading. Programmers, components and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, ICC, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between V $\mathrm{V}_{\mathrm{CC}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between VCC and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## MODE SELECTION

The modes of operation of the NM27C210 are listed in Table I. A single 5V power supply is required in the read mode. All inputs are TTL levels except for $V_{P P}$ and $A 9$ for device signature.

TABLE I. Modes Selection

| Pins | $\overline{\text { CE }}$ | $\overline{O E}$ | $\overline{\text { PGM }}$ | $V_{\text {PP }}$ | Vcc | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |  |
| Read | $\mathrm{V}_{\text {IL }}$ | $V_{\text {IL }}$ | (Note 1) | X | 5.0 V | Dout |
| Output Disable | X | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 5.0 V | High Z |
| Standby | $\mathrm{V}_{\text {IH }}$ | X | X | X | 5.0 V | High Z |
| Programming | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\text {IL }}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | DOUT |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 12.75 V | 6.25 V | High Z |

Note 1: $X$ can be $V_{I L}$ or $V_{I H}$.

TABLE II. Manufacturer's Identification Code

| Pins | AO <br> $(12)$ | A 9 <br> $(26)$ | $\mathbf{O}_{\mathbf{7}}$ <br> $(21)$ | $\mathbf{O}_{\mathbf{6}}$ <br> $(20)$ | $\mathbf{O}_{\mathbf{5}}$ <br> $(19)$ | $\mathbf{O}_{\mathbf{4}}$ <br> $(18)$ | $\mathbf{O}_{\mathbf{3}}$ <br> $(17)$ | $\mathbf{O}_{\mathbf{2}}$ <br> $(15)$ | $\mathbf{O}_{\mathbf{1}}$ <br> $(14)$ | $\mathbf{O}_{\mathbf{0}}$ <br> $(13)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 86 |

NM27C210

## 1,048,576-Bit (64K x 16) High Performance CMOS EPROM

## General Description

The NM27C210 is a high performance Electrically Programmable UV erasable ROM (EPROM). It contains $1,048,576$ bits configured as $64 \mathrm{~K} \times 16$ bit. It is offered in both erasable versions for prototyping and early production applications as well as non-erasable, plastic packaged versions that are ideal for high volume and automated assembly applications. The NM27C210 operates from a single 5 volt $\pm 10 \%$ supply in the read mode.
The NM27C210 is offered in both DIP and surface mount packages. The DIP package is a 40-pin dual-in-line ceramic with a quartz window to allow erasing. The surface mount package is a 44-pin PLCC that is offered in OTP.
This EPROM is manufactured using National's proprietary 1.2 micron CMOS SVG EPROM technology for an excellent combination of speed and economy while providing excellent reliability.

## Block Diagram



TL/D/11093-1

## Connection Diagrams

| IN CONF | ATIONS |  | DIP |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 27C280 | 27C240 | 27C220 | NM27C210 |  | 27C220 | 27 C 240 | 27 C 280 |
| $\mathrm{A}_{18}$ | XX/VPP | XX/VPP | $-\mathrm{xx} \mathrm{NPp} \mathrm{S}_{1}$ | $\mathrm{v}_{\mathrm{cc}}-$ | $\mathrm{V}_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}$ | $V_{\text {cc }}$ |
| $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | $\overline{C E}$ | --CEO2 39 | Px/PGM - | XX/PGM | $\mathrm{A}_{17}$ | $\mathrm{A}_{17}$ |
| $\mathrm{O}_{15}$ | $\mathrm{O}_{15}$ | $\mathrm{O}_{15}$ | $-0,15 \mathrm{O}^{3} \quad 38$ | $\mathrm{P}^{\text {nc }}$ | $\mathrm{A}_{16}$ | $\mathrm{A}_{16}$ | $\mathrm{A}_{16}$ |
| $\mathrm{O}_{14}$ | $\mathrm{O}_{14}$ | $\mathrm{O}_{14}$ | $-0_{14} \mathrm{~S}^{4} \quad 37$ | $\mathrm{Pa}_{15}$ | $\mathrm{A}_{15}$ | $\mathrm{A}_{15}$ | $\mathrm{A}_{15}$ |
| $\mathrm{O}_{13}$ | $\mathrm{O}_{13}$ | $\mathrm{O}_{13}$ | $\longrightarrow 0_{13}$ - $^{5}$ | $\mathrm{Pa}_{\mathrm{A}_{14} \text { - }}$ | $\mathrm{A}_{14}$ | $\mathrm{A}_{14}$ | $\mathrm{A}_{14}$ |
| $\mathrm{O}_{12}$ | $\mathrm{O}_{12}$ | $\mathrm{O}_{12}$ | $-0_{12} \square^{6} \quad 35$ | $\mathrm{Pa}_{13}$ - | $\mathrm{A}_{13}$ | $\mathrm{A}_{13}$ | $\mathrm{A}_{13}$ |
| $\mathrm{O}_{11}$ | $\mathrm{O}_{11}$ | $\mathrm{O}_{11}$ |  | $\mathrm{Pa}_{A_{12}}$ - | $\mathrm{A}_{12}$ | $\mathrm{A}_{12}$ | $\mathrm{A}_{12}$ |
| $\mathrm{O}_{10}$ | $\mathrm{O}_{10}$ | $\mathrm{O}_{10}$ | $-0_{10} \mathrm{H}^{8} \quad 33$ | $\mathrm{P}_{11}$ - | $\mathrm{A}_{11}$ | $\mathrm{A}_{11}$ | $\mathrm{A}_{11}$ |
| $\mathrm{O}_{9}$ | $\mathrm{O}_{9}$ | $\mathrm{O}_{9}$ | $\longrightarrow \mathrm{O}_{9} \mathrm{~S}^{\circ} \longrightarrow{ }^{32}$ | PA $A_{10}$ - | . $\mathrm{A}_{10}$ | $\mathrm{A}_{10}$ | $\mathrm{A}_{10}$ |
| $\mathrm{O}_{8}$ | $\mathrm{O}_{8}$ | $\mathrm{O}_{8}$ | - $0_{8} \mathrm{H}^{10} \longrightarrow{ }^{31}$ | $\mathrm{Pa}_{\mathrm{A}_{\text {g }}}$ | $\mathrm{A}_{9}$ | $\mathrm{A}_{9}$ | $\mathrm{Ag}_{9}$ |
| GND | GND | GND | - ${ }^{\text {NOL }}$-11 $\longrightarrow 30$ | OND -- | GND | GND | GND |
| $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $-0_{7} \mathrm{C} \mathrm{C}_{12} 29^{29}$ | $\mathrm{Pa}_{8}$ | $\mathrm{A}_{8}$ | $A_{8}$ | $\mathrm{A}_{8}$ |
| $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $-0_{6} \mathrm{O}^{13} \quad 28$ | $\mathrm{ar}_{7}$ | $A_{7}$ | $A_{7}$ | $A_{7}$ |
| $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\cdots 0_{5} \mathrm{C}^{14}$ | $\mathrm{A}_{6}$ | $\mathrm{A}_{6}$ | $\mathrm{A}_{6}$ | $\mathrm{A}_{6}$ |
| $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | - $0_{4}$ 号15 26 | $\mathrm{AA}_{5}$ | $\mathrm{A}_{5}$ | $\mathrm{A}_{5}$ | $\mathrm{A}_{5}$ |
| $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $=0_{3}=^{16} \quad 25$ | $\mathrm{a}_{4}$ — | $\mathrm{A}_{4}$ | $\mathrm{A}_{4}$ | $\mathrm{A}_{4}$ |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | - $\mathrm{O}_{2} \mathrm{Cl}_{17} \quad 24$ | $\mathrm{AA}_{3}$ | $\mathrm{A}_{3}$ | $\mathrm{A}_{3}$ | $\mathrm{A}_{3}$ |
| $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | -0, $0_{18} 23$ | $\mathrm{P}_{\mathrm{A}_{2}}$ | $\mathrm{A}_{2}$ | $\mathrm{A}_{2}$ | $\mathrm{A}_{2}$ |
| $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | - $0_{0} 5^{19} 22$ | $\mathrm{Pa}_{1}$ - | $\mathrm{A}_{1}$ | $\mathrm{A}_{1}$ | $\mathrm{A}_{1}$ |
| $\overline{O E} / V_{P P}$ | OE | $\overline{O E}$ | - $\overline{\mathrm{OE}} \mathrm{C}^{20} 21$ | $\mathrm{Aa}_{0}-$ | $\mathrm{A}_{0}$ | $\mathrm{A}_{0}$ | $\mathrm{A}_{0}$ |



Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27C210 pins.

Commercial Temperature Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27C210 N, Q, V 120 | 120 |
| NM27C210 N, Q, V 150 | 150 |
| NM27C210 N, Q, V 200 | 200 |

Military Temperature Range $\left\{-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27C210 QM 200 | 200 |

Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27C210 NE, QE, VE 120 | 120 |
| NM27C210 NE, QE, VE 150 | 150 |
| NM27C210 NE, QE, VE 200 | 200 |

Note: Surface mount PLCC package available for commercial and extended temperature ranges only.
Package Types: NM27C210 Q, N, V XXX
Q = Quartz-Windowed Ceramic DIP package
$V=$ PLCC package

- All packages conform to JEDEC standard.
- All versions are guaranteed to function in slower applications.

Pin Names

| AO-A15 | Addresses |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{O} 0-\mathrm{O15}$ | Outputs |
| $\overline{\text { PGM }}$ | Program |
| XX | Don't Care (During Read) |
| NC | No Connect |

## PLCC Pin Configuration



TL/D/11093-3

Top View

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

Storage Temperature
All Input Voltages except A9 with
Respect to Ground (Note 10)
$V_{P P}$ and A9 with Respect to Ground $V_{C C}$ Supply Voltage with Respect to Ground $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

$$
-0.6 \mathrm{~V} \text { to }+7 \mathrm{~V}
$$

$$
-0.6 \mathrm{~V} \text { to }+14 \mathrm{~V}
$$

$$
-0.6 \mathrm{~V} \text { to }+7 \mathrm{~V}
$$

ESD Protection
All Output Voltages with Respect to Ground (Note 10)
-0.6 V to +7 V
$>2000 \mathrm{~V}$

## Operating Range

| Range | Temperature | V $_{\text {CC }}$ | Tolerance |
| :--- | :--- | :--- | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |

$$
V_{C C}+1.0 \mathrm{~V} \text { to } \mathrm{GND}-0.6 \mathrm{~V}
$$

DC Read Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level |  | -0.5 | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Level |  | 2.0 | $\mathrm{V}_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $1 \mathrm{OL}=2.1 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 3.5 |  | V |
| ${ }^{\text {ISB1 }}$ | $V_{C C}$ Standby Current (CMOS) | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$ |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {SB2 }}$ | $\mathrm{V}_{\text {CC }}$ Standby Current | $\overline{\mathrm{CE}}=\mathrm{V}_{1 H}$ |  | 1 | mA |
| lcc | $\mathrm{V}_{\text {CC }}$ Active Current | $\overline{C E}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ $\mathrm{f}=5 \mathrm{MHz}$ |  | 50 | mA |
| $l_{\text {PP }}$ | Vpp Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  | 10 | $\mu \mathrm{A}$ |
| $l_{\text {LI }}$ | Input Load Current | $\mathrm{V}_{\text {IN }}=5.5$ or GND | -1 | 1 | $\mu \mathrm{A}$ |
| Lo | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND | -10 | 10 | $\mu \mathrm{A}$ |

AC Read Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | 120 |  | 150 |  | 200 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 120 |  | 150 |  | 200 | ns |
| ${ }^{\text {t Ce }}$ | $\overline{\mathrm{C} E}$ to Output Delay |  | 120 |  | 150 |  | 200 |  |
| $\mathrm{t}_{\mathrm{OE}}$ | $\overline{\text { OE }}$ to Output Delay |  | 50 |  | 50 |  | 50 |  |
| $t_{D F}$ <br> (Note 2) | Output Disable to Output Float |  | 35 |  | 45 |  | 55 |  |
| ${ }^{\mathrm{t}} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{C E}$ or $\overline{O E}$, Whichever Occurred First | 0 |  | 0 |  | 0 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathbb{I N}}$ | Input Capacitance | $\mathrm{V}_{\mathbb{I N}}=0 \mathrm{~V}$ | 12 | 20 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\mathrm{OUT}}=\mathrm{OV}$ | 13 | 20 | pF |

## AC Test Conditions

| Output Load | 1 TTL Gate and <br>  <br> Input Rise and Fall Times | Timing Measurement Reference Level <br> Inputs | 0.8 V and 2 V |
| :--- | ---: | ---: | ---: |
| Input Pulse Levels | $\leq 5 \mathrm{~ns}$ | Outputs | 0.8 V and 2 V |
| $100 \mathrm{pFote} \mathrm{8)}$ |  |  |  |

## AC Waveforms (Notes 6, 7, \& 9)



TL/D/11093-4
Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The $t_{\mathrm{DF}}$ and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE ${ }^{\circ}$, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V ;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} 1}$ (DC) +0.10 V .
Note 5: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND.

Note 7: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$, $\mathrm{IOH}=-400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.
Note 10: Inputs and outputs can undershoot to $\mathbf{- 2 . 0 V}$ for 20 ns Max.

Programming Characteristics (Notes 1, 2, 3, 4\&5)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| tCES | $\overline{C E}$ Setup Time | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IH}}$ | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {dS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tVPS | $\mathrm{V}_{\mathrm{PP}}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tves | $\mathrm{V}_{\text {cc }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| ${ }^{t}{ }_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toe | Data Valid from $\overline{O E}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 100 | ns |
| IPP | $V_{\text {Pp }}$ Supply Current during Programming Pulse | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}} \end{aligned}$ |  |  | 40 | mA |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\mathrm{A}}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{\text {CC }}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $V_{P P}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| ${ }_{\text {t }} \mathrm{FR}^{\text {R }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

## Programming Waveforms (Note 3)



TL/D/11093-5
Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{Pp}}$ or $\mathrm{V}_{\mathrm{CC}}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{Pp}}$, $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm, at typical power supply voltages and timings.
Note 5: During power up the $\overline{\text { PGM }}$ pin must be brought high $\left(~ Z V_{I H}\right)$ either coincident with or before power is applied to $V_{p p}$.

Fast Programming Algorithm Flow Chart


FIGURE 1

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{pp}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $V_{C C}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable (CE) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that the addresses are stable, address access time ( $t_{A C C}$ ) is equal to the delay from $\overline{C E}$ to output ( $t_{C E}$ ). Data is available at the outputs $t_{O E}$ after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{\text {ACC- }}$ toe.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from 275 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the $\overline{C E}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the $\overline{O E}$ input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Tying

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2 -line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.

To most efficiently use these two control lines, it is recommended that CE be decoded and used as the primary device selecting function, while OE be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on the $\mathrm{V}_{\mathrm{PP}}$ or A 9 pin will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 ' $s$ " state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 ' $s$ " and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the $V_{P P}$ power supply is at 12.75 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 16 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{PGM}}$ input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu \mathrm{~s}$ pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu$ s pulse.
The EPROM must not be programmed with a DC signal applied to the $\overline{\text { PGM }}$ input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the PGM input programs the paralleled EPROM.

## Functional Description (Continued)

## Program Inhibit

Programming multiple EPROM's in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}}$ all like inputs (including $\overline{\mathrm{OE}}$ and $\overline{\mathrm{PGM}}$ ) of the parallel EPROM may be common. A TTL low level program pulse applied to an EP. ROM's $\overline{\mathrm{PGM}}$ input with $\overline{\mathrm{CE}}$ at $\mathrm{V}_{\mathrm{IL}}$ and $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V will program that EPROM. A TTL high level $\overline{C E}$ input inhibits the other EPROM's from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V . $\mathrm{V}_{\mathrm{PP}}$ must be at $\mathrm{V}_{\mathrm{CC}}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for the NM27C210 is " $8 \mathrm{FD6}$ ", where " 8 F " designates that it is made by National Semiconductor, and "D6" designates a 1 Megabit ( $64 \mathrm{~K} \times 16$ ) part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin $\mathrm{A}_{9}$. Addresses $\mathrm{A}_{1}-\mathrm{A}_{8}, \mathrm{~A}_{10}-\mathrm{A}_{15}$, and all control pins are held at $V_{\mathrm{IL}}$. Address pin $A O$ is held at $V_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the lower eight data pins, $\mathrm{O}_{0}-0_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of 15 W $\mathrm{sec} / \mathrm{cm}^{2}$.
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increases as the square of the distance from the lamp (if distance is doubled the erasure time increases by factor of 4). Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, ICC, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## MODE SELECTION

The modes of operation of the NM27C210 are listed in Table I. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for $V_{P P}$ and A9 for device signature.

TABLE I. Modes Selection

| Pins | $\overline{C E}$ | $\overline{O E}$ | $\overline{\text { PGM }}$ | $V_{\text {PP }}$ | V cc | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |  |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | (Note 1) | X | 5.0V | Dout |
| Output Disable | X | $V_{\text {IH }}$ | X | X | 5.0 V | High Z |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | X | X | 5.0 V | High Z |
| Programming | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\text {IL }}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | Dout |
| Program Inhibit | $\mathrm{V}_{\text {IH }}$ | X | X | 12.75 V | 6.25 V | High Z |

Note 1: $X$ can be $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$.

TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(21)$ | A 9 <br> $(31)$ | $\mathrm{O}_{7}$ <br> $(12)$ | $\mathbf{O}_{6}$ <br> $(13)$ | $\mathrm{O}_{5}$ <br> $(14)$ | $\mathbf{O}_{4}$ <br> $(15)$ | $\mathbf{O}_{3}$ <br> $(16)$ | $\mathbf{O}_{\mathbf{2}}$ <br> $(17)$ | $\mathbf{O}_{1}$ <br> $(18)$ | $\mathbf{O}_{\mathbf{0}}$ <br> $(19)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{1 \mathrm{~L}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\text {IH }}$ | 12 V | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | D 6 |

NM27C040

## 4,194,304-Bit (512K x 8) High Performance CMOS EPROM

## General Description

The NM27C040 is a high performance, 4,194,304-bit Electrically Programmable UV Erasable Read Only Memory. It is organized as 512 K words of 8 bits each. Its pin-compatibility with byte-wide JEDEC EPROMs enables upgrades through 8 Mbit EPROMs. The "Don't Care" feature on VPP during read operations allows memory expansions from 1M to 8 Mbits with no printed circuit board changes.
The NM27C040 provides microprocessor-based systems extensive storage capacity for large portions of operating system and application software. Its 150 ns access time provides high speed operation with high-performance CPUs. The NM27C040 offers a single chip solution for the code storage requirements of $100 \%$ firmware-based equipment. Frequently used software routines are quickly executed from EPROM storage, greatly enhancing system utility.

The NM27C040 is manufactured using National's advanced CMOS SVG EPROM technology.

## Features

- High performance CMOS - 150 ns access time
- High reliability with EPI processing
- Latch-up immunity to 200 mA
- ESD protection exceeds 2000 V
- Simplified upgrade path
- VPP is a "Don't Care" during normal read operation
- JEDEC standard pin configuration -32-pin DIP package
- Manufacturer's identification code


## Block and Connection Diagrams



Block and Connection Diagrams (Continued)
DIP

| 27C080 | 27C020 | 27C010 |
| :---: | :---: | :---: |
| A19 | XX/VPP | XX/VPP |
| A16 | A16 | A16 |
| A15 | A15 | A15 |
| A12 | A12 | A12 |
| A7 | A7 | A7 |
| A6 | A6 | A6 |
| A5 | A5 | A5 |
| A4 | A4 | A4 |
| A3 | A3 | A3 |
| A2 | A2 | A2 |
| A1 | A1 | A1 |
| A0 | A0 | AO |
| $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ |
| $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ |
| GND | GND | GND |

NM27C040


| $\mathbf{2 7 C 0 1 0}$ | $\mathbf{2 7 C 0 2 0}$ | $\mathbf{2 7 C 0 8 0}$ |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{XX} / \mathrm{PGM}$ | $\mathrm{XX} / \overline{\mathrm{PGM}}$ | A 18 |
| XX | A 17 | A 17 |
| A 14 | A 14 | A 14 |
| A 13 | A 13 | A 13 |
| A 8 | AB | $\mathrm{A8}$ |
| A 9 | A 9 | A 9 |
| A 11 | A 11 | A 11 |
| $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}}$ | $\mathrm{OE} / \mathrm{V}_{\mathrm{PP}}$ |
| A 10 | A 10 | A 10 |
| $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ | $\mathrm{CE} / \overline{\mathrm{PGM}}$ |
| $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ |
| $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ |
| $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ |
| $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ |
| $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ |

Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27C040 pin.

Commercial Temperature Range $\left(0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27C040 Q 150 | 150 |
| NM27C040 Q 170 | 170 |
| NM27C040 Q 200 | 200 |

Military Temperature Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27C040 QM 200 | 200 |

Pin Names

| A0-A16 | Addresses |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{O}-\mathrm{O7}$ | Outputs |
| $\overline{\mathrm{PGM}}$ | Program |
| XX | Don't Care (During Read) |

Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27C040 QE 150 | 150 |
| NM27C040 QE 170 | 170 |
| NM27C040 QE 200 | 200 |

Package Types: NM27C040 Q,VXXX
$Q=$ Quartz-Windowed Ceramic DIP

- All packages conform to the JEDEC standard.
- All versions are guaranteed to function for slower speeds.


Operating Range

| Range | Temperature | V $_{\text {CC }}$ | Tolerance |
| :--- | :--- | :--- | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $\pm 5 \mathrm{~V}$ | $\pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $\pm 5 \mathrm{~V}$ | $\pm 10 \%$ |

## Read Operation

DC. Electrical Characteristics Over operating range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Test Conditions |  | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level |  |  | -0.5 | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Level |  |  | 2.0 | $V_{C C}+1$ | V |
| V OL | Output Low Voltage | $\mathrm{IOL}=2.1 \mathrm{~mA}$ |  |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |  | 3.5 |  | V |
| $\mathrm{I}_{\mathrm{SB} 1}$ | $\mathrm{V}_{\text {CC }}$ Standby Current (CMOS) | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3$ |  |  | 100 | $\mu \mathrm{A}$ |
| ISB2 | $V_{\text {CC }}$ Standby Current | $\overline{C E}=\mathrm{V}_{1 H}$ |  |  | 1 | mA |
| lcC | $V_{\text {CC }}$ Active Current | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | $f=5 \mathrm{MHz}$ |  | 60 | mA |
| IPP | VPP Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  |  | 10 | $\mu \mathrm{A}$ |
| VPP | Vpp Read Voltage |  |  | $\mathrm{V}_{C C}-0.4$ | $\mathrm{V}_{\mathrm{CC}}$ | V |
| ILI | Input Load Current | $\mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ or GN |  | -1 | 1 | $\mu \mathrm{A}$ |
| Lo | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or |  | -10 | 10 | $\mu \mathrm{A}$ |

AC Electrical Characteristics over operating range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | 150 |  | 170 |  | 200 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 150 |  | 170 |  | 200 | ns |
| $\mathrm{t}_{\text {CE }}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 150 |  | 170 |  | 200 |  |
| toe | $\overline{\mathrm{OE}}$ to Output Delay |  | 50 |  | 50 |  | 50 |  |
| tDF <br> (Note 2) | Output Disable to Output Float |  | 35 |  | 45 |  | 55 |  |
| $\mathrm{t}_{\mathrm{O}} \mathrm{H}$ <br> (Note 2) | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | 0 |  | 0 |  | 0 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}$ | 9 | 15 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 12 | 15 | pF |

## AC Test Conditions

Output Load

Input Rise and Fall Times
Input Pulse Levels
$C_{L}=100 \mathrm{pF}$ (Note 8)
$\leq 5 \mathrm{~ns}$
0.45 V to 2.4 V

1 TTL Gate and

Timing Measurement Reference Level (Note 10) $\begin{array}{ll}\text { Inputs } & 0.8 \mathrm{~V} \text { and } 2 \mathrm{~V} \\ \text { Outputs } & 0.8 \mathrm{~V} \text { and } 2 \mathrm{~V}\end{array}$

AC Waveforms (Notes 6, 7, and 9)


TL/D/10836-4
Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{\mathrm{OE}}$ may be delayed up to $\mathrm{t}_{\mathrm{ACC}}-\mathrm{t}_{\mathrm{OE}}$ after the falling edge of $\overline{C E}$ without impacting $\mathrm{t}_{\mathrm{ACC}}$.
Note 4: The $\mathrm{t}_{\mathrm{DF}}$ and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE ${ }^{\otimes}$, the measured $\mathrm{V}_{\mathrm{OH}}$ (DC) -0.10 V ;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL1}}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 5: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $V_{C C}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TL Gate: $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.

$$
\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF} \text { includes fixture capacitance. }
$$

Note 9: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.
Note 10: Inputs and outputs can undershoot to $\mathbf{- 2 . 0 V}$ for 20 ns Max.

Programming Waveform (Note 3)


TL/D/10836-5

Programming Characteristics (Notes $1,2,3 \& 4$ )

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\mathrm{OE}}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvps | VPP Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tVCs | $V_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {DH }}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{C E} / \overline{\text { PGM }}=\mathrm{X}$ | 0 |  | 60 | ns |
| $t_{\text {pw }}$ | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{S}$ |
| toe | Data Valid from $\overline{\mathrm{OE}}$ | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}=\mathrm{X}$ |  |  | 100 | ns |
| IPP | $V_{\text {PP }}$ Supply Current during Programming Pulse | $\overline{C E} / \overline{\text { PGM }}=\mathrm{V}_{\text {IL }}$ |  |  | 30 | mA |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  |  | 50 | mA |
| $T_{\text {A }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{\text {CC }}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $V_{\text {PP }}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $\mathrm{t}_{\mathrm{FR}}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.1 | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{pp}}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{PP}}$ or $\mathrm{V}_{\mathrm{CC}}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $\mathrm{V}_{\mathrm{PP}}$ pin during programming is 14 V . Care must be taken when switching the $\mathrm{V}_{\mathrm{PP}}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{Pp}}$, $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Progam Algorithm, at typical power supply voltages and timings.
Note 5: During power up the PGM pin must be brought high $\left(\geq \mathrm{V}_{\mathrm{H}}\right)$ either coincident with or before power is applied to $\mathrm{V}_{\mathrm{PP}}$.

Fast Programming Algorithm Flow Chart


FIGURE 1

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{Pp}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $V_{C C}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable (CE/PGM) is the power control and should be used for device selection. Output Enable (OE) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from CE to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs $\mathrm{t}_{\mathrm{OE}}$ after the falling edge of OE, assuming that CE/PGM has been low and addresses have been stable for at least $t_{\text {ACC }}-$ toe.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from of 385 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the CE/PGM input. When in standby mode, the outputs are in a high impedance state, independent of the OE input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the OE input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Typing

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2 -line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.

To most efficiently use these two control lines, it is recommended that CE/PGM be decoded and used as the primary device selecting function, while OE be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on pin $1\left(\mathrm{~V}_{\mathrm{PP}}\right)$ will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 ' $s$ " state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 's" and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the $V_{P P}$ power supply is at 12.75 V and OE is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the CE/PGM input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu$ s pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu$ s pulse.
The EPROM must not be programmed with a DC signal applied to the CE/PGM input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the CE/PGM input programs the paralleled EPROM.
Note: Some programmer manufacturers, due to equipment limitation, may offer interactive program Algorithm (shown in Figure 2).

## Functional Description (Continued)

## Program Inhibit

Programming multiple EPROMs in parallel with different data is also easily accomplished. Except for CE/PGM all like inputs (including OE) of the parallel EPROMs may be common. A TTL low level program pulse applied to an EPROM's CE/PGM input with VPP at 12.75 V will program that EPROM. A TTL high level CE/PGM input inhibits the other EPROMs from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V . $\mathrm{V}_{\mathrm{PP}}$ must be at $\mathrm{V}_{\mathrm{CC}}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for NM27C040 is " 8 F08", where " 8 F "' designates that it is made by National Semiconductor, and "08" designates a 4 Megabit ( $512 \mathrm{~K} \times 8$ ) part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A16, and all control pins are held at $\mathrm{V}_{\mathrm{IL}}$. Address pin $A O$ is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the eight data pins, $\mathrm{O}_{0}-\mathrm{O}_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wave-
lengths shorter than approximately 4000 Angstroms (A). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $X$ exposure time) for erasure should be minimum of 15 W - $\mathrm{sec} / \mathrm{cm}^{2}$.

The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.

An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increase as the square of the distance from the lamp. (If distance is doubled the erasure time increases by factor of 4.) Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, Icc, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent of the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $\mathrm{V}_{\mathrm{CC}}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## Mode Selection

The modes of operation of the NM27C040 are listed in Table I. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for $V_{P P}$ and $A 9$ for device signature.

TABLE I. Modes Selection

| Pins | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | $\overline{O E}$ | $V_{\text {PP }}$ | $\mathrm{V}_{\mathrm{cc}}$ | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |
| Read | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | (Note 1) | 5.0 V | DOUT |
| Output Disable | X | $\mathrm{V}_{1 \mathrm{H}}$ | X | 5.0 V | High Z |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 5.0 V | High Z |
| Programming | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | DIN |
| Program Verify | X | $V_{\text {IL }}$ | 12.75 V | 6.25 V | DOUT |
| Program Inhibit | $V_{1 H}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | High $Z$ |

Note 1: X can be $\mathrm{V}_{\text {IL }}$ or $\mathrm{V}_{\mathrm{H}}$

TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(\mathbf{1 2 )}$ | A9 <br> $(\mathbf{2 6})$ | O7 <br> $(\mathbf{2 1 )}$ | O6 <br> $(20)$ | O5 <br> $(19)$ | O4 <br> $(18)$ | O3 <br> $(17)$ | O2 <br> $(15)$ | O1 <br> $(14)$ | O0 <br> $(13)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 08 |

## Processor Oriented EPROM Selection Guide

## General Description

National Semiconductor's family of Processor Oriented EPROMs are devices with features or functions to enhance their operation with various microprocessors and microcontrollers. There are 3 devices with specification improvements to help eliminate wait states and glue logic. These
are the NM27P512, NM27P210, and NM27P040. There is one device that has address latches to facilitate multiplexed data/address busses without the use of external address latches, the NMC87C257.

## Available Product

|  | Packages | Temperature Ranges* | Improved $\mathbf{t}_{\mathrm{DF}} / \mathbf{t}_{\mathbf{O H}}$ | Latches |
| :--- | :---: | :---: | :---: | :---: |
| NM27P512 | $\mathrm{Q}, \mathrm{N}, \mathrm{V}$ | C,, M | Y |  |
| NM27P210 | $\mathrm{Q}, \mathrm{N}, \mathrm{V}$ | C, E, M | Y |  |
| NM27P040 | $\mathrm{Q}, \mathrm{N}, \mathrm{V}$ | C, E, M | Y |  |
| NMC87C257 | $\mathrm{Q}, \mathrm{V}$ | C, E, M |  | $Y$ |

Contact your National Semiconductor sales representative for military operating temperature range devices.

## Ordering Information



$$
512=64 \mathrm{k} \times 8
$$

$$
040=512 k \times 8
$$


Operating Temperature Range No Entry $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

$$
\mathrm{E}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}
$$

$$
\mathrm{M}=-55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}
$$

Q = Quartz Window Ceramic
$N=$ Plastic DIP (OTP)
$V=$ PLCC (OTP)

## NM27P512

## 524,288-Bit (64K x 8) Processor Oriented CMOS EPROM

## General Description

The NM27P512 is a 512K Processor Oriented EPROM configured as $64 \mathrm{k} \times 8$. It's designed to simplify microprocessor interfacing while remaining compatible with standard EPROMs. It can reduce both wait states and glue logic when the specification improvements are taken advantage of in the system design. The NM27P512 is implemented in National's advanced CMOS EPROM process to provide a reliable solution and access times as fast as 120 ns .
The interface improvements address two areas to eliminate the need for additional devices to adapt the EPROM to the microprocessor and to eliminate wait states at the termination of the access cycle. Even with these improvements, the NM27P512 remains compatible with industry standard JEDEC pinout EPROMs. The time from CE or OE being negated until the outputs are guaranteed to be in the high impedance state has been reduced to eliminate the need for wait states at the termination of the memory cycle and the data-out hold time has been extended to eliminate the need to provide data hold time for the microprocessor by delaying control signals or latching and holding the data in external latches.

## Features

- Fast output turn off to eliminate wait states
- Extended data hold time for microprocessor compatibility
- High performance CMOS
- 120 ns access time
- High reliability with EPI processing
- Latch-up immunity to 200 mA
- ESD protection exceeds 2000 V
- JEDEC standard pin configuration
- Manufacturer's identification code


## Block Diagram



TL/D/11365-1

## Connection Diagrams



TL/D/11365-2
Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27P512 pins.

Commercial Temp Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Access Time (ns)* |
| :--- | :---: |
| NM27P512 Q, N, V 120 | 120 |
| NM27P512 Q, N, V 150 | 150 |

Military Temp Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Access Time (ns)* |
| :--- | :---: |
| NM27P512 QM 200 | 200 |

Pin Names

| $\mathrm{AO}-\mathrm{A} 15$ | Addresses |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{O}-\mathrm{O} 7$ | Outputs |
| $\overline{\mathrm{PGM}}$ | Program |
| $X X$ | Don't Care (During Read) |

Extended Temp Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Access Time (ns)* $^{*}$ |
| :---: | :---: |
| NM27P512 QE, NE, VE 120 | 120 |
| NM27P512 QE, NE, VE 150 | 150 |

Note: Surface mount PLCC package available for commercial and extended temperature ranges only.
"All versions are guaranteed to function for slower speeds.
Package Types: NM27P512 Q, N, V XXX
Q = Quartz-Windowed Ceramic DIP Package
$N=$ Plastic OTP DIP Package
$\mathrm{V}=$ PLCC Package

- All packages conform to the JEDEC standard.

PLCC


TL/D/11365-3

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specifled devices are required, please contact the National Semiconductor Sales Office/Distributors for avallability and specifications.
Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input Voltages Except A9 with Respect to Ground
$V_{P P}$ and A9 with Respect to Ground
Operating Range

| Range | Temperature | $\mathbf{V}_{\mathbf{C C}}$ | Tolerance |
| :--- | :---: | :---: | :---: |
| Comm'l | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |

## Read Operation

## DC Electrical Characteristics

| Symbol | Parameter | Test Conditions |  | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level |  |  | -0.5 | 08 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Level |  |  | 2.0 | $\mathrm{V}_{\mathrm{CC}}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{lOL}=2.1 \mathrm{~mA}$ |  |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |  | 3.5 |  | V |
| $\mathrm{ISB1}^{(10)}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current (CMOS) | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3$ |  |  | 100 | $\mu \mathrm{A}$ |
| ISB2 | $V_{C C}$ Standby Current | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  |  | 1 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}$ Active Current | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{f}=5 \mathrm{MHz}$ |  | 40 | mA |
| Ipp | VPP Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  |  | 10 | $\mu \mathrm{A}$ |
| $V_{P P}$ | VPP Read Voltage |  |  | $\mathrm{V}_{\mathrm{C}}-0.7$ | VCC | V |
| $\mathrm{ILI}^{\text {l }}$ | Input Load Current | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ or GN |  | -1 | 1 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or |  | -10 | 10 | $\mu \mathrm{A}$ |

## AC Electrical Characteristics

| Symbol | Parameter | 120 |  | 150 |  | 200 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 120 |  | 150 |  | 200 | ns |
| $\mathrm{t}_{\text {CE }}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 120 |  | 150 |  | 200 |  |
| toe | $\overline{\mathrm{OE}}$ to Output Delay |  | 50 |  | 50 |  | 50 |  |
| $t_{D F}{ }^{(2)}$ | Output Disable to Output Float |  | 25 |  | 25 |  | 25 |  |
| $\mathrm{tOH}^{(2)}$ | Output Hold from Addresses, $\overline{\text { CE }}$ or $\overline{O E}$, Whichever Occurred First | 7 |  | 7 |  | 7 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN} 1}$ | Input Capacitance <br> except $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ | $\mathrm{V}_{\mathbb{I N}}=\mathrm{OV}$ | 6 | 12 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 9 | 12 | pF |
| $\mathrm{C}_{\mathbb{N} 2}$ | $\mathrm{OE} / \mathrm{V}_{\mathrm{Pp}}$ Input <br> Capacitance | $\mathrm{V}_{\mathbb{N}}=0 \mathrm{~V}$ | 20 | 25 | pF |

## AC Test Conditions

Output Load

> 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}($ Note 8$)$ $\leq 5 \mathrm{~ns}$
> 0.45 V to 2.4 V

Input Rise and Fall Times
Input Pulse Levels
Timing Measurement Reference Level (Note 9)
Inputs
Outputs

## AC Waveforms (Notes 6, 7)



TL/D/11365-4
Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The $\mathrm{t}_{\mathrm{DF}}$ and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V ;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} 1}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 5: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{IOL}_{\mathrm{OL}}=1.6 \mathrm{~mA}$, $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$C_{L}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: Inputs and outputs can undershoot to -2.0 V for 20 ns Max.
Note 10: CMOS inputs; $\mathrm{V}_{\mathrm{IL}}=G N D \pm 0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$.

Programming Characteristics (Notes 1 and 2 )

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| tos | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvcs | $\mathrm{V}_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DH }}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{CF}}$ | Chip Enable to Output Float Delay | $\overline{O E}=V_{\text {IL }}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toen | $\overline{\text { OE Hold Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| tov | Data Valid from $\overline{C E}$ | $\overline{O E}=V_{\text {IL }}$ |  |  | 250 | ns |
| $t_{\text {PRT }}$ | $\overline{O E}$ Pulse Rise Time during Programming |  | 50 |  |  | ns |
| $t_{V R}$ | Vpp Recovery Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| IPP | $V_{\text {PP }}$ Supply Current during Programming Pulse | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{PP}} \end{aligned}$ |  |  | 30 | mA |
| Icc | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\text {R }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ | Power Supply Voltage |  | 6 | 6.25 | 6.5 | V |
| $\mathrm{V}_{\mathrm{PP}}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13 | V |
| $t_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4 |  | V |
| $\mathrm{t}_{\mathrm{N}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2 | V |

## Programming Waveforms



TL/D/11365-5
Note 1: National's standard product warranty applies to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{PP}}$ or $\mathrm{V}_{\mathrm{CC}}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm at typical power supply voltages and timings.

Fast Programming Algorithm Flow Chart


TL/D/11365-6
FIGURE 1

## Interactive Programming Algorithm Flow Chart



FIGURE 2

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and OE/Vpp. The OE/VPp power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable (CE/PGM) is the power control and should be used for device selection. Output Enable ( $O E / V_{P P}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from CE to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs toE after the falling edge of OE, assuming that CE has been low and addresses have been stable for at least $t_{\mathrm{ACC}}-\mathrm{t}_{\mathrm{OE}}$.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from 385 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the CE/PGM input. When in standby mode, the outputs are in a high impedance state, independent of the $O E$ input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the OE input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Typing

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that CE/PGM be decoded and used as the primary device selecting function, while $O E / V_{P P}$ be made a common connection to all devices in the array and connected to the READ line from the system control bus.

This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14V on pin 22 ( $O E / V_{\mathrm{PP}}$ ) will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 ' s " state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 's" and " 0 's" can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the OE/VPP is at 12.75 V . It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $V_{C C}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.

When the address and data are stable, an active low, TTL program pulse is applied to the CE/PGM input. A program pulse must be applied at each address location to be programmed.
The EPROM is programmed with the Fast Programming AIgorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu \mathrm{~s}$ pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu \mathrm{~s}$ pulse.
The EPROM must not be programmed with a $D C$ signal applied to the CE/PGM input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the CE/PGM input programs the paralleled EPROM.
Note: Some programmer manufacturers, due to equipment limitation, may offer interactive program Algorithm (shown in Figure 2).

## Program Inhibit

Programming multiple EPROMs in parallel with different data is also easily accomplished. Except for CE/PGM all like inputs (including OE/VPP) of the parallel EPROMs may be common. A TTL low level program pulse applied to an EPROM's CE/PGM input with OE/VPP at 12.75 V will program that EPROM. A TTL high level CE/PGM input inhibits the other EPROMs from being programmed.

## Functional Description (Continued)

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify is accomplished with OE/V ${ }_{P P}$ and CE at $V_{\text {IL }}$. Data should be verified TDV after the falling edge of CE.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for NM27P512 is " $8 F 85$ ", where " $8 F$ " designates that it is made by National Semiconductor, and " 85 " designates a 512 K part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A16, and all control pins are held at $\mathrm{V}_{\mathrm{IL}}$. Address pin $A 0$ is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the eight data pins, $\mathrm{O}_{0}-\mathrm{O}_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wave-
length of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be minimum of 15 W -sec/cm².
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table III shows the minimum EPROM erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increase as the square of the distance from the lamp (if distance is doubled the erasure time increases by factor of 4). Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, Icc, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent of the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $\mathrm{V}_{\mathrm{CC}}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

Mode Selection
The modes of operation of the NM27P512 are listed in Table I. A single 5V power supply is required in the read mode. All inputs are TTL levels excepts for $\mathrm{V}_{\mathrm{PP}}$ and A9 for device signature.

TABLE I. Mode Selection

| Mode Pins | $\overline{\text { CE/PGM }}$ | $\overline{\mathbf{O E} / V_{P P}}$ | $\mathbf{V}_{\mathbf{C C}}$ | Outputs |
| :--- | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | 5.0 V | $\mathrm{D}_{\mathrm{OUT}}$ |
| Output Disable | X <br> (Note 1$)$ | $\mathrm{V}_{\mathrm{IH}}$ | 5.0 V | High Z |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | 5.0 V | High Z |
| Programming | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{PP}}(2)$ | 6.25 V | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | 6.25 V | $\mathrm{D}_{\mathrm{OUT}}$ |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{PP}}(2)$ | 6.25 V | High Z |

Note 1: $X$ can be $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$.

TABLE II. Manufacturer's Identification Code

| Pins | AO <br> $(10)$ | A9 <br> $(24)$ | 07 <br> $(19)$ | 06 <br> $(18)$ | 05 <br> $(17)$ | 04 <br> $(16)$ | 03 <br> $(15)$ | 02 <br> $(13)$ | 01 <br> $(12)$ | 00 <br> $(11)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 85 |

NM27P210

## 1,048,576-Bit (64K x 16) Processor Oriented CMOS EPROM

## General Description

The NM27P210 is a 1024 K Processor Oriented EPROM configured as $64 \mathrm{~K} \times 16$. It's designed to simplify microprocessor interfacing while remaining compatible with standard EPROMs. It can reduce both wait states and glue logic when the specification improvements are taken advantage of in the system design. The NM27P210 is implemented in National's advanced CMOS EPROM process to provide a reliable solution and access times as fast as 120 ns .

The interface improvements address two areas to eliminate the need for additional devices to adapt the EPROM to the microprocessor and to eliminate wait states at the termination of the access cycle. Even with these improvements, the NM27P210 remains compatible with industry standard JEDEC pinout EPROMs. The time from CE or OE being negated until the outputs are guaranteed to be in the high impedance state has been reduced to eliminate the need for wait states at the termination of the memory cycle and the
data-out hold time has been extended to eliminate the need to provide data hold time for the microprocessor by delaying control signals or latching and holding the data in external latches.

## Features

- Fast output turn-off to eliminate wait states
- Extended data hold time for microprocessor compatibility
n High performance CMOS
- 120 ns access time
- High reliability with EPI processing
- Latch-up immunity to 200 mA
- ESD protection exceeds 2000 V
- JEDEC standard pin configuration
- Manufacturer's identification code


## Block Diagram



Connection Diagrams

## DIP PIN CONFIGURATIONS

| 27 C 280 | 27C240 | 27 C 220 |
| :---: | :---: | :---: |
| ${ }^{\text {A }} 18$ | XX/VPP | $\mathrm{XX/V} \mathrm{~V}_{\mathrm{P}}$ |
| CE/PGM | $\overline{C E / P G M}$ | $\overline{C E}$ |
| $\mathrm{O}_{15}$ | $\mathrm{O}_{15}$ | $\mathrm{O}_{15}$ |
| $\mathrm{O}_{14}$ | $\mathrm{O}_{14}$ | $\mathrm{O}_{14}$ |
| $\mathrm{O}_{13}$ | $\mathrm{O}_{13}$ | $\mathrm{O}_{13}$ |
| $\mathrm{O}_{12}$ | $\mathrm{O}_{12}$ | $\mathrm{O}_{12}$ |
| $\mathrm{O}_{11}$ | $\mathrm{O}_{11}$ | $\mathrm{O}_{11}$ |
| $\mathrm{O}_{10}$ | $\mathrm{O}_{10}$ | $\mathrm{O}_{10}$ |
| $\mathrm{O}_{9}$ | $\mathrm{O}_{9}$ | $\mathrm{O}_{9}$ |
| $\mathrm{O}_{8}$ | $\mathrm{O}_{8}$ | $\mathrm{O}_{8}$ |
| GND | GND | GND |
| $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ |
| $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ |
| $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ |
| $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ |
| $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ |
| $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ |
| $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ |
| $\overline{O E} / V_{P P}$ | OE | OE |

DIP
NM27P2 10


| $27 C 220$ | $\mathbf{2 7 C 2 4 0}$ | $\mathbf{2 7 C 2 8 0}$ |
| :---: | :---: | :---: |
| $V_{C C}$ | $V_{C C}$ | $V_{C C}$ |
| $X X / P G M$ | $A_{17}$ | $A_{17}$ |
| $A_{16}$ | $A_{16}$ | $A_{16}$ |
| $A_{15}$ | $A_{15}$ | $A_{15}$ |
| $A_{14}$ | $A_{14}$ | $A_{14}$ |
| $A_{13}$ | $A_{13}$ | $A_{13}$ |
| $A_{12}$ | $A_{12}$ | $A_{12}$ |
| $A_{11}$ | $A_{11}$ | $A_{11}$ |
| $A_{10}$ | $A_{10}$ | $A_{10}$ |
| $A_{9}$ | $A_{9}$ | $A_{9}$ |
| $G N D$ | $G N D$ | $G N D$ |
| $A_{8}$ | $A_{8}$ | $A_{8}$ |
| $A_{7}$ | $A_{7}$ | $A_{7}$ |
| $A_{6}$ | $A_{6}$ | $A_{6}$ |
| $A_{5}$ | $A_{5}$ | $A_{5}$ |
| $A_{4}$ | $A_{4}$ | $A_{4}$ |
| $A_{3}$ | $A_{3}$ | $A_{3}$ |
| $A_{2}$ | $A_{2}$ | $A_{2}$ |
| $A_{1}$ | $A_{1}$ | $A_{1}$ |
| $A_{0}$ | $A_{0}$ | $A_{0}$ |

TL/D/11366-2
Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27P210 pins.

Commercial Temperature Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27P210 Q, V 120 | 120 |
| NM27P210 Q, V 150 | 150 |

Military Temperature Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27P210 QM 200 | 150 |

Extended Temperature Range ( $-\mathbf{4 0 ^ { \circ }} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27P210 QE, VE 120 | 120 |
| NM27P210 QE, VE 150 | 150 |

Note: Surface mount PLCC package available for commercial and extended temperature ranges only.
Package Types: NM27P210 Q, V XXX
$Q=$ Quartz-Windowed Ceramic DIP package
$V=P L C C$ package

- All packages conform to JEDEC standard.
- All versions are guaranteed to function in slower applications.

Pin Names

| $A 0-A 15$ | Addresses |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{O} 0-\mathrm{O} 15$ | Outputs |
| $\overline{\mathrm{PGM}}$ | Program |
| XX | Don't Care (During Read) |
| NC | No Connect |

PLCC Pin Configuration


TL/D/11366-3

## Top View

Absolute Maximum Ratings (Note 1)
If Milltary/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input Voltages except A9 with
Respect to Ground (Note 10)
$V_{\text {PP }}$ and A9 with Respect to Ground
-0.6 V to +7 V
$V_{C C}$ Supply Voltage with
Respect to Ground

$$
-0.6 \mathrm{~V} \text { to }+7 \mathrm{~V}
$$

$>2000 \mathrm{~V}$

$$
-0.6 \mathrm{~V} \text { to }+14 \mathrm{~V}
$$

ESD Protection
All Output Voltages with
Respect to Ground (Note 10)

$$
V_{C C}+1.0 \mathrm{~V} \text { to } \mathrm{GND}-0.6 \mathrm{~V}
$$

## Operating Range

| Range | Temperature | V $_{\text {CC }}$ | Tolerance |
| :--- | :--- | :--- | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |

DC Read Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{Cc}}$

| Symbol | Parameter | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level |  | -0.5 | 0.8 | V |
| $\mathrm{V}_{\text {H }}$ | Input High Level |  | 2.0 | $V_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{lOL}^{\prime}=2.1 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 3.5 |  | V |
| ISB1 <br> (Note 11) | $V_{C C}$ Standby Current (CMOS) | $\overline{C E}=V_{C C} \pm 0.3 V$ |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {SB2 }}$ | $\mathrm{V}_{\text {CC }}$ Standby Current | $\overline{C E}=V_{I H}$ |  | 1 | mA |
| $\mathrm{l} C \mathrm{C}$ | $V_{C C}$ Active Current | $\overline{C E}=\overline{O E}=V_{\text {IL }} \quad 1 \quad f=5 \mathrm{MHz}$ |  | 50 | mA |
| lpp | VPP Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  | 10 | $\mu \mathrm{A}$ |
| ILI | Input Load Current | $\mathrm{V}_{\mathrm{IN}}=5.5$ or GND | -1 | 1 | $\mu \mathrm{A}$ |
| LO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND | -10 | 10 | $\mu \mathrm{A}$ |

AC Read Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | 120 |  | 150 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 120 |  | 150 | ns |
| $t_{\text {CE }}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 120 |  | 150 |  |
| $\mathrm{t}_{\mathrm{OE}}$ | $\overline{\mathrm{OE}}$ to Output Delay |  | 50 |  | 50 |  |
| $t_{D F} / t_{C F}$ <br> (Note 2) | Output Disable to Output Float |  | 25 |  | 25 |  |
| ${ }^{\mathrm{t}} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{C E}$ or $\overline{O E}$, Whichever Occurred First | 7 |  | 7 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{I N}=0 \mathrm{~V}$ | 12 | 20 | pF |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 13 | 20 | pF |

## AC Test Conditions

Output Load

Input Rise and Fall Times
Input Pulse Levels

1 TTL Gate and $C_{L}=100 \mathrm{pF}$ (Note 8)
$\leq 5 \mathrm{~ns}$
0.45 V to 2.4 V

Timing Measurement Reference Level Inputs 0.8 V and 2 V 0.8 V and 2 V Outputs )

## AC Waveforms (Notes 6, 7, \& 9)



TL/D/11366-4
Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{\sigma E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The $t_{D F}$ and $t_{C F}$ compare level is determined as follows:
High to TRI-STATE ${ }^{*}$, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V ;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} 1}$ (DC) +0.10 V .
Note 5: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: $\uparrow T \mathrm{TL}$ Gate: $\mathrm{IOL}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{C}}$ except during programming.
Note 10: Inputs and outputs can undershoot to $\mathbf{- 2 . 0 V}$ for 20 ns Max.
Note 11: CMOS inputs; $\mathrm{V}_{\mathrm{IL}}=\mathrm{GND} \pm 0.3 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{H}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$.

Programming Characteristics (Notes 1, 2, 3, 485)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A S}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{O E}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {CES }}$ | $\overline{\text { CE Setup Time }}$ | $\overline{O E}=V_{I H}$ | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvPS | $V_{\text {PP }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tves | $V_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DH }}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{C E}=V_{\text {IL }}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toe | Data Valid from $\overline{O E}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |  |  | 100 | ns |
| lpp | Vpp Supply Current during Programming Pulse | $\begin{aligned} & \overline{\overline{C E}=V_{\mathrm{IL}}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}} \end{aligned}$ |  |  | 40 | mA |
| ICC | $V_{\text {CC }}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\mathrm{A}}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{\text {cc }}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $V_{\text {PP }}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $\mathrm{t}_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{N}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

## Programming Waveforms (Note3)



TL/D/11366-5
Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{\text {PP. }}$. The EPROM must not be inserted into or removed from a board with voltage applied to $V_{P P}$ or $V_{C C}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $\mathrm{V}_{\mathrm{PP}}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{PP}}$, $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm, at typical power supply voltages and timings.
Note 5: During power up the $\overline{\mathrm{PGM}}$ pin must be brought high $\left(Z \mathrm{~V}_{\mid H}\right)$ either coincident with or before power is applied to $\mathrm{V}_{\mathrm{PP}}$.

Fast Programming Algorithm Flow Chart


FIGURE 1

## Functional Description

## device operation

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{PP}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that the addresses are stable, address access time ( $t_{A C C}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs toE after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{\text {ACC }}-t_{0 E}$.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from 275 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the $\overline{\mathrm{CE}}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the $\overline{\mathrm{OE}}$ input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Tying

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.

To most efficiently use these two control lines, it is recommended that CE be decoded and used as the primary device selecting function, while OE be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on the Vpp or A9 pin will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 's" state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 's" and " 0 's" can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the $V_{P P}$ power supply is at 12.75 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{1 \mathrm{H}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{Pp}}, \mathrm{V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 16 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{PGM}}$ input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu \mathrm{~s}$ pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu \mathrm{~s}$ pulse.
The EPROM must not be programmed with a DC signal applied to the $\overline{\text { PGM }}$ input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the PGM input programs the paralleled EPROM.

## Functional Description (Continued)

## Program Inhibit

Programming multiple EPROM's in parallel with different data is also easily accomplished. Except for CE all like inputs (including $\overline{O E}$ and $\overline{\mathrm{PGM}}$ ) of the parallel EPROM may be common. A TTL low level program pulse applied to an EPROM's $\overline{\mathrm{PGM}}$ input with $\overline{\mathrm{CE}}$ at $V_{\mathrm{IL}}$ and $V_{\mathrm{PP}}$ at 12.75 V will program that EPROM. A TTL high level $\overline{C E}$ input inhibits the other EPROM's from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V . $\mathrm{V}_{\mathrm{PP}}$ must be at $V_{C C}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for the NM27P210 is "8FD6", where "8F" designates that it is made by National Semiconductor, and "D6" designates a 1 Megabit ( $64 \mathrm{~K} \times 16$ ) part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin $A_{g}$. Addresses $A_{1}-A_{8}, A_{10}-A_{15}$, and all control pins are held at $\mathrm{V}_{\mathrm{IL}}$. Address pin A 0 is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the lower eight data pins, $\mathrm{O}_{0}-0_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA \AA-4000 \AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of 15 W $\mathrm{sec} / \mathrm{cm}^{2}$.
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increases as the square of the distance from the lamp (if distance is doubled the erasure time increases by factor of 4). Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, ICC, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated VCC transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between V $\mathrm{V}_{\mathrm{C}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## MODE SELECTION

The modes of operation of the NM27P210 are listed in Table I. A single 5V power supply is required in the read mode. All inputs are TTL levels except for VPP and A9 for device signature.

TABLE I. Modes Selection

| Pins | $\overline{\text { CE }}$ | $\overline{O E}$ | $\overline{\text { PGM }}$ | $\mathbf{V P P}_{\text {P }}$ | Vcc | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |  |
| Read | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | (Note 1) | X | 5.0 V | Dout |
| Output Disable | X | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 5.0 V | High Z |
| Standby | $V_{\text {IH }}$ | X | X | X | 5.0 V | High Z |
| Programming | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | $\mathrm{V}_{\text {IL }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | Dout |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 12.75 V | 6.25 V | High Z |

Note 1: $X$ can be $V_{I L}$ or $V_{I H}$.

TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(21)$ | A 9 <br> $(\mathbf{3 1})$ | $\mathbf{O}_{\mathbf{7}}$ <br> $(12)$ | $\mathbf{O}_{\mathbf{6}}$ <br> $(13)$ | $\mathbf{O}_{\mathbf{5}}$ <br> $(14)$ | $\mathbf{O}_{\mathbf{4}}$ <br> $(15)$ | $\mathbf{O}_{\mathbf{3}}$ <br> $(16)$ | $\mathbf{O}_{\mathbf{2}}$ <br> $(17)$ | $\mathbf{O}_{\mathbf{1}}$ <br> $(18)$ | $\mathbf{O}_{\mathbf{0}}$ <br> $(19)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | $\mathbf{1}$ | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | D 6 |

## NM27P040

## 4,194,304-Bit (512K x 8) Processor Oriented CMOS EPROM

## General Description

The NM27P040 is a 4096K Processor Oriented EPROM configured as $512 \mathrm{~K} \times 8$. It's designed to simplify microprocessor interfacing while remaining compatible with standard EPROMs. It can reduce both wait states and glue logic when the specification improvements are taken advantage of in the system design. The NM27P040 is implemented in National's advanced CMOS EPROM process to provide a reliable solution and access times as fast as 150 ns .
The interface improvements address two areas to eliminate the need for additional devices to adapt the EPROM to the microprocessor and to eliminate wait states at the termination of the access cycle. Even with these improvements, the NM27P040 remains compatible with industry standard JEDEC pinout EPROMs. The time from CE or OE being negated until the outputs are guaranteed to be in the high impedance state has been reduced to eliminate the need for wait states at the termination of the memory cycle and
the data-out hold time has been extended to eliminate the need to provide data hold time for the microprocessor by delaying control signals or latching and holding the data in external latches.

## Features

- Fast output turn off to eliminate wait states
- Extended data hold time for microprocessor compatibility
- High performance CMOS - 150 ns access time
- High reliability with EPI processing - Latch-up immunity to 200 mA - ESD protection exceeds 2000 V
- JEDEC standard pin configuration
- Manufacturer's identification code

Block Diagram


Connection Diagrams

| 27C080 | 27C020 | 27C010 |
| :---: | :---: | :---: |
| A19 | XX/VPP | XX/V $V_{P P}$ |
| A16 | A16 | A16 |
| A15 | A15 | A15 |
| A12 | A12 | A12 |
| A7 | A7 | A7 |
| A6 | A6 | A6 |
| A5 | A5 | A5 |
| A4 | A4 | A4 |
| A3 | A3 | A3 |
| A2 | A2 | A2 |
| A1 | A1 | A1 |
| A0 | A0 | A0 |
| $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ |
| $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ |
| GND | GND | GND |



| $\mathbf{2 7 C 0 1 0}$ | $\mathbf{2 7 C 0 2 0}$ | $\mathbf{2 7 C 0 8 0}$ |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{XX} / \mathrm{PGM}$ | $\mathrm{XX} / \mathrm{PGM}$ | A 18 |
| XX | A 17 | A 17 |
| A 14 | A 14 | A 14 |
| A 13 | A 13 | A 13 |
| AB | AB | AB |
| A 9 | A 9 | A 9 |
| A 11 | A 11 | A 11 |
| $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ |
| A 10 | A 10 | A 10 |
| $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ | $\mathrm{CE} / \overline{\mathrm{PGM}}$ |
| $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ |
| $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ |
| $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ |
| $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ |
| $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ |

TL/D/11367-2
Note: Compatible EPROM pin configurations are shown in the blocks adjacent to the NM27P040 pin.
Commercial Temperature Range $\left(\mathbf{0}^{\circ} \mathbf{C}\right.$ to $\left.+\mathbf{7 0}{ }^{\circ} \mathrm{C}\right)$

$\mathbf{V}_{\mathbf{C C}}=\mathbf{5 V} \pm \mathbf{1 0 \%}$ | Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27P040 Q 150 | 150 |
| NM27P040 Q 170 | 170 |

Military Temperature Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27P040 QM 200 | 250 |

Pin Names

| $\mathrm{A} 0-\mathrm{A16}$ | Addresses |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{O}-\mathrm{O} 7$ | Outputs |
| $\overline{\mathrm{PGM}}$ | Program |
| XX | Don't Care (During Read) |

Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27P040 QE 150 | 150 |
| NM27P040 QE 170 | 170 |

Package Types: NM27P040 QXXX
Q = Quartz-Windowed Ceramic DIP

- All packages conform to the JEDEC standard.
- All versions are guaranteed to function for slower speeds.

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for avallability and specifications.
Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input Voltages except A9 with
Respect to Ground
$V_{P P}$ and A9 with Respect to Ground
$V_{C C}$ Supply Voltage with
Respect to Ground
ESD Protection
-0.6 V to +7 V
-0.6 V to +14 V
-0.6 V to +7 V
$>2000 \mathrm{~V}$
All Output Voltages with
Respect to Ground
$V_{C C}+10 \mathrm{~V}$ to $\mathrm{GND}-0.6 \mathrm{~V}$

Operating Range

| Range | Temperature | V $_{\text {CC }}$ | Tolerance |
| :--- | :--- | :--- | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | +5 V | $\pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $\pm 5 \mathrm{~V}$ | $\pm 10 \%$ |
| Military | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $\pm 5 \mathrm{~V}$ | $\pm 10 \%$ |

## Read Operation

DC Electrical Characteristics Over operating range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Test Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level |  | -0.5 | 0.8 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Level |  | 2.0 | $V_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ | 3.5 |  | V |
| $\mathrm{I}_{\text {SB1 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current (CMOS) <br> (Note 11) | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$ |  | 100 | $\mu \mathrm{A}$ |
| ISB2 | $\mathrm{V}_{\text {CC }}$ Standby Current | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  | 1 | mA |
| ICC | $V_{C C}$ Active Current | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{f}=5 \mathrm{MHz}$ |  | 60 | mA |
| Ipp | VPP Supply Current | $V_{P P}=V_{C C}$ |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{PP}}$ | VPP Read Voltage |  | $V_{C C}-0.4$ | $\mathrm{V}_{\mathrm{CC}}$ | V |
| $\mathrm{ILI}^{\prime}$ | Input Load Current | $\mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ or GND | -1 | 1 | $\mu \mathrm{A}$ |
| ILO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND | -10 | 10 | $\mu \mathrm{A}$ |

AC Electrical Characteristics Over operating range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | 150 |  | 170 |  | 250 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 150 |  | 170 |  | 250 | ns |
| $\mathrm{t}_{\text {CE }}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 150 |  | 170 |  | 250 |  |
| $\mathrm{t}_{\mathrm{OE}}$ | $\overline{\text { OE }}$ to Output Delay |  | 50 |  | 50 |  | 50 |  |
| $\mathrm{t}_{\mathrm{DF}} / \mathrm{t}_{\mathrm{CF}}$ (Note 2) | Output Disable to Output Float |  | 25 |  | 25 |  | 25 |  |
| ${ }^{t} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | 7 |  | 7 |  | 7 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ | 9 | 15 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 12 | 15 | pF |

## AC Test Conditions

Output Load

Input Rise and Fall Times Input Pulse Levels

1 TTL Gate and
$C_{L}=100 \mathrm{pF}$ (Note 8)
$\leq 5 \mathrm{~ns}$
0.45 V to 2.4 V

Timing Measurement Reference Level (Note 10) Inputs Outputs

## AC Waveforms (Notes 6, 7, and 9)



TL/D/11367-3

Note 1: 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.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{O E}$ may be delayed up to $t_{A C C}$ - $t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The tDF and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE ${ }^{\circ}$, the measured $\mathrm{V}_{\mathrm{OH} 1}(\mathrm{DC})-0.10 \mathrm{~V}$;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OLI}}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 5: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $V_{P P}$ may be connected to $V_{C C}$ except during programming.

Note 11: CMOS input: $V_{I L}=G N D \pm 0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$.

Programming Waveform (Note 3)


TL/D/11367-4

Programming Characteristics (Notes $1,2,3 \& 4$ )

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvps | $V_{\text {Pp }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvos | $\mathrm{V}_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{S}$ |
| ${ }_{\text {th }}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {dF }}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}} / \overline{\text { PGM }}=\mathrm{X}$ | 0 |  | 60 | ns |
| tPW | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{S}$ |
| toe | Data Valid from $\overline{\mathrm{OE}}$ | $\overline{\mathrm{CE}} / \overline{\text { PGM }}=\mathrm{X}$ |  |  | 100 | ns |
| Ipp | VPp Supply Current during Programming Pulse | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 30 | mA |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\text {A }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{C C}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $\mathrm{V}_{\mathrm{PP}}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $t_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.1 | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{PP}}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{PP}}$ or $\mathrm{V}_{\mathrm{C}}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{Pp}}$, $\mathrm{V}_{\text {cc }}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Progam Algorithm, at typical power supply voltages and timings.
Note 5: During power up the $\overline{\mathrm{PGM}}$ pin must be brought high $\left(Z \mathrm{~V}_{\mid H}\right)$ either coincident with or before power is applied to $V_{\text {Pp }}$.

Fast Programming Algorithm Flow Chart


FIGURE 1

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{Pp}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other three modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable (CE/PGM) is the power control and should be used for device selection. Output Enable (OE) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $t_{A C C}$ ) is equal to the delay from CE to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs tOE after the falling edge of OE, assuming that CE/PGM has been low and addresses have been stable for at least $t_{A C C}$ toe.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from of 385 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the CE/PGM input. When in standby mode, the outputs are in a high impedance state, independent of the OE input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the OE input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Typing

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that CE/PGM be decoded and used as the primary device selecting function, while $O E$ be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on pin $1\left(\mathrm{~V}_{\mathrm{PP}}\right)$ will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 's" state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 's" and " 0 's" can be pre-
sented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the $V_{P P}$ power supply is at 12.75 V and OE is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the CE/PGM input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu$ s pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu \mathrm{~s}$ pulse.
The EPROM must not be programmed with a DC signal applied to the CE/PGM input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the CE/PGM input programs the paralleled EPROM.
Note: Some programmer manufacturers, due to equipment limitation, may offer interactive program Algorithm (shown in Figure 2).

## Program Inhibit

Programming multiple EPROMs in parallel with different data is also easily accomplished. Except for CE/PGM all like inputs (including OE) of the parallel EPROMs may be common. A TTL low level program pulse applied to an EPROM's CE/PGM input with $V_{P P}$ at 12.75 V will program that EPROM. A TTL high level CE/PGM input inhibits the other EPROMs from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V . $\mathrm{V}_{\mathrm{PP}}$ must be at $\mathrm{V}_{\mathrm{CC}}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for NM27P040 is " 8 F 08 ", where " 8 F " designates that

## Functional Description (Continued)

it is made by National Semiconductor, and " 08 " designates a 4 Megabit ( $512 \mathrm{~K} \times 8$ ) part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A16, and all control pins are held at $\mathrm{V}_{I L}$. Address pin $A 0$ is held at $\mathrm{V}_{I L}$ for the manufacturer's code, and held at $\mathrm{V}_{1 \mathrm{H}}$ for the device code. The code is read on the eight data pins, $\mathrm{O}_{0}-\mathrm{O}_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $X$ exposure time) for erasure should be minimum of 15 W - $\mathrm{sec} / \mathrm{cm}^{2}$.
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increase as the square of the distance from the lamp. (If distance is doubled the erasure time increases by factor of 4.) Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make cer-
tain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, Icc, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent of the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## Mode Selection

The modes of operation of the NM27P040 are listed in Table I . A single 5 V power supply is required in the read mode. All inputs are TTL levels except for $V_{\text {PP }}$ and A9 for device signature.

TABLE I. Modes Selection

| Pins | $\overline{\text { CE }} / \overline{\text { PGM }}$ | $\overline{O E}$ | $V_{\text {PP }}$ | $\mathrm{V}_{\mathrm{cc}}$ | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |
| Read | $\mathrm{V}_{\text {IL }}$ | $V_{\text {IL }}$ | (Note 1) | 5.0 V | Dout |
| Output Disable | X | $V_{\text {IH }}$ | X | 5.0 V | High Z |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 5.0 V | High Z |
| Programming | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\text {IH }}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | X | $\mathrm{V}_{\text {IL }}$ | 12.75 V | 6.25 V | DOUT |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | High Z |

Note 1: $X$ can be $V_{I L}$ or $V_{H}$

TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(12)$ | A9 <br> $(26)$ | O7 <br> $(\mathbf{2 1 )}$ | O6 <br> (20) | O5 <br> $(19)$ | O4 <br> $(18)$ | O3 <br> $(17)$ | O2 <br> $(15)$ | O1 <br> $(14)$ | O0 <br> $(13)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\text {IH }}$ | 12 V | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 08 |

## NMC87C257

262,144-Bit (32K x 8) CMOS EPROM with On-Chip Address Latches

## General Description

The NMC87C257 is a CMOS EPROM, ideally suited for applications where fast turnaround, pattern experimentation and low power consumption are important requirements.
The NMC87C257 has latched addresses for direct interfacing with address/data multiplexed microprocessors and microcontrollers. The A0-A7 pins can be tied to the respective 00-O7 pins and then bused to the microprocessor or microcontroller directly. No latch device is needed for interfacing.
The part is designed to operate with a single +5 V power supply with $\pm 10 \%$ tolerance.
The part is packaged in a 28 -pin dual-in-line package with a quartz window or PLCC. The quartz window allows the user to expose the chip to ultraviolet light to erase the bit pattern. A new pattern can then be written electrically into the device by following the programming procedure. The PLCC is not erasable.
This EPROM is fabricated with National's proprietary CMOS double-poly silicon gate technology.

## Features

- Address latches for direct interfacing with address/data multiplexed microprocessors
■ Low CMOS power consumption: - Active power: 110 mW max - Standby power: 0.55 mW max
- Pin compatible with standard 256K EPROM
- Fast and reliable programming
- TTL, CMOS compatible inputs/outputs
- TRI-STATE® output
- Manufacturer's identification code for automatic programming control use NMC27C256B PGM Algorithm
- High current CMOS level output drivers


## Block Diagram



TL/D/11012-1

## Connection Diagram

| $27 C 256$ |
| :---: |
| $V_{P P}$ |
| A12 |
| A7 |
| A6 |
| A5 |
| A4 |
| A3 |
| A2 |
| A1 |
| A0 |
| O0 |
| O1 |
| O2 |
| GND |



TL/D/11012-2
Note: Socket compatible 27C256 EPROM pin configuration is shown in the block adjacent to the NMC87C257 pins.

Pin Names

| Symbol | Description |
| :--- | :--- |
| AO-A14 | Addresses |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{OO}-\mathrm{O7}$ | Outputs |
| $\overline{\text { PGM }}$ | Program |
| ALE | Address Latch Enable |
| VPP $^{\text {VCC }}$ | Programming Supply |
| GND | Power Supply |
| NC | Ground |

Commercial Temperature Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )
$V_{\mathbf{C C}}=\mathbf{5 V} \pm 10 \%$

| Parameter/Order <br> Number | Access <br> Time (ns) |
| :---: | :---: |
| NMC87C257Q150, V150 | 150 |
| NMC87C257Q200, V200 | 200 |

Extended Temperature Range ( $-\mathbf{4 0 ^ { \circ }} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

$$
V_{C C}=5 V \pm 10 \%
$$

| Parameter/Order <br> Number | Access <br> Time (ns) |
| :---: | :---: |
| NMC87C257QE150 | 150 |
| NMC87C257QE200 | 200 |



Absolute Maximum Ratings (Note 1) If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

| Temperature under Bias | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :--- | :--- |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| VCC Supply Voltages <br> with Respect to Ground | +7.0 V to -0.6 V |
| All Input Voltages except A9 <br> with Respect to Ground (Note 2) | +6.5 V to -0.6 V |
| All Output Voltages with Respect <br> to Ground (Note 2)$\quad \mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to GND -0.6 V |  |

READ OPERATION

## DC Electrical Characteristics

| Symbol | Parameter |  | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $1{ }_{1}$ | Input Load Current |  | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or GND |  | 0.01 | 1.0 | $\mu \mathrm{A}$ |
| lo | Output Leakage Current |  | $V_{\text {OUT }}=V_{\text {CC }}$ or $\mathrm{GND}, \overline{\mathrm{CE}}=\mathrm{V}_{\text {IH }}$ |  | 0.01 | 1.0 | $\mu \mathrm{A}$ |
| ICC1 <br> (Note 4) | $V_{C C}$ Current (Active) <br> TTL Inputs |  | $\begin{aligned} & \text { ALE }=V_{I H}, f=5 \mathrm{MHz} \\ & \text { All Inputs }=V_{I H} \text { or } V_{I L}, I / O=0 \mathrm{~mA} \end{aligned}$ |  | 15 | 30 | mA |
| ICC2 <br> (Note 4) | $V_{C C}$ Current (Active) CMOS Inputs |  | $\begin{aligned} & A L E=V_{C C}, f=5 \mathrm{MHz} \\ & \text { All Inputs }=V_{C C} \text { or } G N D, I / O=0 \mathrm{~mA} \end{aligned}$ |  | 10 | 20 | mA |
| Iccsb1 | $V_{C C}$ Current (Standby) <br> TTL Inputs | Switching | $\overline{C E}=V_{I H}, A L E=V_{I H}$ |  | 10 | 12 | mA |
|  |  | Stable | $\overline{C E}=V_{I H}, A L E=V_{I L}$ |  | 0.3 | 1 | mA |
| $\mathrm{I}_{\text {CCSB2 }}$ | $V_{\text {CC }}$ Current (Standby) CMOS Inputs | Switching | $\overline{C E}=V_{C C}, A L E=V_{C C}$ |  | 8 | 10 | mA |
|  |  | Stable | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}}, \mathrm{ALE}=\mathrm{GND}$ |  | 0.5 | 100 | $\mu \mathrm{A}$ |
| Ipp | VPP Load Current |  | $V_{P P}=V_{C C}$ |  |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | -0.2 |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  |  | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage |  | $\mathrm{lOL}=2.1 \mathrm{~mA}$ |  |  | 0.40 | V |
| VOH | Output High Voltage |  | $\mathrm{lOH}=-2.5 \mathrm{~mA}$ | 3.5 |  |  | V |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage |  | $\mathrm{l}_{\mathrm{OL}}=10 \mu \mathrm{~A}$ |  |  | 0.1 | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $V_{C C}-0.1$ |  |  | V |

Note 1: 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 section of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: Inputs and outputs can undershoot to $\mathbf{- 2 . 0 V}$ for 20 ns Max.
Note 3: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 4: $V_{P P}$ may be connected to $V_{C C}$ except during programming.

| Symbol | Parameter | Conditions | NMC87C257 |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 150 |  | 200 |  |  |
|  |  |  | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address Access Time | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ |  | 150 |  | 200 | ns |
| tce | Chip Enable Access Time | $\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |  | 150 |  | 200 | ns |
| ${ }_{\text {t L }}$ | Chip Deselect Width |  | 30 |  | 50 |  | ns |
| $t_{\text {AL }}$ | Address to ALE Latch Set-Up |  | 5 |  | 15 |  | ns |
| tLA | Address Hold from ALE Latch |  | 20 |  | 30 |  | ns |
| toe | Output Enable to Output Valid | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 50 |  | 75 | ns |
| tLOE | ALE to Output Enable |  | 20 |  | 30 |  | ns |
| $t_{\mathrm{CF}}$ <br> (Note 1) | Chip Disable to Output in High Z | $\overline{O E}=V_{\text {IL }}$ | 0 | 50 | 0 | 55 | ns |
| tDF <br> (Note 1) | Output Disable to Output in High Z | $\overline{C E}=V_{1 L}$ | 0 | 50 | 0 | 55 | ns |
| ${ }^{\text {toh }}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever occurred first |  | 0 |  | 0 |  | ns |

Note 1: This parameter is only sampled and is not $100 \%$ tested.

## Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ (Note 1)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathbb{I N}}$ | Input Capacitance | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ | 6 | 12 | PF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ | 9 | 12 | pF |

## AC Test Conditions

Output Load

| 1 TTL Gate and $C_{L}=100 \mathrm{pF}(\text { Note } 7)$ |
| :---: |
| $\leq 5 \mathrm{~ns}$ |
| 5 V to |

Timing Measurement Reference Level Inputs Outputs
0.8 V and 2 V 0.8 V and 2 V

Input Rise and Fall Times
Input Pulse Levels
AC Waveforms (Notes 5, 6 and 8 )


TL/D/11012-3
Note 1: This parameter is only sampled and is not $100 \%$ tested.
Note 2: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 3: The $\mathrm{t}_{\mathrm{DF}}$ and $\mathrm{t}_{\mathrm{CF}}$ compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH}}$ (DC) -0.10 V ;
Low to TRI-STATE, the measured $V_{O L 1}(D C)+0.10 \mathrm{~V}$.
Note 4: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 5: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND.
Note 6: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 7: 1 TTL Gate: $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 8: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.

Programming Characteristics (Notes 1, 2, 3 and 4)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A S}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | OE Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tVPS | Vpp Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tves | $V_{C C}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| ${ }_{\text {t }}{ }_{\text {d }}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay |  | 0 |  | 60 | ns |
| tPW | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toe | Data Valid from $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |  |  | 100 | ns |
| Ipp | VPP Supply Current during Programming Pulse | $\begin{aligned} & \overline{\mathrm{CE}}=V_{\mathrm{IL}} \\ & \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IH}} \end{aligned}$ |  |  | 30 | mA |
| ICC | $V_{C C}$ Supply Current |  |  |  | 10 | mA |
| $\mathrm{T}_{\text {A }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{C C}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $V_{\text {PP }}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| ${ }_{\text {t }}{ }_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{N}}$ | Input Timing Reference Voltage |  | 0.8 | 1.5 | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 | 1.5 | 2.0 | V |

## Programming Waveforms



TL/D/11012-4
Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $V_{p p}$ or $V_{C C}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{PP}}$, $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm, at typical power supply voltages and timings.

Fast Programming Algorithm Flow Chart (Note 1) (Same as NMC27C256B)


FIGURE 1
Note 1: Programming and program verify are tested with the fast Program Algorithm, at typical power supply voltages and timings.

## Functional Description

## DEVICE OPERATION

The seven modes of operation of the NMC87C257 are listed in Table I. It should be noted that all inputs for the seven modes are at TTL levels. The power supplies required are $V_{C C}$ and $V_{P P}$. The $V_{P P}$ power supply must be at 12.75 V during the three programming modes, and must be at 5 V in the other modes. The $V_{C C}$ power supply must be at 6.25 V during the three programming modes, and at 5 V in the other modes.

## Read Mode

The NMC87C257 has a chip enable (CE) and an output enable (OE), both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}})$ is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $t_{A C C}$ ), is equal to the delay from $\overline{C E}$ to output ( $t_{C E}$ ). Data is available at the outputs $t_{O E}$ after the falling edge of $\overline{O E}$, assuming that $\overline{\mathrm{CE}}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.
The sense amps are clocked for fast access time. $V_{C C}$ should therefore be maintained at operating voltage during read and verify. If $\mathrm{V}_{\mathrm{CC}}$ temporarily drops below the spec. voltage (but not to ground) an address transition must be performed after the drop to insure proper output data.

## Address Latch Operation

The NMC87C257 has an Address Latch Enable (ALE) pin which latches the address inputs on a negative transition. Addresses must be stable for the address setup time ( $t_{A L}$ ) before the ALE transition, and they must hold for the address hold time ( t LA) after the transition. After the hold time has transpired the address drive can be removed from the address input pins and the bus can be used for other signals. The ALE pin is a feed-through latch and the part will operate as a normal unlatched device when the ALE pin is held high.
An important application for the NMC87C257 is memory in an address/data multiplexed microprocessor system. In an 8 bit system the low order memory address pins, A0-A7, can be tied to the respective memory output pins, $\mathrm{O} 0-\mathrm{O7}$ and run on an 8-bit bus to the ADO-AD7 pins of the microprocessor. This reduces the bus width and it can be done without adding an address latch interface device. In this application the Output Enable ( $\overline{\mathrm{OE}}$ ) pin should be held high until after the address hold time ( $\mathrm{t}_{\mathrm{LA}}$ ) has transpired, to avoid bus contention.

## Standby Mode

The NMC87C257 has a standby mode which reduces the active power dissipation by over $99 \%$, from 110 mW to 0.55 mW . The NMC87C257 is placed in the standby mode by applying a CMOS high signal to the $\overline{C E}$ input and a CMOS low signal to the ALE input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output OR-Tying

Because NMC87C257s are usually used in larger memory arrays, National has provided a 3 -line control function that accommodates this use of multiple memory connections. The 3 -line control function allows for:
a. the lowest possible memory power dissipation, and
b. complete assurance that output bus contention will not occur.
To most efficiently use these control lines, it is recommended that $\overline{C E}$ and ALE be decoded and used as the primary device selecting functions while $\overline{O E}$ be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on pin $1\left(\mathrm{~V}_{\mathrm{PP}}\right)$ will damage the NMC87C257.
Initially, and after each erasure, all bits of the NMC87C257 are in the " 1 " state. Data is introduced by selectively programmings " $0 s$ " into the desired bit locations. Although only "Os" will be programmed, both " 1 s " and " Os " can be present in the data word. The only way to change a " 0 " to a " 1 " is by untraviolet light erasure.
The NMC87C257 is in the programming mode when the $V_{P P}$ power supply is at 12.75 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{C}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{C E}$ input. A program pulse must be applied at each address location to be programmed. The NMC87C257 is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu$ s pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu$ s pulse. The NMC87C257 must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}}$ input.

Functional Description (Continued)
TABLE 1. Mode Selection

| Mode Pins | $\begin{aligned} & \hline \overline{\mathrm{CE}} \\ & (20) \end{aligned}$ | $\begin{aligned} & \hline \overline{\mathrm{OE}} \\ & \text { (22) } \\ & \hline \end{aligned}$ | VPP/ALE <br> (1) | $\begin{aligned} & \hline V_{c c} \\ & (28) \\ & \hline \end{aligned}$ | $\begin{gathered} \text { Outputs } \\ (11-13,15-19) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 5 V | Dout |
| Latched | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | 5 V | DOUT |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | $\mathrm{V}_{\text {IL }}$ | 5 V | $\mathrm{Hi}-\mathrm{Z}$ |
| Output Disable | Don't Care | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 5 V | $\mathrm{Hi}-\mathrm{Z}$ |
| Program | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IL}}$ | 12.75 V | 6.25 V | Dout |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | Hi-Z |

Programming multiple NMC87C257s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NMC87C257 may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{C E}$ input programs the paralleled NMC87C257.

## Program Inhibit

Programming multiple NMC87C257s in parallel with different data is also easily accomplished. Except $\overline{\mathrm{CE}}$, all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel NMC87C257s may be common. A TTL low level program pulse applied to an NMC87C257 $\overline{\mathrm{CE}}$ input with $\mathrm{V}_{\mathrm{PP}}$ at 12.75 V will program that NMC87C257. A TTL high level $\overline{C E}$ input inhibits the other NMC87C257 from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $V_{P P}$ at 12.75 V . $\mathrm{V}_{\mathrm{PP}}$ must be at $V_{C C}$ except during programming and program verify.

## Manufacturer's Identification Code

The NMC87C257 has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's identification code, shown in Table II, specifically identifies the manufacturer and the device type. The code for NMC87C257 is "8F04", where " 8 F " designates that it is made by National Semiconductor, and "04" designates a 256 K part.
The code is accessed by applying $12.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A14, and all control pins are held at $\mathrm{V}_{\text {IL }}$ and $\mathrm{V}_{\mathrm{PP}} / \mathrm{ALE}$ is held at $\mathrm{V}_{\mathrm{IH}}$. Address pin A 0 is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the eight data pins, $00-07$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm$ $5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the NMC87C257 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms
( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range. After programming, opaque labels should be placed over the NMC87C257 window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.
The recommended erasure procedure for the NMC87C257 is exposure to short wave ultraviolet light which has a wavelength of 2537 Angstroms ( $\AA$ ). The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$.
The NMC87C257 should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table III shows the minimum NMC87C257 erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to unit should be maintained at one inch. The erasure time increases as the square of the distance. (If distance is doubled the erasure time increases by a factor of 4.) Lamps lose intensity as they age. When a lamp is changed, the distance has changed, or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, ICC, has three segments that are of interest to the system de-signer-the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated $V_{C C}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

Functional Description (Continued)
TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(10)$ | 07 <br> $(19)$ | 06 <br> $(18)$ | 05 <br> $(17)$ | 04 <br> $(16)$ | 03 <br> $(15)$ | 02 <br> $(13)$ | 01 <br> $(12)$ | 00 <br> $(11)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 04 |

TABLE III. Minimum NMC87C257 Erasure Time

| Light Intensity <br> (Micro-Watts/cm <br> ) | Erasure Time <br> (Minutes) |
| :---: | :---: |
| 15,000 | 20 |
| 10,000 | 25 |
| 5,000 | 50 |

NM27LC256
262,144-Bit (32k x 8) Low Current CMOS EPROM

## General Description

The NM27LC256 is a $32 \mathrm{k} \times 8$ EPROM manufactured on a proven, manufacturable CMOS process, consuming extremely low current in both the active and standby modes. The NM27LC256 consumes a mere 17.5 mW , (typical) making it ideal for battery powered portable and hand held systems, and for systems using "in-line" power.
The NM27LC256 is one among a family of Power Miser products from National Semiconductor catering to the increasing low current demands of the market.
Offered in the JEDEC Pinout, the NM27LC256 offers a viable alternative to the user as a replacement for existing high power devices, while also providing an upgrade path to higher densities.

## Block Diagram



Connection Diagrams


TL/D/11405-2
Note: Compatible EPROM plan configurations are shown in the blocks adjacent to the NM27LC256 plan

Commercial Temperature Range
$\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27LC256 Q, N, 170 | 170 |
| NM27LC256 Q, N, 200 | 200 |
| NM27LC256 Q, N, 250 | 250 |

Extended Temperature Range
$\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
$V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27LC256 QE, NE, 170 | 170 |
| NM27LC256 QE, NE, 200 | 200 |
| NM27LC256 QE, NE, 250 | 250 |

## Ordering Information



## Absolute Maximum Ratings (Note 1)

Storage Temperature
All Input Voltages Except A9 with Respect to Ground
$V_{P P}$ and A9 with Respect to Ground
$V_{C C}$ Supply Voltage with
Respect to Ground

$$
\begin{array}{r}
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
-0.6 \mathrm{~V} \text { to }+7 \mathrm{~V} \\
-0.6 \mathrm{~V} \text { to }+14 \mathrm{~V} \\
-0.6 \mathrm{~V} \text { to }+7 \mathrm{~V}
\end{array}
$$

ESD Protection >2000V
All Output Voltages with
Respect to Ground
$V_{C C}+1.0 \mathrm{~V}$ to $\mathrm{GND}-0.6 \mathrm{~V}$
Operating Range

| Range | Temperature | V $_{\text {c }}$ |
| :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ |

## Read Operation

DC Electrical Characteristics Over Operating Range with $v_{P P}=v_{C C}$

| Symbol | Parameter | Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Level |  |  | -0.1 |  | 0.8 | V |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Level |  |  | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{IOL}=2.1 \mathrm{~mA}$ |  |  |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{lOH}^{\prime}=-400 \mu \mathrm{~A}$ |  | 2.4 |  |  | V |
| $\mathrm{I}_{\text {SB1 }}$ | $\mathrm{V}_{\text {CC }}$ Standby Current (CMOS) | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$ |  |  | 0.5 | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {SB2 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |  |  | 0.1 | 1.0 | mA |
| ${ }^{1} \mathrm{CC} 1$ | $V_{C C}$ Active Current TTL Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\overline{\mathrm{OE}} \mathrm{~V}_{\mathrm{IL}}, F=3 \mathrm{MHz} \\ & \text { Inputs } V_{\mathrm{IH}} \text { or } V_{\mathrm{IL}} \end{aligned}$ | Com'l |  | 7.0 | 9.0 | mA |
|  |  |  | Ind'l |  | 7.0 | 10.0 |  |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current CMOS Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{GND}, \mathrm{~F}=3 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \text {, } \\ & 1 / \mathrm{O}=0 \mathrm{~mA} \\ & (\text { See Figures } 1,2) \end{aligned}$ | Com'l |  | 3.5 | 4.5 | mA |
|  |  |  | Ind'I |  | 3.5 | 5.0 |  |
| IPP | $\mathrm{V}_{\mathrm{PP}}$ Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  |  |  | 10 |  |
| $V_{P P}$ | VPp Read Voltage |  |  | $\mathrm{V}_{\mathrm{CC}}-0.7$ |  | $\mathrm{V}_{\mathrm{CC}}+0.7$ |  |
| lıI | Input Load Current | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ or GND |  | -1 |  | 1 |  |
| lo | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND |  | -10 |  | 10 |  |

AC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | 170 |  | 200 |  | 250 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 170 |  | 200 |  | 250 | ns |
| $t_{\text {ce }}$ | $\overline{C E}$ to Output Delay |  | 170 |  | 200 |  | 250 |  |
| toe | $\overline{\text { OE }}$ to Output Delay |  | 75 |  | 75 |  | 100 |  |
| $t_{D F}$ <br> (Note 2) | Output Disable to Output Float |  | 60 |  | 60 |  | 60 |  |
| ${ }^{t} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{C E}$ or $\overline{O E}$, whichever Occurred First |  | 0 |  | 0 |  | 0 |  |



TL/D/11405-3
FIGURE 1. ICC_ACTIVE_CMOS vs Temperature $V_{C C}=V_{P}=5.0 \mathrm{~V}$, Frequency 1 MHz


TL/D/11405-4
FIGURE 2. ICC_ACTIVE_CMOS vs Temperature vs Frequency $\mathbf{V}_{\mathbf{C C}}=\mathbf{V}_{\mathrm{PP}}=5.0 \mathrm{~V}$, Temperature $=\mathbf{2 5}^{\circ} \mathbf{C}$

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, 1=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}$ | 6 | 12 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ | 9 | 12 | pF |

## AC Test Conditions

Output Load

Input Pulse Levels

$$
\begin{array}{r}
1 \mathrm{TTL} \text { Gate and } \\
\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}(\text { Note } 8) \\
\leq 5 \mathrm{~ns}
\end{array}
$$

| Input Pulse Level | 0.45 V to 2.4 V |
| :--- | ---: |
| Timing Measurement Level (Note 10) | (Note 10) |
| Inputs | 0.8 V to 2 V |
| Outputs | 0.8 V to 2 V |

AC Waveforms (Notes 6, 7, and 9)


TL/D/11405-5
Note 1: 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 operations sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{Z E}$ may be delayed up to $t_{A C C}-t_{C E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$
Note 4: The $T_{D F}$ and TCF compare level is determined as follows:
High to TRI-STATE ${ }^{\text {, }}$, the measure $\mathrm{V}_{\mathrm{CH}}$ ( DC ) -0.10 V
Low to TRI-STATE, the measure $\mathrm{V}_{\mathrm{OL} .1}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 5: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or CE .
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at last a $0.2 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.
Note 10: Inputs and outputs can undershoot to $\mathbf{- 2 . 0} \mathrm{V}$ for 20 ns Max.
Note 11: CMOS inputs $\mathrm{V}_{\mathrm{IL}}=\mathrm{GND} \pm 0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}} \pm 0.3 \mathrm{~V}$.

Programming Characteristics (Notes 1, 2, 3, 4 and 5)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A S}$ | Address Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 2 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {ds }}$ | Data Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| tvPS | $V_{\text {PP }}$ Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| tves | $\mathrm{V}_{\text {CC }}$ Setup Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}} / \overline{\text { PGM }}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 130 | ns |
| tpw | Program Pulse Width |  | 0.45 | 0.5 | 0.55 | ms |
| TOE | Data Valid from $\overline{O E}$ | $\overline{\mathrm{CE}} / \overline{\text { PGM }}=\mathrm{V}_{\text {IL }}$ |  |  | 150 | ns |
| IPP | VPP Supply Current during Programming Pulse | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}}$. |  |  | 30 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  |  | 10 | mA |
| $\mathrm{T}_{\mathrm{A}}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{\text {CC }}$ | Power Supply Voltage |  | 5.75 | 6.0 | 6.25 | V |
| $V_{P P}$ | Programming Supply Voltage |  | 12.2 | 13.0 | 13.3 | V |
| $\mathrm{t}_{\mathrm{FR}}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

## Programming Waveforms (Note 3)



TL/D/11405-6
Note 1: National's standard product warranty applies to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P p}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{Pp}}$ or $\mathrm{V}_{\mathrm{Cc}}$.

Note 3: The maximum absolute allowable voltage which may be applied to the $V_{\text {PP }}$ pin during programming is 14 V . Care must be taken when switching the spurious
$V_{P P}$ voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the Interactive Program Algorithm, at typical power supply voltages and timings.


## Interactive Programming Algorithm Flow Chart



FIGURE 3

## Functional Description

## dEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{Pp}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 13.0 V during the three programming modes, and must be at 5 V in the other three modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6.0 V during the three programming modes, and at 5 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs $\mathrm{t}_{\mathrm{OE}}$ after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.
The sense amps are clocked for fast access time. $\mathrm{V}_{\mathrm{CC}}$ should therefore be maintained at operating voltage during read and verify. If $V_{C C}$ temporarily drops below the spec. voltage (but not to ground) an address transition must be performed after the drop to ensure proper output data.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $97 \%$, from 24.75 mW to 0.55 mW . The EPROM is placed in the standby mode by applying a CMOS high signal to the $\overline{C E}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the $\overline{O E}$ input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Tying

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2 -line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.

To most efficiently use these two control lines, it is recommended that $\overline{\mathrm{CE}}$ be decoded and used as the primary device selecting function, while $\overline{\mathrm{OE}}$ be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming; Interactive Algorithm

CAUTION: Exceeding 14 V on pin 1 (VPP) will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 's" state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 ' $s$ " will be programmed, both " 1 ' $s$ " and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The EPROM is in the programming mode when the VPP power supply is at 13.0 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{C E}$ input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Interactive Programming Algorithm shown in Figure 3. Each Address is programmed with a series of $500 \mu$ s pulses until it verifies good, up to a maximum of 20 pulses. Most memory cells will program with a single $500 \mu$ s pulse.
The EPROM must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}}$ input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\mathrm{CE}}$ input programs the paralleled EPROM.

## Program Inhibit

Programming multiple EPROMs in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}}$, all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel EPROMs may be common. A TTL low level program pulse applied to an EPROMs $\overline{\mathrm{CE}}$ input with $\mathrm{V}_{\mathrm{PP}}$ at 13.0 V will program that EPROM. A TTL high level $\overline{C E} / \overline{\text { PGM }}$ input inhibits the other EPROM from being programmed.

TABLE I. Modes Selection

| Pins | $\overline{\mathrm{CE}} / \overline{\text { PGM }}$ | $\overline{O E}$ | $\mathbf{V P P}_{\text {P }}$ | Vcc | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}$ | 5.0 V | DOUT |
| Output Disable | $\begin{gathered} X \\ \text { (Note 1) } \\ \hline \end{gathered}$ | $\mathrm{V}_{\mathrm{IH}}$ | $V_{C C}$ | 5.0 V | High $\mathbf{Z}$ |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | $V_{\text {cc }}$ | 5.0 V | High Z |
| Programming | $\mathrm{V}_{\text {IL }}$ | X | 12.75 V | 6.25 V | $\mathrm{DIN}_{\text {I }}$ |
| Program Verify | X | $V_{1 L}$ | 12.75 V | 12.75 V | Dout |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | High Z |

Note 1: X can be $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$.

## Functional Description (Continued)

## Program Verlfy

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $V_{P p}$ at 13.0 V . $V_{\text {Pp }}$ must be at $V_{C C}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for NM27LC256 is " $8 F C 4$ ", where " 8 F " designates that it is made by National Semiconductor, and "C4" designates a 256 k ( 32 k 8 ) part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A16, and all control pins are held at $\mathrm{V}_{\mathrm{IH}}$. Address pin AO is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the eight data pins, $\mathrm{O}_{0}-\mathrm{O}_{7}$. Proper code access is only guaranteed at $25^{\circ} \mathrm{C}$ to $\pm 5^{\circ} \mathrm{C}$.

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms (Å). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.

The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of 15 W -sec/cm².
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increases as the square of the distance from the lamp. (If distance is doubled the erasure time increases by factor of 4.) Lamps lose intensity as they age. When a lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristic of EPROMs require careful decoupling of the devices. The supply current, Icc, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent of the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $\mathrm{V}_{\mathrm{CC}}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(10)$ | A9 <br> $(24)$ | O7 <br> $(19)$ | O6 <br> $(18)$ | O5 <br> $(17)$ | O4 <br> $(16)$ | O3 <br> $(15)$ | O2 <br> $(13)$ | O1 <br> $(12)$ | O0 <br> $(11)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | C 4 |

## NM27LC512 <br> 524,288-Bit (64k x 8) Low Current CMOS EPROM

## General Description

The NM27LC512 is a $64 \mathrm{k} \times 8$ EPROM manufactured on a proven, manufacturable CMOS process, consuming extremely low current in both the active and standby modes. The NM27LC512 consumes a mere 30 mW , making it ideal for portable and hand held computers, data acquisition and medical equipment, and for systems using in-line power.
The NM27LC512 is one among a family of Power Miser products from National Semiconductor catering to the increasing low current demands of the market.
Offered in a JEDEC Standard Pinout, the NM27LC512 offers a viable alternative to the user as a replacement for existing high power devices, while also providing an upgrade path from lower densities.

Features

- Low CMOS power consumption
-5 V operation
- 8.0 mA (Max) active
- $100 \mu \mathrm{~A}$ (Max) standby
- 150 ns access time
- Latch-up immunity to 200 mA
- ESD protection exceeds 2000 V
- JEDEC standard pinout
- Manufacturer's identification code


## Block Diagram



Connection Diagram


TL/D/11406-2
Note: Compatible EPROM plan configurations are shown in the blocks adjacent to the NM27LC256 plan.

| $\begin{gathered} \text { Commercial Temperature Range } \\ \left(0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}\right) \\ \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ \hline \end{gathered}$ |  | Extended Temperature Range$\begin{aligned} & \left(-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}\right) \\ & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{VV} \pm 10 \% \end{aligned}$ |  |
| :---: | :---: | :---: | :---: |
| Parameter/Order Number | Access Time (ns) | Parameter/Order Number | Access Time (ns) |
| NM27LC256 Q, N 150 | 150 | NM27LC256 QE, NE 150 | 150 |
| NM27LC256 Q, N 200 | 200 | NM27LC256 QE, NE 200 | 200 |
| NM27LC256 Q, N 250 | 250 | NM27LC256 QE, NE 250 | 250 |

## Ordering Information



| Absolute Maximum Ratings (Note 1) |
| :--- |
| If Military/Aerospace specified devices are required, |
| please contact the National Semiconductor Sales |
| Office/Distributors for avallability and specifications. |
| Storage Temperature |
| All Input Voltages Except A9 with <br> Respect to Ground <br> VPp and A9 with <br> Respect to Ground <br> Vcc Supply Voltage with <br> Respect to Ground$\quad-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |


| ESD Protection | $>2000 \mathrm{~V}$ |
| :--- | :--- |
| All Output Voltages with |  |
| Respect to Ground |  |$\quad \mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to GND -0.6 V

## Operating Range

| Range | Temperature | $\mathbf{V}_{\text {CC }}$ |
| :---: | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ |

## Read Operation

DC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\text {PP }}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level |  | -0.2 |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Level |  | 2.0 |  | $\mathrm{V}_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{IOL}=2.1 \mathrm{~mA}$ |  |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{I}_{\mathrm{OH}}=-2.5 \mathrm{~mA}$ | 3.5 |  |  | V |
| ${ }^{\text {ISB1 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current CMOS Inputs | $\overline{C E}=V_{C C} \pm 0.3 \mathrm{~V}$ | 0.5 | 0.5 | 100 | $\mu \mathrm{A}$ |
| $I_{\text {SB2 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current TTL Inputs | $\overline{C E}=V_{1 H}$ | 0.1 | 0.1 | 1.0 | mA |
| ICCl | $V_{\text {CC }}$ Active Current TTL Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{f}=3 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \end{aligned}$ |  | 16.0 | 12.5 | mA |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current CMOS Inputs | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{GND}, \mathrm{f}=3 \mathrm{MHz} \\ & \text { Inputs }=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \\ & \text { (Refer to Figures } 1,2 \text { ) } \end{aligned}$ | 5.0 | 6.0 | 8.0 | mA |
| IPP | VPp Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  |  | 10 | $\mu \mathrm{A}$ |
| ILI | Input Load Current | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ or GND | -1 |  | 1 | $\mu \mathrm{A}$ |
| lo | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ or GND | -10 |  | 10 | $\mu \mathrm{A}$ |

AC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{v}_{\mathrm{CC}}$

| Symbol | Parameter | 150 |  | 200 |  | 250 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 150 |  | 200 |  | 250 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 150 |  | 200 |  | 250 |  |
| toe | $\overline{\mathrm{OE}}$ to Output Delay |  | 60 |  | 75 |  | 100 |  |
| $t_{D F}$ <br> (Note 2) | Output Disable to Output Float |  | 50 |  | 55 |  | 60 |  |
| ${ }^{\mathrm{t}} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever Occurred First |  | 0 |  | 0 |  | 0 |  |



TL/D/11406-3
FIGURE 1. Icc_ACTIVE_CMOS vs Frequency

$$
\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{P}}=5.0 \mathrm{~V} \text {, Temperature }=25^{\circ} \mathrm{C}
$$



FIGURE 2. ICC_ACTIVE_CMOS vs Temperature $V_{C C}=V_{P P}=5.0 \mathrm{~V}$, Frequency $=1 \mathrm{MHz}$

Capacitance $T_{A}=+25^{\circ} \mathrm{C}, 1=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}$ | 6 | 12 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ | 9 | 12 | pF |

## AC Test Conditions

Output Load
Input Rise and Fall Times

1 TTL Gate and
$C_{L}=100 \mathrm{pF}$ (Note 8)
$\leq 5 \mathrm{~ns}$

Input Pulse Levels
Timing Measurement Reference Level Inputs Outputs
0.45 V to 2.4 V
(Note 9)
0.8 V to 2 V 0.8 V to 2 V

AC Waveforms (Notes 6, 7 , and 9 )


TL/D/11406-5
Note 1: 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 operations sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{C E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 4: The TDF and TCF compare level is determined as follows:
High to TRI-STATE ${ }^{*}$, the measure $\mathrm{V}_{\mathrm{CH} 1}(\mathrm{DC})-0.10 \mathrm{~V}$;
Low to TRI-STATE, the measure $\mathrm{V}_{\mathrm{OL}}(\mathrm{DC})+0.10 \mathrm{~V}$.
Note 5: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{IOL}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$\mathrm{C}_{\mathrm{L}}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: Inputs and outputs can undershoot to -2.0 V for 20 ns Max.
Note 10: CMOS inputs $V_{I L}=G N D \pm 0.3 V, V_{I H}=V_{C C} \pm 0.3 V$.

Programming Characteristics (Notes 1, 2, 3 and 4)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvCs | $V_{C C}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{cf}}$ | Chip Enable to Output Float Delay | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{s}$ |
| toen | $\overline{\text { OE Hold Time }}$ |  | 1 |  |  | $\mu \mathrm{S}$ |
| tov | Data Valid from $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |  |  | 250 | ns |
| ${ }_{\text {tPRT }}$ | $\overline{O E}$ Pulse Rise Time During Programming |  | 50 |  |  | ns |
| $t_{V R}$ | $V_{\text {PP }}$ Recovery Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| Ipp | $V_{\text {PP }}$ Supply Current During Programming Pulse | $\begin{aligned} & \overline{\overline{\mathrm{CE}}}=V_{\mathrm{IL}} \\ & \overline{\mathrm{OE}}=V_{\mathrm{PP}} \end{aligned}$ |  |  | 30 | mA |
| $\mathrm{I}_{\mathrm{CC}}$ | $V_{\text {CC }}$ Supply Current |  |  |  | 10 | mA |
| $\mathrm{T}_{\text {R }}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ | Power Supply Voltage |  | 6 | 6.25 | 6.5 | V |
| $V_{P P}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13 | V |
| $\mathrm{t}_{\text {FR }}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4 |  | V |
| $\mathrm{t}_{\mathrm{N}}$ | Input Timing Reference Voltage |  | 0.8 | 1.5 | 2 | V |
| tout | Output Timing Reference Voltage |  | 0.8 | 1.5 | 2 | V |

Note 1: National's standard product warranty applies to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P p}$. The EPROM must not be inserted into or removed from a board with voltage applied to $V_{P P}$ or $V_{C C}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $\mathrm{V}_{\mathrm{PP}}$ pin during programming is 14 V . Care must be taken when switching the $\mathrm{V}_{\mathrm{PP}}$ supply to prevent any overshoot from exceeding this 14 V maximum specitication. At least $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm at typical power supply voltages and timings.

## Programming Waveforms



## Interactive Programming Algorithm Flow Chart



FIGURE 3

## Fast Programming Algorithm Flow Chart



TL/D/11406-7
FIGURE 4

## Functional Description

## device operation

The six modes of operation of the NM27LC512 are listed in Table I. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ during programming. In the program mode the $\overline{O E} / V_{P P}$ input is pulsed from a TTL low level to 12.75 V .

## Read Mode

The NM27LC512 has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}})$ is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.
The sense amps are clocked for fast access time. $\mathrm{V}_{\mathrm{CC}}$ should therefore be maintained at operating voltage during read and verify. If $V_{C C}$ temporarily drops below the spec. voltage (but not to ground) an address transition must be performed after the drop to ensure proper output data.

## Standby Mode

The NM27LC512 has a standby mode which reduces the active power dissipation by over $99 \%$, from 44 mW to 0.55 mW . The NM27LC512 is placed in the standby mode by applying a CMOS high signal to the $\overline{C E}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output OR-Typing

Because the NM27LC512 is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that $\overline{C E}$ (pin 20) be decoded and used as the primary device selecting function, while $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ (pin 22) be made a common connection to all devices in the array and connected to the READ line from the system control bus.

This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14V on pin $22\left(\overline{O E} / V_{P P}\right)$ will damage the NM27LC512.
Initially, and after each erasure, all bits of the NM27LC512 are in the " 1 " state. Data is introduced by selectively programming " 0 ' $s$ " into the desired bit locations. Although only " 0 ' $s$ " will be programmed, both " 1 ' $s$ " and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The NM27LC512 is in the programming mode when the $\overline{O E} / V_{P P}$ is at 12.75 V . It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $V_{C C}$ and ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{CE}}$ input. A program pulse must be applied at each address location to be programmed.
The NM27LC512 is programmed with the Fast Programming Algorithm shown in Figure 4. Each Address is programmed with a series of $100 \mu$ s pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu \mathrm{~s}$ pulse.
The NM27LC512 must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}}$ input.
Programming multiple NM27LC512 in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NM27LC512 may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\mathrm{CE}}$ input programs the paralleled NM27LC512.
Note: Some programmer manufacturers due to equipment limitation may offer interactive program Algorithm (Shown in Figure 3).

## Mode Selection

The modes of operation of the NM27LC512 are listed in Table I. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for $V_{P P}$ and $A 9$ for device signature.

TABLE I. Modes Selection

| Pins | $\overline{\text { CE }} / \overline{\text { PGM }}$ | $\overline{O E}$ | $V_{\text {PP }}$ | Vcc | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |
| Read | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | $V_{C C}$ | 5.0 V | Dout |
| Output Disable | X <br> (Note 1) | $\mathrm{V}_{\mathrm{IH}}$ | $V_{C C}$ | 5.0 V | High Z |
| Standby | $\mathrm{V}_{\text {IH }}$ | X | $\mathrm{V}_{\mathrm{CC}}$ | 5.0 V | High Z |
| Programming | $\mathrm{V}_{\text {IL }}$ | X | 12.75 V | 6.25 V | DIN |
| Program Verify | X | $\mathrm{V}_{\text {IL }}$ | 12.75 V | 12.75 V | DOUT |
| Program Inhibit | $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | High Z |

[^0]
## Functional Description (Continued)

## Program Inhibit

Programming multiple NM27LC512 in parallel with different data is also easily accomplished. Except for $\overline{C E}$, all like inputs (including $\overline{O E}$ ) of the parallel NM27LC512 may be common. A TTL low level program pulse applied to an NM27LC512's $\overline{\mathrm{CE}}$ input with $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ at 12.75 V will program that NM27LC512. A TTL high level CE input inhibits the other NM27LC512 from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify is accomplished with $\overline{O E} / V_{P P}$ and $\overline{C E}$ at $V_{\text {IL }}$. Data should be verified tDV after the falling edge of $\overline{\mathrm{CE}}$.

## Manufacturer's Identification Code

The NM27LC512 has a manufacturer's identification code to aid in programming. The code, shown in Table !l, is two bytes wide and is stored in a ROM configuration on the chip. It identifies the manufacturer and the device type. The code for the NM27LC512 is , " 8 F 85 ", where " 8 F " designates that it is made by National Semiconductor, and " 85 " designates a 512 k part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses At-A8, A10-A15, $\overline{\mathrm{CE}}$, and $\overline{\mathrm{OE}}$ are held at $\mathrm{V}_{\mathrm{IL}}$. Address $A 0$ is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the 8 data pins. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.
The primary purpose of the manufacturer's identification code is automatic programming control. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.

## ERASURE CHARACTERISTICS

The erasure characteristics of the NM27LC512 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.

After programming opaque labels should be placed over the NM27LC512 window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.
The recommended erasure procedure for the NM27LC512 is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of 15 W - $\mathrm{sec} / \mathrm{cm}^{2}$.
The NM27LC512 should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table III shows the minimum NM27LC512 erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to unit should be maintained at one inch. The erasure time increases as the square of the distance. (If distance is doubled the erasure time increases by a factor of 4.) Lamps lose intensity as they age. When a lamp is changed, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, ICC, has three segments that are of interest to the system de-signer-the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $\mathrm{V}_{\mathrm{CC}}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

TABLE III. Minimum NM27LC512 Erasure Time

| Light Intensity <br> (Micro-Watts/cm <br> 2 | Erasure Time <br> (Minutes) |
| :---: | :---: |
| 15,000 | 20 |
| 10,000 | 25 |
| 5,000 | 50 |

NM27LV512
524,288-Bit (64k x 8) Low Voltage EPROM

## General Description

The NM27LV512 is a high performance Low Voltage Electrical Programmable Read Only Memory. It is manufactured using National's latest $1.2 \mu$ CMOS split gate SVG EPROM technology. This technology allows the part to operate at speeds as fast as 200 ns over commercial temperature $\left(0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$, and 250 ns over industrial temperatures $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$.
This Low Voltage and Low Power EPROM is designed with power sensitive handheld and portable battery products in mind. This allows for code storage of firmware for applications like notebook computers, palm top computers, cellular phones, and HDD.
National still maintains its' commitment to high quality and reliability with EPI processing on the NM27LV512. Latch-up immunity is guaranteed for stresses up to 200 mA on address and data pins from -1 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$. ESD protection is guaranteed 2000 V .
Small outline packages are just as critical to portable applications as Low Voltage and Low Power. National Semiconductor has forseen this need and provides win-
dowed LCC for prototyping and software development, PLCC for production runs, and TSOP for PC board sensitive users.
The NM27LV512 is one member of National's growing Low Voltage product family.

## Features

■ 3.0 V to 5.5 V operation

- 200 ns access time
- Low current operation
-12 mA Icc Active Current @ 5 MHz
$-20 \mu \mathrm{~A}$ ICC Standby Current @ 5 MHz
- Ultra Low Power operation
$-50 \mu \mathrm{~W}$ Standby Power @ 3.3V
- 50 mW Active Power © 3.3V
- High reliability EPI processing
- Latch up immunity up to 200 mA
- 2000V ESD protection
- Surface mount package options
- 28-pin CERPACK
- 28-pin PLCC
- 28-pin TSOP


## Block Diagram



TL/D/11375-1

NM27LV010
1,048,576-Bit (128k x 8) Low Voltage EPROM

## General Description

The NM27LV010 is a high performance Low Voltage Electrically Programmable Read Only Memory. It is manufactured using National's latest $1.2 \mu$ CMOS split gate SVG EPROM technology. This technology allows the part to operate at speeds as fast as 200 ns over Industrial temperatures $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$.
This Low Voltage and Low Power EPROM is designed with power sensitive hand held and portable battery products in mind. This allows for code storage of firmware for applications like notebook computers, palm top computers, cellular phones, and HDD.
National still maintains its commitment to high quality and reliability with EPI processing on the NM27LV010. Latch-up immunity is guaranteed for stresses up to 200 mA on address and data pins from -1 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$. ESD protection is guaranteed for 2000 V .
Small outline packages are just as critical to portable applications as Low Voltage and Low Power. National Semiconductor has foreseen this need and provides windowed LCC for prototyping and software development, PLCC for production runs, and TSOP for PC board sensitive applications.

The NM27C010 is one member of National's growing Low Voltage product Family.

## Features

- 3.0 V to 5.5 V operation
- 200 ns access time
- Low current operation
- $15 \mathrm{~mA} \mathrm{I}_{\mathrm{CC}}$ active current @ 5 MHz
- $20 \mu \mathrm{~A}$ ICC standby current @ 5 MHz
- Ultra low power operation
$-33 \mu \mathrm{~W}$ standby power @ 3.3V
-50 mW active power @ 3.3V
■ High reliability EPI processing - Latch-up immunity up to 200 mA - 2000V ESD protection
- Surface mount package options
- TSOP package
-32-pin PLCC


## Block Diagram



## Connection Diagram

PLCC and CLCC Pin Configuration


TL/D/11377-6
Top View

Commercial Temperature Range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$
$\mathbf{V}_{\mathbf{c c}}=3.3 \pm 0.3$

| Parameter/Order Number | Access Time (ns) |
| :---: | :---: |
| NM27LV010 L, V, T 200 | 200 |
| NM27LV010 L, V, T 250 | 250 |
| NM27LV010 L, V, T 300 | 300 |

Pin Names

| $\mathrm{AO}-\mathrm{A} 16$ | Addresses |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\mathrm{OE}}$ | Output Enable |
| $\mathrm{O} 0-\mathrm{O7}$ | Outputs |
| $\overline{\mathrm{PGM}}$ | Program |
| XX | Don't Care (During Read) |
| V | Programming Voltage |

Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
$V_{\text {CC }}=3.3 \pm 0.3$

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NM27LV010 LE, VE, TE | 250 |
| NM27LV010 LE, VE, TE | 300 |

Note: Surface mount PLCC available for commercial and extended temperature ranges only.
Package Types: NM27LV010 L, V, T
$L=$ Quartz-Windowed LCC Package
$T=T S O P$
$V=P L C C$

- All packages conform to the JEDEC standard.
- All versions are guaranteed to function for slower speeds.

TSOP Pin Configuration


```
Absolute Maximum Ratings (Note 1)
If Military/Aerospace specifled devices are required,
please contact the National Semiconductor Sales
Office/Distributors for avallability and specifications.
```

Storage Temperature All Input Voltages except A9 with
Respect to Ground (Note 10)
$V_{\text {PP }}$ and A9 with Respect to Ground
$V_{C C}$ Supply Voltage with
Respect to Ground
ESD Protection
All Output Voltages with
Respect to Ground (Note 10)
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
-0.6 V to +7 V
-0.6 V to +14 V

$$
-0.6 \mathrm{~V} \text { to }+7 \mathrm{~V}
$$

$$
>2000 \mathrm{~V}
$$

$$
V_{c c}+1.0 V
$$

$$
\text { to GND }-0.6 \mathrm{~V}
$$

Operating Range

| Range | Temperature | $V_{\text {CC }}$ | Tolerance |
| :--- | :--- | :---: | :---: |
| Commercial | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 3.3 V | $\pm 0.3$ |
| Industrial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | 3.3 V | $\pm 0.3$ |

DC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Test Conditions |  | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Level |  |  | -0.3 | 0.8 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Level |  |  | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage (TTL) | $1 \mathrm{OL}=2.0 \mathrm{~mA}$ |  |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage (TTL) | $\mathrm{IOH}=-2.0 \mathrm{~mA}$ |  | 2.4 |  | V |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage | $\mathrm{lOL}=100 \mu \mathrm{~A}$ |  |  | 0.2 | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (CMOS) | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ |  | $V_{C C}-0.3$ |  |  |
| $\mathrm{I}_{\text {SB1 }}$ | $V_{C C}$ Standby Current (CMOS) | $\overline{C E}=V_{C C} \pm 0.3$ |  |  | 20 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {SB2 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current(TTL) | $\overline{\mathrm{CE}}=\mathrm{V}_{1 H}$ |  |  | 100 | $\mu \mathrm{A}$ |
| ICC | $V_{\text {cc }}$ Active Current | $\overline{\mathrm{CE}}+\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{f}=5 \mathrm{MHz}$ |  | 15 | mA |
| Ipp | VPP Supply Current | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |  |  | 10 | $\mu \mathrm{A}$ |
| VPP | V Pp Read Voltage |  |  | $V_{C C}-0.7$ | $\mathrm{V}_{\mathrm{CC}}$ | V |
| lil | Input Load Current | $\mathrm{V}_{\text {IN }}=3.0 \mathrm{~V}$ or GN |  |  | 1 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=3.0 \mathrm{~V}$ or |  | -1 | 1 | $\mu \mathrm{A}$ |

AC Electrical Characteristics Over Operating Range with $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | 200 |  | 250 |  | 300 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | 200 |  |  | 120 |  | 150 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay | 200 |  |  | 120 |  | 150 |  |
| toe | $\overline{\mathrm{OE}}$ to Output Delay | 70 |  | 70 |  | 75 |  |  |
| ${ }^{t}$ DF <br> (Note 2) | Output Disable to Output Float | 50 |  | 50 |  | 60 |  |  |
| ${ }^{\mathrm{t}} \mathrm{OH}$ <br> (Note 2) | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | 0 |  | 0 |  | 0 |  |  |

Capacitance $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, 1=1 \mathrm{MHz}$ (Note 2)

| Symbol | Parameter | Conditions | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ | 9 | 15 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ | 12 | 15 | pF |

## AC Test Conditions

Output Load

Input Rise and Fall Times
Input Pulse Levels

> 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}($ Note 8$)$
> $\leq 5 \mathrm{~ns}$
> 0.45 V to 2.4 V

Timing Measurement Reference Level Inputs Outputs 0.8 V and 2 V 0.8 V and 2 V

## AC Waveforms (Notes 6, 7, and 9)



TL/D/11377-3
Note 1: 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 operations sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: This parameter is only sampled and is not $100 \%$ tested.
Note 3: $\overline{\mathrm{O}}$ may be delayed up to $\mathrm{t}_{\mathrm{ACC}}-\mathrm{t}_{\mathrm{CE}}$ after the falling edge of $\overline{C E}$ without impacting $\mathrm{t}_{\mathrm{ACC}}$.
Note 4: The $t_{D F}$ and $t_{C F}$ compare level is determined as follows:
High to TRI-STATE ${ }^{\star}$, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V ;
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} 1}$ (DC) +0.10 V .
Note 5: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 6: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.2 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 7: The outputs must be restricted to $V_{C C}+1.0 \mathrm{~V}$ to avoid latch-up and device damage.
Note 8: 1 TTL Gate: $\mathrm{IOL}^{2}=1.6 \mathrm{~mA}$, $\mathrm{IOH}=-400 \mu \mathrm{~A}$.
$C_{L}: 100 \mathrm{pF}$ includes fixture capacitance.
Note 9: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.
Note 10: Inputs and outputs can undershoot to $\mathbf{- 2 . 0 V}$ for 20 ns Max.

Programming Characteristics (Notes 1, 2, 3, 4 and 5)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A S}$ | Address Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Setup Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tvps | $V_{\text {pp }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tves | $\mathrm{V}_{\text {CC }}$ Setup Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{AH}}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| tpw | Program Pulse Width |  | 95 | 100 | 105 | $\mu \mathrm{S}$ |
| toe | Data Valid from $\overline{\mathrm{OE}}$ | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 100 | ns |
| Ipp | Vpp Supply Current during Programming Pulse | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 30 | mA |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  |  | 50 | mA |
| $\mathrm{T}_{\mathrm{A}}$ | Temperature Ambient |  | 20 | 25 | 30 | ${ }^{\circ} \mathrm{C}$ |
| $V_{\text {CC }}$ | Power Supply Voltage |  | 6.0 | 6.25 | 6.5 | V |
| $V_{P P}$ | Programming Supply Voltage |  | 12.5 | 12.75 | 13.0 | V |
| $\mathrm{t}_{\mathrm{FR}}$ | Input Rise, Fall Time |  | 5 |  |  | ns |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.0 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | 2.4 | 4.0 |  | V |
| $\mathrm{t}_{\mathrm{IN}}$ | Input Timing Reference Voltage |  | 0.8 |  | 2.0 | V |
| tout | Output Timing Reference Voltage |  | 0.8 |  | 2.0 | V |

## Programming Waveform (Note 3)



TL/D/11377-4
Note 1: National's standard product warranty applies to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The EPROM must not be inserted into or removed from a board with voltage applied to $\mathrm{V}_{\mathrm{Pp}}$ or $\mathrm{V}_{\mathrm{CC}}$.
Note 3: The maximum absolute allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent any overshoot from exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{PP}}$, $\mathrm{V}_{\mathrm{CC}}$ to $G N D$ to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested with the fast Program Algorithm, at typical power supply voltages and timings.


Fast Programming Algorithm Flow Chart


FIGURE 1

## Functional Description

## DEVICE OPERATION

The six modes of operation of the EPROM are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are $V_{C C}$ and $V_{\text {PP }}$. The VPP power supply must be at 12.75 V during the three programming modes, and must be at 3.3 V in the other three modes. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6.25 V during the three programming modes, and at 3.3 V in the other three modes.

## Read Mode

The EPROM has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $t_{A C C}$ ) is equal to the delay from $\overline{C E}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs $\mathrm{t}_{\mathrm{OE}}$ after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.

## Standby Mode

The EPROM has a standby mode which reduces the active power dissipation by over $99 \%$, from 50 mW to $33 \mu \mathrm{~W}$. The EPROM is placed in the standby mode by applying a CMOS high signal to the $\overline{C E}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output Disable

The EPROM is placed in output disable by applying a TTL high signal to the $\overline{O E}$ input. When in output disable all circuitry is enabled, except the outputs are in a high impedance state (TRI-STATE).

## Output OR-Tying

Because the EPROM is usually used in larger memory arrays, National has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2-line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that $\overline{\mathrm{CE}}$ be decoded and used as the primary device selecting function, while $\overline{O E}$ be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby modes and that the output pins are active only when data is desired from a particular memory device.

## Programming

CAUTION: Exceeding 14 V on pin $1\left(\mathrm{~V}_{\mathrm{PP}}\right)$ will damage the EPROM.
Initially, and after each erasure, all bits of the EPROM are in the " 1 's" state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 's" and " 0 's" can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.

The EPROM is in the programming mode when the VPP power supply is at 12.75 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}$ and $V_{C C}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{PGM}}$ input. A program pulse must be applied at each address location to be programmed. The EPROM is programmed with the Fast Programming Algorithm shown in Figure 1. Each Address is programmed with a series of $100 \mu \mathrm{~s}$ pulses until it verifies good, up to a maximum of 25 pulses. Most memory cells will program with a single $100 \mu$ s pulse.
The EPROM must not be programmed with a DC signal applied to the $\overline{\text { PGM }}$ input.
Programming multiple EPROM in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel EPROM may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\text { PGM }}$ input programs the paralleled EPROM.

## Program Inhibit

Programming multiple EPROM's in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}}$, all like inputs (including $\overline{\mathrm{OE}}$ and $\overline{\mathrm{PGM}}$ ) of the parallel EPROM may be common. A TTL low level program pulse applied to an EPROM's $\overline{\text { PGM }}$ input with $\overline{C E}$ at $V_{I L}$ and $V_{\text {PP }}$ at 12.75 V will program that EPROM. A TTL high level CE input inhibits the other EPROM's from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $V_{P P}$ at 12.75 V . $V_{P P}$ must be at $V_{C C}$, except during programming and program verify.

## AFTER PROGRAMMING

Opaque labels should be placed over the EPROM window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.

## MANUFACTURER'S IDENTIFICATION CODE

The EPROM has a manufacturer's identification code to aid in programming. When the device is inserted in an EPROM programmer socket, the programmer reads the code and then automatically calls up the specific programming algorithm for the part. This automatic programming control is only possible with programmers which have the capability of reading the code.
The Manufacturer's Identification code, shown in Table II, specifically identifies the manufacturer and device type. The code for the NM27LV010 is " 8 F86", where " 8 F " designates that it is made by National Semiconductor, and " 86 " designates a 1 Megabit (128k x 8) part.
The code is accessed by applying $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ to address pin A9. Addresses A1-A8, A10-A16, and all control pins are held at $\mathrm{V}_{\mathrm{IL}}$. Address pin $A 0$ is held at $\mathrm{V}_{\mathrm{IL}}$ for the manufacturer's code, and held at $\mathrm{V}_{\mathrm{IH}}$ for the device code. The code is read on the lower eight data pins, 00-07. Proper code access is only guaranteed at $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$.

## Functional Description (Continued)

## ERASURE CHARACTERISTICS

The erasure characteristics of the device are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range.
The recommended erasure procedure for the EPROM is exposure to short wave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ exposure time) for erasure should be a minimum of 15 W $\mathrm{sec} / \mathrm{cm}^{2}$.
The EPROM should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.
An erasure system should be calibrated periodically. The distance from lamp to device should be maintained at one inch. The erasure time increases as the square of the distance from the lamp (if distance is doubled the erasure time increases by factor of 4). Lamps lose intensity as they age. When a lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Program-
mers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

The power switching characteristics of EPROMs require careful decoupling of the devices. The supply current, ICC, has three segments that are of interest to the system designer: the standby current level, the active current level, and the transient current peaks that are produced by voltage transitions on input pins. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated $\mathrm{V}_{\mathrm{CC}}$ transient voltage peaks can be suppressed by properly selected decoupling capacitors. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, at least a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between VCC and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage drop caused by the inductive effects of the PC board traces.

## Mode Selection

The modes of operation of the NM27LV010 are listed in Table I. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for VPP and A9 for device signature.

TABLE I. Modes Selection

| Pins | CE/PGM | OE | $\mathbf{V P P}_{\text {P }}$ | Vcc | Outputs |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |
| Read | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | $V_{C C}$ | 3.3 V | DOUT |
| Output Disable | X | $V_{\text {IH }}$ | $\mathrm{V}_{\mathrm{CC}}$ | 3.3 V | High Z |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | $\mathrm{V}_{\mathrm{CC}}$ | 3.3 V | High Z |
| Programming | $V_{\text {IL }}$ | $V_{\text {IH }}$ | 12.75 V | 6.25 V | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | X | $\mathrm{V}_{\text {IL }}$ | 12.75 V | 12.75 V | DOUT |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 12.75 V | 6.25 V | High Z |

Note 1: $X$ can be $\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{IH}}$.
TABLE II. Manufacturer's Identification Code

| Pins | A0 <br> $(12)$ | A9 <br> (26) | O7 <br> $(21)$ | O6 <br> $(20)$ | 05 <br> $(19)$ | O4 <br> $(18)$ | O3 <br> $(17)$ | O2 <br> $(15)$ | 01 <br> $(14)$ | O0 <br> $(13)$ | Hex <br> Data |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Manufacturer Code | $\mathrm{V}_{\mathrm{IL}}$ | 12 V | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 F |
| Device Code | $\mathrm{V}_{\mathrm{IH}}$ | 12 V | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 86 |

National
Semiconductor
NM27LV210
1,048,576-Bit (64K x 16) Low Voltage EPROM

## General Description

The NM27LV210 is a high performance Low Voltage Electrical Programmable read only memory. It is manufactured using National's latest $1.2 \mu$ CMOS split gate SVG EPROM technology. This technology allows the part to operate at speeds as fast as 200 ns over commercial temperature ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ) and 250 ns over industrial temperatures $\left(-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}$ ).
This Low Voltage and Low Power EPROM is designed with power sensitive hand held and portable battery products in mind. This allows for code storage of firmware for applications like notebook computers, palm top computers, cellular phones, and HDD.
National still maintains its commitment to High Quality and Reliability with EPI processing on the NM27LV210. Latch up immunity is guaranteed for stresses up to 200 mA on address and data pins from -1 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$. ESD protection is also guaranteed up to 2000 V .
Small outline packages are just as critical to portable applications as Low Voltage and Low Power. National Semiconductor has foreseen this need and provides windowed LCC
for prototyping and software development, PLCC for production runs, and TSOP for PC board sensitive users.
The NM27LV010 is one member of National's growing Low Voltage product family.

## Features

■ 3.0 V to 5.5 V operation

- 200 ns maximum access time
- Low current operation
- 15 mA lcc active current @ 5 MHz
$-20 \mu \mathrm{~A}$ ICC standby current @ 5 MHz
- Ultra low power operation
$-60 \mu \mathrm{~A}$ standby power @ 3.3V
- 50 mW active power @ 3.3 V
a High reliability EPI processing
- Latch up immunity up to 200 mA
- 2000V ESD protection
- Surface mount package options
- TSOP package
- 44-Pin PLCC


## Block Diagram



TL/D/11376-1

Section 2 CMOS EEPROMs
Section 2 Contents
${ }^{12} \mathrm{C}$ CMOS EEPROM Selection Guide ..... 2-3
MICROWIRE CMOS EEPROM Selection Guide ..... 2-4
Specialty Products CMOS EEPROM Selection Guide ..... 2-5
I2C SYNCHRONOUS 2-WIRE BUS
NM24C02/C04/C08/C16 2K-/4K-/8K-/16K-Bit Serial EEPROM (I2C Synchronous 2-Wire Bus) ..... 2-6
NM24C03/C05/C09/C17 2K-/4K-/8K-/16K-Bit Serial EEPROM with Write Protect ( ${ }^{2} \mathrm{C}$ Synchronous 2-Wire Bus) ..... 2-17
NM24C02L/C04L 2K-/4K-Bit Serial EEPROM with Extended Voltage (I2C Synchronous 2-Wire Bus) ..... 2-27
NM24C03L/C05L 2K-/4K-Bit Serial EEPROM with Write Protect and Extended Voltage (I2C Synchronous 2-Wire Bus) ..... 2-39
MICROWIRE SERIAL EEPROMS
NM59C11 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable with Programming Status ..... 2-51
NM93C06/C46/C56/C66 256-/1024-/2048-/4096-Bit Serial EEPROM (MICROWIRE) ..... 2-58
NM93CS06/CS46/CS56/CS66 256-/1024-/2048-/4096-Bit Serial EEPROM with Data Protect and Sequential Read ..... 2-66
NM93C06L/C46L/C56L/C66L 256-/1024-/2048-/4096-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5 V ) ..... 2-77
NM93CS06L/CS46L/CS56L/CS66L 256-/1024-/2048-/4096-Bit Serial EEPROM with Extended Voltage ( 2.0 V to 5.5 V ) and Data Protect ..... 2-87
NM93C46A 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable ..... 2-100
NM93C46AL 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable ..... 2-108
APPLICATION SPECIFIC EEPROM
NM95C12 1K-Bit CMOS EEPROM with Programmable Switches ..... 2-118

## General Description

National Semiconductor's family of $\mathrm{I}^{2} \mathrm{C}$ CMOS EEPROMs share the following features: A serial interface and software protocol allowing operation on a two wire bus. Also, programming of the upper half of the memory can be disabled by connecting the WP pin to $V_{C C}$ on certain members of the family.
National Semiconductor EEPROMs offer 100,000 write cycles guaranteed-500,000 typical with data retention greater than 40 years. The $\mathrm{I}^{2} \mathrm{C}$ CMOS EEPROMs are all available in DIP and SO packaging.

## Features

- Low power CMOS
-2 mA active current typical
- $60 \mu \mathrm{~A}$ standby current typical
- Hardwire write protect for upper half of memory
- 2 wire serial interface
- Bidirectional data transfer protocol
- Sixteen byte page write mode
- Minimizes total write time per byte

Self timed write cycle

- Typical write cycle time of 5 ms

Data retention greater than 40 years
8 -pin mini-DIP, 8-pin SO or 14-pin SO package

| Available Product | Packages | Temperature Ranges | 4.5V-5.5V | 2.5V-5.5V | Security |
| :--- | :---: | :---: | :---: | :---: | :---: |
| NM24C02 | N, M, M8 | C, E, M | $Y$ | $Y$ |  |
| NM24C03 | N, M, M8 | C, E, M | $Y$ | $Y$ |  |
| NM24C04 | N, M, M8 | C, E, M | $Y$ | $Y$ |  |
| NM24C05 | N, M, M8 | C, E, M | $Y$ | $Y$ |  |
| NM24C08 | N, M | C, E, M | $Y$ |  |  |
| NM24C09 | N, M | C, E, M | $Y$ |  |  |
| NM24C16 | N, M | C, E, M | $Y$ |  |  |
| NM24C17 | N,M | C, E, M | $Y$ |  |  |
|  |  |  | $Y$ |  |  |



## MICROWIRE ${ }^{\text {TM }}$ CMOS EEPROM Selection Guide

## General Description

National Semiconductor offers a family of CMOS EEPROMs which share the following features: MICROWIRE Serial Interface, floating gate $\mathrm{M}^{2} \mathrm{CMOSTM}$ technology, 5 V only operation, 100,000 cycle operation, Directwrite ${ }^{\dagger}$, and self-timed programming cycle with programming status on the data out pin. All of these devices are offered in compatible packages and pinouts.
There are also several features not shared by all family members, which separate the family into three groups. These features are operating voltage range, write protection, and sequential register read. Other differences are memory size, packaging, and operating temperature range. Although, for the purpose of this selection guide, the family will not be separated by these differences, as each individual device is available with all of these variants.

## Features

- 40 year data retention
- Extended voltage operation
- Endurance: $10^{6}$ data changes
- Reliable CMOS floating gate technology
- Single voltage operation in all modes
- MICROWIRE compatible serial interface
- Directwrite ${ }^{\dagger}$, no erase cycles required
- Self-timed programming cycle
- Device status signal during programming mode
- Sequential Register Read*
- User configurable write protection*
*Features available on NM93CS only.


## Available Product

|  | Packages | Temperature Ranges | 4.5V-5.5V | 2.0V-5.5V* |
| :--- | :---: | :---: | :---: | :---: |
| NM93CS06 | $N, M 8$ | $C, E, M$ | $Y$ | $Y$ |
| NM93CS46 | N, M8 | C, E, M | $Y$ | $Y$ |
| NM93CS56 | $N, M 8$ | $C, E, M$ | $Y$ | $Y$ |
| NM93CS66 | $N, M$ | $C, E, M$ | $Y$ | $Y$ |
|  |  |  |  | $Y$ |
| NM93C06 | $N, M 8$ | $C, E, M$ | $Y$ | $Y$ |
| NM93C46 | $N, M 8$ | $C, E, M$ | $Y$ | $Y$ |
| NM93C56 | $N, M 8$ | $C, E, M$ | $Y$ | $Y$ |

*Extended Voltage (2.0-5.5) operation is not available on the M Temperature Range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
NOTE: For 14-Pin SO availability, contact local sales office.


## Specialty Products CMOS EEPROM Selection Guide

## General Description

National Semiconductor offers a full line of CMOS EEPROMs. Some share the MICROWIRETM Serial Interface such as the NM93C06 and the NM93CS06; others share the I2C ( 2 wire) Interface such as the NM24C02 and the NM24C08. In addition to the above EEPROMs, we also offer some specialty EEPROMs.
These include the NM95C12, NM93C46A and the NM59C11 EEPROMs.

## Features

- No erase necessary
- MICROWIRE compatible interface
- Self-timed programming cycle
- 40 years data retention
- Endurance: $10^{6}$ data changes
- Compatible with COPSTM Microcontroller
- Reliable CMOS floating gate technology

The NM95C12 is a 976 -bit CMOS EEPROM with 8 programmable outputs that can be used as DIP switches. The 976 bits of memory are divided into 61 registers of 16 bits each with each register individually accessible. Registers 61-63 are dedicated for DIP switch functions. The NM95C12 contains 8 individually programmable outputs which can be used as switches.

The NM93C46A and the NM59C11 are both 1024 bits of CMOS EEPROM which can be organized as either 64 16-bit registers or as 1288 -bit registers. The NM93C46A and the NM59C11 share the MICROWIRE Interface and the $\times 8$ and x16 configuration. The differentiating feature is in the pin configuration: The NM93C46A's Program/Erase status is output on the Data-Out (DO) pin; the NM59C11's on a separate RDY/BUSY pin. Both devices use a low to high transition on the clock (SK) to clock all data into or out of the device, except device programming status which is independent of the clock.

## Available Product

Packages
NM95C12
NM93C46A
NM59C11

N, M
N, M8
N, M8

## Temperature Ranges

C, E, M
C, E, M
C, E, M
4.5V-5.5V

Y
Y
Y
2.0V-5.5V

Y

## NM24C02/C04/C08/C16

 2K-/4K-/8K-/16K-Bit Serial EEPROM (I²C Synchronous 2-Wire Bus)
## General Description

The NM24C02/C04/C08/C16 devices are 2048/4096/ 8192/16,384 bits, respectively, of CMOS non-volatile electrically erasable memory. These devices conform to all specifications in the I2C 2-wire protocol and are designed to minimize device pin count and simplify PC board layout requirements.
This communication protocol uses CLOCK (SCL) and DATA I/O (SDA) lines to synchronously clock data between the master (for example a microprocessor) and the slave EEPROM device(s). In addition, this bus structure allows for a maximum of 16 K of EEPROM memory. This is supported by the NSC family in $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$ and 16 K devices, allowing the user to configure the memory as the application requires with any combination of EEPROMs (not to exceed 16K).
National EEPROMs are designed and tested for applications requiring high endurance, high reliability and low power consumption.

## Features

- Low Power CMOS
- 2 mA active current typical
- $60 \mu \mathrm{~A}$ standby current typical
- 2-wire ${ }^{2} \mathrm{C}$ serial interface - Provides bidirectional data transfer protocol
- Sixteen byte page write mode - Minimizes total write time per byte
- Self timed write cycle - Typical write cycle time of 5 ms
- Endurance: $10^{6}$ data changes
- Data retention greater than 40 years
- Packages available: 8 pin mini-DIP or 14 pin SO package


## Functional Diagram



## Connection Diagrams

Dual-In-Line Package (N)


TL/D/11099-2
Top View
See NS Package Number N08E (N)


TL/D/11099-21
Top View
See NS Package Number M08A (M8)


Top View
See NS Package Number M14B (M)

Pin Names

| $A 0, A 1, A 2$ | Device Address Inputs |
| :--- | :--- |
| $V_{\text {SS }}$ | Ground |
| SDA | Data I/O |
| SCL | Clock Input |
| NC | No Connection |
| $V_{C C}$ | +5 V |

## Ordering Information

$$
\text { Commerclal Temperature Range }\left(0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}\right)
$$

| Order Number |
| :---: |
| NM24C02N/NM24CO4N/NM24C08N/NM24C16N |
| NM24C02M/NM24C04M/NM24C08M/NM24C16M |
| NM24C02M8/NM24C04M8 |

Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM24C02EN/NM24C04EN/NM24CO8EN/NM24C16EN |
| NM24C02EM/NM24C04EM/NM24C08EM/NM24C16EM |
| NM24CO2EM8/NM24C04EM8 |

Military Temperature Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM24C02MN/NM24C04MN/NM24C08MN/NM24C16MN |
| NM24C02MM/NM24C04MM/NM24C08MM/NM24C16MM |
| NM24C02MM8/NM24C04MM8 |

Absolute Maximum Ratings
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Ambient Storage Temperature
All Input or Output Voltages with Respect to Ground Lead Temperature
(Soldering, 10 seconds)
ESD Rating
2000 V min

| Symbol | Parameter | Test Conditions | Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | $\begin{gathered} \text { Typ } \\ \text { (Note 1) } \end{gathered}$ | Max |  |
| ICCA | Active Power Supply Current | $\mathrm{f}_{\text {SCL }}=100 \mathrm{kHz}$ |  | 2.0 | 3.0 | mA |
| $I_{\text {SB }}$ | Standby Current | $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ or $\mathrm{V}_{\mathrm{CC}}$ |  | 60 | 100 | $\mu \mathrm{A}$ |
| lıI | Input Leakage Current | $V_{I N}=G N D$ to $V_{C C}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{CC}}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.3 |  | $\mathrm{V}_{\mathrm{CC}} \times 0.3$ | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | $\mathrm{V}_{\mathrm{CC}} \times 0.7$ |  | $V_{C C}+0.5$ | V |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=3 \mathrm{~mA}$ |  |  | 0.4 | V |

Capacitance $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$

| Symbol | Test | Conditions | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I / O}$ (Note 2) | Input/Output Capacitance (SDA) | $\mathrm{V}_{1 / O}=0 \mathrm{~V}$ | 8 | pF |
| $\mathrm{C}_{I N}$ (Note 2) | Input Capacitance (AO, A1, A2, SCL) | $\mathrm{V}_{I N}=0 \mathrm{~V}$ | 6 | pF |

## AC Conditions of Test

| Input Pulse Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.1$ to $\mathrm{V}_{\mathrm{CC}} \times 0.9$ |
| :--- | :---: |
| Input Rise and <br> Fall Times | 10 ns |
| Input and Output | $\mathrm{V}_{\mathrm{CC}} \times 0.5$ |
| Timing Levels | 1 TTL Gate and |
| Output Load | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |

Note 1: Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage ( 5 V ).
Note 2: This parameter is periodically sampled and not $100 \%$ tested.

Read and Write Cycle Limits

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{SCL}}$ | SCL Clock Frequency |  | 100 | kHz |
| $\mathrm{T}_{1}$ | Noise Suppression Time Constant at SCL, SDA Inputs |  | 100 | ns |
| $t_{\text {AA }}$ | SCL Low to SDA Data Out Valid | 0.3 | 3.5 | $\mu \mathrm{S}$ |
| $t_{\text {BUF }}$ | Time the Bus Must Be Free before a New Transmission Can Start | 4.7 |  | $\mu s$ |
| $t_{\text {HD: }}$ STA | Start Condition Hold Time | 4.0 |  | $\mu \mathrm{s}$ |
| tow | Clock Low Period | 4.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {HIGH }}$ | Clock High Period | 4.0 |  | $\mu \mathrm{s}$ |
| tsu:STA | Start Condition Setup Time (for a Repeated Start Condition) | 4.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {HD: }}$ DAT | Data in Hold Time | 0 |  | $\mu \mathrm{S}$ |
| $t_{\text {SU }}$ DAT | Data in Setup Time | 250 |  | ns |
| $t_{R}$ | SDA and SCL Rise Time |  | 1 | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{F}}$ | SDA and SCL Fall Time |  | 300 | ns |
| tsu:STO | Stop Condition Setup Time | 4.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {dH }}$ | Data Out Hold Time | 300 |  | ns |
| $t_{\text {WR }}$ (Note 3) | Write Cycle Time |  | 10 | ms |

Note 3: The write cycle time (twR) is the time from a valid stop condition of a write sequence to the end ot the internal erase/program cycle. During the write cycle, the NM24Cxx bus interface circuits are disabled, SDA is allowed to remain high per the bus-level pull-up resistor, and the device does not respond to its slave address.

Bus Timing


TL/D/11099-4

## BACKGROUND INFORMATION (I2C Bus)

As mentioned, the $I^{2} \mathrm{C}$ bus allows synchronous bidirectional communication between transmitter/Receiver using the SCL (clock) and SDA (Data I/O) lines. All communication must be started with a valid START condition, concluded with a STOP condition and acknowledged by the Receiver with an ACKNOWLEDGE condition.
In addition, since the I2C bus is designed to support other devices such as RAM, EPROM, etc., the device type identifier string must follow the START condition. For EEPROMs, this 4-bit string is 1010 .
As shown below, the EEPROMS on the $I^{2} \mathrm{C}$ bus may be configured in any manner required, providing the total memory addressed does not exceed 16K ( 16,834 bits). EEPROM memory addressing is controlled by two methods:

- Hardware configuring the AO, A1 and A2 pins (Device Address pins) with pull-up or pull-down resistors. ALL UNUSED PINS MUST BE GROUNDED (Tied to VSS).
- Software addressing the required PAGE BLOCK within the device memory array (as sent in the Slave Address string).
Addressing an EEPROM memory location involves sending a command string with the following information:
[DEVICE TYPE]-[DEVICE ADDRESS]-[PAGE BLOCK
ADDRESS]-[BYTE ADDRESS]

|  | DEFINITIONS |
| :--- | :--- |
| WORD | 8 bits (byte) of data. |
| PAGE | 16 sequential addresses (one byte |
| each) that may be programmed |  |
| during a "Page Write" programming |  |
| cycle. |  |
| PAGE BLOCK | 2,048 (2K) bits organized into 16 |
| pages of addressable memory. |  |
|  | $(8$ bits) $\times(16$ bytes) $\times$ (16 pages) $=$ |
| 2,048 bits |  |
| Any I2C device CONTROLLING the |  |
| MASTER | transfer of data (such as a <br> microprocessor). |
|  | Device being controlled (EEPROMs <br> are always considered Slaves). |
| SLAVE | Device currently SENDING data on <br> the bus (may be either a Master OR |
| RECEIVER | Slave). <br> Device currently receiving data on <br> the bus (Master or Slave). |

## Example of 16K (Maximum Size) of Memory on 2-Wire Bus



TL/D/11099-20
Note: The SDA pull-up resistor is required due to the open-drain/open-collector output of ${ }^{2} \mathrm{C}$ bus devices.
Note: The SCL pull-up resistor is recommended because of the normal SCL line inactive "high" state.
Note: It is recommended that the total line capacitance be less than 400 pF .
Note: Specific timing and addressing considerations are described in greater detail in the following sections.

| Device | Address Pins |  |  | Memory Size | Number of <br> Page Blocks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | A0 | A1 | A2 |  | 1 |
| NM24C02 | DA | DA | DA | 2048 Bits | 2 |
| NM24C04 | $V_{S S}$ | DA | DA | 4096 Bits | 2 |
| NM24C08 | $V_{S S}$ | $V_{S S}$ | DA | 8192 Bits | 4 |
| NM24C16 | $V_{S S}$ | $V_{S S}$ | $V_{S S}$ | 16,384 Bits | 8 |

DA: Device Address

## Pin Descriptions

## SERIAL CLOCK (SCL)

The SCL input is used to clock all data into and out of the device.

SERIAL DATA (SDA)
SDA is a bidirectional pin used to transfer data into and out of the device. It is an open drain output and may be wireORed with any number of open drain or open collector outputs.

DEVICE ADDRESS INPUTS (A0, A1, A2)
Device address pins A0, A1 and A2 are connected to $V_{C C}$ or $V_{S S}$ to configure the EEPROM address. The following table (Table A) shows the active pins across the NM24Cxx device family.

TABLE A

| Device | A0 | A1 | A2 | Effects of Addresses |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| NM24C02 | ADR | ADR | ADR | $2^{3}=8$ | $(8) \times(2 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C04 | $X$ | ADR | ADR | $2^{2}=4$ | $(4) \times(4 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C08 | $X$ | $X$ | ADR | $2^{1}=2$ | $(2) \times(8 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C16 | $X$ | $X$ | $X$ | $2^{2}=1$ | $(1) \times(16 \mathrm{~K})=16 \mathrm{~K}$ |

ADR: Denotes an active pin used for device addressing
X : Not used for addressing (Must be tied to Ground/ $\mathrm{V}_{\mathrm{SS}}$ )

## Device Operation

The NM24Cxx supports a bidirectional bus oriented protocol. The protocol defines any device that sends data onto the bus as a transmitter and the receiving device as the receiver. The device controlling the transfer is the master and the device that is controlled is the slave. The master will always initiate data transfers and provide the clock for both transmit and receive operations. Therefore, the NM24Cxx will be considered a slave in all applications.

## CLOCK AND DATA CONVENTIONS

Data states on the SDA line can change only during SCL LOW. SDA state changes during SCL HIGH are reserved for indicating start and stop conditions. Refer to Figures 1 and 2.

## START CONDITION

All commands are preceded by the start condition, which is a HIGH to LOW transition of SDA when SCL is HIGH. The NM24Cxx continuously monitors the SDA and SCL lines for the start condition and will not respond to any command until this condition has been met.

## STOP CONDITION

All communications are terminated by a stop condition, which is a LOW to HIGH transition of SDA when SCL is HIGH. The stop condition is also used by the NM24Cxx to place the device in the standby power mode.

## Write Cycle Timing



FIGURE 1. Data Validity
TL/D/11099-6


FIGURE 2. Definition of Start and Stop


FIGURE 3. Acknowledge Response from Receiver

## ACKNOWLEDGE

Acknowledge is a software convention used to indicate successful data transfers. The transmitting device, either master or slave, will release the bus after transmitting eight bits. During the ninth clock cycle the receiver will pull the SDA line LOW to acknowledge that it received the eight bits of data. Refer to Figure 3.
The NM24Cxx device will always respond with an acknowledge after recognition of a start condition and its slave address. If both the device and a write operation have been
selected, the NM24Cxx will respond with an acknowledge after the receipt of each subsequent eight bit word.
In the read mode the NM24Cxx slave will transmit eight bits of data, release the SDA line and monitor the line for an acknowledge. If an acknowledge is detected and no stop condition is generated by the master, the slave will continue to transmit data. If an acknowledge is not detected, the slave will terminate further data transmissions and await the stop condition to return to the standby power mode.

## Device Addressing

Following a start condition the master must output the address of the slave it is accessing. The most significant four bits of the slave address are those of the device type identifier (see Figure 4). This is fixed as 1010 for all four devices: NM24C02, NM24C04, NM24C08 and NM24C16.


TL/D/11099-17


TL/D/11099-9

(LSB)

BLOCK ADDRESS
TL/D/11099-18


## DEVICE ADDRESSING

Refer to the following table for Slave Addresss string details:

| Device | A0 | A1 | A2 | Number of <br> Page Blocks | Page Block Addresses |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NM24C02 | A | A | A | 1 | $(2 K)$ | (NONE) |  |  |  |
| NM24C04 | P | A | A | 2 | $(4 \mathrm{~K})$ | 0 | 1 |  |  |
| NM24C08 | P | P | A | 4 | $(8 \mathrm{~K})$ | 00 | 01 | 10 | 11 |
| NM24C16 | P | P | P | 8 | $(16 \mathrm{~K})$ | 000001010 | 011 |  |  |

A: Refers to a hardware configured Device Address pin P: Refers to an internal PAGE BLOCK memory segment

All $1^{2} \mathrm{C}$ EEPROMs use an internal protocol that defines a PAGE BLOCK size of 2 K bits (for Word addresses 0000 through 1111). Therefore, address bits A0, A1 or A2 (if designated "P") are used to access a PAGE BLOCK in conjunction with the Word address used to access any individual data byte (Word).
The last bit of the slave address defines whether a write or read condition is requested by the master. A " 1 " indicates that a read operation is to be executed, and a " 0 " initiates the write mode.
A simple review: After the NM24C02/C04/C08/C16 recognizes the start condition, the devices interfaced to the I ${ }^{2} \mathrm{C}$ bus wait for a slave address to be transmitted over the SDA line. If the transmitted slave address matches an address of one of the devices, the designated slave pulls the line LOW with an acknowledge signal and awaits further transmissions.

## Write Operations

## BYTE WRITE

For a write operation a second address field is required which is a word address that is comprised of eight bits and provides access to any one of the 256 words in the selected page of memory. Upon receipt of the word address the NM24Cxx responds with an acknowledge and waits for the next eight bits of data, again, responding with an acknowledge. The master then terminates the transfer by generating a stop condition, at which time the NM24Cxx begins the internal write cycle to the nonvolatile memory. While the internal write cycle is in progress the NM24Cxx inputs are disabled, and the device will not respond to any requests from the master. Refer to Figure 5 for the address, acknowledge and data transfer sequence.

## PAGE WRITE

The NM24Cxx is capable of a sixteen byte page write operation. It is initiated in the same manner as the byte write operation; but instead of terminating the write cycle after the first data word is tranferred, the master can transmit up to fifteen more words. After the receipt of each word, the NM24Cxx will respond with an acknowledge.

After the receipt of each word, the internal address counter increments to the next address and the next SDA data is accepted. If the master should transmit more than sixteen words prior to generating the stop condition, the address counter will "roll over" and the previously written data will be overwritten. As with the byte write operation, all inputs are disabled until completion of the internal write cycle. Refer to Figure 6 for the address, acknowledge and data transfer sequence.

## ACKNOWLEDGE POLLING

Once the stop condition is issued to indicate the end of the host's write operation the NM24Cxx initiates the internal write cycle. ACK polling can be initiated immediately. This involves issuing the start condition followed by the slave address for a write operation. If the NM24Cxx is still busy with the write operation no ACK will be returned. If the NM24Cxx has completed the write operation an ACK will be returned and the host can then proceed with the next read or write operation.


FIGURE 5. Byte Write

FIGURE 6. Page Write

## Read Operations

Read operations are initiated in the same manner as write operations, with the exception that the $\mathrm{R} / \overline{\mathrm{W}}$ bit of the slave address is set to a one. There are three basic read operations: current address read, random read and sequential read.

## CURRENT ADDRESS READ

Internally the NM24Cxx contains an address counter that maintains the address of the last word accessed, incremented by one. Therefore, if the last access (either a read or write) was to address $n$, the next read operation would access data from address $n+1$. Upon receipt of the slave address with $R / \bar{W}$ set to one, the NM24Cxx issues an acknowledge and transmits the eight bit word. The master will not acknowledge the transfer but does generate a stop condition, and therefore the NM24Cxx discontinues tranmission. Refer to Figure 7 for the sequence of address, acknowledge and data transfer.

## RANDOM READ

Random read operations allow the master to access any memory location in a random manner. Prior to issuing the slave address with the R/W bit set to one, the master must first perform a "dummy" write operation. The master issues the start condition, slave address and then the word ad-
dress it is to read. After the word address acknowledge, the master immediately reissues the start condition and the slave address with the $R / \bar{W}$ bit set to one. This will be followed by an acknowledge from the NM24Cxx and then by the eight bit word. The master will not acknowledge the transfer but does generate the stop condition, and therefore the NM24Cxx discontinues transmission. Refer to Figure 8 for the address, acknowledge and data transfer sequence.

## SEQUENTIAL READ

Sequential reads can be initiated as either a current address read or random access read. The first word is transmitted in the same manner as the other read modes; however, the master now responds with an acknowledge, indicating it requires additional data. The NM24Cxx continues to output data for each acknowledge received. The read operation is terminated by the master not responding with an acknowledge or by generating a stop condition.
The data output is sequential, with the data from address $n$ followed by the data from $n+1$. The address counter for read operations increments all word address bits, allowing the entire memory contents to be serially read during one operation. After the entire memory has been read, the counter "rolls over" and the NM24Cxx continues to output data for each acknowledge received. Refer to Figure 9 for the address, acknowledge and data transfer sequence.

Read Operations (Continued)


TL/D/11099-15
FIGURE 10. Typical System Configuration
Note: Due to open drain configuration of SDA, a bus-level pull-up resistor is called for, (typical value $=4.7 \mathrm{k} \Omega$ )

## NM24C03/C05/C09/C17

2K-/4K-/8K-/16K-Bit Serial EEPROM with Write Protect (I2C Synchronous 2-Wire Bus)

## General Description

The NM24C03/C05/C09/C17 devices are 2048/4096/ 8192/16,834 bits, respectively, of CMOS non-volatile electrically erasable memory. These devices conform to all specifications in the I2C 2-wire protocol, and are designed to minimize device pin count and simplify PC board layout requirements.
The upper half of the memory can be disabled (Write Protected) by connecting the WP pin to $\mathrm{V}_{\mathrm{Cc}}$. This section of memory then becomes ROM.
This communication protocol uses CLOCK (SCL) and DATA I/O (SDA) lines to synchronously clock data between the master (for example a microprocessor) and the slave EEP. ROM device(s). In addition, this bus structure allows for a maximum of 16 K of EEPROM memory. This is supported by the NSC family in $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$ and 16 K devices, allowing the user to configure the memory as the application requires with any combination of EEPROMs (not to exceed 16K).
National EEPROMs are designed and tested for applications requiring high endurance, high reliability, and low power consumption.

## Features

■ Hardwire write protect for upper block

- Low Power CMOS
- 2 mA active current typical
$-60 \mu \mathrm{~A}$ standby current typical
- 2-wire ${ }^{2} \mathrm{C}$ serial interface
- Provides bidirectional data transfer protocol
- Sixteen byte page write mode
- Minimizes total write time per byte
- Self timed write cycle
- Typical write cycle time of 5 ms

■ Endurance: $10^{6}$ data changes

- Data retention greater than 40 years
- Packages available: 8 pin mini-DIP or 14 pin SO package


## Functional Diagram



Connection Diagrams

| Dual－In－Line Package（ N ） | Pin Names |  |
| :---: | :---: | :---: |
| T | A0，A1，A2 | Device Address Inputs |
|  | $V_{S S}$ | Ground |
| $\begin{aligned} & 24 \mathrm{CO3} \\ & 24 \mathrm{CO5} \end{aligned}$ | SDA | Data I／O |
| 24 cog | SCL | Clock Input |
|  | $V_{C C}$ | ＋5V |
| Top View | WP | Write Protect |
| See NS Package Number N08E | NC | No Connection |



See NS Package Number M14B

## Ordering Information

Commercial Temperature Range（ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ）

| Order Number |
| :---: |
| NM24C03N／NM24C05N／NM24C09N／NM24C17N |
| NM24C03M／NM24C05M／NM24C09M／NM24C17M |

Extended Temperature Range（ $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ）

| Extended Temperature Range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ |
| :---: |
| Order Number |
| NM24C03EN／NM24C05EN／NM24C09EN／NM24C17EN |
| NM24C03EM／NM24C05EM／NM24C09EM／NM24C17EM |

Military Temperature Range（ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ）

| Order Number |
| :---: |
| NM24C03MN／NM24C05MN／NM24C09MN／NM24C17MN |
| NM24C03MM／NM24C05MM／NM24C09MM／NM24C17MM |

## Absolute Maximum Ratings

If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

| Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| All Input or Output Voltages |  |
| with Respect to Ground | +6.5 V to -0.3 V |
| Lead Temperature | $+300^{\circ} \mathrm{C}$ |
| (Soldering, 10 sec.) | 2000 V |
| ESD Rating |  |

## Operating Conditions

Ambient Operating Temperature NM24C03/C05/C09/C17
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
NM24C03E/C05E/C09E/C17E NM24C03M/C05M/C09M/C17M (Mil. Temp.)
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
4.5 V to 5.5 V

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ (unless otherwise specified)

| Symbol | Parameter | Test Conditions | Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ. <br> (Note 1) | Max |  |
| l CCA | Active Power Supply Current | $\mathrm{fSCL}=100 \mathrm{kHz}$ |  | 2.0 | 3.0 | mA |
| $\mathrm{I}_{\text {SB }}$ | Standby Current | $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ or $\mathrm{V}_{\text {CC }}$ |  | 60 | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{1}$ | Input Leakage Current | $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ to $\mathrm{V}_{\text {CC }}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ to $\mathrm{V}_{\text {CC }}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.3 |  | $\mathrm{V}_{\text {cC }} \times 0.3$ | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | $\mathrm{V}_{\text {CC }} \times 0.7$ |  | $V_{C C}+0.5$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=3 \mathrm{~mA}$ |  |  | 0.4 | V |

Capacitance $T_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$

| Symbol | Test | Conditions | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ (Note 2) | Input/Output Capacitance (SDA) | $\mathrm{V}_{I / O}=0 \mathrm{~V}$ | 8 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ (Note 2) | Input Capacitance $\left(\mathrm{A}_{0}, \mathrm{~A}_{1}, \mathrm{~A}_{2}, \mathrm{SCL}, \mathrm{WP}\right)$ | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ | 6 | pF |

## A.C. Conditions of Test

| Input Pulse Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.1$ to $\mathrm{V}_{\mathrm{CC}} \times 0.9$ |
| :--- | :---: |
| Input Rise and <br> Fall Times | 10 ns |
| Input and Output <br> Timing Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.5$ |
| Output Load | 1 TTL Gate and <br> $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |

Note 1: Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage ( 5 V ). Note 2: This parameter is periodically sampled and not $100 \%$ tested.

## Lเכ／60う／G0つ／E0つもZWN

Read and Write Cycle Limits

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| fSCL | SCL Clock Frequency |  | 100 | kHz |
| TI | Noise Suppression Time Constant at SCL，SDA Inputs |  | 100 | ns |
| $t_{\text {AA }}$ | SCL Low to SDA Data Out Valid | 0.3 | 3.5 | $\mu \mathrm{s}$ |
| $t_{\text {BUF }}$ | Time the Bus Must Be Free before a New Transmission Can Start | 4.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {HD：}}$ STA | Start Condition Hold Time | 4.0 |  | $\mu \mathrm{s}$ |
| tLow | Clock Low Period | 4.7 |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {HIGH }}$ | Clock High Period | 4.0 |  | $\mu \mathrm{s}$ |
| tsu：STA | Start Condition Setup Time （for a Repeated Start Condition） | 4.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {HD：}}$ DAT | Data in Hold Time | 0 |  | $\mu \mathrm{s}$ |
| tsu：DAT | Data in Setup Time | 250 |  | ns |
| $t_{R}$ | SDA and SCL Rise Time |  | 1 | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{F}}$ | SDA and SCL Fall Time |  | 300 | ns |
| tsu：Sto | Stop Condition Setup Time | 4.7 |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Out Hold Time | 300 |  | ns |
| $\mathrm{t}_{\text {WR }}$（Note 3） | Write Cycle Time |  | 10 | ms |

Note 3：The write cycle time（ ${ }_{W R}$ ）is the time from a valid stop condition of a write sequence to the end ot the internal erase／program cycle．During the write cycle， the NM24Cxx bus interface circuits are disabled，SDA is allowed to remain high per the bus－level pull－up resistor，and the device does not respond to its slave address．

## Bus Timing



## BACKGROUND INFORMATION (I2C Bus)

As mentioned, the $I^{2} \mathrm{C}$ bus allows synchronous bidirectional communication between Transmitter/Receiver using the SCL (clock) and SDA (Data I/O) lines. All communication must be started with a valid START condition, concluded with a STOP condition and acknowledged by the Receiver with an ACKNOWLEDGE condition.
In additon, since the $I^{2} \mathrm{C}$ bus is designed to support other devices such as RAM, EPROM, etc., the device type identifier string must follow the START condition. For EEPROMs, this 4-bit string is 1010 .
As shown below, the EEPROMs on the I ${ }^{2} \mathrm{C}$ bus may be configured in any manner required, providing the total memory addressed does not exceed 16K (16,834 bits). EEPROM memory addressing is controlled by two methods:

- Hardware configuring the A0, A1 and A2 pins (Device Address pins) with pull-up or pull-down resistors. ALL UNUSED PINS MUST BE GROUNDED (tied to $\mathrm{V}_{S S}$ ).
- Software addressing the required PAGE BLOCK within the device memory array (as sent in the Slave Address string)
Addressing an EEPROM memory location involves sending a command string with the following information:
[DEVICE TYPE]-[DEVICE ADDRESS]-[PAGE BLOCK AD-DRESS]-[BYTE ADDRESS]

| DEFINITIONS |  |
| :--- | :--- |
| WORD | 8 bits (byte) of data. <br> PAGE <br> 16 sequential addresses (one byte <br> each) that may be programmed <br> during a "Page Write" programming <br> cycle. |
| PAGE BLOCK | 2,048 (2K) bits organized into 16 <br> pages of addressable memory. <br> (8 bits) $\times$ (16 bytes) $\times$ (16 pages) $=$ <br> 2,048 bits |
| MASTER | Any I2C device CONTROLLING the <br> transfer of data (such as a <br> microprocessor). |
| SLAVE | Device being controlled (EEPROMs <br> are always considered Slaves). |
| TRANSMITTER | Device currently SENDING data on <br> the bus (may be either a Master OR |
|  | Slave). <br> Device currently receiving data on <br> the bus (Master or Slave). |

Example of 16k (Maximum Size) of Memory on 2-Wire Bus


TL/D/11100-20
Note:
The SDA pull-up resistor is required due to the open-drain/open-collector output of ${ }^{2} \mathrm{C}$ bus devices.
The SCL pull-up resistor is recommended because of the normal SCL line inactive "high" state.
It is recommended that the total line capacitance be less than 400 pF .
Specific timing and addressing considerations are described in greater detail in the following sections.

| Device | Address Pins |  |  | Memory Slze | Number of <br> Page Blocks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | A0 | A1 | A2 |  | 1 |
| NM24C03 | DA | DA | DA | 2048 Bits | 2 |
| NM24C05 | $V_{S S}$ | DA | DA | 4096 Bits | 2 |
| NM24C09 | $V_{S S}$ | $V_{S S}$ | DA | 8192 Bits | 4 |
| NM24C17 | $V_{S S}$ | $V_{S S}$ | $V_{S S}$ | 16,384 Bits | 8 |

DA: Device Address

## Pin Descriptions

## SERIAL CLOCK (SCL)

The SCL input is used to clock all data into and out of the device.

## SERIAL DATA (SDA)

SDA is a bidirectional pin used to transfer data into and out of the device. It is an open drain output and may be wireORed with any number of open drain or open collector outputs.

## DEVICE ADDRESS INPUTS (AO, A1, A2)

Device address pins $A 0, A 1$ and $A 2$ are connected to $V_{C C}$ or $V_{S S}$ to configure the EEPROM address. The following table (Table A) shows the active pins across the NM24Cxx device family.

TABLE A

| Device | A0 | A1 | A2 | Effects of Addresses |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| NM24C02 | ADR | ADR | ADR | $2^{3}=8$ | $(8) \times(2 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C04 | $X$ | ADR | ADR | $2^{2}=4$ | $(4) \times(4 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C08 | $X$ | $X$ | ADR | $2^{1}=2$ | $(2) \times(8 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C16 | $X$ | $X$ | $X$ | $2^{0}=1$ | $(1) \times(16 \mathrm{~K})=16 \mathrm{~K}$ |

ADR: Denotes an active pin used for device addressing
X : Not used for addressing (must be tied to Ground/ $\mathrm{V}_{\mathrm{SS}}$ )

## WP WRITE PROTECTION

If tied to $\mathrm{V}_{\mathrm{CC}}$, PROGRAM operations onto the upper half of the memory will not be executed. READ operations are possible.

If tied to $\mathrm{V}_{\mathrm{SS}}$, normal memory operation is enabled, READ/ WRITE over the entire memory is possible.
This feature allows the user to assign the upper half of the memory as ROM which can be protected against accidental programming. When write is disabled, slave address and word address will be acknowledged but data will not be acknowledged.

## Device Operation

The NM24C03/C05/C09/C17 supports a bidirectional bus oriented protocol. The protocol defines any device that sends data onto the bus as a transmitter and the receiving device as the receiver. The device controlling the transfer is the master and the device that is controlled is the slave. The master will always initiate data transfers and provide the clock for both transmit and receive operations. Therefore, the NM24Cxx is considered a slave in all applications.

## CLOCK AND DATA CONVENTIONS

Data states on the SDA line can change only during SCL LOW. SDA state changes during SCL HIGH are reserved for indicating start and stop conditions. Refer to Figures 1 and 2.

## START CONDITION

All commands are preceded by the start condition, which is a HIGH to LOW transition of SDA when SCL is HIGH. The NM24Cxx continuously monitors the SDA and SCL lines for the start condition and will not respond to any command until this condition has been met.

## Write Cycle Timing



FIGURE 1. Data Validity


TL/D/11100-7
FIGURE 2. Definition of Start and Stop


## STOP CONDITION

All communications are terminated by a stop condition, which is a LOW to HIGH transition of SDA when SCL is HIGH. The stop condition is also used by the NM24Cxx to place the device in the standby power mode.

## ACKNOWLEDGE

Acknowledge is a software convention used to indicate successful data transfers. The transmitting device, either master or slave, will release the bus after transmitting eight bits. During the ninth clock cycle the receiver will pull the SDA line LOW to acknowledge that it received the eight bits of data. Refer to Figure 3.
The NM24Cxx device will always respond with an acknowledge after recognition of a start condition and its slave address. If both the device and a write operation have been selected, the NM24Cxx will respond with an acknowledge after the receipt of each subsequent eight bit word.
In the read mode the NM24Cxx slave will transmit eight bits of data, release the SDA line and monitor the line for an acknowledge. If an acknowledge is detected and no stop condition is generated by the master, the slave will continue to transmit data. If an acknowledge is not detected, the slave will terminate further data transmissions and await the stop condition to return to the standby power mode.

## Device Addressing

Following a start condition the master must output the address of the slave it is accessing. The most significant four bits of the slave address are those of the device type identifier, (see Figure 4). This is fixed as 1010 for all four devices: NM24C03, NM24C05, NM24C09 and NM24C17.


FIGURE 4. Slave Addresses

## Device Addressing (Continued)

Refer to the following table for Slave Address string details:


A: Refers to a hardware configured Device Address pin
P: Refers to an internal PAGE BLOCK memory segment

All ${ }^{2} \mathrm{C}$ EEPROMs use an internal protocol that defines a PAGE BLOCK size of 2 K bits (for Word addresses 0000 through 1111). Therefore, address bits A0, A1 or A2 (if designated " $P$ ") are used to access a PAGE BLOCK in conjunction with the Word address used to access any individual data byte (Word).
The last bit of the slave address defines whether a write or read condition is requested by the master. A " 1 " indicates that a read operation is to be executed and a " 0 " initiates the write mode.
A simple review: After the NM24C03/C05/C09/C17 recognizes the start condition, the devices interfaced to the I2C bus wait for a slave address to be transmitted over the SDA line. If the transmitted slave address matches an address of one of the devices, the designated slave pulls the line LOW with an acknowledge signal and awaits further transmissions.

## Write Operations

## BYTE WRITE

For a write operation a second address field is required which is a word address that is comprised of eight bits and provides access to any one of the 256 words in the selected page of memory. Upon receipt of the word address the NM24Cxx responds with an acknowledge and waits for the next eight bits of data, again, responding with an acknowledge. The master then terminates the transfer by generating a stop condition, at which time the NM24Cxx begins the internal write cycle to the nonvolatile memory. While the internal write cycle is in progress the NM24Cxx inputs are disabled, and the device will not respond to any requests from the master. Refer to Figure 5 for the address, acknowledge and data transfer sequence.


TL/D/11100-10

FIGURE 5. Byte Write

## Write Operations (Continued)

## PAGE WRITE

The NM24Cxx is capable of a sixteen byte page write operation. It is initiated in the same manner as the byte write operation; but instead of terminating the write cycle after the first data word is tranferred, the master can transmit up to fifteen more words. After the receipt of each word, the NM24Cxx will respond with an acknowledge.
After the receipt of each word, the internal address counter increments to the next address and the next SDA data is accepted. If the master should transmit more than sixteen words prior to generating the stop condition, the address counter will "roll over" and the previously written data will be overwritten. As with the byte write operation, all inputs are disabled until completion of the internal write cycle. Refer to Figure 6 for the address, acknowledge and data transfer sequence.

## ACKNOWLEDGE POLLING

Once the stop condition is issued to indicate the end of the host's write operation, the NM24Cxx initiates the internal write cycle. ACK polling can be initiated immediately. This involves issuing the start condition followed by the slave address for a write operation. If the NM24Cxx is still busy with the write operation, no ACK will be returned. If the NM24Cxx has completed the write operation, an ACK will be returned and the host can then proceed with the next read or write operation.

## WRITE PROTECTION

Programming of the upper half of the memory will not take place if the WP pin of the NM24Cxx is connected to $\mathrm{V}_{\mathrm{CC}}$ $(+5 \mathrm{~V})$. The NM24Cxx will accept slave and word addresses; but if the memory accessed is write protected by the WP pin, the NM24Cxx will not generate an acknowledge after the first byte of data has been received, and thus the program cycle will not be started when the stop condition is asserted.

## Read Operations

Read operations are initiated in the same manner as write operations, with the exception that the R/W bit of the slave address is set to a one. There are three basic read operations: current address read, random read and sequential read.

## CURRENT ADDRESS READ

Internally the NM24Cxx contains an address counter that maintains the address of the last word accessed, incremented by one. Therefore, if the last access (either a read or write) was to address $n$, the next read operation would access data from address $n+1$. Upon receipt of the slave address with $R / \bar{W}$ set to one, the NM24Cxx issues an acknowledge and transmits the eight bit word. The master will not acknowledge the transfer but does generate a stop condition, and therefore the NM24Cxx discontinues tranmission. Refer to Figure 7 for the sequence of address, acknowledge and data transfer.

## RANDOM READ

Random read operations allow the master to access any memory location in a random manner. Prior to issuing the slave address with the R/ $\bar{W}$ bit set to one, the master must first perform a "dummy" write operation. The master issues a start condition, slave address and then the word address it is to read. After the word address acknowledge, the master immediately reissues the start condition and the slave address with the $R / \bar{W}$ bit set to one. This will be followed by an acknowledge from the NM24Cxx and then by the eight bit word. The master will not acknowledge the transfer but does generate the stop condition, and therefore the NM24Cxx discontinues transmission. Reter to Figure 8 for the address, acknowledge and data transfer sequence.


FIGURE 6. Page Write


TL/D/11100-12
FIGURE 7. Current Address Read

## Read Operations（Continued）

SEQUENTIAL READ
Sequential reads can be initiated as either a current address read or random access read．The first word is transmitted in the same manner as the other read modes；however，the master now responds with an acknowledge，indicating it re－ quires additional data．The NM24Cxx continues to output data for each acknowledge received．The read operation is terminated by the master not responding with an acknowl－ edge or by generating a stop condition．

The data output is sequential，with the data from address $n$ followed by the data from $\mathrm{n}+1$ ．The address counter for read operations increments all word address bits，allowing the entire memory contents to be serially read during one operation．After the entire memory has been read，the coun－ ter＂rolls over＂and the NM24Cxx continues to output data for each acknowledge received．Refer to Figure 9 for the address，acknowledge and data transfer sequence．


FIGURE 8．Random Read


FIGURE 9．Sequential Read


TL／D／11100－15
FIGURE 10．Typical System Configuration

National Semiconductor

NM24C02L／C04L
2K－／4K－Bit Serial EEPROM with Extended Voltage （ ${ }^{2}{ }^{2}$ C Synchronous 2－Wire Bus）

## General Description

The NM24C02L／O4L devices are 2048／4096 bits，respec－ tively，of CMOS non－volatile electrically erasable memory． These devices conform to all specifications in the $1^{2} \mathrm{C} 2$－wire protocol and are designed to minimize device pin count and simplify PC board layout requirements．National EEPROMs are designed and tested for applications requiring high reli－ ability，high endurance and low power consumption．
These devices have an operating voltage range of 2.5 V to 5.5 V and are offered in an 8 －pin small outline（SO）package， making these devices perfectly suited for low power applica－ tions that require minimal board space usage．
This communication protocol uses CLOCK（SCL）and DATA I／O（SDA）lines to synchronously clock data between the master（for example a microprocessor）and the slave EEP－ ROM device（s）．In addition，this bus structure allows for a maximum of 16 K of EEPROM memory．This is supported by the NSC family in $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$ and 16 K devices，allowing the
user to configure the memory as the application requires with any combination of EEPROMs（not to exceed 16K）．

## Features

－Extended operating voltage， $2.5 \mathrm{~V}-5.5 \mathrm{~V}$
－Low Power CMOS
－ 2 mA active current typical
$-60 \mu \mathrm{~A}$ standby current typical
－2－wire $\mathrm{I}^{2} \mathrm{C}$ serial interface
－Provides bidirectional data transier protocol
－Sixteen byte page write mode
－Minimizes total write time per byte
－Self timed write cycle
－Typical write cycle time of 5 ms
m Endurance： $10^{6}$ data changes
－Data retention greater than 40 years
－Packages available： 8 pin mini－DIP or 8 pin SO package

## Functional Diagram



## Connection Diagrams

| Dual-In-Line Package ( N ) and SO Package (M8) | Pin Names |  |
| :---: | :---: | :---: |
|  | A0, A1, A2 | Device Address Inputs |
| -1 ${ }^{\text {c }}$ | VSS | Ground |
| $1-2{ }^{2}$ NM24CO2L ${ }^{7}$-NC | SDA | Data 1/O |
| $\begin{array}{l\|l} \text { NM24CO4L } & 6 \\ \hline \end{array}$ | SCL | Clock Input |
| $5-5 D A$ | NC | No Connection |
| Top View | $V_{\text {cc }}$ | $+5 \mathrm{~V}$ |

See NS Package Number M08A (M8) and N08E (N)

## Ordering Information

Commercial Temperature Range $\left(0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM24CO2LN/NM24C04LN |
| NM24CO2LM/NM24C04LM |

Extended Temperature Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM24C02LEN/NM24C04LEN |
| NM24C02LEM/NM24C04LEM |

## LOW VOLTAGE ( $2.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{Cc}}<4.5 \mathrm{~V}$ ) SPECIFICATIONS

Absolute Maximum Ratings

| If Military/Aerospace specified devices are required, |  |
| :--- | ---: |
| please contact the National Semiconductor Sales |  |
| Office/Distributors for availability and specifications. |  |
| Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| $\begin{array}{l}\text { All Input or Output Voltages } \\ \text { with Respect to Ground } \\ \text { Lead Temperature } \\ \text { (Soldering, } 10 \text { seconds) } \\ \text { ESD Rating }\end{array}+6.5 \mathrm{~V}$ to -0.3 V |  |

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=2.5 \mathrm{~V}$ to 4.5 V (unless otherwise specified)

| Symbol | Parameter | Test Conditions | Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min |  | Max |  |
| ICCA | Active Power Supply Current | $\mathrm{f}_{\text {SCL }}=100 \mathrm{kHz}$ |  | 2.0 | 3.0 | mA |
| $\mathrm{I}_{\text {SB }}$ | Standby Current | $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ or $\mathrm{V}_{\text {CC }}$ |  | 60 | 100 | $\mu \mathrm{A}$ |
| $\mathrm{t}_{\mathbf{L}}$ | Input Leakage Current | $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ to $\mathrm{V}_{\text {CC }}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $V_{\text {OUT }}=$ GND to $V_{\text {CC }}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.3 |  | $V_{C C} \times 0.3$ | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | $\mathrm{V}_{\mathrm{CC}} \times 0.7$ |  | $V_{C C}+0.5$ | V |
| V OL | Output Low Voltage | $1 \mathrm{OL}=200 \mu \mathrm{~A}$ |  |  | 0.4 | V |

## Capacitance $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$

| Symbol | Test | Conditions | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I / O}$ (Note 2) | Input/Output Capacitance (SDA) | $\mathrm{V}_{I / O}=0 \mathrm{~V}$ | 8 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ (Note 2) | Input Capacitance (AO, A1, A2, SCL, WP) | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ | 6 | pF |

## AC Conditions of Test

| Input Pulse Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.1$ to $\mathrm{V}_{\mathrm{CC}} \times 0.9$ |
| :--- | :---: |
| Input Rise and <br> Fall Times | 10 ns |
| Input and Output |  |
| Timing Levels |  |$\quad \mathrm{V}_{\mathrm{CC}} \times 0.5$.

Note 1: Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage ( 5 V ).
Note 2: This parameter is periodically sampled and not $100 \%$ tested.

LOW VOLTAGE ( $2.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V}$ ) SPECIFICATIONS
Read and Write Cycle Limits

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| fSCL | SCL Clock Frequency |  | 80 | kHz |
| TI | Noise Suppression Time Constant at SCL., SDA Inputs |  | 100 | ns |
| $t_{\text {AA }}$ | SCL Low to SDA Data Out Valid | 0.3 | 7.0 | $\mu \mathrm{s}$ |
| $t_{\text {BUF }}$ | Time the Bus Must Be Free before a New Transmission Can Start | 6.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {HD }}$ STA | Start Condition Hold Time | 4.5 |  | $\mu \mathrm{S}$ |
| tLow | Clock Low Period | 6.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {HIGH }}$ | Clock High Period | 4.5 |  | $\mu \mathrm{S}$ |
| tsu:STA | Start Condition Setup Time (for a Repeated Start Condition) | 6.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {HD: }}$ DAT | Data in Hold Time | 0 |  | $\mu \mathrm{S}$ |
| ${ }^{\text {t SUU:DAT }}$ | Data in Setup Time | 500 |  | ns |
| $t_{R}$ | SDA and SCL Rise Time |  | 1 | $\mu \mathrm{s}$ |
| $t_{\text {f }}$ | SDA and SCL Fall Time |  | 300 | ns |
| tsu:STO | Stop Condition Setup Time | 6.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {DH }}$ | Data Out Hold Time | 300 |  | ns |
| twR (Note 3) | Write Cycle Time |  | 15 | ms |

Note 3: The write cycle time (twR) is the time from a valid stop condition of a write sequence to the end ot the internal erase/program cycle. During the write cycle, the NM24Cxx bus interface circuits are disabled, SDA is allowed to remain high per the bus-level pull-up resistor, and the device does not respond to its slave address.

## Bus Timing



TL/D/11272-19

## STANDARD VOLTAGE ( $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ ) SPECIFICATIONS

Absolute Maximum Ratings
If Milltary/Aerospace specifled devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Ambient Storage Temperature
All Input or Output Voltages
with Respect to Ground
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
+6.5 V to -0.3 V
Lead Temperature
(Soldering, 10 seconds)
ESD Rating

## Operating Conditions

Ambient Operating Temperature

> NM24C02L/C04L
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ NM24C02EL/C04EL
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Positive Power Supply ( $\mathrm{V}_{\mathrm{CC}}$ )

DC and AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V (unloss otherwis specifiea)

| Symbol | Parameter | Test Conditions | Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ (Note 1) | Max |  |
| ICCA | Active Power Supply Current | $\mathrm{f}_{\text {SCL }}=100 \mathrm{kHz}$ |  | 2.0 | 3.0 | mA |
| $I_{\text {SB }}$ | Standby Current | $\mathrm{V}_{\mathrm{IN}}=\mathrm{GND}$ or $\mathrm{V}_{\mathrm{CC}}$ |  | 60 | 100 | $\mu \mathrm{A}$ |
| ${ }_{\text {L }}$ | Input Leakage Current | $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{CC}}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| Lo | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=$ GND to $\mathrm{V}_{\text {CC }}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.3 |  | $\mathrm{V}_{\mathrm{CC}} \times 0.3$ | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | $\mathrm{V}_{\mathrm{CC}} \times 0.7$ |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{lOL}=3 \mathrm{~mA}$ |  |  | 0.4 | V |

Capacitance $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$

| Symbol | Test | Conditions | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I / O}$ (Note 2) | Input/Output Capacitance (SDA) | $\mathrm{V}_{I / O}=0 \mathrm{~V}$ | 8 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ (Note 2) | Input Capacitance (AO, A1, A2, SCL) | $\mathrm{V}_{I N}=0 \mathrm{~V}$ | 6 | pF |

## AC Conditions of Test

| Input Pulse Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.1$ to $\mathrm{V}_{\mathrm{CC}} \times 0.9$ |
| :--- | :---: |
| Input Rise and <br> Fall Times | 10 ns |
| Input and Output <br> Timing Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.5$ |
| Output Load | 1 TTL Gate and |
| $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |  |

Note 1: Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage ( 5 V ).
Note 2: This parameter is periodically sampled and not $100 \%$ tested.

STANDARD VOLTAGE ( $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ ) SPECIFICATIONS
Read and Write Cycle Limits

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\text {SCL }}$ | SCL Clock Frequency |  | 100 | kHz |
| TI | Noise Suppression Time Constant at SCL, SDA Inputs |  | 100 | ns |
| $t_{\text {AA }}$ | SCL Low to SDA Data Out Valid | 0.3 | 3.5 | $\mu \mathrm{s}$ |
| t ${ }_{\text {BUF }}$ | Time the Bus Must Be Free before a New Transmission Can Start | 4.7 |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{HD}}$ STA | Start Condition Hold Time | 4.0 |  | $\mu \mathrm{s}$ |
| tLOW | Clock Low Period | 4.7 |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{HIGH}}$ | Clock High Period | 4.0 |  | $\mu \mathrm{s}$ |
| tsu:STA | Start Condition Setup Time (for a Repeated Start Condition) | 4.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {HD: DAT }}$ | Data in Hold Time | 0 |  | $\mu \mathrm{S}$ |
| tSU:DAT | Data in Setup Time | 250 |  | ns |
| $t_{R}$ | SDA and SCL Rise Time |  | 1 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{F}}$ | SDA and SCL Fall Time |  | 300 | ns |
| tsu:sto | Stop Condition Setup Time | 4.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {DH }}$ | Data Out Hold Time | 300 |  | ns |
| $\mathrm{t}_{\text {WR }}$ (Note 3) | Write Cycle Time |  | 10 | ms |

Note 3: The write cycle time (twR) is the time from a valid stop condition of a write sequence to the end ot the internal erase/program cycle. During the write cycle, the NM24Cxx bus interface circuits are disabled, SDA is allowed to remain high per the bus-level pull-up resistor, and the device does not respond to its slave address.

## Bus Timing



## BACKGROUND INFORMATION (I2C Bus)

As mentioned, the $I^{2} \mathrm{C}$ bus allows synchronous bidirectional communication between Transmitter/Receiver using the SCL (clock) and SDA (Data I/O) lines. All communication must be started with a valid START condition, concluded with a STOP condition and acknowledged by the Receiver with an ACKNOWLEDGE condition.
In addition, since the ${ }^{2} \mathrm{C}$ bus is designed to support other devices such as RAM, EPROM, etc., the device type identifier string must follow the START condition. For EEPROMs, this 4-bit string is 1010.
As shown below, the EEPROMs on the $1^{2} \mathrm{C}$ bus may be configured in any manner required, providing the total memory addressed does not exceed 16K (16,834 bits). EEPROM memory addressing is controlled by two methods:

- Hardware configuring the A0, A1 and A2 pins (Device Address pins) with pull-up or pull-down resistors. ALL UNUSED PINS MUST BE GROUNDED (Tied to VSS).
- Software addressing the required PAGE BLOCK within the device memory array (as sent in the Slave Address string).
Addressing an EEPROM memory location involves sending a command string with the following information:
[DEVICE TYPE]-[DEVICE ADDRESS]-[PAGE BLOCK ADDRESS]-[BYTE ADDRESS]

| DEFINITIONS |  |
| :---: | :---: |
| WORD | 8 bits (byte) of data. |
| PAGE | 16 sequential addresses (one byte each) that may be programmed during a "Page Write" programming cycle. |
| PAGE BLOCK | 2,048 (2K) bits organized into 16 pages of addressable memory. <br> $(8$ bits) $\times(16$ bytes $) \times(16$ pages $)=$ 2,048 bits |
| MASTER | Any ${ }^{2}{ }^{2} \mathrm{C}$ device CONTROLLING the transfer of data (such as a microprocessor). |
| SLAVE | Device being controlled (EEPROMs are always considered Slaves). |
| TRANSMITTER | Device currently SENDING data on the bus (may be either a Master OR Slave). |
| RECEIVER | Device currently receiving data on the bus (Master or Slave). |

Note 1: The SDA puil-up resistor is required due to the open-drain/open-collector output of $I^{2} \mathrm{C}$ bus devices.
Note 2: The SCL pull-up resistor is recommended because of the normal SCL line inactive "high" state.
Note 3: It is recommended that the total line capacitance be less than 400 pF .
Note 4: Specific timing and addressing considerations are described in greater detail in the following sections.

| Device | Address Pins |  |  | Memory Size | Number of <br> Page Blocks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | A0 | A1 | A2 |  | 1 |
| NM24C02L | DA | DA | DA | 2048 Bits | 1 |
| NM24C04L | VSS | DA | DA | 4096 Bits | 2 |

DA: Device Address

## Pin Descriptions

## SERIAL CLOCK (SCL)

The SCL input is used to clock all data into and out of the device.

## SERIAL DATA (SDA)

SDA is a bidirectional pin used to transfer data into and out of the device. It is an open drain output and may be wireORed with any number of open drain or open collector outputs.

## DEVICE ADDRESS

INPUTS (A0, A1, A2)
Device address pins A0, A1 and A2 are connected to $V_{C C}$ or $\mathrm{V}_{\mathrm{SS}}$ to configure the EEPROM address. The following table (Table A) shows the active pins across the NM24Cxx device family.

TABLE A

| Device | A0 | A1 | A2 | Effects of Addresses |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| NM24C02 | ADR | ADR | ADR | $2^{3}=8$ | $(8) \times(2 K)=16 \mathrm{~K}$ |
| NM24C04 | $X$ | ADR | ADR | $2^{2}=4$ | $(4) \times(4 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C08 | $X$ | $X$ | ADR | $2^{1}=2$ | $(2) \times(8 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C16 | $X$ | $X$ | $X$ | $2^{0}=1$ | $(1) \times(16 \mathrm{~K})=16 \mathrm{~K}$ |

ADR: Denotes an active pin used for device addressing $X$ : Not used for addressing (must be tied to Ground/ $V_{S S}$ )

## Device Operation

The NM24C02L/C04L supports a bidirectional bus oriented protocol. The protocol defines any device that sends data onto the bus as a transmitter and the receiving device as the receiver. The device controlling the transfer is the master and the device that is controlled is the slave. The master will always initiate data transfers, and provide the clock for both transmit and receive operations. Therefore, the NM24C02L/C04L will be considered a slave in all applications.

## CLOCK AND DATA CONVENTIONS

Data states on the SDA line can change only during SCL LOW. SDA state changes during SCL HIGH are reserved for indicating start and stop conditions. Refer to Figures 1 and 2.

## START CONDITION

All commands are preceded by the start condition, which is a HIGH to LOW transition of SDA when SCL is HIGH. The NM24CxxL continuously monitors the SDA and SCL lines for the start condition and will not respond to any command until this condition has been met.

## STOP CONDITION

All communications are terminated by a stop condition, which is a LOW to HIGH transition of SDA when SCL is HIGH. The stop condition is also used by the NM24Cxx to place the device in the standby power mode.

## Write Cycle Timing



FIGURE 1. Data Validity


TL/D/11272-6
FIGURE 2. Definition of Start and Stop


## ACKNOWLEDGE

Acknowledge is a software convention used to indicate successful data transfers. The transmitting device, either master or slave, will release the bus after transmitting eight bits. During the ninth clock cycle the receiver will pull the SDA line LOW to acknowledge that it received the eight bits of data. Refer to Figure 3.
The NM24CxxL will always respond with an acknowledge after recognition of a start condition and its slave address. If both the device and a write operation have been selected, the NM24CxxL will respond with an acknowledge after the receipt of each subsequent eight bit word.
In the read mode the NM24CxxL will transmit eight bits of data, release the SDA line and monitor the line for an acknowledge. If an acknowledge is detected and no stop condition is generated by the master, the slave will continue to transmit data. If an acknowledge is not detected, the slave will terminate further data transmissions and await the stop condition to return to the standby power mode.

## Device Addressing

Following a start condition the master must output the address of the slave it is accessing. The most significant four bits of the slave address are those of the device type identifier, (see Figure 4). This is fixed as 1010 for both devices: NM24C02L and NM24C04L.


TL/D/11272-8


FIGURE 4. Slave Addresses

Refer to the following table for Slave Address string details:

| Device | A0 | A1 | A2 | Number of Page Blocks |  | age B | ock A | Addresses |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NM24C02 | A | A | A | 1 (2K) | (NONE) |  |  |  |
| NM24C04 | P | A | A | 2 (4K) | 0 | 1 |  |  |
| NM24C08 | P | P | A | 4 (8K) | 00 | 01 | 10 | 11 |
| NM24C02 | P | P | P | 8 (16K) | 000 | 001 | 010 | 011 ... 111 |

A: Refers to a hardware configured Device Address pin
P: Refers to an internal PAGE BLOCK memory segment
All I2C EEPROMs use an internal protocol that defines a PAGE BLOCK size of 2 K bits (for Word addresses 0000 through 1111). Therefore, address bits A0, A1 or A2 (if designated "P") are used to access a PAGE BLOCK in conjunction with the Word address used to access any individual data byte (Word).

## Device Addressing (Continued)

The last bit of the slave address defines whether a write or read condition is requested by the master. $A$ " 1 " indicates that a read operation is to be executed and a " 0 " initiates the write mode.

A simple review: After the NM24C02L/C04L recognizes the start condition, the devices interfaced to the $I^{2} \mathrm{C}$ bus wait for a slave address to be transmitted over the SDA line. If the transmitted slave address matches an address of one of the devices, the designated slave pulls the line LOW with an acknowledge signal and awaits further transmissions.

## Write Operations

## BYTE WRITE

For a write operation a second address field is required which is a word address that is comprised of eight bits and provides access to any one of the 256 words in the selected page of memory. Upon receipt of the word address the NM24C02L/C04L responds with an acknowledge and waits for the next eight bits of data, again, responding with an acknowledge. The master then terminates the transfer by generating a stop condition, at which time the NM24CxxL
begins the internal write cycle to the nonvolatile memory. While the internal write cycle is in progress the NM24CxxL inputs are disabled, and the device will not respond to any requests from the master. Refer to Figure 5 for the address, acknowledge and data transfer sequence.

## PAGE WRITE

The NM24CxxL is capable of a sixteen byte page write operation. It is initiated in the same manner as the byte write operation; but instead of terminating the write cycle after the first data word is tranferred, the master can transmit up to fifteen more words. After the receipt of each word, the NM24CxxL will respond with an acknowledge.
After the receipt of each word, the internal address counter increments to the next address and the next SDA data is accepted. If the master should transmit more than sixteen words prior to generating the stop condition, the address counter will "roll over" and the previously written data will be overwritten. As with the byte write operation, all inputs are disabled until completion of the internal write cycle. Refer to Figure 6 for the address, acknowledge and data transfer sequence.


FIGURE 5. Byte Write


FIGURE 6. Page Write

## Write Operations (Continued) <br> acknowledge polling

Once the stop condition is issued to indicate the end of the host's write operation, the NM24CxxL initiates the internal write cycle. ACK polling can be initiated immediately. This involves issuing the start condition followed by the slave address for a write operation. If the NM24CxxL is still busy with the write operation, no ACK will be returned. If the NM24CxxL has completed the write operation, an ACK will be returned and the host can then proceed with the next read or write operation.

## Read Operations

Read operations are initiated in the same manner as write operations, with the exception that the R/信 bit of the slave address is set to a one. There are three basic read operations: current address read, random read and sequential read.

## CURRENT ADDRESS READ

Internally the NM24CxxL contains an address counter that maintains the address of the last word accessed, incremented by one. Therefore, if the last access (either a read or write) was to address $n$, the next read operation would access data from address $n+1$. Upon receipt of the slave address with $R / \bar{W}$ set to one, the NM24CxxL issues an acknowledge and transmits the eight bit word. The master will not acknowledge the transfer but does generate a stop condition, and therefore the NM24CxxL discontinues tranmission. Refer to Figure 7 for the sequence of address, acknowledge and data transfer.

## RANDOM READ

Random read operations allow the master to access any memory location in a random manner. Prior to issuing the slave address with the R/W bit set to one, the master must first perform a "dummy" write operation. The master issues a start condition, slave address and then the word address it is to read. After the word address acknowledge, the master immediately reissues the start condition and the slave address with the R/W bit set to one. This will be followed by an acknowledge from the NM24CxxL and then by the eight bit word. The master will not acknowledge the transfer but does generate the stop condition, and the NM24CxxL discontinues transmission. Refer to Figure 8 for the address, acknowledge and data transfer sequence.

## SEQUENTIAL READ

Sequential reads can be initiated as either a current address read or random access read. The first word is transmitted in the same manner as the other read modes; however, the master now responds with an acknowledge, indicating it requires additional data. The NM24CxxL continues to output data for each acknowledge received. The read operation is terminated by the master not responding with an acknowledge or by generating a stop condition.
The data output is sequential, with the data from address $n$ followed by the data from $n+1$. The address counter for read operations increments all word address bits, allowing the entire memory contents to be serially read during one operation. After the entire memory has been read, the counter "rolls over" and the NM24CxxL continues to output data for each acknowledge received. Refer to Figure 9 for the address, acknowledge and data transfer sequence.


TL/D/11272-11
FIGURE 7. Current Address Read


TL/D/11272-12
FIGURE 8. Random Read


Write Operations (Continued)


TL/D/11272-14
FIGURE 10. Typical System Configuration

## NM24C03L/C05L

## 2K-/4K-Bit Serial EEPROM with Write Protect and Extended Voltage ( ${ }^{2} \mathrm{C}$ Synchronous 2-Wire Bus)

## General Description

The NM24C03L/C05L devices are 2048/4096 bits, respectively, of CMOS non-volatile electrically erasable memory. These devices conform to all specifications in the $I^{2} \mathrm{C} 2$-wire protocol, and are designed to minimize device pin count and simplify PC board layout requirements. National EEPROMs are designed and tested for applications requiring high endurance, high reliability, and low power consumption.
The upper half of the memory can be disabled (Write Protected) by connecting the WP pin to $\mathrm{V}_{\mathrm{CC}}$. This section of memory then becomes ROM.
These devices have an operating voltage range of 2.5 V to 5.5 V and are offered in an 8-pin small outline (SO) package, making these devices perfectly suited for low power applications that require minimal board space usage.
This communication protocol uses CLOCK (SCL) and DATA I/O (SDA) lines to synchronously clock data between the master (for example a microprocessor) and the slave EEPROM device(s). In addition, this bus structure allows for a maximum of 16 K of EEPROM memory. This is supported by the NSC family in $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$ and 16 K devices, allowing the user to configure the memory as the application requires with any combination of EEPROMs (not to exceed 16K).

## Features

- Hardwire write protect for upper block
- Low Power CMOS
- 2 mA active current typical
$-60 \mu \mathrm{~A}$ standby current typical
- 2-wire I2C serial interface
- Provides bidirectional data transfer protocol
- Sixteen byte page write mode
- Minimizes total write time per byte
- Self timed write cycle
- Typical write cycle time of 5 ms
- Endurance: $10^{6}$ data changes
- Data retention greater than 40 years
- Packages available: 8-pin mini-DIP or 14-pin SO package


## Functional Diagram



## Connection Diagram



Top View

See NS Package Number N08E ( N ) and M08A (M8)

## Ordering Information

| Commercial Temperature Range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ |
| :---: |
| Order Number |
| NM24C03LN/NM24C05LN |
| NM24C03LM8/NM24C05LM8 |

Extended Temperature Range ( $\mathbf{4 0 ^ { \circ }} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM24C03LEN/NM24C05LEN |
| NM24C03LEM8/NM24C05LEM8 |

## LOW VOLTAGE ( $2.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V}$ ) SPECIFICATIONS

If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Ambient Storage Temperature
All Input or Output Voltages
with Respect to Ground
Lead Temperature
(Soldering, 10 seconds)
ESD Rating
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
+6.5 V to -0.3 V
$+300^{\circ} \mathrm{C}$
2000 V min

## Operating Conditions

Ambient Operating Temperature
NM24C03L/C05L
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ NM24C03LE/C05LE

$$
-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}
$$

2.5 V to 5.5 V

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=2.5 \mathrm{~V}$ to 4.5 V (unless otherwise speciifed)

| Symbol | Parameter | Test Conditions | Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ (Note 1) | Max |  |
| ICCA | Active Power Supply Current | $\mathrm{f}_{\text {SCL }}=100 \mathrm{kHz}$ |  | 2.0 | 3.0 | mA |
| $\mathrm{I}_{\text {SB }}$ | Standby Current | $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ or $\mathrm{V}_{\text {CC }}$ |  | 60 | 100 | $\mu \mathrm{A}$ |
| $\mathrm{l}_{\mathrm{LI}}$ | Input Leakage Current | $V_{I N}=G N D$ to $V_{C C}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{CC}}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.3 |  | $\mathrm{V}_{\mathrm{CC}} \times 0.3$ | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  | $\mathrm{V}_{\mathrm{CC}} \times 0.7$ |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=200 \mu \mathrm{~A}$ |  |  | 0.4 | V |

Note 1: Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage ( 5 V ).
Capacitance $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$

| Symbol | Test | Conditions | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I / O}$ (Note 2) | Input/Output Capacitance (SDA) | $\mathrm{V}_{1 / O}=0 \mathrm{~V}$ | 8 | pF |
| $\mathrm{C}_{I N}$ (Note 2) | Input Capacitance (AO, A1, A2, SCL, WP) | $\mathrm{V}_{I N}=0 \mathrm{~V}$ | 6 | pF |

Note 2: This parameter is periodically sampled and not $\mathbf{1 0 0 \%}$ tested.

## AC Conditions of Test

| Input Pulse Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.1$ to $\mathrm{V}_{\mathrm{CC}} \times 0.9$ |
| :--- | :---: |
| Input Rise and <br> Fall Times | 10 ns |
| Input and Output <br> Timing Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.5$ |
| Output Load | 1 TTL Gate and <br> $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |

## LOW VOLTAGE (2.5V $\leq$ V $_{\text {CC }}<4.5 \mathrm{~V}$ ) SPECIFICATIONS

Read and Write Cycle Limits

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\text {SCL }}$ | SCL Clock Frequency |  | 80 | kHz |
| TI | Noise Suppression Time Constant at SCL, SDA Inputs |  | 100 | ns |
| $t_{A A}$ | SCL Low to SDA Data Out Valid | 0.3 | 7.0 | $\mu \mathrm{s}$ |
| $t_{\text {guF }}$ | Time the Bus Must Be Free before a New Transmission Can Start | 6.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {HD }}$ STA | Start Condition Hold Time | 4.5 |  | $\mu \mathrm{s}$ |
| tow | Clock Low Period | 6.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {HIGH }}$ | Clock High Period | 4.5 |  | $\mu \mathrm{s}$ |
| tsu:STA | Start Condition Setup Time (for a Repeated Start Condition) | 6.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {HD: }}$ DAT | Data in Hold Time | 0 |  | $\mu \mathrm{s}$ |
| tsu:DAT | Data in Setup Time | 500 |  | ns |
| $t_{\text {R }}$ | SDA and SCL Rise Time |  | 1 | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{F}}$ | SDA and SCL Fall Time |  | 300 | ns |
| tsu:STO | Stop Condition Setup Time | 6.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {DH }}$ | Data Out Hold Time | 300 |  | ns |
| $\mathrm{t}_{\mathrm{WR}}$ (Note 3) | Write Cycle Time |  | 15 | ms |

Note 3: The write cycle time ( $\mathrm{FWR}^{\prime}$ ) is the time from a valid stop condition of a write sequence to the end ot the internal erase/program cycle. During the write cycle, the NM24Cxx bus interface circuits are disabled, SDA is allowed to remain high per the bus-level pull-up resistor, and the device does not respond to its slave address.

## Bus Timing



## STANDARD VOLTAGE ( $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ ) SPECIFICATIONS

## Absolute Maximum Ratings

If Military/Aerospace specified devices are required, please contact the Natlonal Semiconductor Sales Office/Distributors for availability and specifications.
Ambient Storage Temperature
All Input or Output Voltages with Respect to Ground
Lead Temperature
(Soldering, 10 seconds)
ESD Rating
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

$$
+6.5 \mathrm{~V} \text { to }-0.3 \mathrm{~V}
$$

$$
+300^{\circ} \mathrm{C}
$$

$$
2000 \mathrm{~V} \text { min }
$$

## Operating Conditions

Ambient Operating Temperature
NM24C03L/C05L
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
NM24C03LE/C05LE
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

Positive Power Supply ( $\mathrm{V}_{\mathrm{CC}}$ )
2.5 V to 5.5 V

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V (unless otherwise specified)

| Symbol | Parameter | Test Conditions | Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ (Note 1) | Max |  |
| $I_{\text {CCA }}$ | Active Power Supply Current | $\mathrm{f}_{\text {SCL }}=100 \mathrm{kHz}$ |  | 2.0 | 3.0 | mA |
| $\mathrm{I}_{\text {SB }}$ | Standby Current | $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ or $\mathrm{V}_{\text {CC }}$ |  | 60 | 100 | $\mu \mathrm{A}$ |
| $\mathrm{ILI}^{\text {l }}$ | Input Leakage Current | $V_{\text {IN }}=G N D$ to $V_{C C}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| Lo | Output Leakage Current | $V_{\text {OUT }}=$ GND to $V_{C C}$ |  | 0.1 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.3 |  | $V_{\text {cc }} \times 0.3$ | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | $\mathrm{V}_{\mathrm{CC}} \times 0.7$ |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=3 \mathrm{~mA}$ |  |  | 0.4 | V |

Note 1: Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage ( 5 V ).
Capacitance $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$

| Symbol | Test | Conditions | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I / \mathrm{O}}$ (Note 2) | Input/Output Capacitance (SDA) | $\mathrm{V}_{I / \mathrm{O}}=0 \mathrm{~V}$ | 8 | pF |
| $\mathrm{C}_{\\| \mathrm{N}}$ (Note 2) | Input Capacitance (AO, A1, A2, SCL) | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ | 6 | pF |

Note 2: This parameter is periodically sampled and not $100 \%$ tested.

## AC Conditions of Test

| Input Pulse Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.1$ to $\mathrm{V}_{\mathrm{CC}} \times 0.9$ |
| :--- | :---: |
| Input Rise and <br> Fall Times | 10 ns |
| Input and Output <br> Timing Levels | $\mathrm{V}_{\mathrm{CC}} \times 0.5$ |
| Output Load | 1 TTL Gate and <br> $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |

STANDARD VOLTAGE ( $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ ) SPECIFICATIONS
Read and Write Cycle Limits

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{SCL}}$ | SCL Clock Frequency |  | 100 | kHz |
| TI | Noise Suppression Time Constant at SCL, SDA Inputs |  | 100 | ns |
| $t_{A A}$ | SCL Low to SDA Data Out Valid | 0.3 | 3.5 | $\mu \mathrm{s}$ |
| $t_{\text {t }}$ | Time the Bus Must Be Free before a New Transmission Can Start | 4.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {HD: }}$ STA | Start Condition Hold Time | 4.0 |  | $\mu \mathrm{S}$ |
| tLow | Clock Low Period | 4.7 |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{HIGH}}$ | Clock High Period | 4.0 |  | $\mu \mathrm{S}$ |
| ${ }^{\text {tSUSSTA }}$ | Start Condition Setup Time (for a Repeated Start Condition) | 4.7 |  | $\mu \mathrm{s}$ |
| $t_{\text {HD: }}$ DAT | Data in Hold Time | 0 |  | $\mu \mathrm{s}$ |
| $t_{\text {SU:DAT }}$ | Data in Setup Time | 250 |  | ns |
| $\mathrm{t}_{\mathrm{R}}$ | SDA and SCL Rise Time |  | 1 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{F}}$ | SDA and SCL Fall Time |  | 300 | ns |
| tsu:STO | Stop Condition Setup Time | 4.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {DH }}$ | Data Out Hold Time | 300 |  | ns |
| tWR (Note 3) | Write Cycle Time |  | 10 | ms |

Note 3: The write cycle time (twR) is the time from a valid stop condition of a write sequence to the end ot the internal erase/program cycle. During the write cycle, the NM24Cxx bus interface circuits are disabled, SDA is allowed to remain high per the bus-level pull-up resistor, and the device does not respond to its slave address.

## Bus Timing



TL/D/11400-4

## BACKGROUND INFORMATION (I²C Bus)

As mentioned, the $1^{2} \mathrm{C}$ bus allows synchronous bidirectional communication between Transmitter/Receiver using the SCL (clock) and SDA (Data I/O) lines. All communication must be started with a valid START condition, concluded with a STOP condition and acknowledged by the Receiver with an ACKNOWLEDGE condition.
In additon, since the ${ }^{2} \mathrm{C}$ bus is designed to support other devices such as RAM, EPROM, etc., the device type identifier string must follow the START condition. For EEPROMs, this 4 -bit string is 1010 .
As shown below, the EEPROMs on the $1^{2} \mathrm{C}$ bus may be configured in any manner required, providing the total memory addressed does not exceed 16K (16,834 bits). EEPROM memory addressing is controlled by two methods:

- Hardware configuring the A0, A1 and A2 pins (Device Address pins) with pull-up or pull-down resistors. ALL UNUSED PINS MUST BE GROUNDED (tied to $\mathrm{V}_{\text {SS }}$ ).
- Software addressing the required PAGE BLOCK within the device memory array (as sent in the Slave Address string)

Addressing an EEPROM memory location involves sending a command string with the following information:
[DEVICE TYPE]-[DEVICE ADDRESS]-[PAGE BLOCK AD-DRESS]-[BYTE ADDRESS]

Example of 8 k ( $1 / 2$ Maximum Size) of Memory on 2-Wire Bus


TL/D/11400-05

## Notes:

The SDA pull-up resistor is required due to the open-drain/open-collector output of $\mathrm{I}^{2} \mathrm{C}$ bus devices.
The SCL pull-up resistor is recommended because of the normal SCL line inactive "high" state.
It is recommended that the total line capacitance be less than 400 pF .
Specific timing and addressing considerations are described in greater detail in the following sections.

| Device | Address Pins |  |  | Memory Size | Number of <br> Page Blocks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | A0 | A1 | A2 |  | 1 |
| NM24C03L | DA | DA | DA | 2048 Bits | 1 |
| NM24C05L | $V_{S S}$ | DA | DA | 4096 Bits | 2 |

DA: Device Address

## Pin Descriptions

## SERIAL CLOCK (SCL)

The SCL input is used to clock all data into and out of the device.

## SERIAL DATA (SDA)

SDA is a bidirectional pin used to transfer data into and out of the device. It is an open drain output and may be wireORed with any number of open drain or open collector outputs.

## DEVICE ADDRESS INPUTS (A0, A1, A2)

Device address pins A0, A1 and A2 are connected to $V_{C C}$ or $V_{S S}$ to configure the EEPROM address. The following table (Table A) shows the active pins across the NM24Cxx device family.

TABLE A

| Device | A0 | A1 | A2 | Effects of Addresses |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| NM24C03L | ADR | ADR | ADR | $2^{3}=8$ | $(8) \times(2 \mathrm{~K})=16 \mathrm{~K}$ |
| NM24C05L | X | ADR | ADR | $2^{2}=4$ | $(4) \times(4 \mathrm{~K})=16 \mathrm{~K}$ |

ADR: Denotes an active pin used for device addressing
X : Not used for addressing (must be tied to Ground/$/ \mathrm{V}_{\mathrm{SS}}$ )

## WP WRITE PROTECTION

If tied to $\mathrm{V}_{\mathrm{CC}}$, PROGRAM operations onto the upper half of the memory will not be executed. READ operations are possible.

If tied to $\mathrm{V}_{\mathrm{SS}}$, normal memory operation is enabled, READ/ WRITE over the entire memory is possible.
This feature allows the user to assign the upper half of the memory as ROM which can be protected against accidental programming. When write is disabled, slave address and word address will be acknowledged but data will not be acknowledged.

## Device Operation

The NM24C03L/C05L supports a bidirectional bus oriented protocol. The protocol defines any device that sends data onto the bus as a transmitter and the receiving device as the receiver. The device controlling the transfer is the master and the device that is controlled is the slave. The master will always initiate data transfers and provide the clock for both transmit and receive operations. Therefore, the NM24Cxx is considered a slave in all applications.

## CLOCK AND DATA CONVENTIONS

Data states on the SDA line can change only during SCL LOW. SDA state changes during SCL HIGH are reserved for indicating start and stop conditions. Refer to Figures 1 and 2.

## START CONDITION

All commands are preceded by the start condition, which is a HIGH to LOW transition of SDA when SCL is HIGH. The NM24Cxx continuously monitors the SDA and SCL lines for the start condition and will not respond to any command until this condition has been met.

## Write Cycle Timing



FIGURE 1. Data Validity


TL/D/11400-8
FIGURE 2. Definition of Start and Stop


## STOP CONDITION

All communications are terminated by a stop condition, which is a LOW to HIGH transition of SDA when SCL is HIGH. The stop condition is also used by the NM24Cxx to place the device in the standby power mode.

## ACKNOWLEDGE

Acknowledge is a software convention used to indicate successful data transfers. The transmitting device, either master or slave, will release the bus after transmitting eight bits. During the ninth clock cycle the receiver will pull the SDA line LOW to acknowledge that it received the eight bits of data. Refer to Figure 3.
The NM24Cxx device will always respond with an acknowledge after recognition of a start condition and its slave address. If both the device and a write operation have been selected, the NM24Cxx will respond with an acknowledge after the receipt of each subsequent eight bit word.
In the read mode the NM24Cxx slave will transmit eight bits of data, release the SDA line and monitor the line for an acknowledge. If an acknowledge is detected and no stop condition is generated by the master, the slave will continue to transmit data. If an acknowledge is not detected, the slave will terminate further data transmissions and await the stop condition to return to the standby power mode.

## Device Addressing

Following a start condition the master must output the address of the slave it is accessing. The most significant four bits of the slave address are those of the device type identifier, (see Figure 4). This is fixed as 1010 for both devices: NM24C03L and NM24C05L.


FIGURE 4. Slave Addresses

Device Addressing (Continued)
Refer to the following table for Slave Address string details:

| Device | A0 | A1 | A2 | Number of <br> Page Blocks | Page Block Addresses |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NM24C03L | A | A | A | 1 <br> $(2 K)$ <br> 2 | (None) |  |
| NM24C05L | P | A | A | 0 | 1 |  |

A: Refers to a hardware configured Device Address pin
P: Refers to an internal PAGE BLOCK memory segment

All 12 C EEPROMs use an internal protocol that defines a PAGE BLOCK size of 2 K bits (for Word addresses 0000 through 1111). Therefore, address bits A0, A1 or A2 (if designated "P") are used to access a PAGE BLOCK in conjunction with the Word address used to access any individual data byte (Word).
The last bit of the slave address defines whether a write or read condition is requested by the master. A " 1 " indicates that a read operation is to be executed and a " 0 " initiates the write mode.
A simple review: After the NM24C03L/C05L recognizes the start condition, the devices interfaced to the I2C bus wait for a slave address to be transmitted over the SDA line. If the transmitted slave address matches an address of one of the devices, the designated slave pulls the line LOW with an acknowledge signal and awaits further transmissions.

## Write Operations

## BYTE WRITE

For a write operation a second address field is required which is a word address that is comprised of eight bits and provides access to any one of the 256 words in the selected page of memory. Upon receipt of the word address the NM24Cxx responds with an acknowledge and waits for the next eight bits of data, again, responding with an acknowledge. The master then terminates the transfer by generating a stop condition, at which time the NM24Cxx begins the internal write cycle to the nonvolatile memory. While the internal write cycle is in progress the NM24Cxx inputs are disabled, and the device will not respond to any requests from the master. Refer to Figure 5 for the address, acknowledge and data transfer sequence.


FIGURE 5. Byte Write

## Write Operations (Continued)

## PAGE WRITE

The NM24Cxx is capable of a sixteen byte page write operation. It is initiated in the same manner as the byte write operation; but instead of terminating the write cycle after the first data word is tranferred, the master can transmit up to fifteen more words. After the receipt of each word, the NM24Cxx will respond with an acknowledge.
After the receipt of each word, the internal address counter increments to the next address and the next SDA data is accepted. If the master should transmit more than sixteen words prior to generating the stop condition, the address counter will "roll over" and the previously written data will be overwritten. As with the byte write operation, all inputs are disabled until completion of the internal write cycle. Refer to Figure 6 for the address, acknowledge and data transfer sequence.

## ACKNOWLEDGE POLLING

Once the stop condition is issued to indicate the end of the host's write operation, the NM24Cxx initiates the internal write cycle. ACK polling can be initiated immediately. This involves issuing the start condition followed by the slave address for a write operation. If the NM24Cxx is still busy with the write operation, no ACK will be returned. If the NM24Cxx has completed the write operation, an ACK will be returned and the host can then proceed with the next read or write operation.

## WRITE PROTECTION

Programming of the upper half of the memory will not take place if the WP pin of the NM24Cxx is connected to $V_{C C}$ ( +5 V ). The NM24Cxx will accept slave and word addresses; but if the memory accessed is write protected by the WP pin, the NM24Cxx will not generate an acknowledge after the first byte of data has been received, and thus the program cycle will not be started when the stop condition is asserted.

## Read Operations

Read operations are initiated in the same manner as write operations, with the exception that the R/W bit of the slave address is set to a one. There are three basic read operations: current address read, random read and sequential read.

## CURRENT ADDRESS READ

Internally the NM24Cxx contains an address counter that maintains the address of the last word accessed, incremented by one. Therefore, if the last access (either a read or write) was to address $n$, the next read operation would access data from address $n+1$. Upon receipt of the slave address with $\mathrm{R} / \overline{\mathrm{W}}$ set to one, the NM24Cxx issues an acknowledge and transmits the eight bit word. The master will not acknowledge the transfer but does generate a stop condition, and therefore the NM24Cxx discontinues tranmission. Refer to Figure 7 for the sequence of address, acknowledge and data transfer.

## RANDOM READ

Random read operations allow the master to access any memory location in a random manner. Prior to issuing the slave address with the $R / \bar{W}$ bit set to one, the master must first perform a "dummy" write operation. The master issues a start condition, slave address and then the word address it is to read. After the word address acknowledge, the master immediately reissues the start condition and the slave address with the R/W bit set to one. This will be followed by an acknowledge from the NM24Cxx and then by the eight bit word. The master will not acknowledge the transfer but does generate the stop condition, and therefore the NM24Cxx discontinues transmission. Refer to Figure 8 for the address, acknowledge and data transfer sequence.

## Read Operations (Continued)

## SEQUENTIAL READ

Sequential reads can be initiated as either a current address read or random access read. The first word is transmitted in the same manner as the other read modes; however, the master now responds with an acknowledge, indicating it requires additional data. The NM24Cxx continues to output data for each acknowledge received. The read operation is terminated by the master not responding with an acknowledge or by generating a stop condition.

The data output is sequential, with the data from address $\mathbf{n}$ followed by the data from $n+1$. The address counter for read operations increments all word address bits, allowing the entire memory contents to be serially read during one operation. After the entire memory has been read, the counter "rolls over" and the NM24Cxx continues to output data for each acknowledge received. Refer to Figure 9 for the address, acknowledge and data transfer sequence.


TL/D/11400-15
FIGURE 8. Random Read

| BUS ACTIVITY: |  |
| :--- | :--- | :--- |
| MASTER |  |
| SUS LINE |  |
| BUCTIVITY: |  |
| NM24CO3L/CO5L | SLAVESS |

FIGURE 9. Sequential Read


TL/D/11400-17
FIGURE 10. Typical System Configuration

## NM59C11 1024-Bit Serial EEPROM $64 \times 16$-Bit or $128 \times 8$-Bit Configurable with Programming Status

## General Description

The NM59C11 is 1024 bits of CMOS non-volatile electrically erasable memory organized as either 64 16-bit registers or as 1288 -bit registers. The organization is determined by the status of the ORG input. This memory device is fabricated using National Semiconductor's floating gate CMOS process for high reliability, high endurance and low power consumption. The NM59C11 is available in an SO package for small space considerations.
The interface that controls the EEPROM is MICROWIRETM compatible for simple interfacing to a wide variety of microcontrollers and microprocessors. There are 6 instructions that operate the NM59C11: Read, Erase/Write Enable, Write, Erase/Write Disable, Write All, and Erase All. The device programming status is output on the RDY/ $\overline{B U S Y}$ output.
The NM59C11 has programming status in adddition to the functions found in the NM93C46A.

## Features

- Device status during programming mode
- Typical active current of $400 \mu \mathrm{~A}$; typical standby current of $25 \mu \mathrm{~A}$
- Direct Write
- Reliable CMOS floating gate technology

■ 4.5 V to 5.5 V operation in all modes (also available with 3.0 V to 5.5 V )

- MICROWIRE compatible interface
- Self-timed programming cycle
- 40 years data retention
m Endurance: $10^{6}$ data changes
- Packages available: 8-pin SO, 8-pin DIP


## Block Diagram



## Connection Diagram



TL/D/11051-2
Top View
See NS Package Number N08E and M08A

Pln Names

| CS | Chip Select |
| :--- | :--- |
| SK | Serial Data Clock |
| DI | Serial Data Input |
| DO | Serial Data Output |
| GND | Ground |
| V CC $^{\text {ORG }}$ | Power Supply |
| RDY/BUSY | Organization |

## Ordering Information

Commercial Temp. Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM59C11N |
| NM59C11M8 |

Extended Temp. Range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

| Order Number |
| :--- |
| NM59C11EN |
| NM59C11EM8 |

Military Temp. Range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

| Order Number |
| :--- |
| NM59C11MN |
| NM59C11MM8 |

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for avallability and specifications.

| Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| All Input or Output Voltages | +6.5 V to -0.3 V |
| with Respect to Ground | $+300^{\circ} \mathrm{C}$ |
| Lead Temp. (Soldering, 10 sec.) | 2000 V |
| ESD Rating |  |

## Operating Conditions

Ambient Operating Temperature

| NM59C11 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| NM59C11E | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| NM59C11M | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Power Supply (VCC) | 4.5 V to 5.5 V |

DC and AC Electrical Characteristics $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwise specified)
Note: Throughout this table, "M" refers to temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$, not package.

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICCl | Operating Current CMOS Input Levels | NM59C11 <br> NM59C11E <br> MN59C11M | $\begin{aligned} \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =1.0 \mathrm{MHz} \\ \mathrm{SK} & =0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | mA |
| ICC2 | Operating Current TTL Input Levels | NM59C11 NM59C11E MN59C11M | $\begin{aligned} \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =1.0 \mathrm{MHz} \\ \mathrm{SK} & =0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \\ & 4 \end{aligned}$ | mA |
| $\mathrm{ICC3}$ | Standby Current | NM59C11 NM59C11E NM59C11M | $C S=0 V$ |  | $\begin{gathered} 50 \\ 100 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ |
| IIL. | Input Leakage | NM59C11 NM59C11E NM59C11M | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & -10 \\ & \hline \end{aligned}$ | $\begin{gathered} 2.5 \\ 10 \\ 10 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| lol | Output Leakage | NM59C11 NM59C11E NM59C11M | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & -10 \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | -0.1 | 0.8 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | . |  | 2 | $\mathrm{V}_{\mathrm{CC}}+1$ | V |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage | NM59C11 NM59C11E NM59C11M | $\begin{aligned} \mathrm{I}_{\mathrm{OL}} & =2.1 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =2.1 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =1.8 \end{aligned}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & 0.4 \\ & \hline \end{aligned}$ | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  | V |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage |  | $\mathrm{IOL}^{2}=10 \mu \mathrm{~A}$ |  | 0.2 | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}-0.2$ |  | V |
| ${ }_{\text {f }} \mathrm{K}$ | SK Clock Frequency | NM59C11 NM59C11E NM59C11M |  | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 \\ 1 \\ 0.5 \end{gathered}$ | MHz |
| ${ }^{\text {tSKH }}$ | SK High Time | NM59C11 NM59C11E NM59C11M | (Note 2) (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 300 \\ & 500 \end{aligned}$ |  | ns |
| ${ }^{\text {t SKL }}$ | SK Low Time | $\begin{aligned} & \text { NM59C11 } \\ & \text { NM59C11E } \\ & \text { NM59C11M } \end{aligned}$ | (Note 2) <br> (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \end{aligned}$ |  | ns |
| ${ }^{\text {t SKS }}$ | SK Setup Time | NM59C11 NM59C11E NM59C11M | Relative to CS | $\begin{gathered} \hline 50 \\ 50 \\ 100 \\ \hline \end{gathered}$ |  | ns |
| $\mathrm{t}_{\mathrm{CS}}$ | Minimum CS Low Time | NM59C11 NM59C11E NM59C11M | (Note 4) <br> (Note 4) <br> (Note 5) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \\ & \hline \end{aligned}$ |  | ns |
| ${ }^{\text {t CSS }}$ | CS Setup Time | NM59C11 NM59C11E NM59C11M | Relative to SK | $\begin{gathered} 50 \\ 50 \\ 100 \end{gathered}$ |  | ns |

DC and AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwise specified) (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{DH}}$ | DO Hold Time |  | Relative to SK | 10 |  | ns |
| tois | DI Setup Time | NM59C11A NM59C11AE NM59C11AM | Relative to SK | $\begin{aligned} & 100 \\ & 100 \\ & 200 \\ & \hline \end{aligned}$ |  | ns |
| $\mathrm{t}_{\text {CSH }}$ | CS Hold Time |  | Relative to SK | 0 |  | ns |
| til | DI Hold Time |  | Relative to SK | 20 |  |  |
| tpD1 | Output Delay to " 1 " | NM59C11A NM59C11AE NM59C11AM | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \\ \hline \end{gathered}$ | ns |
| tpDo | Output Delay to "0" | NM5911A NM59C11AE NM59C11AM | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \\ \hline \end{gathered}$ | ns |
| $t_{\text {DF }}$ | CS to DO in <br> TRI-STATE ${ }^{\text {® }}$ | NM59C11A NM59C11AE NM59C11AM | AC Test $C S=V_{I L}$ |  | $\begin{aligned} & 100 \\ & 100 \\ & 200 \\ & \hline \end{aligned}$ | ns |
| twp | Write Cycle Time |  |  |  | 10 | ms |

Capacitance (Note 6)
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Max | Units |
| :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 5 | pF |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 5 | pF |

## AC Test Conditions



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 specfication is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: The SK frequency specification for Commercial and Extended temperature range parts specifies a minimum SK clock period of $1 \mu \mathrm{~s}$; therefore, in a SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to $1 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=250 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=750 \mathrm{~ns}$ in order to meet the SK frequency specification.
Note 3: The SK frequency specification for Military Temperature parts specifies a minimum SK clock period of $2 \mu \mathrm{~s}$; therefore, in an SK clock cycle, tsKH + tSLK must be greater than or equal to $2 \mu \mathrm{~s}$. For example, if the $\mathrm{t}_{\mathrm{SKL}}=500 \mathrm{~ns}$, then the mimimum $\mathrm{t}_{\mathrm{SKH}}=1.5 \mu \mathrm{~s}$ in order to meet the SK frequency specification.
Note 4: For Commercial and Extended temperature range parts, CS must be brought low for a minimum of 250 ns ( t CS) between consecutive instruction cycles.
Note 5: For Military Temperature parts, CS must be brought low for a minimum of 500 ns ( tcs ) between consecutive instruction cycles.
Note 6: This parameter is periodically sampled and not $100 \%$ tested.

## Functional Description

The NM59C11 has 6 instructions as described below. Note that the MSB of any instruction is a " 1 " and is viewed as a start bit in the interface sequence. The next $8 / 9$ bits carry the op code and the 6/7-bit address for register selection.

## Read (READ)

The Read (READ) instruction outputs serial data on the DO pin. After a READ instruction is received, the instruction and address are decoded, followed by data transfer from the selected memory register into an 8 - or 16 -bit serial-out shift register. A dummy bit (logical 0 ) precedes the 8 - or 16 -bit data output string. Output data changes are initiated by a low to high transition of the SK clock.

## Erase/Write Enable (EWEN)

When $V_{C C}$ is applied to the part, it powers up in the Erase/Write Disable (EWDS) state. Therefore, all programming modes must be preceded by an Erase/Write Enable (EWEN) instruction. Once an Erase/Write Enable instruction is executed, programming remains enabled until an Erase/Write Disable (EWDS) instruction is executed or $V_{C C}$ is removed from the part.

## RDY/BUSY

The NM59C11 has a separate output that indicates if the device is in the programming mode. It enters the programming mode when the last data bit is clocked in. When it enters the programming mode, the NM59C11 drives the RDY/BUSY output low. After it completes the programming mode, it drives the RDY/BUSY output high. The RDY/ BUSY output remains at a high level at all times except while the device is in the programming mode.

## Program (PROGRAM)

The program instruction is used to write data into an 8- or 16-bit register at the specified address. When the last data bit is clocked in, the NM59C11 automatically enters the programming mode. While the device is in the programming mode it cannot accept any other instructions and the RDY/BUSY output is driven low to indicate BUSY. When the device has completed the internally timed programming cycle, the RDY/BUSY output is driven high to indicate it is ready to accept the next instruction.

The Chip Select (CS) input does not need to be driven low to initiate the programming cycle, but it must be driven low for the minimum CS low timer ( $\mathrm{t}_{\mathrm{CS}}=250 \mu \mathrm{~s}$ ) before a new cycle can be initiated.

## Erase All (ERAL)

The ERAL instruction will erase all memory registers simultaneously (all bits set to a logical "1"). To initiate the internal programming mode, an 8 - or 16 -bit data field must be clocked in, although the contents of the data field are "don't care" in this instruction. The internally timed programming cycle will be initiated when the last data bit is clocked in. As with the Program mode, the RDY/BUSY line will indicate when the device is able to accept the next instruction.
The Chip Select (CS) input does not need to be driven low to initiate the internal programming cycle, but it must be driven low for the minimum chip select low time ( t cs $=$ 250 ns ) before a new cycle can be initiated.

## Write All (WRAL)

The WRAL instruction will write the same data into all memory registers simultaneously. The address field is "don't care" in this instruction, although must be clocked in. The internal programming cycle is initiated when the last data bit is clocked in. As with the Program mode, the RDY/BUSY output indicates when the device is ready to accept the next instruction.
The Chip Select (CS) input does not need to be driven low to initiate the internal programming cycle, but it must be driven low for the minimum chip select low time ( t CS $=$ 250 ns ) before a new cycle can be initiated.

## Erase/Write Disable (EWDS)

To protect against accidental data disturb, the Erase/Write Disable (EWDS) instruction disables all programming modes and should follow all programming operations. Execution of a READ instruction is independent of both the EWEN and EWDS instructions.

## Instruction Set

| Instruction | Start <br> Bit | Opcode | Address* |  | Data |  | Comments |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathbf{1 2 8 \times 8}$ | $\mathbf{6 4 \times 1 6}$ | $\mathbf{1 2 8 \times 8}$ | $\mathbf{6 4 \times 1 6}$ |  |
| READ | 1 | 1000 | A6-A0 | A5-A0 |  |  | Read Address AN-A0 |
| PROGRAM | 1 | 0100 | A6-A0 | A5-A0 | D7-D0 | D15-D0 | Write Address AN-A0 |
| EWEN | 1 | 0011 | XXXXXXX | XXXXXX |  |  | Program Enable |
| EWDS | 1 | 0000 | XXXXXXX | XXXXXX |  |  | Program Disable |
| ERAL | 1 | 0010 | XXXXXXX | XXXXXX |  |  | Erase All Addresses |
| WRAL | 1 | 0001 | XXXXXXX | XXXXXX | D7-D0 | D15-D0 | Program All Addresses |

[^1]
## Timing Diagrams


*This is the minimum SK period (Note 2).
${ }^{+}{ }^{\text {tSKS }}$ is not needed if $D 1=V_{1 L}$ when CS is going active (HIGH).


EWEN


TL/D/11051-5

EWDS $\dagger$


TL/D/11051-6
$\dagger$ For the EWEN, EWDS, WRAL and ERAL it is necessary to provide a number of clock cycles after the last bit of opcode is clocked in. In the $64 \times 16$ configuration, 6 additional clock cycles are required. In the $128 \times 8$ configuration, 7 additional clock cycles are required.

Timing Diagrams (Continued)


WRAL (128 $\times 8$ Organization)


WRAL (64 $\times 16$ Organization)




TL/D/11051-9

ERAL $\dagger$ (128 x 8 Organization)


TL/D/11051-11

ERAL† (64 x 16 Organization)


TL/D/11051-12
$\dagger$ For the EWEN, EWDS, WRAL and ERAL it is necessary to provide a number of clock cycles after the last bit of opcode is clocked in. In the $64 \times 16$ configuration, 6 additional clock cycles are required. In the $128 \times 8$ configuration, 7 additional clock cycles are required.

## NM93C06/C46/C56/C66

256-/1024-/2048-/4096-Bit Serial EEPROM (MICROWIRETM)

## General Description

The NM93C06/C46/C56/C66 devices are 256/1024/ 2048/4096 bits, respectively, of CMOS non-volatile electrically erasable memory divided into 16/64/128/256 16-bit registers. They are fabricated using National Semiconductor's floating-gate CMOS process for high reliability and low power consumption. These memory devices are available in an SO package for small space considerations.
The serial interface that operates these EEPROMs is MICROWIRE compatible for simple interface to standard microcontrollers and microprocessors. There are 7 instructions that control these devices: Read, Erase/Write Enable, Erase, Erase All, Write, Write All, and Erase/Write Disable. The ready/busy status is available on the DO pin to indicate the completion of a programming cycle.

## Features

- Device status during programming mode
- Typical active current of $400 \mu \mathrm{~A}$; Typical standby current of $25 \mu \mathrm{~A}$
- Direct Write
- Reliable CMOS floating gate technology
- 4.5 V to 5.5 V operation in all modes
- MICROWIRE compatible serial I/O
- Self-timed programming cycle
- 40 years data retention
- Endurance: $10^{6}$ data changes
- Packages available: 8-pin SO, 8-pin DIP


## Block Diagram



TL/D/10751-1

## Connection Diagrams

Dual-In-Line Package ( $\mathbf{N}$ ) and 8-Pin SO (M8)


TL/D/10751-2
Top View
See NS Package Number N08E and M08A

## Ordering Information

| Commercial Temp. Range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ |
| :---: |
| Order Number* |
| NM93C06N/NM93C46N |
| NM93C56N/NM93C66N |
| NM93C06M8/NM93C46M8 |
| NM93C56M8/NM93C66M8 |

Extended Temp. Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Order Number* |
| :---: |
| NM93C06EN/NM93C46EN |
| NM93C56EN/NM93C66EN |
| NM93C06EM8/NM93C46EM8 |
| NM93C56EM8/NM93C66EM8 |

*For 14-Pin SO availability contact your local National Semiconductor Sales Office.

Pin Names

| CS | Chip Select |
| :--- | :--- |
| SK | Serial Data Clock |
| DI | Serial Data Input |
| DO | Serial Data Output |
| GND | Ground |
| VCC | Power Supply |


| Order Number* |
| :---: |
| NM93C06MN/NM93C46MN |
| NM93C56MN/NM93C66MN |
| NM93C06MM8/NM93C46MM8 |
| NM93C56MM8/NM93C66MM8 |

Alternate (Turned) SO Pinout

## Order Number

NM93C46TM8 Commercial Temp. NM93C46TEM8 Extended Temp.



#### Abstract

Absolute Maximum Ratings (Note 1) If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications. Ambient Storage Temperature All Input or Output Voltages with Respect to Ground Lead Temp. (Soldering, 10 sec.) ESD Rating $$
\begin{array}{r} -65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\ +6.5 \mathrm{~V} \text { to }-0.3 \mathrm{~V} \\ +300^{\circ} \mathrm{C} \\ 2000 \mathrm{~V} \end{array}
$$


## Operating Conditions

Ambient Operating Temperature $\begin{array}{lr}\text { NM93C06-NM93C66 } & 0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ \text { NM93C06E-NM93C66E } & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ \text { NM93C06M-NM93C66M } & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C}\end{array}$
Power Supply $\left(V_{C C}\right) \quad 4.5 \mathrm{~V}$ to 5.5 V

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwise specified)
Note: Throughout this table, " M " refers to temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$, not package.

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Operating Current CMOS Input Levels | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | $\begin{aligned} \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | mA |
| ICC2 | Operating Current TTL Input Levels | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | $\begin{aligned} \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \\ & 4 \end{aligned}$ | mA |
| $\mathrm{I}_{\mathrm{CC} 3}$ | Standby Current | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | $C S=0 V$ |  | $\begin{gathered} 50 \\ 50 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ |
| IIL | Input Leakage | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & -10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| lol | Output Leakage | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & -10 \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | Input Low Voltage Input High Voltage |  |  | $\begin{gathered} -0.1 \\ 2 \end{gathered}$ | $\begin{gathered} 0.8 \\ V_{C C}+1 \end{gathered}$ | V |
| $\mathrm{V}_{\text {OL. } 1}$ | Output Low Voltage | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | $\begin{aligned} \mathrm{I}_{\mathrm{OL}} & =2.1 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =2.1 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =1.8 \mathrm{~mA} \end{aligned}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & 0.4 \end{aligned}$ | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage |  | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ | 2.4 |  | V |
| $\mathrm{V}_{\mathrm{OL} 2}$ <br> $\mathrm{V}_{\mathrm{OH} 2}$ | Output Low Voltage Output High Voltage | NM93C06E-NM93C66E NM93C06M-NM93C66M | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.2$ | 0.2 | V |
| $\mathrm{f}_{\text {SK }}$ | SK Clock Frequency | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 \\ 1 \\ 0.5 \end{gathered}$ | MHz |
| $\mathrm{t}_{\text {SKH }}$ | SK High Time | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 300 \\ & 500 \end{aligned}$ |  | ns |
| ${ }^{\text {tSKL }}$ | SK Low Time | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | (Note 2) (Note 3) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \\ & \hline \end{aligned}$ |  | ns |
| $\mathrm{t}_{\text {SKS }}$ | SK Setup Time | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | Relative to CS | $\begin{gathered} 50 \\ 50 \\ 100 \\ \hline \end{gathered}$ |  | ns |
| $\mathrm{t}_{\mathrm{CS}}$ | Minimum CS Low Time | NM93C06-NM93C66 NM93C06E-NM93C66E NM93C06M-NM93C66M | (Note 4) (Note 5) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \\ & \hline \end{aligned}$ |  | ns |

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwise specified) (Continued)

| Symbol | Parameter | Part Number | Conditlons | Min | Max | Unlts |
| :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| tCSS | CS Setup Time | NM93C06-NM93C66 <br> NM93C06E-NM93C66E <br>  |  | Relative to SK | 50 |  |

${ }^{*} t_{D H}=70 \mathrm{~ns}$ for the NM93C06 and NM93C46

Capacitance (Note 6)
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Typ | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance |  | 5 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 5 | pF |

## AC Test Conditions

| Output Load | 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| :--- | ---: |
| Input Pulse Levels | 0.4 V to 2.4 V |
| Timing Measurement Reference Level |  |
| $\quad$ |  |
| $\quad$ Input | 1 V and 2 V |
| Output | 0.8 V and 2 V |

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 SK frequency specification for Commercial and Extended temperature range parts specifies a minimum SK clock period of $1 \mu \mathrm{~S}$; therefore, in an SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to $1 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=250 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\text {SKH }}=750 \mathrm{~ns}$ in order to meet the SK frequency specification.

Note 3: The SK frequency specification for Military Temperature parts specifies a minimum SK clock period of $2 \mu \mathrm{~s}$; therefore, in an SK clock cycle, tsKH + tsKL must be greater than or equal to $2 \mu \mathrm{~s}$. For example, if the $\mathrm{t}_{\mathrm{SKL}}=500 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=1.5 \mu \mathrm{~s}$ in order to meet the SK frequency specification.
Note 4: For Commercial and Extended temperature range parts, CS must be brought low for a minimum of 250 ns ( tcs ) between consecutive instruction cycles.
Note 5: For Military Temperature parts, CS must be brought low for a minimum of 500 ns (tcs) between consecutive instruction cycles.
Note 6: This parameter is periodically sampled and not $100 \%$ tested.

## Functional Description

The NM93C06/C46/C56/C66 devices have 7 instructions as described below. Note that the MSB of any instruction is a " 1 " and is viewed as a start bit in the interface sequence. For the C06 and C46 the next 8 bits carry the op code and the 6-bit address for register selection. For the C56 and C66 the next 10-bits carry the op code and the 8-bit address for register selection.
Read (READ):
The Read (READ) instruction outputs serial data on the DO pin. After a READ instruction is received, the instruction and address are decoded, followed by data transfer from the selected memory register into a 16-bit serial-out shift register. A dummy bit (logical 0 ) precedes the 16 -bit data output string. Output data changes are initiated by a low to high transition of the SK clock.

## Erase/Write Enable (EWEN):

When $V_{C C}$ is applied to the part, it powers up in the Erase/ Write Disable (EWDS) state. Therefore, all programming modes must be preceded by an Erase/Write Enable (EWEN) instruction. Once an Erase/Write Enable instruction is executed, programming remains enabled until an Erase/Write Disable (EWDS) instruction is executed or VCC is removed from the part.

## Erase (ERASE):

The ERASE instruction will program all bits in the specified register to the logical ' 1 ' state. CS is brought low following the loading of the last address bit. This falling edge of the CS pin initiates the self-timed programming cycle.
The DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( $\mathrm{t}_{\mathrm{CS}}$ ). DO $=$ logical ' 0 ' indicates that programming is still in progress. DO $=$ logical ' 1 ' indicates that the register, at the address specified in the instruction, has been erased, and the part is ready for another instruction.

## Write (WRITE):

The Write (WRITE) instruction is followed by 16 bits of data to be written into the specified address. After the last bit of data is put on the data-in (DI) pin, CS must be brought low before the next rising edge of the SK clock. This falling edge of CS initiates the self-timed programming cycle. The DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( $\mathrm{t}_{\mathrm{cs}}$ ). $\mathrm{DO}=$ logical 0 indicates that programming is still in progress. $\mathrm{DO}=$ logical 1 indicates that the register at the address specified in the instruction has been written with the data pattern specified in the instruction and the part is ready for another instruction.

## Erase All (ERAL):

The ERAL instruction will simultaneously program all registers in the memory array and set each bit to the logical ' 1 ' state. The Erase All cycle is identical to the ERASE cycle except for the different op-code. As in the ERASE mode, the DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( $\mathrm{t}_{\mathrm{CS}}$ ). The ERASE ALL instruction is not required, see note below.

## Write All (WRAL):

The (WRAL) instruction will simultaneously program all registers with the data pattern specified in the instruction. As in the WRITE mode, the DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( $\mathrm{t}_{\mathrm{CS}}$ ).

## Erase/Write Disable (EWDS):

To protect against accidental data disturb, the Erase/Write Disable (EWDS) instruction disables all programming modes and should follow all programming operations. Execution of a READ instruction is independent of both the EWEN and EWDS instructions.

NOTE: The NM93C06/C46/C56/C66 devices do not require an 'ERASE' or 'ERASE ALL' prior to the 'WRITE' and 'WRITE ALL' instructions. The 'ERASE' and 'ERASE ALL' instructions are included to maintain compatibility with the NMOS NMC9346.

## Instruction Set for the NM93C06 and NM93C46

| Instruction | SB | Op Code | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :--- | :--- |
| READ | 1 | 10 | A5-A0 |  | Reads data stored in memory, at specified address. |
| EWEN | 1 | 00 | $11 X X X X$ |  | Write enable must precede all programming modes. |
| ERASE | 1 | 11 | A5-AO |  | Erase register A5A4A3A2A1A0. |
| WRITE | 1 | 01 | A5-AO | D15-D0 | Writes register. |
| ERAL | 1 | 00 | $10 X X X X$ |  | Erases all registers. |
| WRAL | 1 | 00 | $01 X X X X$ | D15-D0 | Writes all registers. |
| EWDS | 1 | 00 | $00 X X X X$ |  | Disables all programming instructions. |

## Instruction Set for the NM93C56 and NM93C66

| Instruction | SB | Op Code | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :--- | :--- |
| READ | 1 | 10 | A7-A0 |  | Reads data stored in memory, at specified address. |
| EWEN | 1 | 00 | $11 X X X X X X$ |  | Write enable must precede all programming modes. |
| ERASE | 1 | 11 | A7-AO |  | Erase register A7A6A5A4A3A2A1A0. |
| ERAL | 1 | 00 | $10 X X X X X X$ |  | Erases all registers. |
| WRITE | 1 | 01 | A7-A0 | D15-D0 | Writes register if address is unprotected. |
| WRAL | 1 | 00 | $01 X X X X X X$ | D15-D0 | Writes all registers. |
| EWDS | 1 | 00 | $00 X X X X X X$ |  | Disables all programming instructions. |

## Timing Diagrams


*This is the minimum SK period (Note 2).
${ }^{\text {t}}$ SKS is not needed if $\mathrm{DI}=\mathrm{V}_{\mathrm{IL}}$ when CS is going active (HIGH).


TL/D/10751-5
"Address bits $A_{5}$ and $A_{4}$ become "don't care" for NM93C06. *Address bit $A_{7}$ becomes a "don't care" for NM93C56.

## EWEN:



Timing Diagrams (Continued)
EWDS:

*The NM93C56 and NM93C66 require a minimum of 11 clock cycles. The NM93C06 and NM93C46 require a minimum of 9 clock cycles. TL/D/10751-7


TL/D/10751-8
"Address bit $\mathrm{A}_{5}$ and $\mathrm{A}_{4}$ become "don't care" for NM93C06.
"Address bit $A_{7}$ becomes a "don't care" for NM93C56.

*The NM93C56 and NM93C66 require a minimum of 11 clock cycles. The NM93C06 and NM93C46 require a minimum of 9 clock cycles.

Timing Diagrams (Continued)


TL/D/10751-10
"Address bits A5 and A4 are "don't care" for NM93C06.
"Address bits A7 is "don't care" for NM93C56.


## NM93CS06/CS46/CS56/CS66

## 256-/1024-/2048-/4096-Bit Serial EEPROM with Data Protect and Sequential Read

## General Description

The NM93CS06/CS46/CS56/CS66 devices are 256/ 1024/2048/4096 bits, respectively, of CMOS non-volatile electrically erasable memory divided into 16/64/128/ 256 registers of 16 bits each. $N$ registers ( $\mathrm{N} \leq 16, \mathrm{~N} \leq 64$, $\mathrm{N} \leq 128, \mathrm{~N} \leq 256$ ) can be protected against data modification by programming the Protect Register with the address of the first register to be protected against data modification. Additionally, this address can be "locked" into the device, making all future attempts to change data impossible. These devices are fabricated using National Semiconductor floating-gate CMOS process for high reliability, high endurance and low power consumption. The NM93CSXX Family is offered in an SO package for small space considerations. The serial interface that operates these EEPROMs is MICROWIRETM compatible providing simple interfacing to standard microcontrollers and microprocessors. There are a total of 10 instructions, 5 which operate on the EEPROM memory, and 5 which operate on the Protect Register. The memory instructions are READ, WRITE, WRITE ALL, WRITE ENABLE, and WRITE DISABLE. The Protect register instructions are PRREAD, PRWRITE, PREN, PRCLEAR, and PRDS.

## Features

- Write protection in a user defined section of memory
- Sequential register read
m Typical active current of $400 \mu \mathrm{~A}$ and standby current of $25 \mu \mathrm{~A}$
- Direct write
- Reliable CMOS floating gate technology
- MICROWIRE compatible serial I/O
- Self timed write cycle
- Device status during programming mode
- 40 year data retention
- Endurance: $10^{6}$ data changes
- 4.5 V to 5.5 V operation in all modes of operation

■ Packages available: 8-pin SO, 8-pin DIP

## Block Diagram



## Connection Diagrams

## PIN OUT:

Dual-In-Line Package ( N ) and 8-Pin SO (M8)*


Top View
See NS Package Number N08E and M08A

TL/D/10750-2
N08E

## Pin Names

## CS Chip Select

SK Serial Data Clock
DI Serial Data Input
DO Serial Data Output
GND Ground
PE Program Enable
PRE Protect Register Enable
VCC Power Supply

PIN OUT:


TL/D/10750-3
Top View
See NS Package Number M14A

## Ordering Information

Commercial Temp. Range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Order Number* |
| :---: |
| NM93CS06N/NM93CS46N/NM93CS56N/NM93CS66N |
| NM93CS06M8/NM93CS46M8/NM93CS56M8/NM93CS66M* |

Extended Temp. Range $\left(-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}$ )

| Order Number* |
| :---: |
| NM93CS06EN/NM93CS46EN/NM93CS56EN/NM93CS66EN |
| NM93CS06EM8/NM93CS46EM8/NM93CS56EM8/NM93CS66EM* |

Military Temp. Range ( $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ )

| Order Number* |
| :---: |
| NM93CS06MN/NM93CS46MN/NM93CS56MN/NM93CS66MN |
| NM93CS06MM8/NM93CS46MM8/NM93CS56MM8 |

*The NM93CS66 is available in 8-Pin DIP and 14-Pin SO only.
Note: For 14 -pin SO availability on the 93CS06, CS46 and CS56, contact your local National Semiconductor Sales Office.

## Absolute Maximum Ratings

| If Military/Aerospace specified devices are required, |  |
| :--- | ---: |
| please contact the National | Semiconductor Sales |
| Office/Distributors for availability and specifications. |  |
| Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input or Output Voltages | +6.5 V to -0.3 V |
| with Respect to Ground |  |
| Lead Temperature (Soldering, 10 sec.$)$ | $+300^{\circ} \mathrm{C}$ |
| ESD rating | 2000 V |

## Operating Conditions

Ambient Operating Temperature

| NM93CSxx | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| NM93CSxxE | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| NM93CSxxM | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Power Supply (VCC) | 4.5 V to 5.5 V |

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V unless otherwise specified
Throughout this table, " $M$ " refers to temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ ), not package.

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC1 | Operating Current CMOS Input Levels | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | $\begin{aligned} & \mathrm{CS}=\mathrm{V}_{1 \mathrm{H}}, \mathrm{SK}=1.0 \mathrm{MHz} \\ & \mathrm{SK}=1.0 \mathrm{MHz} \\ & \mathrm{SK}=0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | mA |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Operating Current TTL Input Levels | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | $\begin{aligned} & \mathrm{CS}=\mathrm{V}_{1 \mathrm{H}}, \mathrm{SK}=1.0 \mathrm{MHz} \\ & \mathrm{SK}=1.0 \mathrm{MHz} \\ & \mathrm{SK}=0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \\ & 4 \end{aligned}$ | mA |
| $\mathrm{I}_{\mathrm{CC3}}$ | Standby Current | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | $\mathrm{CS}=0 \mathrm{~V}$ |  | $\begin{gathered} 50 \\ 50 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ |
| IIL | Input Leakage | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & -10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| loL | Output Leakage | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | $V_{\text {OUT }}=O V$ to $V_{C C}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & -10 \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | Input Low Voltage Input High Voltage |  |  | $\begin{gathered} -0.1 \\ 2 \end{gathered}$ | $\begin{gathered} 0.8 \\ v_{C C}+1 \end{gathered}$ | V |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage | NM93CS06E-NM93CS66E NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | $\begin{aligned} & \mathrm{IOL}^{2}=2.1 \mathrm{~mA} \\ & \mathrm{IOL}=2.1 \mathrm{~mA} \\ & \mathrm{IOL}=1.8 \mathrm{~mA} \end{aligned}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & 0.4 \end{aligned}$ | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage | NM93CS06M-NM93CS66M | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  | V |
| $\mathrm{V}_{\mathrm{OL} 2}$ $\mathrm{V}_{\mathrm{OH} 2}$ | Output Low Voltage Output High Voltage |  | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.2$ | 0.2 | V |
| ${ }_{\text {f }} \mathrm{K}$ | SK Clock Frequency | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M |  | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 \\ 1 \\ 0.5 \end{gathered}$ | MHz |
| $\mathrm{t}_{\text {SKH }}$ | SK High Time | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | (Note 2) (Note 2) (Note 3) | $\begin{aligned} & 250 \\ & 300 \\ & 500 \end{aligned}$ |  | ns |
| ${ }^{\text {t SKL }}$ | SK Low Time | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | (Note 2) (Note 2) (Note 3) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \end{aligned}$ |  | ns |
| ${ }^{\text {tSKS }}$ | SK Setup Time | $\begin{aligned} & \text { NM93CS06-NM93CS66 } \\ & \text { NM93CS06E-NM93CS66E } \\ & \text { NM93CS06M-NM93CS66M } \end{aligned}$ | Relative to CS | $\begin{aligned} & 50 \\ & 50 \\ & 100 \end{aligned}$ |  | ns |
| $t_{\text {cS }}$ | Minimum CS Low Time | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | (Note 4) (Note 4) (Note 5) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \end{aligned}$ |  | ns |
| tcss | CS Setup Time | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | Relative to SK | $\begin{aligned} & 50 \\ & 50 \\ & 100 \end{aligned}$ |  | ns |
| ${ }^{\text {tPRES }}$ | PRE Setup Time | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | Relative to SK | $\begin{gathered} 50 \\ 50 \\ 100 \end{gathered}$ |  | ns |

DC and AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V unless otherwise specified (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{DH}}$ | DO Hold Time |  | Relative to SK | 10 |  | ns |
| tpes | PE Setup Time | NM93CS06-NM93CS66 <br> NM93CS06E-NM93CS66E <br> NM93CS06M-NM93CS66M | Relative to SK | $\begin{aligned} & 50 \\ & 50 \\ & 100 \end{aligned}$ |  | ns |
| ${ }^{\text {t }}$ IS | DI Setup Time | NM93CS06-NM93CS66 <br> NM93CS06E-NM93CS66E <br> NM93CS06M-NM93CS66M | Relative to SK | $\begin{aligned} & 100 \\ & 100 \\ & 200 \end{aligned}$ |  | ns |
| ${ }^{\text {t }}$ CSH | CS Hold Time |  | Relative to SK | 0 |  | ns |
| tPEH | PE Hold Time | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | Relative to CS Relative to CS Relative to CS | $\begin{aligned} & 250 \\ & 250 \\ & 500 \end{aligned}$ |  | ns |
| $t_{\text {PREH }}$ | PRE Hold Time |  | Relative to SK | 0 |  | ns |
| $\mathrm{t}_{\text {DIH }}$ | DI Hold Time |  | Relative to SK | 20 |  | ns |
| $t_{\text {PD1 }}$ | Output Delay to "1" | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \\ \hline \end{gathered}$ | ns |
| tpDo | Output Delay to "0" | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \\ \hline \end{gathered}$ | ns |
| $\mathrm{t}_{\text {SV }}$ | CS to Status Valid | NM93CS06-NM93CS66 NM93CS06E-NM93CS66E NM93CS06M-NM93CS66M | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| ${ }^{\text {t }}$ F | CS to DO in TRI-STATE ${ }^{\circledR}$ | NM93CS06-NM93CS66 <br> NM93CS06E-NM93CS66E <br> NM93CS06M-NM93CS66M | AC Test $\mathrm{CS}=\mathrm{V}_{\mathrm{IL}}$ |  | $\begin{aligned} & 100 \\ & 100 \\ & 200 \end{aligned}$ | ns |
| $t_{\text {WP }}$ | Write Cycle Time |  |  |  | 10 | ms |

Capacitance (Note 6)
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Typ | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance |  | 5 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 5 | pF |

## AC Test Conditions

Output Load 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ Input Pulse Levels 0.4 V to 2.4 V

Timing Measurement Reference Level Input Output

1V and 2 V 0.8 V and 2 V

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 SK frequency specification for Commercial and Extended parts specifies a minimum SK clock period of 1 microsecond; therefore, in an SK clock cycle, $t_{S K H}+t_{\text {SKL }}$ must be greater than or equal to 1 microsecond. For example, if $\mathrm{t}_{\mathrm{SKL}}=250 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=750 \mathrm{~ns}$ in order to meet the SK frequency specification.

Note 3: The SK frequency specification for Military Temperature parts specifies a minimum SK clock period of 2 microseconds; therefore, in an SK clock cycle, $t_{S K H}+t_{\text {SKL }}$ must be greater than or equal to 2 microseconds. For example, if $\mathrm{t}_{\mathrm{SKL}}=500 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=1.5$ microseconds in order to meet the SK frequency specification.
Note 4: For Commercial and Extended parts, CS must be brought low for a minimum of $\mathbf{2 5 0} \mathbf{~ n s ~ ( ~} \mathrm{tcs}$ ) between consecutive instruction cycles.
Note 5: For Military Temperature parts, CS must be brought low for a minimum of 500 ns ( tcs ) between consecutive instruction cycles.
Note 6: This parameter is periodically sampled and not $100 \%$ tested.

## Functional Description

The NM93CSxx EEPROM Family has 10 instructions as described below. Note that there is a difference in the length of the instruction for the NM93CS06 and NM93CS46 vs. the NM93CS56 and NM93CS66. This is due to the fact that the two larger devices require 2 additional address bits which are not required for the smaller devices. Within the two groups of devices the number of address bits remain constant even though in some cases the most significant bit(s) are not used. In every instruction, the first bit is always a " 1 " and is viewed as a start bit. The next 8 or 10 bits (depending on device size) carry the op code and address. The address is either 6 or 8 bits depending on the device size.

## Read and Sequential Register Read (READ):

The Read (READ) instruction outputs serial data on the DO pin. After a READ instruction is received, the instruction and address are decoded, followed by data transfer from the selected memory register into a 16-bit serial-out shift register. A dummy bit (logical 0 ) precedes the 16 -bit data output string. Output data changes are initiated by a low to high transition of the SK clock. In the sequential register read mode of operation, the memory automatically cycles to the next register after each 16 data bits are clocked out. The dummy-bit is suppressed in this mode and a continuous string of data is obtained.

## Write Enable (WEN):

When $V_{C C}$ is applied to the part, it "powers up" in the Write Disable (WDS) state. Therefore, all programming modes must be preceded by a Write Enable (WEN) instruction. Once a Write Enable instruction is executed, programming remains enabled until a Write Disable (WDS) instruction is executed or $\mathrm{V}_{\mathrm{CC}}$ is removed from the part.
Write (WRITE):
The Write (WRITE) instruction is followed by 16 bits of data to be written into the specified address. After the last bit of data is put on the data-in (DI) pin, CS must be brought low before the next rising edge of the SK clock. This falling edge of the CS initiates the self-timed programming cycle. The PE pin MUST be held high while loading the WRITE instruction, however, after loading the WRITE instruction the PE pin becomes a "don't care". The DO pin indicates the READY/ BUSY status of the chip if CS is brought high after a minimum of 250 ns ( t CS ). DO $=$ logical 0 indicates that programming is still in progress. $\mathrm{DO}=$ logical 1 indicates that the register at the address specified in the instruction has been written with the data pattern specified in the instruction and the part is ready for another instruction.
Write All (WRALL):
The Write All (WRALL) instruction is valid only when the Protect Register has been cleared by executing a PRCLEAR instruction. The WRALL instruction will simultaneously program all registers with the data pattern specified in the instruction. Like the WRITE instruction, the PE pin MUST be held high while loading the WRALL instruction, however, after loading the WRITE instruction the PE pin becomes a "don't care". As in the WRITE mode, the DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of $250 \mathrm{~ns}\left(\mathrm{t}_{\mathrm{CS}}\right)$.

## Write Disable (WDS):

To protect against accidental data disturb, the Write Disable (WDS) instruction disables all programming modes and should follow all programming operations. Execution of a READ instruction is independent of both the WEN and WDS instructions.

## Protect Register Read (PRREAD):

The Protect Register Read (PRREAD) instruction outputs the address sto in the Protect Register on the DO pin. The PRE pin MUST be held high while loading the instruction. Following the PRREAD instruction the 6 - or 8 -bit address stored in the memory protect register is transferred to the serial out shift register. As in the READ mode, a dummy bit (logical 0) precedes the 6 - or 8 -bit address string.

## Protect Register Enable (PREN):

The Protect Register Enable (PREN) instruction is used to enable the PRCLEAR, PRWRITE, and PRDS modes. Before the PREN mode can be entered, the part must be in the Write Enable (WEN) mode. Both the PRE and PE pins MUST be held high while loading the instruction.
Note that a PREN instruction must immediately precede a PRCLEAR, PRWRITE, or PRDS instruction.

## Protect Register Clear (PRCLEAR):

The Protect Register Clear (PRCLEAR) instruction clears the address stored in the Protect Register and, therefore, enables all registers for the WRITE and WRALL instruction. The PRE and PE pins must be held high while loading the instruction, however, after loading the PRCLEAR instruction the PRE and PE pins become "don't care". Note that a PREN instruction must immediately precede a PRCLEAR instruction. The contents of the Protect Register will be read as O's after a PRCLEAR instruction.

## Protect Register Write (PRWRITE):

The Protect Register Write (PRWRITE) instruction is used to write into the Protect Register the address of the first register to be protected. After the PRWRITE instruction is executed, all memory registers whose addresses are greater than or equal to the address specified in the Protect Register are protected from the WRITE operation. Note that before executing a PRWRITE instruction the Protect Register must first be cleared by executing a PRCLEAR operation and that the PRE and PE pins must be held high while loading the instruction, however, after loading the PRWRITE instruction the PRE and PE pins become 'don't care'. Note that a PREN instruction must immediately precede a PRWRITE instruction.

## Protect Register Disable (PRDS):

The Protect Register Disable (PRDS) instruction is a one time only instruction which renders the Protect Register unalterable in the future. Therefore, the specified registers become PERMANENTLY protected against data changes. As in the PRWRITE instruction the PRE and PE pins must be held high while loading the instruction, and after loading the PRDS instruction the PRE and PE pins become "don't care".
Note that a PREN instruction must immediately precede a PRDS instruction.

## Instruction Set for the NM93CS06 and NM93CS46

| Instruction | SB | Op Code | Address | Data | PRE | PE | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| READ | 1 | 10 | A5-A0 |  | 0 | X | Reads data stored in memory, starting at specified address. |
| WEN | 1 | 00 | 11XXXX |  | 0 | 1 | Write enable must precede all programming modes. |
| WRITE | 1 | 01 | A5-A0 | D15-D0 | 0 | 1 | Writes register if address is unprotected. |
| WRALL | 1 | 00 | 01XXXX | D15-D0 | 0 | 1 | Writes all registers. Valid only when Protect Register is cleared. |
| WDS | 1 | 00 | 00XXXX |  | 0 | x | Disables all programming instructions. |
| PRREAD | 1 | 10 | XXXXXX |  | 1 | X | Reads address stored in Protect Register. |
| PREN | 1 | 00 | 11XXXX |  | 1 | 1 | Must immediately precede PRCLEAR, PRWRITE, and PRDS instructions. |
| PRCLEAR | 1 | 11 | 111111 |  | 1 | 1 | Clears the Protect Register so that no registers are protected from WRITE. Protect Register equals 0's. |
| PRWRITE | 1 | 01 | A5-A0 |  | 1 | 1 | Programs address into Protect Register. Thereafter, memory addresses $\geq$ the address in Protect Register are protected from WRITE. |
| PRDS | 1 | 00 | 000000 |  | 1 | 1 | One time only instruction after which the address in the Protect Register cannot be altered. |

## Instruction Set for the NM93CS56 and NM93CS66

| Instruction | SB | Op Code | Address | Data | PRE | PE | Comments |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| READ | 1 | 10 | A7-A0 |  | 0 | X | Reads data stored in memory, starting at specified address. |
| WEN | 1 | 00 | $11 X X X X X X$ |  | 0 | 1 | Write enable must precede all programming modes. |
| WRITE | 1 | 01 | A7-A0 | D15-D0 | 0 | 1 | Writes register if address is unprotected. |
| WRALL | 1 | 00 | $01 X X X X X X$ | D15-D0 | 0 | 1 | Writes all registers. Valid only when Protect Register is <br> cleared. |
| WDS | 1 | 00 | $00 X X X X X X$ |  | 0 | $X$ | Disables all programming instructions. |
| PRREAD | 1 | 10 | XXXXXXXX |  | 1 | $X$ | Reads address stored in Protect Register. |
| PREN | 1 | 00 | $11 X X X X X X$ |  | 1 | 1 | Must immediately precede PRCLEAR, PRWRITE, and <br> PRDS instructions. |
| PRCLEAR | 1 | 11 | 11111111 |  | 1 | 1 | Clears the "protect register" so that no registers are <br> protected from WRITE. Protect Register equals 0's. |
| PRWRITE | 1 | 01 | A7-A0 |  | 1 | 1 | Programs address into Protect Register. Thereafter, <br> memory addresses 2 the address in Protect Register are <br> protected from WRITE. |
| PRDS | 1 | 00 | 00000000 |  | 1 | 1 | One time only instruction after which the address in the <br> Protect Register cannot be altered. |

## Timing Diagrams



TL/D/10750-15
*This is the minimum SK period (Note 2).
${ }^{\dagger}{ }^{\text {tSKS }}$ is not needed if $\mathrm{DI}=\mathrm{V}_{\mathrm{IL}}$ when CS is going active (HIGH).


Di

"Address bit A7 becomes "don't care" for NM93CS56.
TL/D/10750-4
"Address bits A5 and A4 become "don't cares" for NM93CS06.
tThe memory automatically cycles to the next register.

## Timing Diagrams (Continued)

WEN:
PRE $=0$, D $0=$ TRI-STATE

*The NM93CS56 and NM93CS66 require a minimum of 11 clocks cycles. The NM93CS06 and NM93CS46 require a minimum of 9 clock cycles.

*The NM93CS56 and NM93CS66 require a minimum of 11 clocks cycles. The NM93CS06 and NM93CS46 require a minimum of 9 clock cycles.

WRITE:
PRE $=0$

"Address bit A7 becomes a "don't care" for NM93CS56.
*Address bits A5 and A4 become "don't cares" for NM93CS06.

## Timing Diagrams (Continued)


*Don't care
$\dagger$ Protect Register MUST be cleared.


Address bits A5 and A4 become "don't cares" for NM93CS06.
"Address bit A7 becomes "don't care" for NM93CS56.

Timing Diagrams (Continued)

PREN*:

*A WEN cycle must precede a PREN cycle.


Timing Diagrams (Continued)

"Address bits A5 and A4 become "don't cares" for NM93CS06.
$\dagger$ Protect Register MUST be cleared before a PRWRITE cycle. A PREN cycle must immedlately precede a PRWRITE cycle.


## NM93C06L/C46L/C56L/C66L 256-/1024-/2048-/4096-Bit Serial EEPROM with Extended Voltage (2.0V t0 5.5V)

## General Description

The NM93C06L/C46L/C56L/C66L devices are 256/1024/2048/4096 bits, respectively, of non-volatile electrically erasable memory divided into 16/64/128/256 x 16 -bit registers (addresses). The NM93CxxL Family functions in an extended voltage operating range, requires only a single power supply and is fabricated using National Semiconductor's floating gate CMOS technology for high reliability, high endurance and low power consumption. These devices are available in an SO package for small space considerations.
The NM93CxxL Family interfaces to microprocessors and microcontrollers via a single 4 -wire MICROWIRETM bus which possesses the following parameters: SK (Serial Clock), CS (Chip Select), DI (Data Input) and DO (Data-Output). Dl includes: instruction, address and data to be written. DO offers data read and programming status information. Serial interfacing allows 8 -pin DIP or 8 -pin SO packaging to minimize board space. The following seven instructions (op codes) control device operation: EWEN (Erase/Write Enable), EWDS (Erase/Write Disable), READ (Read), ERAL
(Erase all registers), ERASE (Erase a register/address), WRAL (Write all registers with 16 bits of data) and WRITE (Write a register/address).

## Features

■ 2.0 V to 5.5 V operation in read mode

- 2.5 V to 5.5 V operation in all other modes
- Typical active current of $400 \mu \mathrm{~A}$; Typical standby current of $25 \mu \mathrm{~A}$
- Direct write
- Reliable CMOS floating gate technology
- MICROWIRE compatible serial I/O
- Self-timed programming cycle
- Device status during programming mode
- 40 years data retention
- Endurance: $10^{6}$ data changes
- Packages available: 8-pin SO, 8-pin DIP

Block Diagram


## Connection Diagrams



TL/D/10045-2

Top View

| Pin Names |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| CS | Chip Select |  |  |  |
| SK | Serial Data Clock |  |  |  |
| DI | Serial Data Input |  |  |  |
| DO | Serial Data Output |  |  |  |
| GND | Ground |  |  |  |
| VI/D/10045-2 | Power Supply |  |  |  |

See NS Package Number N08E or M08A
Ordering Information
Commercial Temp. Range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Order Number |
| :---: |
| NM93C06LN/NM93C46LN |
| NM93C56LN/NM93C66LN |
| NM93C06LM8/NM93C46LM8 |
| NM93C56LM8/NM93C66LM8 |

Extended Temp. Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM93C06LEN/NM93C46LEN |
| NM93C56LEN/NM93C66LEN |
| NM93C06LEM8/NM93C46LEM8 |
| NM93C56LEM8/NM93C66LEM8 |

Alternate (Turned) SO Pinout

| Order Number |
| :---: |
| NM93C46TLM8/NM93C46TLEM8 |

Alternate SO Pinout (TM8)


See NS Package Number M08A

## LOW VOLTAGE (<4.5V) SPECIFICATIONS

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required,
please contact the National Semiconductor Sales
Office/Distributors for availability and specifications.
Ambient Storage Temperature

| All Input or Output Voltages | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| with Respect to Ground | +6.5 V to -0.3 V |
| Lead Temp. (Soldering, 10 sec.$)$ | $+300^{\circ} \mathrm{C}$ |
| ESD Rating | 2000 V |

## Operating Conditions

Ambient Operating Temperature

| NM93C06L-NM93C66L | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| NM93C06LE-NM93C66LE | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

Power Supply ( $\mathrm{V}_{\mathrm{CC}}$ ) Range Read Mode
All Other Modes
2.0 V to 5.5 V
2.5 V to 5.5 V

## DC and AC Electrical Characteristics

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {CC1 }}$ | Operating Current CMOS Input Levels | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $\mathrm{CS}=\mathrm{V}_{1 H}, \mathrm{SK}=250 \mathrm{kHz}$ |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | mA |
| Icc2 | Operating Current TTL Input Levels | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $\begin{aligned} & C S=V_{I H}, S K=250 \mathrm{kHz} \\ & 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | mA |
| Icc3 | Standby Current | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $C S=0 V$ |  | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\mu \mathrm{A}$ |
| ILL | Input Leakage | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $V_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{gathered} 2.5 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ |
| Iol | Output Leakage | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $V_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{gathered} 2.5 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL} 1} \\ & \mathrm{~V}_{\mathrm{IH} 1} \end{aligned}$ | Input Low Voltage Input High Voltage |  | $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ | 2 | 0.8 | V |
| $\begin{aligned} & V_{\mathrm{IL} 2} \\ & \mathrm{~V}_{\mathrm{IH} 2} \end{aligned}$ | Input Low Voltage Input High Voltage |  | $2 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 4.5 \mathrm{~V}$ | $\begin{gathered} -0.1 \\ 0.8 \mathrm{~V}_{\mathrm{CC}} \end{gathered}$ | $\begin{aligned} & 0.15 \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}+1 \end{aligned}$ | V |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL} 1} \\ & \mathrm{~V}_{\mathrm{OH} 1} \\ & \hline \end{aligned}$ | Output Low Voltage Output High Voltage |  | $\begin{aligned} & 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V} \\ & \mathrm{IOL}_{\mathrm{OL}}=2.1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \end{aligned}$ | 2.4 | 0.4 | $\begin{aligned} & V \\ & v \end{aligned}$ |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL} 2} \\ & \mathrm{~V}_{\mathrm{OH} 2} \\ & \hline \end{aligned}$ | Output Low Voltage Output High Voltage | , | $\begin{aligned} & 2 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \end{aligned}$ | $0.9 \mathrm{~V}_{\mathrm{CC}}$ | $0.1 \mathrm{~V}_{\mathrm{CC}}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| ${ }_{\text {f } K}$ | SK Clock Frequency | NM93C06L-NM93C66L NM93C06LE-NM93C66LE |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ | kHz |
| ${ }^{\text {tSKH }}$ | SK High Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | (Note 2) | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\mu \mathrm{S}$ |
| ${ }^{\text {t }}$ SKL | SK Low Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | (Note 2) | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\mu \mathrm{S}$ |
| ${ }^{\text {tsks }}$ | SK Setup Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | Relative to CS | $\begin{gathered} 50 \\ 50 \\ 100 \end{gathered}$ |  | ns |
| $\mathrm{t}_{\mathrm{c}}$ | Minimum CS Low Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | (Note 3) | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\text {css }}$ | CS Setup Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | Relative to SK | $\begin{aligned} & 0.2 \\ & 0.2 \end{aligned}$ |  | $\mu \mathrm{S}$ |
| ${ }^{\text {t }}$ D | DO Hold Time |  | Relative to SK | 10 |  | ns |

## LOW VOLTAGE (<4.5V) SPECIFICATIONS

## DC and AC Electrical Characteristics

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {DIS }}$ | DI Setup Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | Relative to SK | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{CSH}}$ | CS Hold Time |  | Relative to SK | 0 |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {DIH }}$ | DI Hold Time |  | Relative to SK | 0.4 |  | $\mu \mathrm{s}$ |
| tPD1 | Output Delay to "1" | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | AC Test |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\mu \mathrm{s}$ |
| tPDo | Output Delay to "0" | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | AC Test |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\mu \mathrm{S}$ |
| tsv | CS to Status Valid | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | AC Test |  | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\mu \mathrm{s}$ |
| $t_{\text {DF }}$ | CS to DO in TRI-STATE ${ }^{\text {® }}$ | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | AC Test $C S=V_{\mathrm{IL}}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & \hline \end{aligned}$ | $\mu \mathrm{S}$ |
| twp | Write Cycle Time |  |  |  | 15 | ms |

## Capacitance (Note 4)

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Max | Units |
| :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 5 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | pF |

## AC Test Conditions

| Output Load: 1 TTL Gate and $C_{L}=100 \mathrm{pF}$ |  |
| :---: | :---: |
| $V_{\text {cc }}$ Range | AC Test Conditions |
| $4.5 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<5.5 \mathrm{~V}$ | Input Pulse Levels 0.8 V and 2.0 V <br> Timing Measurement Level 0.9 V and 1.9 V <br> $\left(\mathrm{~V}_{\mathrm{IL}} / \mathrm{V}_{\mathrm{IH}}\right)$  <br> Timing Measurement Level 0.8 V and 2.0 V <br> $\left(\mathrm{~V}_{\mathrm{OL}} / \mathrm{V}_{\mathrm{OH}}\right)$  <br> $(\mathrm{TTL}$ Load Conditions:  <br> $\left.\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}\right)$  |
| $2.0 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V}$ | Input Pulse Levels 0.3 V and 1.8 V <br> Timing Measurement Level 0.4 V and 1.6 V <br> $\left(\mathrm{~V}_{\mathrm{IL}} / \mathrm{V}_{\mathrm{IH}}\right)$  <br> Timing Measurement Level 0.8 V and 1.6 V <br> $\left(\mathrm{~V}_{\mathrm{OL}} / \mathrm{V}_{\mathrm{OH}}\right)$  <br> (CMOS Load Conditions:  <br> $\left.\mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A}, \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}\right)$  |

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 above SK frequency specifies a minimum SK clock period of $4 \mu \mathrm{~s}$; therefore, in an SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to $4 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=1 \mu \mathrm{~s}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=3 \mu \mathrm{~s}$ in order to meet the SK frequency specification.
Note 3: CS must be brought low for a minimum of $1 \mu \mathrm{~S}$ ( $\mathrm{t} C \mathrm{~S}$ ) between consecutive instruction cycles.
Note 4: This parameter is periodically sampled and not $100 \%$ tested.

## STANDARD VOLTAGE ( $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ ) SPECIFICATIONS

\section*{Absolute Maximum Ratings (Note 1) <br> If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications. <br> | Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| All Input or Output Voltages | +6.5 V to -0.3 V |
| with Respect to Ground |  |
| Lead Temp. (Soldering, 10 sec.$)$ | $+300^{\circ} \mathrm{C}$ |
| ESD Rating | 2000 V |}

## Operating Conditions

Ambient Operating Temperature

| NM93C06L-NM93C66L | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| NM93C06LE-NM93C66LE | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Power Supply (VCC) | 4.5 V to 5.5 V |

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=5.0 \mathrm{v} \pm 10 \%$ unless otherwise specified

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {c Col }}$ | Operating Current CMOS Input Levels | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $\begin{aligned} \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =1 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | mA |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Operating Current TTL Input Levels | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $\begin{aligned} C S=V_{I H}, S K & =1 \mathrm{MHz} \\ S K & =1 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | mA |
| Icc3 | Standby Current | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $C S=O V$ |  | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\mu \mathrm{A}$ |
| IIL | Input Leakage | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $V_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{gathered} 2.5 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ |
| IOL | Output Leakage | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $V_{I N}=0 V$ to $V_{C C}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & \hline \end{aligned}$ | $\begin{array}{r} 2.5 \\ 10 \\ \hline \end{array}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | Input Low Voltage Input High Voltage |  |  | $\begin{gathered} -0.1 \\ 2 \\ \hline \end{gathered}$ | $\begin{gathered} 0.8 \\ v_{C C}+1 \end{gathered}$ | V |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \end{aligned}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  | V |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage | NM93C06LE-NM93C66LE | $\mathrm{IOL}=10 \mu \mathrm{~A}$ |  | 0.2 | V |
| $\mathrm{f}_{\mathrm{SK}}$ | SK Clock Frequency | NM93C06L-NM93C66L NM93C06LE-NM93C66LE |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | MHz |
| ${ }^{\text {tSKH }}$ | SK High Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 300 \\ & \hline \end{aligned}$ |  | ns |
| ${ }^{\text {tSKL }}$ | SK Low Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ |  | ns |
| ${ }^{\text {t }}$ CS | Minimum CS Low Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | (Note 4) (Note 5) | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ |  | ns |
| tcss | CS Setup Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | Relative to SK | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ |  | ns |
| $\mathrm{t}_{\mathrm{DH}}$ | DO Hold Time |  | Relative to SK | 10 |  | ns |

STANDARD VOLTAGE ( $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ ) SPECIFICATIONS
DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ unless otherwise specified (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tos | DI Setup Time | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | Relative to SK | $\begin{aligned} & 100 \\ & 200 \end{aligned}$ |  | ns |
| ${ }_{\text {t }}$ | CS Hold Time |  | Relative to SK | 0 |  | ns |
| $\mathrm{t}_{\mathrm{DIH}}$ | DI Hold Time |  | Relative to SK | 20 |  | ns |
| tPD1 | Output Delay to "1" | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | AC Test |  | $\begin{array}{r} 500 \\ 500 \\ \hline \end{array}$ | ns |
| tPD0 | Output Delay to "0" | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | AC Test |  | $\begin{array}{r} 500 \\ 500 \\ \hline \end{array}$ | ns |
| tsv | CS to Status Valid | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | AC Test |  | $\begin{aligned} & 500 \\ & 500 \\ & \hline \end{aligned}$ | ns |
| ${ }^{\text {t }}$ D $F$ | CS to DO in TRI-STATE | NM93C06L-NM93C66L NM93C06LE-NM93C66LE | AC Test $C S=V_{\mathrm{IL}}$ |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | ns |
| twp | Write Cycle Time |  |  |  | 10 | ms |

Note: Throughout this table " $M$ " refers to temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$, not package.
Capacitance (Note 6)
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Typ | Max | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance |  | 5 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 5 | pF |

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 SK frequency specification for Commercial and Extended temperature range parts specifies a minimum SK clock period of $1 \mu \mathrm{~s}$; therefore, in an SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to $1 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=250 \mathrm{~ns}$ then the minimum $\mathrm{t}_{\mathrm{SKH}}=750 \mathrm{~ns}$ in order to meet the SK frequency specification.
Note 3: The SK frequency specification for Military Temperature parts specifies a minimum SK clock period of $2 \mu \mathrm{~s}$; therefore, in an SK clock cycle, tsKH + tsKL must be greater than or equal to $2 \mu \mathrm{~s}$. For example, if the $\mathrm{t}_{\mathrm{SKL}}=500 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=1.5 \mu \mathrm{~s}$ in order to meet the SK frequency specification.
Note 4: For Commercial and Extended temperature range parts, CS must be brought low for a minimum of 250 ns ( tcS ) between consecutive instruction cycles.
Note 5: For Military Temperature parts CS must be brought low for a minimum of 500 ns ( tcs ) between consecutive instruction cycles.
Note 6: This parameter is periodically sampled and not $100 \%$ tested.

## Functional Description

The NM93CxxL Family has seven instruction sets as described below. Note that each instruction set is broken down into the Start Bit (SB), Op code, Address (if applicable) and Data (if applicable). As shown in the timing diagrams and INSTRUCTION SET tables, address bits will have 6 bits for the NM93C06 and NM93C46 and 8 bits for the NM93C56 and NM93C66 devices. All instruction bits are entered into the device on the SK low-to-high transitions.
Programming is enabled by bringing CS to a Logical 0 state for the required $\mathrm{t}_{\mathrm{CS}}$ period. After this $\mathrm{t}_{\mathrm{CS}}$ period the selftimed operation may be monitored by bringing CS to a logical 1 and observing the DO status: Logical $1=$ READY (Ready for the next instruction) and Logical $0=$ BUSY (Programming in progress).
Erase/Write Enable (EWEN):
When $V_{C C}$ is applied to the device, it powers up in the programming Erase/Write disabled state. Therefore, all programming modes must be preceded by an Erase/Write Enable (EWEN) instruction. Once this instruction is executed, programming remains enabled until the Erase/Write Disable (EWDS) instruction is executed or until $\mathrm{V}_{\mathrm{CC}}$ is removed from the part.

## Erase/Write Disable (EWDS):

To protect against accidental data disturbance, the Erase/ Write Disable instruction disables all programming modes and should follow the end of all programming cycles.

## Read (READ):

The READ instruction outputs the specified address data on the DO pin. After the READ instruction is received, the instruction and address are decoded and data is transferred from the address to a 16 -bit shift register output buffer. A dummy bit (logical 0 ) precedes all 16 -bit data out strings. The READ instruction may be executed from either the enabled or disabled state.

## Erase (ERASE):

This instruction, when followed by an address location, programs all bits in the selected register/address to a 1 state (Register erase).

## Erase All (ERAL):

This instruction programs all registers/addresses in the memory array to a 1 state, (Bulk erase).

## Write (WRITE):

This instruction, when followed by an address location and 16 bits of data, programs the selected register/address.

Write All (WRAL):
This instruction, when followed by 16 bits of data, programs all registers/addresses in the memory array with the specified data pattern, (Bulk write).

## Instruction Set for the NM93C06L and NM93C46L

| Instruction | SB | Op Code | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :---: | :--- |
| READ | 1 | 10 | A5-A0 |  | Reads data stored in memory at specified address. |
| EWEN | 1 | 00 | $11 X X X X$ |  | Write enable must precede all programming modes. |
| ERASE | 1 | 11 | A5-AO |  | Erase register A5A4A3A2A1AO. |
| WRITE | 1 | 01 | A5-A0 | D15-D0 | Writes register. |
| ERAL | 1 | 00 | $10 X X X X$ |  | Erases all registers. |
| WRAL | 1 | 00 | $01 X X X X$ | D15-D0 | Writes all registers. |
| EWDS | 1 | 00 | $00 X X X X$ |  | Disables all programming instructions. |

## Instruction Set for the NM93C56L and NM93C66L

| Instruction | SB | Op Code | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :---: | :--- |
| READ | 1 | 10 | A7-A0 |  | Reads data stored in memory at specified address. |
| EWEN | 1 | 00 | $11 X X X X X X$ |  | Write enable must precede all programming modes. |
| ERASE | 1 | 11 | A7-A0 |  | Erase register A7A6A5A4A3A2A1A0. |
| WRITE | 1 | 01 | A7-A0 | D15-D0 | Writes register. |
| ERAL | 1 | 00 | $10 X X X X X$ |  | Erases all registers. |
| WRAL | 1 | 00 | $01 X X X X X$ | D15-D0 | Writes all registers. |
| EWDS | 1 | 00 | $00 X X X X X$ |  | Disables all programming instructions. |

## Timing Diagrams



TL/D/10045-13
*This is the minimum SK period (Note 2).
${ }^{\dagger}{ }^{\text {ISKS }}$ is not needed if $\mathrm{DI}=\mathrm{V}_{\mathrm{IL}}$ when CS is going active (HIGH).

"Address bits $\mathrm{A}_{5}$ and $\mathrm{A}_{4}$ become "don't care" for NM93C06L.
"Address bit $A_{7}$ becomes a "don't care" for NM93C56L.

*The NM93C56L and NM93C66L require a minimum of 11 clock cycles. The NM93C06L and NM93C46L require a minimum of 9 clock cycles.

Timing Diagrams (Continued)

*The NM93C56L and NM93C66L require a minimum of 11 clock cycles. The NM93C06L and NM93C46L require a minimum of 9 clock cycles.


TL/D/10045-8
*Address bit $\mathrm{A}_{5}$ and $\mathrm{A}_{4}$ become "don't care" for NM93C06L.
"Address bit $A_{7}$ becomes a "don't care" for NM93C56L.


TL/D/10045-9
*The NM93C56L and NM93C66L require a minimum of 11 clock cycles. The NM93C06L and NM93C46L require a minimum of 9 clock cycles.

Timing Diagrams (Continued)
ERASE:


TL/D/10045-10

ERAL:



TL/D/10045-11

NM93CS06L/CS46L/CS56L/CS66L 256-/1024-/2048-/4096-Bit Serial EEPROM with Extended Voltage (2.0V to 5.5V) and Data Protect

## General Description

The NM93CS06L/CS46L/CS56L/CS66L devices are 256/1024/2048/4096 bits, respectively, of non-volatile electrically erasable memory divided into 16/64/128/256 x 16-bit registers (addresses). The NM93CSxxL Family functions in an extended voltage operating range and is fabricated using National Semiconductor's floating gate CMOS technology for high reliability, high endurance and low power consumption. N registers ( $\mathrm{N} \leq 16, \mathrm{~N} \leq 64, \mathrm{~N} \leq 128$, $N \leq 256$ ) can be protected against data modification by programming the Protect Register with the address of the first register to be protected against data modification. Additionally, this address can be "locked" into the device, making all future attempts to change data impossible.
These devices are available in an SO package for small space considerations.
The serial interface that control these EEPROMs is MICROWIRETM compatible, providing simple interfacing to standard microcontrollers and microprocessors. There are a total of 10 instructions, 5 which operate on the EEPROM memory and 5 which operate on the Protect Register. The memory instructions are READ, WRITE, WRITE ALL, WRITE ENABLE, and WRITE DISABLE. The Protect register instructions are PRREAD, PRWRITE, PREN, PRCLEAR, and PRDS.

## Features

■ Sequential register read

- Write protection in a user defined section of memory
- 2.0 V to 5.5 V operating range in read mode
- 2.5 V to 5.5 V operating range in other modes
- Typical active current of $400 \mu \mathrm{~A}$; typical standby current of $25 \mu \mathrm{~A}$
- Direct Write
- Reliable CMOS floating gate technology
- MICROWIRE compatible serial I/O
- Self timed write cycle
- Device status during programming mode
- 40 year data retention
- Endurance: 106 data changes
- Packages Available: 8-pin SO, 8-pin DIP


## Block Diagram



TL/D/10044-1

## Connection Diagrams

Dual－In－Line Package（ N ） and 8－PIn SO Package（M8）


See NS Package Number N08E（N） See NS Package Number M08A（M8）

Pin Names

| CS | Chip Select |
| :---: | :--- |
| SK | Serial Data Clock |
| DI | Serial Data Input |
| DO | Serial Data Output |
| GND | Ground |
| PE | Program Enable |
| PRE | Protect Register Enable |
| $V_{C C}$ | Power Supply |

PIN OUT：
SO Package（M）


Top View
See NS Package Number M14A（M）

## Ordering Information

Commercial Temp．Range（ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ ）

| Order Number |
| :--- |
| NM93CS06LN／NM93CS46LN／NM93CS56LN／NM93CS66LN |
| NM93CS06LM8／NM93CS46LM8／NM93CS56LM8／NM93CS66LM＊ |

Extended Temp．Range（ $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ）

| Order Number |
| :--- |
| NM93CS06LEN／NM93CS46LEN／NM93CS56LEN／NM93CS66LEN |
| NM93CS06LEM8／NM93CS46LEM8／NM93CS56LEM8／NM93CS66LEM＊ |

＊The NM93CS66 is available in 8－pin DIP and 14－pin SO only．
Note：14－pin SO availability on the 93CS06，CS46 and CS56，contact your local National Semiconductor Sales Office．

## LOW VOLTAGE (<4.5) SPECIFICATIONS

## Absolute Maximum Ratings (Note 1)

If Milltary/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Ambient Storage Temperature All Input or Output Voltages with Respect to Ground
Lead Temperature (Soldering, 10 sec .)
ESD rating

$$
\begin{array}{r}
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
+6.5 \mathrm{~V} \text { to }-0.3 \mathrm{~V} \\
+300^{\circ} \mathrm{C} \\
2000 \mathrm{~V}
\end{array}
$$

Operating Conditions
Ambient Operating Temperature
NM93CSxxL
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
NM93CSxxLE
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

Power Supply ( $\mathrm{V}_{\mathrm{CC}}$ ) Range
Read Mode
2.0 V to 5.5 V
2.5 V to 5.5 V

## DC and AC Electrical Characteristics

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VRPP | Power Supply Ripple |  | Peak-to-Peak (Note 5) |  | $0.1 \mathrm{~V}_{\text {cc }}$ | V |
| ${ }^{\text {l CC1 }}$ | Operating Current CMOS Input Levels | NM93CS06L-NM93CS66L <br> NM93CS06LE-NM93CS66LE | $\mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK}=250 \mathrm{kHz}$ |  | $\begin{array}{r} 2 \\ 2 \\ \hline \end{array}$ | mA |
| ${ }^{\text {ICC2 }}$ | Operating Current TTL Input Levels | NM93CS06L-NM93CS66L NM93CS06LE-NM93CSS66LE | $\begin{aligned} & \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK}=250 \mathrm{kHz} \\ & 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | mA |
| $\mathrm{I}_{\mathrm{CC3}}$ | Standby Current | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | $C S=O V$ |  | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\mu \mathrm{A}$ |
| IIL | Input Leakage | NM93CS06L-NM93CS66L <br> NM93CS06LE-NM93CS66LE | $V_{I N}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{gathered} 2.5 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ |
| IOL | Output Leakage | NM93CS06L-NM93CS66L NM93CS06LE-NM93CSS66LE | $V_{\text {OUT }}=O V$ to $V_{C C}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL1}} \\ & \mathrm{~V}_{\mathrm{IH} 1} \\ & \hline \end{aligned}$ | Input Low Voltage Input High Voltage |  | $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ | 2 | 0.8 | V |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL} 2} \\ & \mathrm{~V}_{\mathrm{IH} 2} \\ & \hline \end{aligned}$ | Input Low Voltage Input High Voltage |  | $2 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 4.5 \mathrm{~V}$ | $\begin{gathered} -0.1 \\ 0.8 \mathrm{~V}_{\mathrm{CC}} \end{gathered}$ | $\begin{aligned} & 0.15 V_{C C} \\ & V_{C C}+1 \end{aligned}$ | V |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL} 1} \\ & \mathrm{~V}_{\mathrm{OH} 1} \end{aligned}$ | Output Low Voltage Output High Voltage |  | $\begin{aligned} & 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \end{aligned}$ | 2.4 | 0.4 | V |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL} 2} \\ & \mathrm{~V}_{\mathrm{OH} 2} \\ & \hline \end{aligned}$ | Output Low Voltage Output High Voltage |  | $\begin{aligned} & 2 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \end{aligned}$ | 0.9 VCC | 0.1 V CC | V |
| $\mathrm{f}_{\mathrm{SK}}$ | SK Clock Frequency | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline 250 \\ & 250 \\ & \hline \end{aligned}$ | kHz |
| ${ }_{\text {tSKH }}$ | SK High Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | (Note 2) | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ SKL | SK Low Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | (Note 2) | $\begin{aligned} & 1 \\ & 1 \\ & \hline \end{aligned}$ |  | $\mu \mathrm{S}$ |
| ${ }^{\text {tSKS }}$ | SK Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to CS | $\begin{gathered} 50 \\ 50 \\ 100 \\ \hline \end{gathered}$ |  | ns |
| ${ }^{\text {t CS }}$ | Minimum CS Low Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | (Note 3) | $\begin{aligned} & 1 \\ & 1 \\ & \hline \end{aligned}$ |  | $\mu \mathrm{S}$ |
| tcss | CS Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to SK | $\begin{aligned} & 0.2 \\ & 0.2 \end{aligned}$ |  | $\mu \mathrm{s}$ |
| tPRES | PRE Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to SK | $\begin{aligned} & 0.2 \\ & 0.2 \end{aligned}$ |  | $\mu \mathrm{S}$ |

## LOW VOLTAGE (<4.5) SPECIFICATIONS (Continued)

DC and AC Electrical Characteristics (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tpes | PE Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to SK | $\begin{aligned} & 0.2 \\ & 0.2 \end{aligned}$ |  | $\mu \mathrm{s}$ |
| ${ }_{\text {t }}$ | DI Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to SK | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | DO Hold Time |  | Relative to SK | 10 |  | ns |
| ${ }^{\text {t CSH }}$ | CS Hold Time |  | Relative to SK | 0 |  | $\mu \mathrm{s}$ |
| $t_{\text {PEH }}$ | PE Hold Time | NM93CS06L-NM93CS66L <br> NM93CS06LE-NM93CS66LE | Relative to CS <br> Relative to CS | $\begin{aligned} & 0.4 \\ & 0.4 \\ & \hline \end{aligned}$ |  | $\mu \mathrm{s}$ |
| tpREH | PRE Hold Time |  | Relative to SK | 0 |  | $\mu \mathrm{s}$ |
| ${ }_{\text {tIIH }}$ | DI Hold Time |  | Relative to SK | 0.4 |  | $\mu \mathrm{s}$ |
| $t_{\text {PD1 }}$ | Output Delay to "1" | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | AC Test |  | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {PDO }}$ | Output Delay to "0" | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | AC Test |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\mu \mathrm{S}$ |
| tsv | CS to Status Valid | NM93CS06L_NM93CS66L NM93CS06LE-NM93CS66LE | AC Test |  | $\begin{aligned} & 1 \\ & 1 \\ & \hline \end{aligned}$ | $\mu \mathrm{S}$ |
| $t_{\text {DF }}$ | $\begin{aligned} & \text { CS to DO in } \\ & \text { TRI-STATE }{ }^{\circledR} \end{aligned}$ | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | $C S=V_{I L}$ <br> AC Test |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & \hline \end{aligned}$ | $\mu \mathrm{S}$ |
| twp | Write Cycle Time |  |  |  | 15 | ms |

Capacitance (Note 4)
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Max | Units |
| :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 5 | pF |
| $\mathrm{C}_{\mathrm{I}}$ | Input Capacitance | 5 | pF |

## AC Test Conditions

| Output Load: 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |  |
| :---: | :---: |
| $V_{\text {cc }}$ Range | AC Test Conditions |
| $4.5 \mathrm{~V}<\mathrm{V}_{C C}<5.5 \mathrm{~V}$ | Input Pulse Levels 0.8 V and 2.0 V <br> Timing Measurement Level $\left(\mathrm{V}_{\mathrm{IL}} / \mathrm{V}_{\mathrm{IN}}\right)$ : 0.9 V and 1.9 V <br> Timing Measurement Level $\left(\mathrm{V}_{\mathrm{OL}} / \mathrm{V}_{\mathrm{OH}}\right)$ : 0.8 V and 2.0 V <br> $\left(\mathrm{TTL}\right.$ Load Conditions: $\left.\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} ; \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}\right)$  |
| $2.0 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V}$ | Input Pulse Levels: 0.3 V and 1.8 V <br> Timing Measurement Level $\left(\mathrm{V}_{\mathrm{IL}} / \mathrm{V}_{\mathrm{IH}}\right)$ : 0.4 V and 1.6 V <br> Timing Measurement Level $\left(\mathrm{V}_{\mathrm{OL}} / \mathrm{V}_{\mathrm{OH}}\right)$ : 0.8 V and 1.6 V <br> (CMOS Load Conditions: $\left.\mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} ; \mathrm{l}_{\mathrm{OH}}=-10 \mu \mathrm{~A}\right)$  |

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 above SK frequency specifies a minimum SK clock period of $4 \mu \mathrm{~s}$; therefore, in an SK clock cycle, $\mathrm{t}_{\text {SKH }}+\mathrm{t}_{\text {SKL }}$ must be greater than or equa! to $4 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=1 \mu \mathrm{~s}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=3 \mu \mathrm{~s}$ in order to meet the SK frequency specification.
Note 3: CS must be brought low for a minimum of $1 \mu \mathrm{~s}\left(\mathrm{t}_{\mathrm{CS}}\right)$ between consecutive instruction cycles.
Note 4: This parameter is periodically sampled and not $100 \%$ tested.
Note 5: Rate of voltage change must be less than $0.5 \mathrm{~V} / \mathrm{ms}$.

## STANDARD VOLTAGE ( $4.5 \leq \mathrm{V} \leq 5.5$ ) SPECIFICATIONS

| Absolute Maximum Ratings (Note 1) |  |
| :---: | :---: |
| If Military/Aerospace specifl please contact the Nation | ices are required, iconductor Sales d specifications. |
| Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input or Output Voltages with Respect to Ground | +6.5 V to -0.3 |
| Lead Temp. (Soldering, 10 second) | $+300^{\circ} \mathrm{C}$ |
| ESD Rating | 200 |

DC and AC Electrical Characteristics $\mathrm{v}_{C C}=4.5 \mathrm{~V}$ to 5.5 V unless otherwise specified
Throughout this table " M " refers to temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ ) not package.

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC1 | Operating Current CMOS Input Levels | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | $\begin{aligned} & C S=V_{I H}, S K=1.0 \mathrm{MHz} \\ & S K=1.0 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | mA |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Operating Current TTL Input Levels | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | $\begin{aligned} & \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK}=1.0 \mathrm{MHz} \\ & \mathrm{SK}=1.0 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | mA |
| ICC3 | Standby Current | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | $\mathrm{CS}=0 \mathrm{~V}$ |  | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ | $\mu \mathrm{A}$ |
| IIL | Input Leakage | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| lol | Output Leakage | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | $V_{\text {OUT }}=O V$ to $V_{C C}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & V_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | Input Low Voltage Input High Voltage |  |  | $\begin{gathered} -0.1 \\ 2 \\ \hline \end{gathered}$ | $\begin{gathered} 0.8 \\ v_{C C}+1 \end{gathered}$ | V |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage | NM93CS06LE-NM93CS66LE NM93CS06LE-NM93CS66LE | $\begin{aligned} \mathrm{IOL} & =2.1 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OL}} & =2.1 \mathrm{~mA} \end{aligned}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & \hline \end{aligned}$ | V |
| VOL2 <br> $\mathrm{VOH}_{2}$ | Output Low Voltage Output High Voltage |  | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=-10 \mu \mathrm{~A} \end{aligned}$ | $\mathrm{V}_{\mathrm{CC}}-0.2$ | 0.2 | V |
| ${ }_{\text {f }} \mathrm{K}$ | SK Clock Frequency | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | MHz |
| ${ }^{\text {tSKH }}$ | SK High Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | (Note 2) <br> (Note 2) | $\begin{aligned} & 250 \\ & 300 \\ & \hline \end{aligned}$ |  | ns |
| ${ }_{\text {tSKL }}$ | SK Low Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | (Note 2) <br> (Note 2) | $\begin{aligned} & 250 \\ & 250 \\ & \hline \end{aligned}$ |  | ns |
| ${ }^{\text {t }}$ cs | Minimum CS Low Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | (Note 4) (Note 4) | $\begin{aligned} & 250 \\ & 250 \\ & \hline \end{aligned}$ |  | ns |
| tcss | CS Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to SK | $\begin{array}{r} 50 \\ 50 \\ \hline \end{array}$ |  | ns |
| tpres | PRE Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to SK | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ |  | ns |
| $t_{\text {DH }}$ | DO Hold Time |  | Relative to SK | 10 |  | ns |

## STANDARD VOLTAGE ( $4.5 \leq \mathrm{V} \leq 5.5$ ) SPECIFICATIONS (Continued)

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{cC}}=4.5 \mathrm{~V}$ to 5.5 V unless otherwise specified Throughout this table " M " refers to temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ ) not package. (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPES | PE Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to SK | $\begin{aligned} & 50 \\ & 50 \end{aligned}$ |  | ns |
| tois | DI Setup Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to SK | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ |  | ns |
| $\mathrm{t}_{\text {CSH }}$ | CS Hold Time |  | Relative to SK | 0 |  | ns |
| tPEH | PE Hold Time | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | Relative to CS Relative to CS | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ |  | ns |
| tPREH | PRE Hold Time |  | Relative to SK | 0 |  | ns |
| $\mathrm{t}_{\text {DIH }}$ | DI Hold Time |  | Relative to SK | 20 |  | ns |
| ${ }_{\text {tPD1 }}$ | Output Delay to "1" | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | AC Test |  | $\begin{aligned} & 500 \\ & 500 \end{aligned}$ | ns |
| tPDO | Output Delay to "0" | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | AC Test |  | $\begin{aligned} & 500 \\ & 500 \end{aligned}$ | ns |
| tsv | CS to Status Valid | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | AC Test |  | $\begin{aligned} & 500 \\ & 500 \end{aligned}$ | ns |
| $t_{\text {DF }}$ | CS to DO in TRI-STATE ${ }^{\circledR}$ | NM93CS06L-NM93CS66L NM93CS06LE-NM93CS66LE | AC Test $\mathrm{CS}=\mathrm{V}_{\mathrm{IL}}$ |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | ns |
| $t_{W P}$ | Write Cycle Time |  |  |  | 10 | ms |

Capacitance (Note 6)
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Max | Units |
| :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 5 | pF |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 5 | pF |

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 SK frequency specification for Commercial and Extended parts specifies a minimum SK clock period of 1 microsecond; therefore, in an SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to 1 microsecond. For example, if $\mathrm{t}_{\mathrm{SKL}}=250 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=750 \mathrm{~ns}$ in order to meet the SK frequency specification.

Note 3: The SK frequency specification for Military Temperature parts specifies a minimum SK clock period of 2 microseconds; therefore, in an SK clock cycle, $t_{S K H}+t_{\text {SKL }}$ must be greater than or equal to 2 microseconds. For example, if $\mathrm{t}_{\mathrm{SKL}}=500 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=1.5$ microseconds in order to meet the SK frequency specification.
Note 4: For Commercial and Extended parts, CS must be brought low for a minimum of 250 ns ( tcs ) between consecutive instruction cycles.
Note 5: For Military Temperature parts, CS must be brought low for a minimum of 500 ns ( $\mathrm{t}_{\mathrm{CS}}$ ) between consecutive instruction cycles.
Note 6.: This parameter is periodically sampled and not $100 \%$ tested.

## Functional Description

The extended voltage EEPROMs of the NM93CSxxL Family have 10 instructions as described below. Note that there is a difference in the length of the instruction for the NM93CS06L and NM93CS46L vs. the NM93CS56L and NM93CS66L since the two larger devices require 2 additional address bits which are not required for the smaller devices. Within the two groups of devices the number of address bits remain constant even though in some cases the most significant bit(s) are not used. In every instruction, the first bit is always a " 1 " and is viewed as a start bit. The next 8 or 10 bits, depending on device size, carry the op code and address. The address is either 6 or 8 bits, depending on the device size.

## Read and Sequential Register Read (READ):

The Read (READ) instruction outputs serial data on the D0 pin. After a READ instruction is received, the instruction and address are decoded, followed by data transfer from the selected memory register into a 16 -bit serial-out shift register. A dummy bit (logical 0 ) precedes the 16 -bit data output string. Output data changes are initiated by a low to high transition of the SK clock. In the Sequential Read mode of operation, the memory automatically cycles to the next register after each 16 data bits are clocked out. The dummy-bit is suppressed in this mode and a continuous string of data is obtained.

## Write Enable (WEN):

When $V_{C C}$ is applied to the part, it "powers up" in the Write Disable (WDS) state. Therefore, all programming modes must be preceded by a Write Enable (WEN) instruction. Once a Write Enable instruction is executed, programming remains enabled until a Write Disable (WDS) instruction is executed or $V_{C C}$ is removed from the part.

## Write (WRITE):

The Write (WRITE) instruction is followed by 16 bits of data to be written into the specified address. After the last bit of data is allocated to the data-in (DI) pin, CS must be brought low before the next rising edge of the SK clock. This falling edge of the CS initiates the self-timed programming cycle. The PE pin MUST be held high while loading the WRITE instruction; however, after loading the WRITE instruction, the PE pin becomes a "don't care". The D0 pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( tcs ). $\mathrm{DO}=$ logical 0 indicates that programming is still in progress. $\mathrm{DO}=$ logical 1 indicates that the register at the address specified in the instruction has been written with the data pattern specified in the instruction and that the part is ready for another instruction.

## Write All (WRALL):

The Write All (WRALL) instruction is valid only when the Protect Register has been cleared by executing a PRCLEAR instruction. The WRALL instruction will simultaneously program all registers with the data pattern specified in the instruction. Like the WRITE instruction, the PE pin MUST be held high while loading the WRALL instruction; however, after loading the WRITE instruction, the PE pin becomes a "don't care". As in the WRITE mode, the DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( tcs ).

## Write Disable (WDS):

To protect against accidental data disturb, the Write Disable (WDS) instruction disables all programming modes and should follow all programming operations. Execution of a READ instruction is independent of both the WEN and WDS instructions.

## Protect Register Read (PRREAD):

The Protect Register Read (PRREAD) instruction outputs the address stored in the Protect Register on the DO pin. The PRE pin MUST be held high while loading the instruction. Following the PRREAD instruction the 6- or 8-bit address stored in the memory protect register is transferred to the serial out shift register. As in the READ mode, a dummy bit (logical 0 ) precedes the 6- or 8-bit address string.

## Protect Register Enable (PREN):

The Protect Register Enable (PREN) instruction is used to enable the PRCLEAR, PRWRITE, and PRDS modes. Before the PREN mode can be entered, the part must be in the Write Enable (WEN) mode. Both the PRE and PE pins MUST be held high while loading the instruction.
Note that a PREN instruction must immediately precede a PRCLEAR, PRWRITE, or PRDS instruction.

## Protect Register Clear (PRCLEAR):

The Protect Register Clear (PRCLEAR) instruction clears the address stored in the Protect Register and therefore enables all registers for the WRITE and WRALL instruction. The PRE and PE pins must be held high while loading the instruction; however, after loading the PRCLEAR instruction, the PRE and PE pins become "don't care". Note that a PREN instruction must immediately precede a PRCLEAR instruction. The Protect Register will be read as Os after it is cleared.

## Protect Register Write (PRWRITE):

The Protect Register Write (PRWRITE) instruction is used to write into the Protect Register which is the address of the first register to be protected. After the PRWRITE instruction is executed, all memory registers whose addresses are greater than or equal to the address specified in the Protect Register are protected from the WRITE operation. Note that before executing a PRWRITE instruction, the Protect Register must first be cleared by executing a PRCLEAR operation and the PRE and PE pins must be held high while loading the instruction; however, after loading the PRWRITE instruction, the PRE and PE pins become "don't care". Note that a PREN instruction must immediately precede a PRWRITE instruction.

## Protect Register Disable (PRDS):

The Protect Register Disable (PRDS) instruction is a one time only instruction which renders the Protect Register unalterable in the future. Therefore, the specified registers become PERMANENTLY protected against data changes. As in the PRWRITE instruction the PRE and PE pins must be held high while loading the instruction, and after loading the PRDS instruction the PRE and PE pins become "don't care".
Note that a PREN instruction must immediately precede a PRDS instruction.

## Instruction Set for the NM93CS06L and NM93CS46L

| Instruction | SB | Op Code | Address | Data | PRE | PE | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| READ | 1 | 10 | A5-A0 |  | 0 | X | Reads data stored in memory, starting at specified address. |
| WEN | 1 | 00 | 11XXXX |  | 0 | 1 | Write enable must precede all programming modes. |
| WRITE | 1 | 01 | A5-A0 | D15-D0 | 0 | 1 | Writes register if address is unprotected. |
| WRALL | 1 | 00 | 01XXXX | D15-D0 | 0 | 1 | Writes all registers. Valid only when Protect Register is cleared. |
| WDS | 1 | 00 | 00XXXX |  | 0 | $x$ | Disables all programming instructions. |
| PRREAD | 1 | 10 | XXXXXX |  | 1 | X | Reads address stored in Protect Register. |
| PREN | 1 | 00 | 11XXXX |  | 1 | 1 | Must immediately precede PRCLEAR, PRWRITE, and PRDS instructions. |
| PRCLEAR | 1 | 11 | 111111 |  | 1 | 1 | Clears the Protect Register so that no registers are protected from WRITE. Cleared state is read as 0's. |
| PRWRITE | 1 | 01 | A5-A0 |  | 1 | 1 | Programs address into Protect Register. Thereafter, memory addresses $\geq$ the address in Protect Register are protected from WRITE. |
| PRDS | 1 | 00 | 000000 |  | 1 | 1 | One time only instruction after which the address in the Protect Register cannot be altered. |

Instruction Set for the NM93CS56L and NM93CS66L

| Instruction | SB | Op Code | Address | Data | PRE | PE | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| READ | 1 | 10 | A7-A0 |  | 0 | X | Reads data stored in memory, starting at specified address. |
| WEN | 1 | 00 | 11XXXXXX |  | 0 | 1 | Write enable must precede all programming modes. |
| WRITE | 1 | 01 | A7-A0 | D15-D0 | 0 | 1 | Writes register if address is unprotected. |
| WRALL | 1 | 00 | 01XXXXXX | D15-D0 | 0 | 1 | Writes all registers. Valid only when Protect Register is cleared. |
| WDS | 1 | 00 | 00xXXXXX |  | 0 | X | Disables all programming instructions. |
| PRREAD | 1 | 10 | XXXXXXXX |  | 1 | X | Reads address stored in Protect Register. |
| PREN | 1 | 00 | 11XXXXXX |  | 1 | 1 | Must immediately precede PRCLEAR, PRWRITE, and PRDS instructions. |
| PRCLEAR | 1 | 11 | 11111111 |  | 1 | 1 | Clears the "protect register" so that no registers are protected from WRITE. Cleared state is read as 0's. |
| PRWRITE | 1 | 01 | A7-A0 |  | 1 | 1 | Programs address into Protect Register. Thereafter, memory addresses $\geq$ the address in Protect Register are protected from WRITE. |
| PRDS | 1 | 00 | 00000000 |  | 1 | 1 | One time only instruction after which the address in the Protect Register cannot be altered. |

## Timing Diagrams



PRE $=0, \mathrm{PE}=\mathrm{X}$

"Address bit A7 becomes "don't care" for NM93CS56L.
TL/D/10044-5
"Address bits A5 and A4 become "don't cares" for NM93CS06L
tThe memory automatically cycles to the next register.

## Timing Diagrams (Continued)



TL/D/10044-6
*The NM93CS56L and NM93CS66L require a minimum of 11 clock cycles. The NM93CS06L and NM93CS46L require a minimum of 9 clock cycles.

-The NM93CS56L and NM93CS66L require a minimum of 11 clock cycles. The NM93CS06L and NM93CS46L require a minimum of 9 clock cycles.


TL/D/10044-8

- Address bit A7 becomes a "don't care" for NM93CS56L.
- Address bits A5 and A4 become "don't cares" for NM93CS06L.

Timing Diagrams (Continued)
WRALL:
PRE $=0$



-Don't care
$\dagger$ Protect Register MUST be cleared.


TL/D/10044-10
-Address bits A5 and A4 become "don't cares" for NM93CS06L. -Address bit A7 becomes "don't care" for NM93CS56L.

Timing Diagrams (Continued)

*A WEN cycle must precede a PREN cycle.

PRCLEAR*:

*A PREN cycle must immediately precede a PRCLEAR cycle.
TL/D/10044-12

Timing Diagrams (Continued)


TL/D/10044-13
*Address bit A7 becomes a "don't care" for NM93CS56L.
"Address bits A5 and A4 become "don't cares" for NM93CS06L.
$\dagger$ Protect Register MUST be cleared before a PRWRITE cycle. A PREN cycle must immediately precede a PRWRITE cycle.


NM93C46A
1024-Bit Serial EEPROM
$64 \times 16$-Bit or $128 \times 8$-Bit Configurable

## General Description

The NM93C46A is 1024 bits of CMOS non-volatile electrically erasable memory organized as either 64 16-bit registers or 1288 -bit registers. The organization is determined by the status of the ORG input. The memory device is fabricated using National Semiconductor's floating gate CMOS process for high reliability, high endurance and low power consumption. The NM93C46A is available in an SO package for space considerations.
The interface that controls the EEPROM is MICROWIRETM compatible for simple interfacing to a wide variety of microcontrollers and microprocessors. There are 7 instructions that operate the NM93C46A: Read, Erase/Write Enable, Erase, Write, Erase/Write Disable, Write All, and Erase All. The NM93C46A is compatible with National Semiconductor's NM93C46 if the ORG pin (Pin 6) is left floating, as it is internally pulled up to $V_{C C}$ to default to the $64 \times 16$ configuration.

## Features

- Device status during programming mode
- Typical active current of $400 \mu \mathrm{~A}$; typical standby current of $25 \mu \mathrm{~A}$
- Direct write
- Reliable CMOS floating gate technology
- MICROWIRE compatible interface
- Self-timed programming cycle
- 40 years data retention
- Endurance: $10^{6}$ data changes
- Packages available: 8 -pin SO, 8 -pin DIP


## Block Diagram



TL/D/11042-1

## Connection Diagrams

| Dual-In-Line Package ( N ) and 8-Pin SO (M8) | Pin Names |  |
| :---: | :---: | :---: |
|  | CS | Chip Select |
| $\mathrm{cs}-1 \quad 8-\mathrm{v}_{\mathrm{cc}}$ | SK | Serial Data Clock |
| $\mathrm{SK}-2 \quad 7$ - 2 - | DI | Serial Data Input |
| -3 ${ }^{3}$-ORG | DO | Serial Data Output |
| $\mathrm{DO} 4^{4} \quad 5-\mathrm{GND}$ | GND | Ground |
|  | $V_{\text {CC }}$ | Power Supply |
| Top View | ORG | Organization |

## Ordering Information

| Commercial Temp. Range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ |
| :---: |
| Order Number |
| NM93C46AN |
| NM93C46AM8 |

Extended Temp. Range ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM93C46AEN |
| NM93C46AEM8 |


| Military Temp. Range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+\mathbf{1 2 5}^{\circ} \mathrm{C}\right)$ |
| :---: |
| Order Number |
| NM93C46AMN |
| NM93C46AMM8 |


#### Abstract

Absolute Maximum Ratings (Note 1) If Milltary/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications. Ambient Storage Temperature All Input or Output Voltages with Respect to Ground Lead Temperature $\begin{array}{lr}\text { (Soldering, } 10 \text { Seconds) } & +300^{\circ} \mathrm{C} \\ \text { EDS Rating } & 2000 \mathrm{~V}\end{array}$ $$
\begin{array}{r} -65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\ +6.5 \mathrm{~V} \text { to }-0.3 \mathrm{~V} \\ +300^{\circ} \mathrm{C} \\ 2000 \mathrm{~V} \end{array}
$$


## Operating Conditions

Ambient Operating Temperature

| NM93C46A | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| NM93C46AE | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| NM93C46AM | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Power Supply (VCC) | 4.5 V to 5.5 V |

DC and AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ Unless Otherwise Specified
Note: Throughout this table, " $M$ " refers to temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$, not package.

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {cC1 }}$ | Operating Current CMOS Input Levels | NM93C46A NM93C46AE NM93C46AM | $\begin{aligned} \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | mA |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Operating Current TTL Input Levels | NM93C46A NM93C46AE NM93C46AM | $\begin{aligned} \mathrm{CS}=\mathrm{V}_{\mathbb{I H}}, \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =1 \mathrm{MHz} \\ \mathrm{SK} & =0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \\ & 4 \end{aligned}$ | mA |
| $\mathrm{I}_{\mathrm{CC3}}$ | Standby Current | NM93C46A NM93C46AE NM93C46AM | $C S=0 V$ |  | $\begin{gathered} 50 \\ 100 \\ 100 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| IIL | Input Leakage | NM93C46A NM93C46AE NM93C46AM | $V_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & -10 \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| loL | Output Leakage | NM93C46A NM93C46AE. NM93C46AM | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & -10 \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & 10 \end{aligned}$ | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | -0.1 | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  |  | 2 | $\mathrm{V}_{C C}+1$ | V |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage | NM93C46A <br> NM93C46AE <br> NM93C46AM | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA} \end{aligned}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & 0.4 \end{aligned}$ | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  | V |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage |  | $\mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A}$ |  | 0.2 | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}-0.2$ |  | V |
| ${ }^{\text {f }}$ K | SK Clock Frequency | NM93C46A <br> NM93C46AE <br> NM93C46AM |  | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 \\ 1 \\ 0.5 \end{gathered}$ | MHz |
| ${ }^{\text {tSKH }}$ | SK High Time | NM93C46A <br> NM93C46AE <br> NM93C46AM | (Note 2) <br> (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 300 \\ & 500 \\ & \hline \end{aligned}$ |  | ns |
| ${ }^{\text {tSKL }}$ | SK Low Time | NM93C46A <br> NM93C46AE <br> NM93C46AM | (Note 2) <br> (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \\ & \hline \end{aligned}$ |  | ns |
| ${ }^{\text {tSKS }}$ | SK Setup Time | NM93C46A <br> NM93C46AE <br> NM93C46AM | Relative to CS | $\begin{gathered} 50 \\ 50 \\ 100 \end{gathered}$ |  | ns |
| $\mathrm{t}_{\mathrm{CS}}$ | Minimum CS <br> Low Time | NM93C46A NM93C46AE NM93C46AM | (Note 4) (Note 4) (Note 5) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \\ & \hline \end{aligned}$ |  | ns |

DC and AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ Unless Otherwised Specified (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tcss | CS Setup Time | NM93C46A NM93C46AE NM93C46AM | Relative to SK | $\begin{gathered} 50 \\ 50 \\ 100 \end{gathered}$ |  | ns |
| tois | DI Setup Time | NM93C46A NM93C46AE NM93C46AM | Relative to SK | $\begin{aligned} & 100 \\ & 100 \\ & 200 \\ & \hline \end{aligned}$ |  | ns |
| ${ }^{\text {t }}$ CSH | CS Hold Time |  | Relative to SK | 0 |  | ns |
| ${ }_{\text {tin }}$ | DI Hold Time |  | Relative to SK | 20 |  | ns |
| $t_{\text {PD1 }}$ | Output Delay to " 1 " | NM93C46A NM93C46AE NM93C46AM | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| $\mathrm{t}_{\text {PDO }}$ | Output Delay to "0" | NM93C46A NM93C46AE NM93C46AM | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| tsv | CS to Status Valid | NM93C46A <br> NM93C46AE <br> NM93C46AM | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| $t_{D F}$ | CS to DO in TRI-STATE ${ }^{\circledR}$ | NM93C46A NM93C46AE NM93C46AM | AC Test $C S=V_{\mathbb{L L}}$ |  | $\begin{aligned} & 100 \\ & 100 \\ & 200 \\ & \hline \end{aligned}$ | ns |
| twp | Write Cycle Time |  |  |  | 10 | ms |
| $t_{\text {DH }}$ | D0 Hold Time |  | Relative to SK | 20 |  | ns |

Capacitance (Note 6)
$\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Max | Units |
| :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 5 | pF |
| $\mathrm{C}_{\mathrm{IH}}$ | Input Capacitance | 5 | pF |

## AC Test Conditions

| Output Load | 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| :--- | ---: |
| Input Pulse Levels | 0.4 V to 2.4 V |
| Timing Measurement Reference Level |  |
| Input | 1 V and 2 V |
| Output | 0.8 V and 2 V |

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 SK frequency specification for Commercial and Extended temperature range parts specifies a minimum SK clock period of $1 \mu \mathrm{~S}$; therefore, in an SK clock cycle, tSKH + tSKL $^{\prime}$ must be greater than or equal to $1 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=250 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=750 \mathrm{~ns}$ in order to meet the SK frequency specitication
Note 3: The SK frequency specification for Military Temperature parts specifies a minimum SK clock period of $2 \mu \mathrm{~s}$; therefore, in an SK clock cycle, $\mathrm{t}_{\text {SKH }}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to $2 \mu \mathrm{~s}$. For example, if the $\mathrm{t}_{\mathrm{SKL}}=500 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=1.5 \mu \mathrm{~s}$ in order to meet the SK frequency specification. Note 4: For Commercial parts, CS must be brought low for a minimum of 250 ns ( tcs ) between consecutive instruction cycles.
Note 5: For Military Temperature parts, CS must be brought low for a minimum of 500 ns ( tcs ) between consecutive instruction cycles.
Note 6: This parameter is periodically sampled and not $100 \%$ tested.

## Functional Description

The NM93C46A has 7 instructions as described below. Note that the MSB of any instruction is a " 1 " and is viewed as a start bit in the interface sequence. The next $8 / 9$ bits carry the op code and the 6/7-bit address for register selection.

## Read (READ)

The Read (READ) instruction outputs serial data on the DO pin. After a READ instruction is received, the instruction and address are decoded, followed by data transfer from the selected memory register into an 8 - or 16 -bit serial-out shift register. A dummy bit (logical 0 ) precedes the 8 - or 16 -bit data output string. Output data changes are initiated by a low to high transition of the SK clock.

## Erase/Write Enable (EWEN)

When $V_{C C}$ is applied to the part, it powers up in the Erase/Write Disable (EWDS) state. Therefore, all programming modes must be preceded by an Erase/Write Enable (EWEN) instruction. Once an Erase/Write Enable instruction is executed, programming remains enabled until an Erase/Write Disable (EWDS) instruction is executed or VCC is removed from the part.

## Erase (ERASE)

The ERASE instruction will program all bits in the specified register to the logical ' 1 ' state. CS is brought low following the loading of the last address bit. This falling edge of the CS pin initiates the self-timed programming cycle.
The DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( $\mathrm{t}_{\mathrm{CS}}$ ). $\mathrm{DO}=$ logical ' 0 ' indicates that programming is still in progress. DO $=$ logical ' 1 ' indicates that the register, at the address specified in the instruction, has been erased, and the part is ready for another instruction.

## Write (WRITE)

The Write (WRITE) instruction is followed by 8 or 16 bits of data to be written into the specified address. After the last bit of data is put on the data-in (DI) pin, CS must be brought low before the next rising edge of the SK clock. This falling edge of CS initiates the self-timed programming cycle. The DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns (tcs). DO $=$ logical 0 indicates that programming is still in progress. DO $=$ logical 1 indicates that the register at the address specified in the instruction has been written with the data pattern specified in the instruction and the part is ready for another instruction.

## Erase All (ERAL)

The ERAL instruction will simultaneously program all registers in the memory array and set each bit to the logical ' 1 ' state. The Erase All cycle is identical to the ERASE cycle except for the different op-code. As in the ERASE mode, the DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( $\mathrm{t}_{\mathrm{CS}}$ ). The ERASE ALL instruction is not required, see note below.

## Write All (WRAL)

The (WRAL) instruction will simultaneously program all registers with the data pattern specified in the instruction. As in the WRITE mode, the DO pin indicates the READY/BUSY status of the chip if CS is brought high after a minimum of 250 ns ( $\mathrm{t}_{\mathrm{cs}}$ ).

## Erase/Write Disable (EWDS)

To protect against accidental data disturb, the Erase/Write Disable (EWDS) instruction disables all programming modes and should follow all programming operations. Execution of a READ instruction is independent of both the EWEN and EWDS instructions.

Note: The NM93C46A device does not require an 'ERASE' or 'ERASE ALL' prior to the 'WRITE' and 'WRITE ALL' instructions. The 'ERASE' and 'ERASE ALL' instructions are included to maintain compatibility with the NMOS NMC9346.

## Instruction Set

| Instruction | Start Bit | Opcode |  | Address* |  | Data |  | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $128 \times 8$ | $64 \times 16$ | $128 \times 8$ | $64 \times 16$ |  |
| READ | 1 | 1 | 0 | A6-AO | A5-A0 |  |  | Read Address AN-A0 |
| ERASE | 1 | 1 | 1 | A6-AO | A5-A0 |  |  | Erase Address AN-A0 |
| WRITE | 1 | 0 | 1 | A6-A0 | A5-A0 | D7-D0 | D15-D0 | Write Address AN-A0 |
| EWEN | 1 | 0 | 0 | 11XXXXX | 11XXXX |  |  | Program Enable |
| EWDS | 1 | 0 | 0 | 00xXXXX | 00XXXX |  |  | Program Disable |
| ERAL | 1 | 0 | 0 | 10XXXXX | 10XXXX |  |  | Erase All Addresses |
| WRAL | 1 | 0 | 0 | 01XXXXX | 01XXXX | D7-D0 | D15-D0 | Program All Addresses |

[^2]
## Timing Diagrams


*This is the minimum SK period (Note 2).
$t_{\text {tSS }}$ is not needed if $\mathrm{DI}=V_{I L}$ when CS is going active (HIGH).


Timing Diagrams (Continued)


TL/D/11042-6


TL/D/11042-7


TL/D/11042-8
$\dagger$ For the EWEN, EWDS, WRAL and ERAL it is necessary to provide a minimum number of clock cycles after the last bit of opcode is clocked in. In the $64 \times 16$ configuration a minimum of 4 additional clock cycles are required. In the $128 \times 8$ configuration a minimum of 5 additional clock cycles are required.

Timing Diagrams (Continued)


TL/D/11042-9


TL/D/11042-10
$\dagger$ For the EWEN, EWDS, WRAL and ERAL it is necessary to provide a minimum number of clock cycles after the last bit of opcode is clocked in. In the $64 \times 16$ configuration a minimum of 4 additional clock cycles are required. In the $128 \times 8$ configuration a minimum of 5 additional clock cycles are required.

*This is the minimum SK period (Note 2).
${ }^{1} t_{\text {SKS }}$ is not needed if $\mathrm{DI}=\mathrm{V}_{\mathrm{IL}}$, when CS is going active (HIGH).

National
Semiconductor

## NM93C46AL

1024-Bit Serial EEPROM
$64 \times 16$-Bit or $128 \times 8$-Bit Configurable

## General Description

The NM93C46AL is 1024 bits of CMOS non-volatile electrically erasable memory organized as either 64 16-bit registers or 1288 -bit registers. The organization is determined by the status of the ORG input. The memory device is fabricated using National Semiconductor's floating gate CMOS process for high reliability, low power consumption and a wide operating voltage range.
The interface is MICROWIRETM compatible for simple interfacing to a wide variety of microcontrollers and microprocessors. There are 7 instructions that operate the NM93C46AL: Read, Erase/Write Enable, Erase, Write, Erase/Write Disable, Write All, and Erase All.
The NM93C46AL is compatible with National Semiconductor's NM93C46L if the ORG pin (Pin 6) is left floating, as it is internally pulled up to $\mathrm{V}_{\mathrm{CC}}$ to default to the $64 \times 16$ configuration.

## Features

- 2.0 V to 5.5 V operation in read mode
- 2.5 V to 5.5 V operation in all other modes
- Typical active current of $400 \mu \mathrm{~A}$; typical standby current of $25 \mu \mathrm{~A}$
- Direct write
- Reliable CMOS floating gate technology
- MICROWIRE compatible interface
- Self-timed programming cycle
- 40 years data retention
- Endurance: $10^{6}$ data changes
- Packages available: 8-pin SO, 8-pin DIP


## Block Diagram



## Connection Diagrams



## Ordering Information

Commercial Temp. Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Order Number |
| :---: |
| NM93C46ALN |
| NM93C46ALM8 |

Extended Temp. Range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

| Order Number |
| :---: |
| NM93C46ALEN |
| NM93C46ALEM8 |

## LOW VOLTAGE (<4.5V) SPECIFICATIONS

## Absolute Maximum Ratings (Note 1)

If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

Ambient Storage Temperature All Input or Output Voltages with Respect to Ground Lead Temperature
(Soldering, 10 Seconds)
ESD Rating
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
+6.5 V to -0.3 V
$+300^{\circ} \mathrm{C}$
2000 V

Operating Conditions
$\begin{array}{lr}\text { Ambient Operating Temperature } & 0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ \text { NM93C46AL }\end{array}$
NM93C46ALE $\quad-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Power Supply Range Read Mode All Other Modes
2.0 V to 5.5 V 2.5 V to 5.5 V

## DC and AC Electrical Characteristics

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| lCCl | Operating Current CMOS Input Levels | NM93C46AL NM93C46ALE | $\mathrm{CS}=\mathrm{V}_{1 H}, \mathrm{SK}=250 \mathrm{kHz}$ |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | mA |
| ICC2 | Operating Current TTL Input Levels | NM93C46AL NM93C46ALE | $\begin{aligned} C S= & V_{I H}, \end{aligned} \quad S K=250 \mathrm{kHz} .$ |  | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | mA |
| Icc3 | Standby Current | NM93C46AL NM93C46ALE | $C S=O V$ |  | $\begin{gathered} 50 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ |
| IIL | Input Leakage | NM93C46AL NM93C46ALE | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{gathered} 2.5 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ |
|  | Pin 6 |  |  | -10 | 10 |  |
| 1 loL | Output Leakage | NM93C46AL NM93C46ALE | $V_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 10 \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL1}} \\ & \mathrm{~V}_{\mathrm{IH} 1} \\ & \hline \end{aligned}$ | Input Low Voltage Input High Voltage |  | $4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ | 2 | 0.8 | V |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL2} 2} \\ & \mathrm{~V}_{\mathrm{IH} 2} \\ & \hline \end{aligned}$ | Input Low Voltage Input High Voltage |  | $2 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 4.5 \mathrm{~V}$ | $\begin{gathered} -0.1 \\ 0.8 V_{C C} \end{gathered}$ | $\begin{aligned} & 0.2 \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{cc}}+1 \end{aligned}$ | V |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OL} 1} \\ & \mathrm{~V}_{\mathrm{OH} 1} \end{aligned}$ | Output Low Voltage <br> Output High Voltage | NM93C46AL NM93C46ALE | $\begin{aligned} & 4.5 \mathrm{~V} \leq \mathrm{VCC}_{\mathrm{CC}} \leq 5.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \end{aligned}$ | 2.4 | 0.4 | V |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage |  | $\begin{aligned} & 2 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ |  | $0.1 \mathrm{~V}_{\mathrm{Cc}}$ | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage |  | $\mathrm{IOH}=-10 \mu \mathrm{~A}$ | $0.9 \mathrm{~V}_{\mathrm{CC}}$ |  | V |
| $\mathrm{f}_{\text {SK }}$ | SK Clock Frequency | NM93C46AL NM93C46ALE |  | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{array}{r} 250 \\ 250 \\ \hline \end{array}$ | kHz |
| ${ }^{\text {tSKH }}$ | SK High Time | NM93C46AL NM93C46ALE | (Note 2) | $\begin{aligned} & 1 \\ & 1 \\ & \hline \end{aligned}$ |  | $\mu \mathrm{s}$ |
| ${ }^{\text {tSKL }}$ | SK Low Time | NM93C46AL NM93C46ALE | (Note 2) | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\mu \mathrm{S}$ |
| tcs | Minimum CS <br> Low Time | NM93C46AL NM93C46ALE | (Note 3) | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\mu \mathrm{S}$ |

LOW VOLTAGE (<4.5V) SPECIFICATIONS
DC and AC Electrical Characteristics (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tcss | CS Setup Time | NM93C46AL NM93C46ALE | Relative to SK | $\begin{aligned} & 0.2 \\ & 0.2 \end{aligned}$ |  | $\mu \mathrm{s}$ |
| tols | DI Setup Time | NM93C46AL NM93C46ALE | Relative to SK | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ |  | $\mu \mathrm{s}$ |
| ${ }_{\text {t }}$ | CS Hold Time |  | Relative to SK | 0 |  | $\mu \mathrm{s}$ |
| ${ }_{\text {tIH }}$ | DI Hold Time |  | Relative to SK | 0.4 |  | $\mu \mathrm{s}$ |
| tPD 1 | Output Delay to "1" | NM93C46AL NM93C46ALE | AC Test |  | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\mu s$ |
| tPDO | Output Delay to "0" | NM93C46AL NM93C46ALE | AC Test |  | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\mu \mathrm{s}$ |
| tsv | CS to Status Valid | NM93C46AL NM93C46ALE | AC Test |  | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ DF | CS to DO in TRI-STATE ${ }^{\circledR}$ | NM93C46AL NM93C46ALE | AC Test $C S=V_{\mathrm{IL}}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ | $\mu \mathrm{s}$ |
| $t_{\text {WP }}$ | Write Cycle Time |  |  |  | 15 | ms |
| $t_{\text {DH }}$ | D0 Hold Time |  | Relative to SK | 10 |  | ns |

## Capacitance (Note 4)

$\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Max | Units |
| :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 5 | pF |
| $\mathrm{C}_{\mathrm{IH}}$ | Input Capacitance | 5 | pF |

AC Test Conditions (>4.5V)

| Output Load | 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| :---: | :---: |
| Input Pulse Levels | 0.4 V to 2.4 V |
| Timing Measureme | Level |
| Input | 1 V and 2 V |
| Output | 0.8 V and 2 V |

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 SK frequency specification for Commercial and Extended temperature range parts specifies a minimum SK clock period of $4 \mu \mathrm{~s}$; therefore, in an SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to $4 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=1 \mu \mathrm{~s}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=3 \mu \mathrm{~s}$ in order to meet the SK frequency specification.
Note 3: For Commercial parts, CS must be brought low for a minimum of $1 \mu$ s between consecutive instruction cycles.
Note 4: This parameter is periodically sampled and not $100 \%$ tested.

## Absolute Maximum Ratings (Note 1)

If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Ambient Storage Temperature All Input or Output Voltages with Respect to Ground Lead Temperature
(Soldering, 10 Seconds)
ESD Rating
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
+6.5 V to -0.3 V
$+300^{\circ} \mathrm{C}$ 2000 V

## Operating Conditions

Ambient Operating Temperature NM93C46AL
NM93C46ALE $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Positive Power Supply ( $\mathrm{V}_{\mathrm{CC}}$ )

## DC and AC Electrical Characteristics

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC1 | Operating Current CMOS Input Levels | NM93C46AL NM93C46ALE | $\begin{aligned} \mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{SK} & =1 \mathrm{MHZ} \\ \mathrm{SK} & =0.5 \mathrm{MHZ} \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | mA |
| $\mathrm{ICC2}$ | Operating Current TTL Input Levels | NM93C46AL NM93C46ALE | $\begin{aligned} C S=V_{I H}, S K & =1 \mathrm{MHz} \\ S K & =0.5 \mathrm{MHz} \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | mA |
| ICC3 | Standby Current | NM93C46AL NM93C46ALE | $C S=0 V$ |  | $\begin{gathered} 50 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ |
| IIL | Input Leakage | NM93C46AL NM93C46ALE | $V_{I N}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{gathered} 2.5 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ |
| lOL | Output Leakage | NM93C46AL NM93C46ALE | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ | $\begin{aligned} & -2.5 \\ & -10 \end{aligned}$ | $\begin{gathered} 2.5 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | -0.1 | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage |  |  | 2 | $\mathrm{V}_{\mathrm{CC}}+1$ | V |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage | NM93C46AL NM93C46ALE | $\begin{aligned} \mathrm{l}_{\mathrm{OL}} & =2.1 \mathrm{~mA} \\ \mathrm{IOL}^{2} & =2.1 \mathrm{~mA} \end{aligned}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \\ & \hline \end{aligned}$ | V |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  | V |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage |  | $\mathrm{IOL}=10 \mu \mathrm{~A}$ |  | 0.2 | V |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage |  | $\mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}-0.2$ |  | V |
| ${ }^{\text {fSK}}$ | SK Clock Frequency | NM93C46AL NM93C46ALE |  | $\begin{aligned} & 0 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{gathered} 1 \\ 0.5 \\ \hline \end{gathered}$ | MHz |
| ${ }^{\text {tSKH }}$ | SK High Time | NM93C46AL NM93C46ALE | (Note 2) <br> (Note 3) | $\begin{array}{r} 250 \\ 500 \\ \hline \end{array}$ |  | ns |
| ${ }^{\text {t SKL }}$ | SK Low Time | NM93C46AL NM93C46ALE | (Note 2) <br> (Note 3) | $\begin{array}{r} 250 \\ 500 \\ \hline \end{array}$ |  | ns |
| $\mathrm{t}_{\mathrm{CS}}$ | Minimum CS <br> Low Time | NM93C46AL NM93C46ALE | (Note 4) <br> (Note 5) | $\begin{array}{r} 250 \\ 500 \\ \hline \end{array}$ |  | ns |

STANDARD VOLTAGE ( $4.5 \leq \mathrm{V} \leq 5.5$ ) (Continued)
DC and AC Electrical Characteristics (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{css}}$ | CS Setup Time | NM93C46AL NM93C46ALE | Relative to SK | $\begin{gathered} 50 \\ 100 \end{gathered}$ |  | ns |
| ${ }_{\text {t }}$ IS | DI Setup Time | NM93C46AL NM93C46ALE | Relative to SK | $\begin{aligned} & 100 \\ & 200 \end{aligned}$ |  | ns |
| $\mathrm{t}_{\mathrm{CSH}}$ | CS Hold Time |  | Relative to SK | 0 |  | ns |
| ${ }_{\text {t }}{ }_{\text {DIH }}$ | DI Hold Time | NM93C46AL NM93C46ALE | Relative to SK | $\begin{array}{r} 100 \\ 200 \\ \hline \end{array}$ |  | ns |
| $t_{\text {PD1 }}$ | Output Delay to "1" | NM93C46AL NM93C46ALE | AC Test |  | $\begin{gathered} 500 \\ 1000 \\ \hline \end{gathered}$ | ns |
| $\mathrm{t}_{\text {PDO }}$ | Output Delay to " 0 " | NM93C46AL NM93C46ALE | AC Test |  | $\begin{gathered} 500 \\ 1000 \\ \hline \end{gathered}$ | ns |
| $\mathrm{t}_{\mathrm{SV}}$ | CS to Status Valid | NM93C46AL NM93C46ALE | AC Test |  | $\begin{gathered} 500 \\ 1000 \end{gathered}$ | ns |
| $t_{\text {DF }}$ | CS to DO in TRI-STATE | NM93C46AL NM93C46ALE | AC Test $C S=V_{I L}$ |  | $\begin{aligned} & 100 \\ & 200 \\ & \hline \end{aligned}$ | ns |
| $t_{\text {WP }}$ | Write Cycle Time |  |  |  | 10 | ms |

## Capacitance (Note 6)

$T_{A}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Max | Units |
| :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 5 | pF |
| $\mathrm{C}_{\mathrm{IH}}$ | Input Capacitance | 5 | pF |

AC Test Conditions (>4.5V)

| Output Load | 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| :---: | :---: |
| Input Pulse Levels | 0.4 V to 2.4 V |
| Timing Measuremen | Level |
| Input | 1 V and 2 V |
| Output | 0.8 V and 2 V |

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 SK frequency specification for Commercial parts specifies a minimum SK clock period of $1 \mu$ s; therefore, in an SK clock cycle, tSKH + tSKL must be greater than or equal to $1 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=250 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=750 \mathrm{~ns}$ in order to meet the SK frequency specification.
Note 3: The SK frequency specification for Extended Temperature parts specifies a minimum SK clock period of $2 \mu \mathrm{~s}$; therefore, in an SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to $2 \mu \mathrm{~s}$. For example, if the $\mathrm{I}_{\mathrm{SKL}}=500 \mathrm{~ns}$, then the minimum $\mathrm{I}_{\mathrm{SKH}}=1.5 \mu \mathrm{~s}$ in order to meet the SK frequency specification.
Note 4: For Commercial parts, CS must be brought low for a minimum of 250 ns ( t CS ) between consecutive instruction cycles.
Note 5: For Extended Temperature parts, CS must be brought low for a minimum of $500 \mathrm{~ns}(\mathrm{tcs})$ between consecutive instruction cycles.
Note 6: This parameter is periodically sampled and not $100 \%$ tested.

## Functional Description

The NM93C46AL has seven instruction sets as described below．Note that each instruction set is broken down into the Start Bit（SB），Op code，Address（if applicable）and Data （if applicable）．As shown in the timing diagrams and IN － STRUCTION SET tables，address bits will have $6 / 7$ bits and $8 / 16$ bits for the data．All instruction bits are entered into the device on the SK low－to－high transitions．
Programming is enabled by bringing CS to a Logical 0 state for the required $\mathrm{t}_{\mathrm{CS}}$ period．After this t CS period the self－ timed operation may be monitored by bringing CS to a logi－ cal 1 and observing the DO status：Logical $1=$ READY （Ready for the next instruction）and Logical $0=$ BUSY（Pro－ gramming in progress）．

## Erase／Write Enable（EWEN）：

When $V_{C C}$ is applied to the device，it powers up in the pro－ gramming Erase／Write disabled state．Therefore，all pro－ gramming modes must be preceded by an Erase／Write En－ able（EWEN）instruction．Once this instruction is executed， programming remains enabled until the Erase／Write Disable （EWDS）instruction is executed or until $\mathrm{V}_{\mathrm{CC}}$ is removed from the part．

## Erase／Write Disable（EWDS）：

To protect against accidental data disturbance，the Erase／ Write Disable instruction disables all programming modes and should follow the end of all programming cycles．

## Read（READ）：

The Read instruction outputs the specified address data on the DO pin．After the READ instruction is received，the in－ struction and address are decoded and data is transferred from the address to an 8－／16－bit shift register output buffer． A dummy bit（logical 0 ）precedes all $8-/ 16$－bit data out strings．The READ instruction may be executed from either the enabled or disabled state．

## Erase（ERASE）：

This instruction，when followed by an address location，pro－ grams all bits in the selected register／address to a 1 state （Register erase）．

## Erase All（ERAL）：

This instruction programs all registers／addresses in the memory array to a 1 state（Bulk erase）．

## Write（WRITE）：

This instruction，when followed by an address location and 8／16 bits of data，programs the selected register／address．

## Write All（WRAL）：

This instruction，when followed by $8 / 16$ bits of data，pro－ grams all registers／addresses in the memory array with the specified data pattern（Bulk write）．

Note：The NM93C46AL device does not require an＇ERASE＇or＇ERASE ALL＇prior to the＇WRITE＇and＇WRITE ALL＇instructions．The＇ERASE＇and＇ERASE ALL＇ instructions are included to maintain compatibility with the NMOS NMC9346．

## Instruction Set

| Instruction | Start Bit | Opcode |  | Address＊ |  | Data |  | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $128 \times 8$ | $64 \times 16$ | $128 \times 8$ | $64 \times 16$ |  |
| READ | 1 | 1 | 0 | A6－AO | A5－A0 |  |  | Read Address AN－AO |
| ERASE | 1 | 1 | 1 | A6－A0 | A5－A0 |  |  | Erase Address AN－AO |
| WRITE | 1 | 0 | 1 | A6－A0 | A5－A0 | D7－D0 | D15－D0 | Write Address AN－A0 |
| EWEN | 1 | 0 | 0 | 11XXXXX | 11XXXX |  |  | Program Enable |
| EWDS | 1 | 0 | 0 | 00xXXXX | 00XXXX |  |  | Program Disable |
| ERAL | 1 | 0 | 0 | 10xXXXX | 10xXXX |  |  | Erase All Addresses |
| WRAL | 1 | 0 | 0 | 01XXXXX | 01XXXX | D7－D0 | D15－D0 | Program All Addresses |

＂It is necessary to clock in the＂Don＇t Care＂Address Bits．

## Timing Diagrams



TL/D/11330-3
${ }^{*}$ This is the minimum SK period (Note 2)
$t_{\text {SKS }}$ is not needed if $\mathrm{DI}=\mathrm{V}_{\mathrm{IL}}$ when CS is going active (HIGH).


## Timing Diagrams（Continued）




TL／D／11330－7


TL／D／11330－8
$\dagger$ For the EWEN，EWDS，WRAL and ERAL it is necessary to provide a minimum number of clock cycles after the last bit of opcode is clocked in．In the $64 \times 16$ configuration a minimum of 4 additional clock cycles are required．In the $128 \times 8$ configuration a minimum of 5 additional clock cycles are required．

Timing Diagrams (Continued)


TL/D/11330-9

TL/D/11330-10
tFor the EWEN, EWDS, WRAL and ERAL it is necessary to provide a minimum number of clock cycles after the last bit of opcode is clocked in. In the $64 \times 16$ configuration a minimum of 4 additional clock cycles are required. In the $128 \times 8$ configuration a minimum of 5 additional clock cycles are required.

## NM95C12 1K-Bit CMOS EEPROM with Programmable Switches

## General Description

The NM95C12 is a 976 -bit, CMOS EEPROM with 8 non-volatile programmable outputs that can be used as DIP switches. The 976 bits of memory are divided into 61 registers of 16 bits each and each register can be individually accessed. Registers 61-63 are dedicated to storing the switch settings.
In addition to the 976 bits of EEPROM memory, the NM95C12 contains eight individually programmable outputs which can be used as switches and two additional registers used in conjunction with the switch logic which are volatile. Each switch output may be programmed to provide either a High or Low level. These outputs may also be programmed to form four individual pairs of SPST switches.
The switch configuration information is obtained from a non volatile register whenever power is first applied to the device. This ensures the switches will always have a user determined state upon power-up.

## Features

- 8 DIP switch positions or 4 SPST switch positions
- 976 bits of CMOS EEPROM memory available
- 4 mA (max) operating current, $50 \mu \mathrm{~A}$ (max) standby current
- Software write protection
- Serial I/O interface fully MICROWIRE compatible
- Single $+5 \mathrm{~V} \pm 10 \%$ operation
- 14-pin DIP or SO package availability
- 100,000 write cycles guaranteed, 500,000 typical
- 40 year data retention
- Reliable floating gate technology
- Sequential register read
- Self-timed write cycle
- Erase cycles not necessary
- Compatible with COPSTM microcontrollers


## Block Diagram



TL/D/9632-1
FIGURE 1. Block Diagram

| Absolute Maximum Ratings (Note 1) |  | Operating Conditions |  |
| :---: | :---: | :---: | :---: |
| If Military/Aerospace specifled please contact the National | ces are required, conductor Sales | Ambient Operating Temperature NM95C12 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Office/Distributors for availability | d specifications. | NM95C12E | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Supply Voltage $\mathrm{V}_{\text {CC }}$ | 6.5 V | NM95C12M* | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Voltage at Any Pin | -0.3 to +6.5 V | Power Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | 4.5 V to 5.5 V |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | *Contact factory for availability |  |
| Maximum Power Dissipation @ $25^{\circ} \mathrm{C}$ | 500 mW |  |  |
| Lead Temperature (Soldering, 10 seconds) | $300^{\circ} \mathrm{C}$ |  |  |
| ESD Rating | 2000 V |  |  |

## DC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Operating Current CMOS Input Levels | $\mathrm{C}_{\mathrm{S}}=\mathrm{V}_{1 \mathrm{H}}, \mathrm{SK}=1 \mathrm{MHz}$ |  | 4 | mA |
| $\mathrm{ICC2}$ | Operating Current TTL Input Levels | $\mathrm{C}_{\mathrm{S}}=\mathrm{V}_{1 H}, \mathrm{SK}=1 \mathrm{MHz}$ |  | 6 | mA |
| ${ }^{\text {c CC3 }}$ | Standby Current CMOS Input Levels on Switches | $\mathrm{C}_{\mathrm{S}}=0 \mathrm{~V}$ |  | 50 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{CC} 4}$ | Standby Current TTL Input Levels on Switches | $\mathrm{C}_{\mathrm{S}}=0 \mathrm{~V}$ |  | 800 | $\mu \mathrm{A}$ |
| $\mathrm{l}_{\mathrm{iL}}$ | Input Leakage | $V_{I N}=O V$ to $V_{C C}$ | -2.5 | +2.5 | $\mu \mathrm{A}$ |
| IOL | Output Leakage | $\mathrm{V}_{\text {OUT }}=O V$ to $\mathrm{V}_{\text {CC }}$ | -2.5 | 2.5 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | -0.1 | 0.8 | V |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | 2.0 | $\mathrm{V}_{C C}+1$ | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | $\mathrm{l}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ | 2.4 |  | $\checkmark$ |
| $\mathrm{R}_{\mathrm{ON}}$ | Switch On Resistance |  |  | 200 | $\Omega$ |
| $\mathrm{R}_{\text {OFF }}$ | Switch Off Resistance |  | 10 |  | $\mathrm{M} \Omega$ |
| $\mathrm{V}_{S}$ | Maximum Voltage Allowed on any Switch Terminal |  |  | $V_{C C}+1$ | V |
| Is | Max Current Allowed through Switch Terminals |  |  | 10 | mA |

AC Electrical Characteristics $\mathrm{v}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ unless otherwise specified

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{\text {f }}$ S | SK Clock Frequency | NM95C12 NM95C12E NM95C12M |  | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} 1 \\ 1 \\ 0.5 \end{gathered}$ | MHz |
| ${ }^{\text {tSKH }}$ | SK High Time | NM95C12 NM95C12E NM95C12M | (Note 2) <br> (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 300 \\ & 500 \end{aligned}$ |  | ns |
| ${ }^{\text {SKL }}$ | SK Low Time | NM95C12 NM95C12E NM95C12M | (Note 2) <br> (Note 2) <br> (Note 3) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \\ & \hline \end{aligned}$ |  | ns |
| ${ }^{\text {t }}$ SKS | SK Setup | NM95C12 NM95C12E NM95C12M |  | $\begin{gathered} \hline 50 \\ 50 \\ 100 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |
| ${ }^{\text {t }}$ S | Minimum CS Low Time | NM95C12 NM95C12E NM95C12M | (Note 4) <br> (Note 4) <br> (Note 5) | $\begin{aligned} & 250 \\ & 250 \\ & 500 \\ & \hline \end{aligned}$ |  | ns |
| tcss | CS Setup Time | NM95C12 <br> NM95C12E <br> NM95C12M | Relative to SK | $\begin{gathered} 50 \\ 50 \\ 100 \end{gathered}$ |  | ns |

AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ unless otherwise specified (Continued)

| Symbol | Parameter | Part Number | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPUSR | Power Up Slew Rate |  |  | 1 |  | ms |
| ${ }_{\text {t }}$ IS | DI Setup Time | NM95C12 <br> NM95C12E <br> NM95C12M | Relative to SK | $\begin{aligned} & 100 \\ & 100 \\ & 200 \end{aligned}$ |  | ns |
| $\mathrm{t}_{\text {CSH }}$ | CS Hold Time |  | Relative to SK | 0 |  | ns |
| $\mathrm{t}_{\text {DIH }}$ | DI Hold Time |  | Relative to SK | 20 |  | ns |
| $t_{\text {PD1 }}$ | Output Delay to " 1 " | NM95C12 <br> NM95C12E <br> NM95C12M | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| $\mathrm{t}_{\text {PDO }}$ | Output Delay to "0" | NM95C12 <br> NM95C12E <br> NM95C12M | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| tsv | CS to Status Valid | NM95C12 <br> NM95C12E <br> NM95C12M | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| $t_{\text {bF }}$ | CS to DO in TRI-STATE ${ }^{\circledR}$ | NM95C12 NM95C12E NM95C12M | $\mathrm{CS}=\mathrm{V}_{\mathrm{IL}}$ <br> AC Test |  | $\begin{aligned} & 100 \\ & 100 \\ & 200 \end{aligned}$ | ns |
| tiswo | Switch Delay from Switch Input | NM95C12 NM95C12E NM95C12M | AC Test |  | $\begin{aligned} & 250 \\ & 250 \\ & 500 \end{aligned}$ | ns |
| tswPDo | Switch Delay to 0 from Config. Change | NM95C12 <br> NM95C12E <br> NM95C12M | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| tswPD1 | Switch Delay to 1 from Config. Change | NM95C12 NM95C12E NM95C12M | AC Test |  | $\begin{gathered} 500 \\ 500 \\ 1000 \end{gathered}$ | ns |
| tsws | A1-A4, B1-B4 Setup Time for SRR Read | NM95C12 NM95C12E NM95C12M |  | $\begin{aligned} & 100 \\ & 100 \\ & 200 \\ & \hline \end{aligned}$ |  | ns |
| tswh | A1-A4, B1-B4 Hold Time for SRR Read | NM95C12 <br> NM95C12E <br> NM95C12M |  | $\begin{aligned} & 100 \\ & 100 \\ & 200 \end{aligned}$ |  | ns |
| twp | Write Cycle Time |  |  |  | 10 | ms |
| $\mathrm{t}_{\mathrm{DH}}$ | DO Hold Time |  | Relative to SK | 10 |  | ns |

Capacitance (Note 6)
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Max | Units |
| :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 5 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | pF |

## AC Test Conditions

| Output Load | 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| :--- | ---: |
| Input Pulse Levels | 0.4 V to 2.4 V |
| Timing Measurement Reference Level |  |
| $\quad$ Input | 1 V and 2 V |
| Output | 0.8 V and 2 V |

1 TTL Gate and $C_{L}=100 \mathrm{pF}$ Input Pulse Levels

1 V and 2 V 0.8 V and 2 V

Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. Except for "Operating Temperature Range", the device should not be operated at these limits. The table of "Electrical Characteristics" provides actual operating limits.
Note 2: The SK frequency specification for Commercial and Extended temperature range parts specifies a minimum SK clock period of $1 \mu \mathrm{~S}$; therefore, in an SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+\mathrm{t}_{\mathrm{SKL}}$ must be greater than or equal to $1 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=250 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=750 \mathrm{~ns}$ in order to meet the SK frequency specification.
Note 3: The SK frequency specification for Military parts specifies a minimum SK clock period of $2 \mu \mathrm{~s}$; therefore, in an SK clock cycle tsKH + tsKL $^{\text {sK }}$ must be greater than or equal to $2 \mu \mathrm{~s}$. For example, if $\mathrm{t}_{\mathrm{SKL}}=500 \mathrm{~ns}$, then the minimum $\mathrm{t}_{\mathrm{SKH}}=1.5 \mu \mathrm{~s}$ in order to meet the SK frequency specification.
Note 4: For Commercial and Extended temperature range parts, CS must be brought low for a minimum of 250 ns (tcs) between consecutive instruction cycles.
Note 5: For Military parts, CS must be brought low for a minimum of 500 ns ( tcs ) between consecutive instruction cycles.
Note 6: This parameter is periodically sampled and not $100 \%$ tested.
Note 7: Power dissipation temperature derating-plastic " $N$ " package: $-12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ from $+65^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

## Connection Diagrams



## Pin Descriptions

| Pin Name | Description |
| :---: | :---: |
| CS | Chip Select, Input-This input must be high while communicating with the NM95C12. When this input is LOW, the chip is powered down into the standby mode. It should be noted that the CS does not control the A1 through A4 and B1 through B4 outputs and hence has no effect on them. The CS input must be made LOW after completing an instruction to prepare the control logic to accept the next instruction. If the CS input becomes LOW prematurely, the operation in progress is aborted. If programming the $\mathrm{E}^{2}$ memory is in progress and the CS goes LOW, the programming is not aborted but will proceed to its normal completion. |
| SK | Serial Clock, Input-This input is used for clocking the serial I/O. The CS input must be high for clocking to have any effect. Information presented on the DI input will be shifted into the device on the LOW to HIGH transition of the clock. Information from the device will be available on the DO output serially, in response to the LOW to HIGH transition of the clock. |
| DI | Serial Data In, Input-All information needed for the operation of the device is entered serially from this input. HIGH represents logic ' 1 ' and LOW represents logic ' 0 '. The entry order is most significant bit first and least significant bit last. |
| DO | Serial Data Out, Output, 3-state-When data is read, data from the addressed location will be available on this output serially, in sync with the LOW to HIGH transitions on the SK input. Normally the DO pin is in high impedance state. During a read instruction, when the last bit of the address is shifted in, the DO will go LOW indicating that data will follow. The data will follow in response to the clock transitions. The data will come out most significant bit first and least significant bit last. During $\mathrm{E}^{2}$ programming operations, this output is also used as the status indicator. During programming operations, LOW indicates Busy (programming in progress) and HIGH indicates Ready. The DO output will be in the high impedance state if the CS input is LOW unconditionally. |
| $\begin{aligned} & \mathrm{A} 1-\mathrm{A} 4 \\ & \mathrm{~B} 1-\mathrm{B} 4 \end{aligned}$ | Switch Terminals-These pins provide the simulated DIP switch features and hence are called terminals. The behavior of these pins is determined by the settings in the Switch Configuration Register and are independent of the CS input. |
| $V_{C C}$ | +5V Power Supply. |
| GND | Ground. |

## Functional Description

Figure 1 is a block diagram of the NM95C12. It consists of a 62 -word X 16-bit E2PROM array, a 16-bit Switch Configuration Register (SCR), a 16 -bit Switch Readback Register (SRR), four identical blocks of switch logic, programming and power-up circuits and the necessary control logic. It may be noted that only eight bit positions of the SRR are used in the NM95C12.

## ADDRESS SPACE

Registers 0-60 of the E2PROM are available to the user as general purpose non-volatile memory. Data may be read or programmed into this memory using the appropriate instructions. Address location 61 is an $E^{2}$ location which also can be read or programmed like any other $E^{2}$ location. However,
address 61 is used in the NM95C12 to provide the initial switch configuration information automatically on power-up.
The SCR is located at address 62. The SCR is not an E2 location and hence is volatile. It does not have endurance limits or programming time requirements associated with it, allowing the switches to be reconfigured an unlimited number of times.
The SCR is automatically loaded from address 61 on powerup. The SCR controls the switch logic and hence the behavior of the terminals A1 through A4 and B1 through B4.
Located at address 63 is the Switch Readback Register (SRR). This is a read only register.

TABLE I. Switch Configurations

| MODE* | z | Y | x | W | SWITCH CONFIGURATION | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | $\xrightarrow{\perp}$ | $A=0, B=0$ |
| 1 | 0 | 0 | 0 | 1 | $\xrightarrow{\sim}$ | $A=0, B=1$ |
| 2 | 0 | 0 | 1 | 0 |  | $A=1, B=0$ |
| 3 | 0 | 0 | 1 | 1 |  | $A=1, B=1$ |
| 4 | 0 | 1 | 0 | 0 | $\frac{\Gamma}{\bar{O}} \longrightarrow$ | $\mathrm{A}=0, \mathrm{~B}=\mathrm{TRI}-\mathrm{STATE}$ |
| 5 | 0 | 1 | 0 | 1 |  | $\mathrm{A}=\mathrm{B}$ |
| 6 | 0 | 1 | 1 | 0 | $\xrightarrow{-\infty}$ | $\mathrm{A}=\overline{\mathrm{B}}$ |
| 7 | 0 | 1 | 1 | 1 | $\xrightarrow{-\quad \mathrm{A}} \stackrel{\mathrm{~A}}{\mathrm{VCC}}$ | $A=1, B=$ TRI-STATE |
| 8 | 1 | 0 | 0 | 0 | $\stackrel{-\infty}{\square}$ | $A=T R I-S T A T E, B=0$ |
| 9 | 1 | 0 | 0 | 1 |  | $\mathrm{B}=\mathrm{A}$ |
| 10 | 1 | 0 | 1 | 0 | $\square-\infty$ | $B=\bar{A}$ |
| 11 | 1 | 0 | 1 | 1 | $\xrightarrow{\mathrm{A}^{\mathrm{V}_{C C}} \longrightarrow}$ | $A=T R 1-S T A T E, B=1$ |
| 12 | 1 | 1 | 0 | X |  | Analog Switch Open |
| 13 | 1 | 1 | 1 | x |  | Analog Switch Closed |

[^3]
## Functional Description (Continued)

## SWITCH CONFIGURATIONS

The 16-bit SCR format is shown in Figure 2. It consists of four 4 -bit fields. Each field controls its corresponding switch control logic. The individual bits in each field are labelled $W$, $\mathrm{X}, \mathrm{Y}$, and Z . Table I shows the relationship between these bit values and the resulting behavior of the terminals. It should be remembered that the CS input has no effect on the behavior of the terminals.

## SWITCH READBACK REGISTER

The SRR allows the current logic level present at the switch terminals to be read back via the Microwire bus. The SRR is loaded by the rising edge of SK immediately after the last instruction bit is clocked in (The same clock edge that loads A0). The SRR is loaded on this clock edge only when register 63 (Switch Readback Register) is being read. In the case of switch mode 13 (Analog switch mode), the SRR will not report the actual levels present at the terminals due to this mode being analog levels. In mode 13, bits 15-8 of the SRR will be all 0 's to indicate a closed analog switch. This is done to avoid ambiguous logic levels which could exist when the device is used in the analog switch mode.

The bit assignments and conceptual function of the SRR is shown in Figure 3. As shown, only bits 15 thru 8 are used, and bits 7 thru 0 are always read as logical 0 . The SRR is a Read-Only register and if it is written, the device will not perform a write or generate a Ready/Busy status. The SRR is not implemented in EEPROM, allowing an infinite number of cycles in the register.

## INSTRUCTION SET

The NM95C12 instruction set contains five instructions, and each instruction is ten bits long. The first 2 bits of the instruction are the start bits (SB) and are always a logical " 01 ", followed by the op code ( 2 bits) and the address field ( 6 bits). The WRITE and WRALL instructions are followed by sixteen bits of data (D15-D0) which is written into the memory. Table II is a list of the instructions and their format.


TL/D/9632-5
FIGURE 3. Switch Readback Register (SRR)
TABLE II. NM95C12 Instructions

| Instruction | SB | Op Code | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :---: | :--- |
| READ | 01 | 10 | A5-A0 |  | Reads data stored in memory, starting at specified address. |
| WEN | 01 | 00 | $11 X X X X$ |  | Write enable must precede all programming modes. |
| WRITE | 01 | 01 | A5-A0 | D15-D0 | Writes register. |
| WRALL | 01 | 00 | $01 X X X X$ | D15-D0 | Writes all registers. |
| WDS | 01 | 00 | $00 X X X X$ |  | Disables all programming instructions. |

## Functional Description (Continued)

WDS (Write Disable): When this instruction is issued, all subsequent writing into the NM95C12 is locked out. Any attempt to write into a locked device is ignored. The NM95C12 powers up in the locked state. The WEN is the only instruction that unlocks the device. The write disable operation has no effect on read operations. Thus reading will occur normally even from a locked device.
WRALL (Write All): When this instruction is executed, the NM95C12 bulk-programs the same 16 -bit data pattern into all of its $E^{2}$ memory locations (address 0 through 61). The SCR is unaffected since it is not an $E^{2}$ location. The data pattern must follow immediately after the last bit of this instruction. The chip enters into the self-timed program mode after CS is brought low, before the next rising edge of SK.
WEN (Write Enable): This instruction is used to unlock the write circuits. The circuits will remain unlocked until the WDS instruction locks them. The NM95C12 powers up in the locked state and hence WEN must be executed prior to any programming instructions.
WRITE (Write/Program): This instruction writes a 16 -bit data word into the address location specified by the $A_{0}-A_{5}$ bits of the instruction. The 16 data bits must follow the last bit of the instruction. After loading the WRITE instruction and the 16 -bit data, the chip enters into the self-timed program mode when CS is brought low before the next rising edge of the SK clock. If the addressed location is the SCR, then the chip does not enter into the self-timed $\mathrm{E}^{2}$ programming mode (the SCR is not an E2 location) but loads the switch configuration data into the SCR. The WRITE instruction can only be aborted by deselecting the chip (CS LOW) before entering all the instruction bits. The NM95C12 does not require erasing prior to writing.
READ (Read): This instruction reads the data from the addressed location. As before, the instruction also contains
the address. The data will come out serially on the DO output on the rising edge of the clock. A logical ' 0 ' precedes the 16 -bit data (dummy bit).
The NM95C12 has a convenient feature called sequential register read. Normally, the CS input is made LOW after the last data bit is shifted out. However; if the CS input is left HIGH and clocking continues, data from the next address location will be delivered on the D0 pin. This sequential read can continue indefinitely whereby the address is automatically incremented after delivering 16 bits of data. It should be noted that in the sequential register read mode, address wrap-around will occur.
During a sequential register read there will be a dummy bit preceding the first word read, after which, the bit stream will be continuous without any dummy bits separating the data words.

## Ready/Busy Indication

Programming an $E^{2}$ memory takes several milliseconds. Unlike some devices which require the user to keep track of the elapsed time to ensure completion of the programming cycle, the NM95C12 contains an on-chip timer. The timer starts when the CS input goes LOW after the last data bit is entered. After entering a programming cycle (CS forced LOW), the timer status may be observed by forcing the CS input back HIGH. The timer status is available on the D0 pin if the CS input is forced HIGH within one ms of starting the programming cycle. LOW on the DO pin indicates that the programming is still in progress while HIGH indicates the device is READY for the next instruction. It should be noted that if the CS input is made HIGH for status observation, it must be made LOW when READY is indicated before loading the next instruction.

## Timing Diagrams



Timing Diagrams (Continued)



TL/D/9632-14




*The memory automatically cycles to the next register.


TL/D/9632-11

WRITE SCR:
cs



DO HI-Z
TL/D/9632-12


TL/D/9632-13

Section 3 PROMs

Section 3 Contents
Bipolar PROM Selection Guide ..... 3-3
NON-REGISTERED BIPOLAR PROMS
DM74S188 ( $32 \times 8$ ) 256-Bit TTL PROM ..... 3-4
DM74S288 ( $32 \times 8$ ) 256-Bit TTL PROM ..... 3-8
DM74S287 ( $256 \times 4$ ) 1024-Bit TTL PROM ..... 3-12
DM74S387 ( $256 \times 4$ ) 1024-Bit TTL PROM ..... 3-16
DM74LS471 ( $256 \times 8$ ) 2048-Bit TTL PROM ..... 3-20
DM74S472 $(512 \times 8)$ 4096-Bit TTL PROM ..... 3-24
DM74S473 ( $512 \times 8$ ) 4096-Bit TTL PROM ..... 3-28
DM74S570 ( $512 \times 4$ ) 2048-Bit TTL PROM ..... 3-32
DM74S571 (512 x 4) 2048-Bit TTL PROM ..... 3-36
DM74S572 (1024 x 4) 4096-Bit TTL PROM ..... 3-40
DM74S573 (1024 x 4) 4096-Bit TTL PROM ..... 3-44
APPLICATIONS INFORMATION
Bipolar PROM Devices in Plastic Leaded Chip Carriers ..... 3-48
Non-Registered PROM Programming Procedure ..... 3-51
Standard Test Load ..... 3-52
Switching Time Waveforms ..... 3-53
Approved Programmers/Quality Enhancement ..... 3-53

## Bipolar PROM Selection Guide



## DM74S188

## (32 x 8) 256-Bit TTL PROM

## General Description

This Schottky memory is organized in the popular 32 words by 8 bits configuration. A memory enable input is provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 8 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
- Schottky-clamped for high speed Address access down to-25 ns max Enable access-20 ns max Enable recovery-20 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming

Open-collector outputs

## Block Diagram



Pin Names

| A0-A4 | Addresses |
| :--- | :--- |
| $\overline{\mathrm{G}}$ | Output Enable |
| GND | Ground |
| Q0-Q7 | Outputs |
| $\mathrm{V}_{\mathrm{CC}}$ | Power Supply |

## Connection Diagrams

Dual-In-Line Package


TL/D/9187-2
Top View
Order Number DM74S188J, 188AJ, DM74S188N or 188AN
See NS Package Number J16A or N16A

Plastic Leaded Chip Carrier (PLCC)


TL/D/9187-3
Top Vlew
Order Number DM74S188V or 188AV See NS Package Number V20A

## Ordering Information

Commercial Temp Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Max Access Time (ns) |
| :--- | :---: |
| DM74S188N | 35 |
| DM74S188J | 35 |
| DM74S188V | 35 |
| DM74S188AN | 25 |
| DM74S188AJ | 25 |
| DM74S188AV | 25 |

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Supply Voltage (Note 2) input Voltage (Note 2)

$$
-0.5 \mathrm{~V} \text { to }+7.0 \mathrm{~V}
$$

-1.2 V to +5.5 V
-0.5 V to +5.5 V
Output Voltage (Note 2)
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temp. (Soldering, 10 seconds) $300^{\circ} \mathrm{C}$
ESD to be determined

DC Electrical Characteristics (Note 3)

| Symbol | Parameter | Conditions | DM74S188 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| IIL | Input Load Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}_{\mathrm{H}}$ | Input Leakage Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $V_{\text {IL }}$ (Note 4) | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{1 H}$ (Note 4) | High Level Input Voltage |  | 2.0 |  |  | V |
| loz | Output Leakage Current (Open-Collector Only) | $\mathrm{V}_{\text {CC }}=$ Max, $\mathrm{V}_{\text {CEX }}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {CEX }}=5.5 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{Min}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{C}_{1}$ | Input Capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{Co}_{0}$ | Output Capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| icc | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$, Input Grounded All Outputs Open |  | 70 | 110 | mA |

Note 1: Absolute Maximum Ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.
Note 3: These limits apply over the entire operating range unless stated otherwise. All typical values are for $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.
Note 4: These are absolute voltages with respect to pin 8 on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment.

AC Electrical Characteristics with Standard Load and Operating Conditions
COMMERCIAL TEMP RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | JEDEC <br> Symbol | Parameter | DM74S188 |  |  | DM74S188A |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| TAA | TAVQV | Address Access Time |  | 22 | 35 |  | 17 | 25 | ns |
| TEA | TEVQV | Enable Access Time |  | 15 | 20 |  | 15 | 20 | ns |
| TER | TEXQX | Enable Recovery Time |  | 15 | 25 |  | 15 | 20 | ns |
| TZX | TEVQX | Output Enable Time |  | 15 | 20 |  | 15 | 20 | ns |
| TXZ | TEXQZ | Output Disable Time |  | 15 | 25 |  | 15 | 20 | ns |

## Functional Description

TESTABILITY
The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP (J-package). Device performance in all package configurations is exceilent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $V_{C C}$ and temperature.

## DM74S288 (32 x 8)

256-Bit TTL PROM

## General Description

This Schottky memory is organized in the popular 32 words by 8 bits configuration. A memory enable input is provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 8 outputs go to the "OFF" or high impedance state.

PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
- Schottky-clamped for high speed Address access down to- 25 ns max Enable access-20 ns max Enable recovery-20 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming
- TRI-STATE® Outputs


## Block Diagram



TL/D/8360-1

| Pin Names |  |
| :--- | :--- |
| AO-A4 | Addresses |
| $\bar{G}$ | Enable |
| GND | Ground |
| Q0-Q7 | Outputs |
| $V_{\text {CC }}$ | Power Supply |

## Connection Diagrams

TL/D/8360-2


Top Vlew


Order Number DM74S288J, 288AJ or DM74S288N, 288AN
See NS Package Number J16A or N16A

Plastic Leaded Chip Carrier (PLCC)


TL/D/8360-7
Top View
Order Number DM74S288V or 288AV See NS Package Number V20A

## Ordering Information

## Absolute Maximum Ratings (Note 1)

If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Supply Voltage (Note 2) Input Voltage (Note 2)

$$
-0.5 \mathrm{~V} \text { to }+7.0 \mathrm{~V}
$$

Output Voltage (Note 2)

$$
-1.2 \mathrm{~V} \text { to }+5.5 \mathrm{~V}
$$

$$
-0.5 \mathrm{~V} \text { to }+5.5 \mathrm{~V}
$$

Storage Temperature

$$
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}
$$

Lead Temperature (Soldering, 10 sec .) $300^{\circ} \mathrm{C}$ ESD rating to be determined

## Operating Conditions

|  | Min | Max | Units |
| :--- | :---: | :---: | :---: |
| Supply Voltage (VCC) <br> Commercial | 4.75 | 5.25 | V |
| Ambient Temperature $\left(\mathrm{T}_{\mathrm{A}}\right)$ <br> Commercial | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
| Logical " 0 " Input Voltage <br> Logical " 1 " Input Voltage | 0 | 0.8 | V |
|  | 2.0 | 5.5 | V |

DC Electrical Characteristics (Note 3)

| Symbol | Parameter | Conditions | DM74S288 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| I/L | Input Load Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| ${ }_{1 / \mathrm{H}}$ | Input Leakage Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{IN}}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $\mathrm{V}_{\text {IL }}$ (Note 4) | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\text {IH }}$ (Note 4) | High Level Input Voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{Cl}_{1}$ | Input Capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0, \mathrm{~V}_{\mathrm{IN}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| Co | Output Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \text {, Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| ICC <br> los | Power Supply Current <br> Short Circuit <br> Output Current | $V_{C C}=$ Max, Input Grounded <br> All Outputs Open $V_{O}=0 V, V_{C C}=M a x$ <br> (Note 5) | -20 | 70 | $\begin{array}{r} 110 \\ -70 \end{array}$ | mA <br> mA |
| loz | Output Leakage (TRI-STATE) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{~V}_{\mathrm{O}}=0.45 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \text { Chip Disabled } \end{aligned}$ |  |  | +50 | $\mu \mathrm{A}$ |
|  |  |  |  |  | -50 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output Voltage High | $\mathrm{l}_{\mathrm{OH}}=-2.0 \mathrm{~mA}$ |  |  |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |

Note 1: Absolute maximum ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.
Note 3: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
Note 4: These are absolute voltages with respect to pin 8 on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment.
Note 5: During los measurement, only one output at a time should be grounded. Permanent damage may otherwise result.

## AC Electrical Characteristics with Standard Load and Operating Conditions

COMMERCIAL TEMPERATURE RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | JEDEC <br> Symbol | DM74S288 |  |  | DM74S288A |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| TAA | Address Access Time | TAVQV |  | 22 | 35 |  | 17 | 25 | ns |
| TEA | Enable Access Time | TEVQV |  | 15 | 20 |  | 15 | 20 | ns |
| TER | Enable Recovery Time | TEXQX |  | 15 | 25 |  | 15 | 20 | ns |
| TZX | Output Enable Time | TEVQX |  | 15 | 25 |  | 15 | 20 | ns |
| TXZ | Output Disable Time | TEXQZ |  | 15 | 25 |  | 15 | 20 | ns |

## Functional Description

## TESTABILITY

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow 100\% functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP (J-package). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metalization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $\mathrm{V}_{\mathrm{CC}}$ and temperature.

## General Description

This Schottky memory is organized in the popular 256 words by 4 bits configuration. Memory enable inputs are provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 4 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
- Schottky-clamped for high speed Address access-down to 30 ns max Enable access-20 ns max Enable recovery-20 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming
- $>2000 \mathrm{~V}$ input protection for electrostatic discharge
- TRI-STATE ${ }^{*}$ outputs


## Block Diagram



TL/D/8359-1

## Connection Diagrams

Dual-In-LIne-Package


Top Vlew
Order Number DM74S287J, 287AJ, 287N or 287AN
See NS Package Number J16A or N16A

Plastic Leaded Chip Carrier (PLCC)


Top View
Order Number DM74S287V or 287AV See NS Package Number V20A

## Ordering Information

| Commerclal Temp Range $\left(\mathbf{0}^{\circ} \mathrm{C}\right.$ to $\left.+\mathbf{7 0 ^ { \circ }} \mathbf{C}\right)$ |
| :--- |
| Parameter/Order Number Max Access Time (ns) <br> DM74S287AJ 30 <br> DM74S287J 50 <br> DM74S287AN 30 <br> DM74S287N 50 <br> DM74S287AV 30 <br> DM74S287V 50 |


| Absolute Maximum Ratings (Note 1) |
| :--- |
| If Military/Aerospace specified devices are required, |
| please contact the Natlonal Semiconductor Sales |
| Office/Distributors for availability and specifications. |
| Supply Voltage (Note 2) |
| Input Voltage (Note 2) |
| Output Voltage (Note 2) |
| Storage Temperature |
| Lead Temp. (Soldering, 10 seconds) |
| ESD |
| ES +7.0 V |

$$
\begin{array}{r}
-1.2 \mathrm{~V} \text { to }+5.5 \mathrm{~V} \\
-0.5 \mathrm{~V} \text { to }+5.5 \mathrm{~V} \\
65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
300^{\circ} \mathrm{C} \\
>2000 \mathrm{~V}
\end{array}
$$

## Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC) |  |  |  |
| Commercial | 4.75 | 5.25 | V |
| Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) |  |  |  |
| Commercial | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |
| Logical "0" Input Voltage | 0 | 0.8 | V |
| Logical "1" Input Voltage | 2.0 | 5.5 | V |

DC Electrical Characteristics (Note 3)

| Symbol | Parameter | Conditions | DM74S287 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $1 / 2$ | Input Load Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input Leakage Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{1 \mathrm{~N}}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $V_{\text {IL }}$ (Note 4) | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\mathrm{IH}}$ (Note 4) | High Level Input Voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{Cl}_{1}$ | Input Capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{I N}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{C}_{0}$ | Output Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & T_{A}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| Icc | Power Supply Current | $V_{C C}=$ Max, Inputs Grounded All Outputs Open |  | 80 | 130 | mA |
| los | Short Circuit Output Current | $\begin{aligned} & V_{O}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Max} \\ & \text { (Note 5) } \end{aligned}$ | -20 |  | -70 | mA |
| loz | Output Leakage (TRI-STATE) | $V_{C C}=M a x, V_{O}=0.45 \mathrm{~V} \text { to } 2.4 \mathrm{~V}$ <br> Chip Disabled |  |  | $+50$ | $\mu \mathrm{A}$ |
|  |  |  |  |  | -50 | $\mu \mathrm{A}$ |
| $\mathrm{VOH}_{\mathrm{OH}}$ | Output Voltage High | $\mathrm{IOH}=-2.0 \mathrm{~mA}$ |  |  |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |

Note 1: Absolute maximum ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.

Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.
Note 3: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
Note 4: These are absolute voltages with respect to pin 8 on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment.
Note 5: During los measurement, only one output at a time should be grounded. Permanent damage may otherwise result.

AC Electrical Characteristics with Standard Load and Operating Conditions
COMMERCIAL TEMP RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | JEDEC Symbol | Parameter | DM74S287 |  |  | DM74S287A |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| TAA | TAVQV | Address Access Time |  | 35 | 50 |  | 20 | 30 | ns |
| TEA | TEVQV | Enable Access Time |  | 15 | 25 |  | 15 | 20 | ns |
| TER | TEXQX | Enable Recovery Time |  | 15 | 25 |  | 15 | 20 | ns |
| TZX | TEVQX | Output Enable Time |  | 15 | 25 |  | 15 | 20 | ns |
| TXZ | TEXQZ | Output Disable Time |  | 15 | 25 |  | 15 | 20 | ns |

## Functional Description

## TESTABILITY

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP (J-package). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $V_{C C}$ and temperature.

## DM74S387

## (256 x 4) 1024-Bit TTL PROM

## General Description

This Schottky memory is organized in the popular 256 words by 4 bits configuration. Memory enable inputs are provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 4 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
- Schottky-clamped for high speed

Address access-down to 30 ns max Enable access-20 ns max Enable recovery-20 ns max

- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming
- Open-collector outputs


## Block Diagram



TL/D/9188-1

| Pin Names |  |
| :--- | :--- |
| A0-A7 | Addresses |
| $\overline{\mathrm{G1}}-\overline{\mathrm{G} 2}$ | Output Enables |
| GND | Ground |
| Q0-Q3 | Outputs |
| $\mathrm{V}_{\text {CC }}$ | Power Supply |

## Connection Diagrams

Dual-In-Line Package


TL/D/9188-2
Top View
Order Number DM74S387J, 387AJ, DM74S387N, 387AN
See NS Package Number J16A or N16A

Plastic Leaded Chip Carrier (PLCC)


TL/D/9188-3
Top View
Order Number DM74S387V, 387AV See NS Package Number V20A

## Ordering Information

Commercial Temp Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Max Access Time (ns) |
| :--- | :---: |
| DM74S387AJ | 30 |
| DM74S387J | 50 |
| DM74S387AN | 30 |
| DM74S387N | 50 |
| DM74S387AV | 30 |
| DM74S387V | 50 |

## Absolute Maximum Ratings (Note 1) <br> If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications. <br> Supply Voltage (Note 2) <br> Input Voltage (Note 2) <br> Output Voltage (Note 2) <br> Storage Temperature <br> Lead Temp. (Soldering, 10 seconds) <br> ESD <br> -0.5 V to +7.0 V <br> -1.2 V to +5.5 V <br> -0.5 V to +5.5 V <br> $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ <br> $300^{\circ} \mathrm{C}$ <br> $>2000 \mathrm{~V}$

Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) Commercial | 4.75 | 5.25 | V |
| Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) Commercial | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |
| Logical "0" Input Voltage | 0 | 0.8 | V |
| Logical "1" Input Voltage | 2.0 | 5.5 | V |

DC Electrical Characteristics (Note 3)

| Symbol | Parameter | Conditions | DM74S387 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| IIL | Input Load Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| IIH | Input Leakage Current | $\mathrm{V}_{C C}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $V_{C C}=M a x, V_{I N}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $V_{\text {IL }}$ (Note 4) | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\text {IH }}$ (Note 4) | High Level Input Voltage |  | 2.0 |  |  | V |
| loz | Output Leakage Current (Open-Collector Only) | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {CEX }}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {CEX }}=5.5 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{C}_{1}$ | Input Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{I N}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{C}_{0}$ | Output Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & T_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| ICC | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=$ Max, Inputs Grounded All Outputs Open |  | 80 | 130 | mA |

Note 1: Absolute maximum ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.
Note 3: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.
Note 4: These are absolute voltages with respect to pin 8 on the device and include all overshoots due to system and/or tester noise. Do not attempt to test these values without suitable equipment.

AC Electrical Characteristics with Standard Load and Operating Conditions
COMMERCIAL TEMP RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | JEDEC Symbol | DM74S387 |  |  | DM74S387A |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| TAA | Address Access Time | TAVQV |  | 35 | 50 |  | 20 | 30 | ns |
| TEA | Enable Access Time | TEVQV |  | 15 | 25 |  | 15 | 20 | ns |
| TER | Enable Recovery Time | TEXQX |  | 15 | 25 |  | 15 | 20 | ns |
| TZX | Output Enable Time | TEVQX |  | 15 | 25 |  | 15 | 20 | ns |
| TXZ | Output Disable Time | TEXQZ |  | 15 | 25 |  | 15 | 20 | ns |

## Functional Description

## testability

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP (J-package). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $\mathrm{V}_{\mathrm{CC}}$ and temperature.

## General Description

These Schottky memories are organized in the popular 256 words by 8 bits configuration. Memory enable inputs are provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 8 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
m Schottky-clamped for high speed Address access down to-60 ns max Enable access-30 ns max Enable recovery-30 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming
- TRI-STATE® outputs

Block Diagram


Pin Names

| $\mathrm{AO}-\mathrm{A} 7$ | Addresses |
| :--- | :--- |
| $\overline{\mathrm{G} 1}-\overline{\mathrm{G} 2}$ | Output Enables |
| GND | Ground |
| Q0-Q7 | Outputs |
| $\mathrm{V}_{\mathrm{CC}}$ | Power Supply |

## Connection Diagrams



Order Number DM74LS471J or DM74LS471N See NS Package Number J20A or N20A

Plastic Leaded Chip Carrier (PLCC)


TL/D/9190-3
Top View
Order Number DM74LS471V See NS Package Number V20A

## Ordering Information

| Commercial Temp Range $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ |  |
| :--- | :---: |
| Parameter/Order Number | Max Access Time (ns) |
| DM74LS471N | 60 |
| DM74LS471J | 60 |
| DM74LS471V | 60 |


Note 1: Absolute maximum ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming ratings, refer to the programming instructions.

## Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  |  |  |
| Commercial | 4.75 | 5.25 | V |
| Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) |  |  |  |
| Commercial | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
| Logical "0' Input Voltage | 0 | 0.8 | V |
| Logical "1" Input Voltage | 2.0 | 5.5 | V |

## DC Electrical Characteristics (Note 1)

| Symbol | Parameter | Conditions | DM74LS471 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| IIL | Input Load Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H}}$ | Input Leakage Current | $\mathrm{V}_{C C}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IL}}$ | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\text {IH }}$ | High Level Input Voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{C}_{1}$ | Input Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{C}_{0}$ | Output Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, V_{O}=2.0 \mathrm{~V} \\ & T_{A}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| ICC | Power Supply Current | $V_{C C}=$ Max, Inputs Grounded All Outputs Open |  | 75 | 100 | mA |
| los | Short Circuit Output Current | $\begin{aligned} & V_{O}=0 V, V_{C C}=\operatorname{Max} \\ & \text { (Note 2) } \end{aligned}$ | -20 |  | -70 | mA |
| IOZ | Output Leakage (TRI-STATE) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{~V}_{\mathrm{O}}=0.45 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \text { Chip Disabled } \end{aligned}$ |  |  | +50 | $\mu \mathrm{A}$ |
|  |  |  |  |  | -50 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output Voltage High | $\mathrm{IOH}=-2.0 \mathrm{~mA}$ |  |  |  | V |
|  |  | $\mathrm{l}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |

Note 1: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{v}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
Note 2: During los measurement, only one output at a time should be grounded. Permanent damage may otherwise result.
AC Electrical Characteristics with Standard Load and Operating Conditions

| Symbol | JEDEC Symbol | Parameter | DM74LS471 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| TAA | TAVQV | Address Access Time |  | 40 | 60 | ns |
| TEA | TEVQV | Enable Access Time |  | 15 | 30 | ns |
| TER | TEXQX | Enable Recovery Time |  | 15 | 30 | ns |
| TZX | TEVQX | Output Enable Time |  | 15 | 30 | ns |
| TXZ | TEXQZ | Output Disable Time |  | 15 | 30 | ns |

## Functional Description

## TESTABILITY

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip． These test fuses are placed at the worst－case chip locations to provide the highest possible confidence in the program－ ming tests in the final product．A ROM pattern is also per－ manently fixed in the additional circuitry and coded to pro－ vide a parity check of input address levels．These and other test circuits are used to test for correct operation of the row and column－select circuits and functionality of input and en－ able gates．All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and para－ metric testing at every stage of the test flow．

## RELIABILITY

As with all National products，the Ti－W PROMs are subject－ ed to an on－going reliability evaluation by the Reliability As－ surance Department．These evaluations employ accelerat－ ed life tests，including dynamic high－temperature operating life，temperature－humidity life，temperature cycling，and ther－ mal shock．To date，nearly 7.4 million Schottky Ti－W PROM device hours have been logged，with samples in Epoxy B molded DIP（N－package），PLCC（V－package）and CERDIP （J－package）．Device performance in all package configura－ tions is excellent．

## TITANIUM－TUNGSTEN FUSES

National＇s Programmable Read－Only Memories（PROMs） feature titanium－tungsten（Ti－W）fuse links designed to pro－ gram efficiently with only 10.5 V applied．The high perform－ ance and reliability of these PROMs are the result of fabrica－ tion by a Schottky bipolar process，of which the titanium－ tungsten metallization is an integral part，and the use of an on－chip programming circuit．
A major advantage of the titanium－tungsten fuse technology is the low programming voltage of the fuse links．At 10.5 V ， this virtually eliminates the need for guard－ring devices and wide spacings required for other fuse technologies．Care is taken，however，to minimize voltage drops across the die and to reduce parasitics．The device is designed to ensure that worst－case fuse operating current is low enough for reliable long－term operation．The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links．The complete circuit design is optimized to provide high performance over the entire oper－ ating ranges of $V_{C C}$ and temperature．

## DM74S472

(512 x 8) 4096-Bit TTL PROM

## General Description

This Schottky memory is organized in the popular 512 words by 8 bits configuration. A memory enable input is provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 8 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

E Advanced titanium-tungsten (Ti-W) fuses

- Schottky-clamped for high speed Address access down to- 35 ns max Enable access-25 ns max Enable recovery-25 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming
- TRI-STATE ${ }^{\circledR}$ outputs


## Block Diagram



Pin Names

| $A 0-A 8$ | Addresses |
| :--- | :--- |
| $\bar{G}$ | Output Enable |
| GND | Ground |
| Q0-Q7 | Outputs |
| $V_{C C}$ | Power Supply |

## Connection Diagrams

Dual-In-LIne Package


Top View

Plastic Leaded Chip Carrier (PLCC)


TL/D/9191-3

## Ordering Information

| Commerclal Temp Range $\left(\mathbf{0}^{\circ} \mathrm{C}\right.$ to $\left.+\mathbf{7 0 ^ { \circ }} \mathbf{C}\right)$ |  |
| :--- | :---: |
| Parameter/Order Number | Max Access Time (ns) |
| DM74S472AN | 45 |
| DM74S472BN | 35 |
| DM74S472N | 60 |
| DM74S472AJ | 45 |
| DM74S472BJ | 35 |
| DM74S472J | 60 |
| DM74S472AV | 45 |
| DM74S472BV | 35 |
| DM74S472V | 60 |

## Absolute Maximum Ratings <br> (Note 1)

If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for avallability and specifications. Supply Voltage (Note 2)

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+7.0 \mathrm{~V} \\
-1.2 \mathrm{~V} \text { to }+5.5 \mathrm{~V} \\
-0.5 \mathrm{~V} \text { to }+5.5 \mathrm{~V} \\
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
300^{\circ} \mathrm{C}
\end{array}
$$

Output Voltage (Note 2) Lead Temp. (Soldering, 10 seconds)
ESD to be determined
Note 1: Absolute maximum ratings are those values beyond which the de vice may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.

## Operating Conditions

|  | $\cdots$ | Min | Max |
| :--- | :---: | :---: | :---: |
| Supply Voltage $\left(V_{C C}\right)$ | 4.75 | 5.25 | V |
| Commercial |  |  |  |
| Ambient Temperature $\left(T_{A}\right)$ <br> Commercial | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
| Logical " " Input Voltage <br> Logical "1" Input Voltage | 0 | 0.8 | V |

## DC Electrical Characteristics (Note 1)

| Symbol | Parameter | Conditions | DM74S472 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| IIL | Input Load Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| ${ }_{\mathrm{I}}^{\mathrm{H}}$ | Input Leakage Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $\mathrm{V}_{\text {IL }}$ | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High Level Input Voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{C}_{1}$ | Input Capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{C}_{0}$ | Output Capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| Icc | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$, Input Grounded All Outputs Open |  | 110 | 155 | mA |
| los | Short Circuit Output Current | $\begin{aligned} & V_{O}=0 V, V_{C C}=M a x \\ & \text { (Note 2) } \end{aligned}$ | -20 |  | -70 | mA |
| Ioz | Output Leakage (TRI-STATE) | $V_{C C}=M a x, V_{O}=0.45 \mathrm{~V} \text { to } 2.4 \mathrm{~V}$ <br> Chip Disabled |  |  | +50 | $\mu \mathrm{A}$ |
|  |  |  |  |  | -50 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output Voltage High | $\mathrm{IOH}=-2.0 \mathrm{~mA}$ |  |  |  | V |
|  |  | $\mathrm{l}_{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |

Note 1: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
Note 2: During los measurement, only one output at a time should be grounded. Permanent damage may otherwise result.

## AC Electrical Characteristics with Standard Load and Operating Conditions

COMMERCIAL TEMP RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | JEDEC Symbol | Parameter | DM74S472 |  |  | DM74S472A |  |  | DM74S472B |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max | Min | Typ | Max |  |
| TAA | TAVQV | Address Access Time |  | 40 | 60 |  | 25 | 45 |  | 25 | 35 | ns |
| TEA | TEVQV | Enable Access Time |  | 15 | 30 |  | 15 | 30 |  | 15 | 25 | ns |
| TER | TEXQX | Enable Recovery Time |  | 15 | 30 |  | 15 | 30 |  | 15 | 25 | ns |
| TZX | TEVQX | Output Enable Time |  | 15 | 30 |  | 15 | 30 |  | 15 | 25 | ns |
| TXZ | TEXQZ | Output Disable Time |  | 15 | 30 |  | 15 | 30 |  | 15 | 25 | ns |

## Functional Description

## testability

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP (J-package). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $\mathrm{V}_{\mathrm{CC}}$ and temperature.

## DM74S473

(512 x 8) 4096-Bit TTL PROM

## General Description

This Schottky memory is organized in the popular 512 words by 8 bits configuration. A memory enable input is provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 8 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
- Schottky-clamped for high speed Address access-45 ns max Enable access- 30 ns max Enable recovery-30 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming

■ Open-collector outputs

## Block Diagram



TL/D/9715-1

| Pin Names |  |
| :--- | :---: |
| $A 0-A 8$ Addresses <br> $\bar{G}$ Output Enable <br> GND Ground <br> Q0-Q7 Outputs <br> $V_{C C}$ Power Supply |  |

## Connection Diagrams



TL/D/9715-2

Top View
Order Number DM74S473J, 473AJ,
DM74S473N or 473AN
See NS Package Number J20A or N20A

Plastic Leaded Chip Carrier (PLCC)


TL/D/9715-3
Top View
Order Number DM74S473V or 473AV See NS Package Number V20A

## Ordering Information

Commercial Temp. Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Max Access Time (ns) |
| :--- | :---: |
| DM74S473AN | 45 |
| DM74S473N | 60 |
| DM74S473AJ | 45 |
| DM74S473J | 60 |
| DM74S473AV | 45 |
| DM74S473V | 60 |

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

Supply Voltage (Note 2) Input Voltage (Note 2) Output Voltage (Note 2) Storage Temperature Lead Temp. (Soldering, 10 seconds)

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+7.0 \mathrm{~V} \\
-1.2 \mathrm{~V} \text { to }+5.5 \mathrm{~V} \\
-0.5 \mathrm{~V} \text { to }+5.5 \mathrm{~V} \\
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
300^{\circ} \mathrm{C}
\end{array}
$$ ESD to be determined

Note 1: Absolute maximum ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.

## Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage (VCC) |  |  |  |
| Commercial | 4.75 | 5.25 | V |
| Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) |  |  |  |
| Commercial | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
| Logical "0" Input Voltage | 0 | 0.8 | V |
| Logical "1" Input Voltage | 2.0 | 5.5 | V |

## DC Electrical Characteristics (Note 1)

| Symbol | Parameter | Conditions | DM74S473 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| I/L | Input Load Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| ${ }_{\mathrm{IH}}$ | Input Leakage Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $\mathrm{V}_{\mathrm{IL}}$ | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\text {IH }}$ | High Level Input Voltage |  | 2.0 |  |  | V |
| loz | Output Leakage Current (Open-Collector Only) | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {CEX }}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {CEX }}=5.5 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{Min}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{C}_{1}$ | Input Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{~N}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{C}_{0}$ | Output Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| ICC | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input Grounded All Outputs Open |  | 110 | 155 | mA |

Note 1: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

AC Electrical Characteristics with Standard Load and Operating Conditions
COMMERCIAL TEMP. RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | JEDEC <br> Symbol | Parameter | DM74S473 |  |  | DM74S473A |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| TAA | TAVQV | Address Access Time |  | 40 | 60 |  | 25 | 45 | ns |
| TEA | TEVQV | Enable Access Time |  | 15 | 30 |  | 15 | 30 | ns |
| TER | TEXQX | Enable Recovery Time |  | 15 | 30 |  | 15 | 30 | ns |
| TZX | TEVQX | Output Enable Time |  | 15 | 30 |  | 15 | 30 | ns |
| TXZ | TEXQZ | Output Disable Time |  | 15 | 30 |  | 15 | 30 | ns |

## Functional Description

## testability

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERIP (Jpackage). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanuim-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $V_{C C}$ and temperature.

National Semiconductor

## DM74S570

(512 x 4) 2048-Bit TTL PROM

## General Description

This Schottky memory is organized in the popular 512 words by 4 bits configuration. A memory enable input is provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 4 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
- Schottky-clamped for high speed Address access down to-45 ns max Enable access-25 ns max Enable recovery-25 ns max
PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming Open-collector outputs


## Block Diagram



TL/D/9189-1

## Connection Diagrams

Dual-In-LIne Package


TL/D/9189-2

Top Vlew
Order Number DM74S570J, 570AJ DM74S570N, 570AN
See NS Package Number J16A or N16A

Plastic Leaded Chip Carrier (PLCC)

TL/D/9189-3

## Top Vlew

Order Number DM74S570V, 570AV See NS Package Number V20A

## Ordering Information

Commercial Temp Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Max Access Time (ns) |
| :--- | :---: |
| DM74S570AN | 45 |
| DM74S570N | 55 |
| DM74S570AJ | 45 |
| DM74S570J | 55 |
| DM74S570AV | 45 |
| DM74S570V | 55 |

## Absolute Maximum Ratings (Note 1)

If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Supply Voltage (Note 2)
Input Voltage (Note 2)
Output Voltage (Note 2)
-0.5 V to +7.0 V

Storage Temperature
Lead Temp. (Soldering, 10 seconds)
-1.2 V to +5.5 V
-0.5 V to +5.5 V
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

ESD to be determined
Note 1: Absolute Maximum Ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.

## Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  |  |  |
| Commercial | 4.75 | 5.25 | V |
| Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) |  |  |  |
| Commercial | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
| Logical "0" Input Voltage | 0 | 0.8 | V |
| Logical "1" Input Voltage | 2.0 | 5.5 | V |

## DC Electrical Characteristics (Note 1)

| Symbol | Parameter | Conditions | DM74S570 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| ILL | Input Load Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H}}$ | Input Leakage Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\mathrm{IN}}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $V_{\text {IL }}$ | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High Level Input Voltage |  | 2.0 |  |  | V |
| loz | Output Leakage Current (Open-Collector Only) | $V_{C C}=M a x, V_{C E X}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {CEX }}=5.5 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{l}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{C}_{1}$ | Input Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{I N}=2.0 \mathrm{~V} \\ & T_{A}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| Co | Output Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| Icc | Power Supply Current | $V_{C C}=$ Max, Input Grounded All Outputs Open |  | 90 | 130 | mA |

Note 1: These limits apply over the entire operating range unless otherwise noted. All typical values are for $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.

## AC Electrical Characteristics with Standard Load and Operating Conditions

COMMERCIAL TEMP RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | JEDEC Symbol | Parameter | DM74S570 |  |  | DM74S570A |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max |  |
| TAA | TAVQV | Address Access Time |  | 40 | 55 |  | 30 | 45 | ns |
| TEA | TEVQV | Enable Access Time |  | 20 | 30 |  | 15 | 25 | ns |
| TER | TEXQX | Enable Recovery Time |  | 20 | 30 |  | 15 | 25 | ns |
| TZX | TEVQX | Output Enable Time |  | 20 | 30 |  | 15 | 25 | ns |
| TXZ | TEXQZ | Output Disable Time |  | 20 | 30 |  | 15 | 25 | ns |

## Functional Description

## TESTABILITY

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow 100\% functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP (J-package). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $\mathrm{V}_{\mathrm{CC}}$ and temperature.

## General Description

This Schottky memory is organized in the popular 512 words by 4 bits configuration. A memory enable input is provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 4 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

■ Advanced titanium-tungsten (Ti-W) fuses

- Schottky-clamped for high speed Address access down to- 35 ns max Enable access-25 ns max Enable recovery-25 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming
- TRI-STATE ${ }^{\circledR}$ outputs


## Block Diagram



| Pin Names |  |
| :--- | :--- |
| AO-A8 | Address |
| $\bar{G}$ | Output Enable |
| GND | Ground |
| Q0-Q3 | Outputs |
| $V_{C C}$ | Power Supply |

## Connection Diagrams

Dual-In-Line Package


Top View
Order Number
DM74S571J, 571AJ, 571 BJ
DM74S571N, 571AN, 571BN See NS Package Number J16A or N16A

Plastic Leaded Chip Carrier (PLCC)


TL/D/9713-3
Top View
Order Number
DM74S571V, 571AV, 571BV
See NS Package Number V20A

## Ordering Information

Commercial Temperature Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Max Access Time (ns) |
| :---: | :---: |
| DM74S571AN | 45 |
| DM74S571BN | 35 |
| DM74S571N | 55 |
| DM74S571AJ | 45 |
| DM74S571BJ | 35 |
| DM74S571J | 55 |
| DM74S571AV | 45 |
| DM74S571BV | 35 |
| DM74S571V | 55 |

## Absolute Maximum Ratings (Note 1)

If Milltary/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Supply Voltage (Note 2) Input Voltage (Note 2)
-0.5 V to +7.0 V
-1.2 V to +5.5 V
-0.5 V to +5.5 V
Storage Temperature $\quad-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temp. (Soldering 10 sec .) $300^{\circ} \mathrm{C}$ ESD to be determined
Note 1: Absolute maximum ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.

## Operating Conditions

| Suppiy Voltage $\left(\mathrm{V}_{\mathrm{CC}}\right)$ | Min | Max |
| :--- | :---: | :---: |
| Commercial | 4.75 | 5.25 |
| Ambient Temperature $\left(\mathrm{T}_{\mathrm{A}}\right)$ | V |  |
| Commercial | 0 | +70 |
| Logical "0" input Voltage | 0 | 0.8 |
| Logical "1" Input Voltage | 2.0 | 5.5 |
| V |  |  | V

## DC Electrical Characteristics <br> (Note 1)

| Symbol | Parameter | Conditions | DM74S571 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| IIL | Input Load Current | $\mathrm{V}_{\text {CC }}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input Leakage Current | $V_{C C}=M a x, V_{\text {IN }}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\text {OL }}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $\mathrm{V}_{\text {IL }}$ | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High Level Input Voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{C C}=\mathrm{Min}, \mathrm{I}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{Cl}_{1}$ | Input Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{I N}=2.0 \mathrm{~V} \\ & T_{A}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{Co}_{0}$ | Output Capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & T_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| ${ }^{\text {ICC }}$ | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input Grounded All Outputs Open |  | 90 | 130 | mA |
| los | Short Circuit Output Current | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Max} \\ & \text { (Note 2) } \end{aligned}$ | -20 |  | -70 | mA |
| l OZ | Output Leakage (TRI-STATE) | $V_{C C}=M a x, V_{O}=0.45 \mathrm{~V} \text { to } 2.4 \mathrm{~V}$ <br> Chip Disabled |  |  | +50 | $\mu \mathrm{A}$ |
|  |  |  |  |  | -50 | $\mu \mathrm{A}$ |
| V OH | Output Voltage High | $\mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA}$ |  |  |  | V |
|  |  | $\mathrm{IOH}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |

Note 1: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
Note 2: During los measurement, only one output at a time should be grounded. Permanent damage may otherwise result.

## AC Electrical Characteristics

COMMERCIAL TEMP RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | JEDEC Symbol | Parameter | DM74S571 |  |  | DM74S571A |  |  | DM74S571B |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max | Min | Typ | Max |  |
| TAA | TAVQV | Address Access Time |  | 40 | 55 |  | 30 | 45 |  | 30 | 35 | ns |
| TEA | TEVQV | Enable Access Time |  | 20 | 30 |  | 15 | 25 |  | 15 | 25 | ns |
| TER | TEXQX | Enable Recovery Time |  | 20 | 30 |  | 15 | 25 |  | 15 | 25 | ns |
| TZX | TEVQX | Output Enable Time |  | 20 | 30 |  | 15 | 25 |  | 15 | 25 | ns |
| TXZ | TEXQZ | Output Disable Time |  | 20 | 30 |  | 15 | 25 |  | 15 | 25 | ns |

## Functional Description

## TESTABILITY

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP ( $J$-package). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $\mathrm{V}_{\mathrm{CC}}$ and temperature.

National
Semiconductor
DM74S572
(1024 x 4) 4096-Bit TTL PROM

## General Description

This Schottky memory is organized in the popular 1024 words by 4 bits configuration. Memory enable inputs are provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 4 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
- Schottky-clamped for high speed Address access-45 ns max Enable access-25 ns max Enable recovery-25 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming - Open collector outputs


## Block Diagram



| Pin Names |  |
| :---: | :--- |
| A0-A9 | Addresses |
| $\overline{\text { G1, }}$ G2 | Output Enables |
| GND | Ground |
| Q0-Q3 | Outputs |
| V $_{\text {CC }}$ | Power Supply |

[^4]
## Connection Diagrams

Dual-In-Line-Package


Top Vlew
Order Number DM74S572J, 572AJ, DM74S572N, 572AN
See NS Package Number J18A or N18A

Plastic Leaded Chip Carrier (PLCC)


TL/D/9712-3
Top Vlew
Order Number DM74S572V, 572AV See NS Package Number V20A

## Ordering Information

Commercial Temp Range ( $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| Parameter/Order Number | Max Access Time (ns) |
| :--- | :---: |
| DM74S572AJ | 45 |
| DM74S572J | 60 |
| DM74S572AN | 45 |
| DM74S572N | 60 |
| DM74S572AV | 45 |
| DM74S572V | 60 |

Absolute Maximum Ratings (Note 1)
If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.
Supply Voltage (Note 2)
Input Voltage (Note 2)
-0.5 to +7.0 V
-1.2 V to +5.5 V
-0.5 V to +5.5 V
Output Voltage (Note 2)
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temp. (Soldering, 10 sec .) $300^{\circ} \mathrm{C}$

Operating Conditions

|  | Min | Max | Units |
| :--- | :---: | :---: | :---: |
| Supply Voltage $\left(V_{C C}\right)$ | 4.75 | 5.25 | V |
| Ambient Temperature $\left(T_{\mathrm{A}}\right)$ | 0 | +70 | ${ }^{\circ} \mathrm{C}$ |
| Logical " 0 " Input Voltage | 0 | 0.8 | V |
| Logic "1" Input Voltage | 2.0 | 5.5 | V |

ESD to be determined
Note 1: Absolute maximum ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.

## DC Electrical Characteristics (Note 1)

| Symbol | Parameter | Conditions | DM74S572 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
| $\mathrm{ILL}^{\text {L }}$ | Input Load Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}-250$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input Leakage Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{IN}}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $\mathrm{V}_{\text {IL }}$ | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{1 H}$ | High Level Input Voltage |  | 2.0 |  |  | V |
| loz | Output Leakage Current (Open-Collector Oniy) | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {CEX }}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {CEX }}=5.5 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voitage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $\mathrm{C}_{1}$ | Input Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{I N}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{C}_{0}$ | Output Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, V_{O}=2.0 \mathrm{~V} \\ & T_{A}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| Icc | Power Supply Current | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input Grounded <br> All Outputs Open |  | 100 | 140 | mA |

Note 1: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$.


## Functional Description

TESTABILITY
The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP (J-package). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $\mathrm{V}_{\mathrm{CC}}$ and temperature.

National
Semiconductor
DM74S573
(1024 x 4) 4096-Bit TTL PROM

## General Description

This Schottky memory is organized in the popular 1024 words by 4 bits configuration. Memory enable inputs are provided to control the output states. When the device is enabled, the outputs represent the contents of the selected word. When disabled, the 4 outputs go to the "OFF" or high impedance state.
PROMs are shipped from the factory with lows in all locations. A high may be programmed into any selected location by following the programming instructions.

## Features

- Advanced titanium-tungsten (Ti-W) fuses
- Schottky-clamped for high speed Address access-down to 35 ns max Enable access- 25 ns max Enable recovery-25 ns max
- PNP inputs for reduced input loading
- All DC and AC parameters guaranteed over temperature
- Low voltage TRI-SAFETM programming

TRI-STATE ${ }^{*}$ Outputs

## Block Diagram



Pin Names

| $\mathrm{A} 0-\mathrm{A} 9$ | Addresses |
| :--- | :--- |
| $\overline{\mathrm{G} 1-\overline{\mathrm{G2}}}$ | Output Enables |
| GND | Ground |
| Q0-Q3 | Outputs |
| $\mathrm{V}_{\text {CC }}$ | Power Supply |

TL/D/9193-1

## Connection Diagrams

Dual-In-Line Package


TL/D/9193-2

Top View
Order Number
DM74S573J, 573AJ, 573BJ DM74S573N, 573AN, 573BN

Plastic Leaded Chip Carrier (PLCC)


TL/D/9193-3
Top View
Order Number
DM74S573V, 573AV, 573BV
See NS Package Number V20A

## Ordering Information

| Commercial Temp Range $\left(\mathbf{0}^{\circ} \mathbf{C}\right.$ to $\left.+\mathbf{7 0 ^ { \circ }} \mathbf{C}\right)$ |  |
| :--- | :---: |
| Parameter/Order Number | Max Access Time (ns) |
| DM74S573AJ | 45 |
| DM74S573BJ | 35 |
| DM74S573J | 60 |
| DM74S573AN | 45 |
| DM74S573BN | 35 |
| DM74S573N | 60 |
| DM74S573AV | 45 |
| DM74S573BV | 35 |
| DM74S573V | 60 |


| Absolute Maximum Ratings (Note 1) |  |
| :---: | :---: |
| If Military/Aerospace specified od please contact the National S Office/Distributors for availability | ces are required, conductor Sales specifications. |
| Supply Voltage (Note 2) | -0.5 V to +7.0 V |
| Input Voltage (Note 2) | -1.2 V to +5.5 V |
| Output Voltage (Note 2) | -0.5 V to +5.5 V |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temp. (Soldering, 10 seconds) | $300^{\circ} \mathrm{C}$ |

Note 1: Absolute maximum ratings are those values beyond which the device may be permanently damaged. They do not mean that the device may be operated at these values.
Note 2: These limits do not apply during programming. For the programming ratings, refer to the programming instructions.

## Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  |  |  |
| Commercial | 4.75 | 5.25 | V |
| Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) |  |  |  |
| Commercial | 0 | $+70$ | ${ }^{\circ} \mathrm{C}$ |
| Logical "0' Input Voltage | 0 | 0.8 | V |
| Logical "1" Input Voltage | 2.0 | 5.5 | V |

## DC Electrical Characteristics (Note 1)

| Symbol | Parameter | Conditions | DM74S573 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max |  |
|  | Input Load Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |  | -80 | -250 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input Leakage Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{IN}}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
|  |  | $V_{\text {CC }}=M a x, V_{\text {IN }}=5.5 \mathrm{~V}$ |  |  | 1.0 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Low Level Output Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.35 | 0.45 | V |
| $\mathrm{V}_{\text {IL }}$ | Low Level Input Voltage |  |  |  | 0.80 | V |
| $\mathrm{V}_{\text {IH }}$ | High Level Input Voltage |  | 2.0 |  |  | V |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{IN}}=-18 \mathrm{~mA}$ |  | -0.8 | -1.2 | V |
| $c_{1}$ | Input Capacitance | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{1 N}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz} \end{aligned}$ |  | 4.0 |  | pF |
| $\mathrm{C}_{0}$ | Output Capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, 1 \mathrm{MHz}, \text { Outputs Off } \end{aligned}$ |  | 6.0 |  | pF |
| ICC | Power Supply Current | $V_{C C}=$ Max, Input Grounded <br> All Outputs Open |  | 100 | 140 | mA |
| Ios | Short Circuit Output Current | $\begin{aligned} & V_{O}=O V, V_{C C}=\operatorname{Max} \\ & \text { (Note 2) } \end{aligned}$ | -20 |  | -70 | mA |
| loz | Output Leakage (TRI-STATE) | $V_{C C}=M a x, V_{O}=0.45 \mathrm{~V} \text { to } 2.4 \mathrm{~V}$ <br> Chip Disabled |  |  | $+50$ | $\mu \mathrm{A}$ |
|  |  |  |  |  | $-50$ | $\mu \mathrm{A}$ |
| $\mathrm{VOH}^{\prime}$ | Output Voltage High | $\mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA}$ |  |  |  | V |
|  |  | $\mathrm{IOH}^{\prime}=-6.5 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |

Note 1: These limits apply over the entire operating range unless stated otherwise. All typical values are for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
Note 2: During los measurement, only one output at a time should be grounded. Permanent damage may otherwise result.

## AC Electrical Characteristics with Standard Load and Operating Conditions

COMMERCIAL TEMP RANGE $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| Symbol | JEDEC Symbol | Parameter | DM74S573 |  |  | DM74S573A |  |  | DM74S573B |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Typ | Max | Min | Typ | Max | Min | Typ | Max |  |
| TAA | TAVQV | Address Access Time |  | 40 | 60 |  | 25 | 45 |  | 25 | 35 | ns |
| TEA | TEVQV | Enable Access Time |  | 20 | 35 |  | 15 | 25 |  | 15 | 25 | ns |
| TER | TEXQX | Enable Recovery Time |  | 20 | 35 |  | 15 | 25 |  | 15 | 25 | ns |
| TZX | TEVQX | Output Enable Time |  | 20 | 35 |  | 15 | 25 |  | 15 | 25 | ns |
| TXZ | TEXQZ | Output Disable Time |  | 20 | 35 |  | 15 | 25 |  | 15 | 25 | ns |

## Functional Description

## testability

The Schottky PROM die includes extra rows and columns of fusable links for testing the programmability of each chip. These test fuses are placed at the worst-case chip locations to provide the highest possible confidence in the programming tests in the final product. A ROM pattern is also permanently fixed in the additional circuitry and coded to provide a parity check of input address levels. These and other test circuits are used to test for correct operation of the row and column-select circuits and functionality of input and enable gates. All test circuits are available at both wafer and assembled device levels to allow $100 \%$ functional and parametric testing at every stage of the test flow.

## RELIABILITY

As with all National products, the Ti-W PROMs are subjected to an on-going reliability evaluation by the Reliability Assurance Department. These evaluations employ accelerated life tests, including dynamic high-temperature operating life, temperature-humidity life, temperature cycling, and thermal shock. To date, nearly 7.4 million Schottky Ti-W PROM device hours have been logged, with samples in Epoxy B molded DIP (N-package), PLCC (V-package) and CERDIP (J-package). Device performance in all package configurations is excellent.

## TITANIUM-TUNGSTEN FUSES

National's Programmable Read-Only Memories (PROMs) feature titanium-tungsten (Ti-W) fuse links designed to program efficiently with only 10.5 V applied. The high performance and reliability of these PROMs are the result of fabrication by a Schottky bipolar process, of which the titaniumtungsten metallization is an integral part, and the use of an on-chip programming circuit.
A major advantage of the titanium-tungsten fuse technology is the low programming voltage of the fuse links. At 10.5 V , this virtually eliminates the need for guard-ring devices and wide spacings required for other fuse technologies. Care is taken, however, to minimize voltage drops across the die and to reduce parasitics. The device is designed to ensure that worst-case fuse operating current is low enough for reliable long-term operation. The Darlington programming circuit is liberally designed to insure adequate power density for blowing the fuse links. The complete circuit design is optimized to provide high performance over the entire operating ranges of $\mathrm{V}_{\mathrm{CC}}$ and temperature.

## Bipolar PROM Devices in Plastic Leaded Chip Carriers (PLCC)

## Introduction of Surface Mount Technology

Recent years have seen rapid advances in microcircuit technology. The integrated circuits of the 1980's are more complex than the circuit boards of the 1960's. It is evident that the next decade will bring demands for packages with higher lead counts and closer lead spacing, both to support the greater system density sought by designers.
National Semiconductor Corporation is committed to surface mount devices, for they provide the most practical solution to these needs. Geared to development of high-complexity semiconductor chips National has placed great emphasis on package development and introducing plastic leaded chip carriers with various number of leads as surface mounted components.

## Features of Surface Mount Devices

Surface mount devices have additional features compared to molded Dual-In-Line Packages (DIP):

1. Compact design that saves space during assembly.
2. Mounting on both sides of the substrate.
3. Easier handling and excellent reliability.
4. Automation of the assembly process.
5. Lower board manufacturing costs.
6. Improved operating speed.
7. Increased board density and reduced weight.

## Applications

Surface mount devices can be used where substrate size, as well as weight and thickness are limited. The surface mount device can also be used in areas where conventional packages cannot be used. Areas of application include; portable video cassette recorders, video cameras, hand-held computers, personal computers, electronic toys, car electronics, cameras, telephones, and various telecommunication equipment.

## Products in PLCC

National Semiconductor has a broad Family of high performance PROMs. All the PAL® and PROM products presently offered in DIP packages will now be available in the PLCC (plastic leaded chip carrier) package including the 15 ns industries fastest PAL.

## Advantages of PLCC

1. Permits automated assembly.
2. Lower manufacturing costs.
3. Smaller PLCC size, reduces board density and weight.
4. Lower noise and improved frequency response resulting from shorter circuit paths. Automated assembly ensures accurate component placement which improves reliability and provides more consistent product quality.

## Additional Information

National Semiconductor offers a variety of technical briefs covering surface mount topics. These include:
STARTM Tape-and-Reel Shipping System Order Number 113635
Getting Started in Surface Mount (Equipment Suppliers) Order Number 570435

A Basic Guide to Surface Mounting of Electronic Components

Order Number 113615
Reliability Report: Small Outline Packages Order Number 570430

Reliability Report: Plastic Chip Carrier Order Number 980040

Plastic Chip Carrier Technology Order Number 113295



## Programming Support

PROM devices may be programmed with hardware and software readily available in the market. Most programmer manufacturers will offer a PLCC adapter which will fit in existing equipment. For the availability of PLCC adapter please check with your programmer manufacturer.

## Programming Equipment

1. Data I/O
2. Structured Design
3. Stag
4. Dig Elec
5. Kontron
6. Prolog
7. Citel

Programming Parameters Do not test or you may program the device

| Symbol | Parameters | Conditions | Min | Recommended Value | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CCP }}$ | Required $\mathrm{V}_{\mathrm{CC}}$ for Programming |  | 10.0 | 10.5 | 11.0 | V |
| ICCP | ICC during Programming | $V_{C C}=11 \mathrm{~V}$ |  |  | 750 | mA |
| $V_{\text {OP }}$ | Required Output Voltage for Programming |  | 10.0 | 10.5 | 11.0 | V |
| lop | Output Current while Programming | $\mathrm{V}_{\text {OUT }}=11 \mathrm{~V}$ |  |  | 20 | mA |
| $I_{\text {RR }}$ | Rate of Voltage Change of $V_{\text {CC }}$ or Output |  | 1.0 |  | 10.0 | $\mathrm{V} / \mu \mathrm{s}$ |
| PWE | Programming Pulse Width (Enabled) |  | 9 | 10 | 11 | $\mu \mathrm{S}$ |
| $\mathrm{V}_{\text {CCVH }}$ | Required High V ${ }_{\text {CC }}$ for Verification |  | 5.8 | 6.0 | 6.2 | V |
| $\mathrm{V}_{\text {CCVL }}$ | Required Low $\mathrm{V}_{\text {CC }}$ for Verification |  | 3.8 | 4.0 | 4.2 | V |
| M ${ }_{\text {DC }}$ | Maximum Duty Cycle for $V_{C C}$ at $V_{C C P}$ |  |  | 25 | 25 | \% |

Programming Waveforms Non-Registered PROM
$\mathrm{T}_{1}=100 \mathrm{~ns}$ Min.
$\mathrm{T}_{2}=5 \mu \mathrm{~s}$ Min. T2 may be $>0$ if
$V_{\mathrm{CCP}}$ rises at the same rate or.
faster than (VOP)
$\mathrm{T}_{3}=100 \mathrm{~ns} \mathrm{Min}$.
$T_{4}=100 \mathrm{~ns}$ Min.
$T_{5}=100 \mathrm{~ns}$ Min.
PWE is repeated for 5 additional pulses after verification of $\mathrm{V}_{\mathrm{OH}}$ indicates a bit has been programmed.


NOTE: ENABLE WAVEFORM FOR AN ACTIVE LOW ENABLE. SOME PROMS HAVE MORE THAN ONE CHIP ENABLE. hOLD ALL OTHER ENABLE(S) TO ACTIVE STATE(S).

## Standard Test Loads <br> Non-Registered PROMs



## Switching Time Waveforms



## Approved Programmers for NSC PROMs

| Manufacturer | System \# |
| :--- | :--- |
| DATA I/O | $5 / 17 / 19 / 29 A$ |
| PRO-LOG | M910,M980 |
| KONTRON | MPP80S |
| STAG | PPX |
| AIM | RP400 |
| DIGELEC | UP803 |
| STARPLEXTM |  |

Quality Enhancement Programs For Bipolar Memory

| A+ PROGRAM* |  |  | B+ PROGRAM |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Condition | Guaranteed LOT AQL 5 | Test | Condition | Guaranteed LOT AQL 5 |
| D.C Parametric and Functionality | $25^{\circ} \mathrm{C}$ | 0.05 | D.C Parametric and Functionality | $25^{\circ} \mathrm{C}$ | 0.05 |
|  | Each Temperature Extreme | 0.05 |  | Each Temperature Extreme | 0.05 |
| A.C. Parametric | $25^{\circ} \mathrm{C}$ | 0.4 | A.C Parametric | $25^{\circ} \mathrm{C}$ | 0.4 |
| Mechanical | Critical | 0.01 | Mechanical | Critical | 0.01 |
|  | Major | 0.28 |  | Major | 0.28 |
| Seal Tests Hermetic | Fine Leak $\left(5 \times 10^{-8}\right)$ | 0.4 | Seal Tests <br> Hermetic | Fine Leak $\left(5 \times 10^{-8}\right)$ | 0.4 |
|  | Gross | 0.4 |  | Gross | 0.4 |

*Includes 160 hours of burn-in at $125^{\circ} \mathrm{C}$.

## Section 4 <br> Application Notes

## Section 4 Contents

AB-15 Protecting Data in Serial EEPROMs... ..... 4-3
AB-18 Electronic Compass Calibration Made Easy with EEPROMs ..... 4-5
AN-338 Designing with the NM93C06 A Versatile Simple to Use EEPROM ..... 4-6
AN-423 The NM93C46-An Amazing Device ..... 4-12
AN-507 Using the NM93CSXX Family of Electrically Erasable Programmable Memory ..... 4-15
AN-716 Using the NM93CS EEPROM Family Features ..... 4-29
AN-731 Using National's NMC87C257 256K EPROM with On-Chip Latches ..... 4-31
AN-735 Understanding National's NM95C12 EEPROM with Programmable Switches ..... 4-33
AN-755 NM95C12 Flexibility in Industrial Control Applications ..... 4-39
AN-756 Using the NM95C12 to Solve Common Manufacturing Problems ..... 4-50
AN-758 Using National's MICROWIRE EEPROM ..... 4-62
AN-765 Using the NM95C12 CMOS EEPROM with Programmable Switches for Analog Applications ..... 4-73
AN-766 Using the NM95C12 in a Stand Alone Metering Device ..... 4-80
AN-767 NM95C12 Memory Mapping Solution for PC® Applications ..... 4-89
AN-789 Integrated Manufacturing Control-NM95C12 ..... $4-93$
AN-790 NM95C12 EEPROM Controls Amplifier Gain ..... 4-96
AN-791 Stand Alone Control of MICROWIRE Peripherals Using the NMC87C257 ..... 4-102
AN-792 NM95C12 Applications in a PC-AT Ethernet Adapter ..... 4-123
AN-794 Using an EEPROM-I²C Interface NM24C02/03/04/05/08/09/16/17 ..... 4-127

## Protecting Data in Serial EEPROMs

National offers a broad line of serial interface EEPROMs which share a common set of features:

- Low cost
- Single supply in all modes ( $+5 \mathrm{~V} \pm 10 \%$ )
- TTL compatible interface
- MICROWIRETM compatible interface
- Read-Only mode or read-write mode

This Application Brief will address protecting data in any of National's Serial Interface EEPROMs by using read-only mode.
Whereas EEPROM is non-volatile and does not require $V_{C C}$ to retain data, the problem exists that stored data can be destroyed during power transitions. This is due to either uncontrolled interface signals during power transitions or noise on the power supply lines. There are various hardware design considerations which can help eliminate the problem although the simplest most effective method may be the following programming method.
All National Serial EEPROMs, when initially powered up are in the Program Disable Mode*. In this mode, the EEPROM will abort any requested Erase or Write cycles. Prior to Eras-

National Semiconductor Application Brief 15 Paul Lubeck
ing or Writing it is necessary to place the device in the Program Enable Mode $\dagger$. Following placing the device in the Program Enable Mode, Erase and Write will remain enabled until either executing the Disable instruction or removing $V_{C C}$. Having $V_{C C}$ unexpectedly removed often results in uncontrolled interface signals which could result in the EEPROM interpreting a programming instruction causing data to be destroyed.
Upon power up the EEPROM will automatically enter the Program Disable Mode. Subsequently the design should incorporate the following to achieve protection of stored data.

1) The device powers up in the read-only mode. However, as a backup, the EWDS instruction should be executed as soon as possible after $V_{C C}$ to the EEPROM is powered up to ensure that it is in the read-only mode.
2) Immediately preceding a programming instruction (ERASE, WRITE, ERAL or WRAL), the EWEN instruction should be executed to enable the device for programming; the EWDS instruction should be executed immediately following the programming instruction to return -EWDS or WDS, depending on exact device. tEWE'N or WEN, depending on exact device.


TL/D/7085-1

TL/D/7085-2 -EWDS must be executed before $\mathrm{V}_{\mathrm{CC}}$ drops below 4.5 V to prevent accidental data loss during subsequent power down and/or power up transients.

FIGURE 2. Typical Instruction Flow for Maximum Data Protection
the device to the read-only mode and protect the stored data from accidental disturb during subsequent power transients or noise.
3) Special care must be taken in designs in which programming instructions are initiated to store data in the EEPROM after the main power supply has gone down. This is usually accomplished by maintaining $V_{C C}$ for the EEP. ROM and its controller on a capacitor for a sufficient amount of time (approximately 50 ms , depending on the clock rate) to complete these operations. This capacitor
must be large enough to maintain $V_{C C}$ between 4.5 and 5.5 volts for the total duration of the store operation, INCLUDING the execution of the EWDS instruction immediately following the last programming instruction. FAILURE TO EXECUTE THE LAST EWDS INSTRUCTION BEFORE VCC DROPS BELOW 4.5 VOLTS MAY CAUSE INADVERTENT DATA DISTURB DURING SUBSEQUENT POWER DOWN ANDIOR POWER UP TRAN SIENTS.

## Electronic Compass Calibration Made Easy with EEPROMs

When a compass is first installed in a vehicle, or when new equipment, such as car speakers, are added to a vehicle with a compass, the compass must be compensated for stray magnetic fields. With a magnetic compass, it must be pointed towards magnetic north and then adjusted. This procedure is repeated at all four main points of the compass until the compass is calibrated. This procedure is lengthy and also requires another calibrated compass to point the vehicle in the correct direction.
The block diagram illustrates an electronic compass that, with the aide of an $E^{2}$ memory, makes adjusting a compass as easy as pushing a button, and also eliminates the need for another compass. In addition it gives you the ability to adjust for variation between magnetic and true north. This is a major advantage because it is something that even the most expensive magnetic compass cannot do.
The brain of the electronic compass is the COP421 microcontroller. There are two sense coils, one for north/south and one for east/west. The output of each of the sense amplifiers is an analog voltage which is fed into the $A$ to $D$ converter. These voltages are read by the COP421 over the microwire interface. From these voltages, the microcontroller determines the direction and displays the results
once again over the microwire interface. To compensate the compass in a new environment the procedure is very simple. Start by pointing the car in any direction and push the switch. The CPU at this time will measure the voltage at the sense amplifiers and store this information in the $\mathrm{E}^{2}$ memory over the microwire interface. Now the vehicle is turned $180^{\circ}$, and the button is pushed again. The same procedure will be followed internally. The compensation procedures are now complete. During operation the CPU will compensate for stray fields by adding an analog voltage back into the sense amplifiers. This value is stored in $E^{2}$ memory and not lost when the power is turned off, but is readjustable if its environment is modified.
Compass variation is the difference between true and magnetic north. This variation differs all over the world and is something that must be taken into consideration when navigating by compass. With the $E^{2}$ memory device, a variance can be programmed in for any given location. In California this is approximately $17^{\circ}$, in Michigan approximately $1^{\circ}$. Once again, this cannot be accomplished by a magnetic compass, and would have been impossible to accomplish without an $E^{2}$ memory device.

## Designing with the NM93C06 <br> A Versatile Simple to Use E2 PROM

This application note outlines various methods of interfacing an NM93C06 with the COPSTM family of microcontrollers and other microprocessors. Figures 1-6 show pin connections involved in such interfaces. Figure 7 shows how parallel data can be converted into a serial format to be inputted to the NM93C06; as well as how serial data outputted from an NM93C06 can be converted to a parallel-format.
The second part of the application note summarizes the key points covering the critical electrical specifications to be kept in mind when using the NM93C06.
The third part of the application note shows a list of various applications that can use a NM93C06.

## GENERIC CONSIDERATIONS

A typical application should meet the following generic criteria:

1. Allow for no more than 10,000 E/W cycles for optimum and reliable performance.
2. Allow for any number of read cycles.
3. Allow for an erase or write cycle that operates in the $10-30 \mathrm{~ms}$ range, and not in the tens or hundreds of ns range as used in writing RAMs. (Read vs write speeds are distinctly different by orders of magnitude in E2P. ROM, not so in RAMs.)

4. No battery back-up required for data-retention, which is fully non-volatile for at least 10 years at room-ambient.

## SYSTEM CONSIDERATIONS

When the control processor is turned on and off, power supply transitions between ground and operating voltage may cause undesired pulses to occur on data, address and control lines. By using WEEN and WEDS instructions in conjunction with a LO-HI transition on CS, accidental erasing or writing into the memory is prevented.
The duty cycle in conjunction with the maximum frequency translates into having a minimum Hi-time on the SK clock. If the minimum SK clock high time is greater than $1 \mu \mathrm{~s}$, the duty cycle is not a critical factor as long as the frequency does not exceed the 250 kHz max. On the low side no limit exists on the minimum frequency. This makes it superior to the COP499 CMOS-RAM. The rise and fall times on the SK clock can also be slow enough not to require termination up to reasonable cable-lengths.

Since the device operates off of a simple 5 V supply, the signal levels on the inputs are non-critical and may be operated anywhere within the specified input range.


FIGURE 1. NM93C06-COP420 Interface


TL/D/5286-2
FIGURE 2. NM93CO6-Standard $\mu$ P Interface Via COP Processor


TL/D/5286-3

$$
\left.\begin{array}{rl}
\text { PAO } & \rightarrow \begin{array}{l}
\text { SK } \\
\text { PA1 }
\end{array} \\
\text { DI/DO }
\end{array}\right\} \begin{aligned}
& \text { Commor } \\
& \text { PA2-7 }
\end{aligned} \rightarrow \begin{aligned}
& \text { 6CS for } 6-9306 ' s
\end{aligned}
$$

*SK is generated on port pins by bit-set and blt-clear operations in software. A symmetrical duty cycle is not critical.

* CS is set in software. To generate $\mathbf{1 0 - 3 0} \mathbf{~ m s}$ write/erase the timer/counter is used. During write/erase. SK may be turned off.

FIGURE 3. NSC800TM to NM93C06 Interface (also Valld for 8085/8085A and 8156)

(3)
$\left.\begin{array}{ll}\text { Z80-P10 } & 9306 \\
\text { A0 } & \text { SK } \\
\text { A1 } & \text { DI/DO }\end{array}\right\} \quad$ Common to all 9306's (Bank 1)

| A2-A7 |
| :--- |
| CS1-CS6 |


| Only used if priority interrupt daisy chain is desired |
| :--- |
| - Identical connection for Port B |

FIGURE 4. Z80-NM93C06 Interface Using Z80-PIO Chip


TL/D/5286-5

* SK and DI are generated by software. It should be noted that at $2.72 \mu \mathrm{~s} / \mathrm{Instruction}$. The minimum SK period achlevable will be $\mathbf{1 0 . 8 8} \mu \mathrm{s}$ or $\mathbf{9 2} \mathbf{k H z}$, well within the NM93C06 frequency range.
- DO may be brought out on a separate port pin if desired.

FIGURE 5.48 Series $\mu$ P—NM93C06 Interface


Expander outputs


Port 5-6 CS3-CS10
Port 7 DO (COMMON)
FIGURE 6. 8048 I/O Expansion


FIGURE 7. Converting Parallel Data into Serial Input for NM93C06


TL/D/5286-8
FIGURE 8. NM93C06 Timing

## THE NM93C06A

Extremely simple to interface with any $\mu \mathrm{P}$ or hardware logic. The device has six pins for the following functions:

| Pin 1 | CS* | HI enabled |
| :--- | :--- | :--- |
| Pin 2 | SK | Serial Clock input |
| Pin 3 | DI | For instruction or data <br> input |
| Pin 4 | DO** | For data read, TRI-STATE <br> otherwise |
| Pin 5 | GND |  |
| Pin 8 | VCC | For 5V power |
| Pins 6-7 | No Connect | No termination required |

*Following an E/W instruction feed, CS is also toggled low for 10 ms (typical) for an E/W operation. This internally turns the VPP generator on (HI-LO on CS) and off (LO-HI on CS).
**DI and DO can be on a common line since DO is TRISTATED when unselected DO is only on in the read mode.

## USING THE NM93C06

## The following points are worth noting:

1. SK clock frequency should be in the $0-250 \mathrm{kHz}$ range. With most $\mu \mathrm{Ps}$ this is easily achieved when implemented in software by bit-set and bit-clear instructions, which take 4 instructions to execute a clock or a frequency in the 100 kHz range for standard $\mu \mathrm{P}$ speeds. Symmetrical duty cycle is irrelevant if SK HI time is 2 $2 \mu \mathrm{~s}$.
2. CS low period following an E/W instruction must not exceed the 30 ms max. It should best be set at typical or minimum spec of 10 ms . This is easily done by timer or a software connect. The reason is that it minimizes the 'on time' for the high VPP internal voltage, and so maximizes endurance. SK-clock during this period may be turned off if desired.
3. All E/W instructions must be preceded by EWEN and should be followed by an EWDS. This is to secure the stored data and avoid inadvertent erase or write.
4. A continuously 'on' SK clock does not hurt the stored data. Proper sequencing of instructions and data on DI is essential to proper operation.
5. Stored data is fully non-volatile for a minimum of ten years independent of $V_{c c}$, which may be on or off. Read cycles have no adverse effects on data retention.
6. Up to 10,000 E/W cycles/register are possible. Under typical conditions, this number may actually approach 1 million. For applications requiring a large number of cycles, redundant use of internal registers beyond 10,000 cycles is recommended.
7. Data shows a fairly constant E/W Programming behavior over temperature. In this sense E2PROMs supersede EPROMs which are restricted to room temperature programming.
8. As shown in the timing diagrams, the start bit on Dl must be set by a ZERO - ONE transition following a CS enable (ZERO - ONE), when executing any instruction. ONE CS enable transition can only execute ONE instruction.
9. In the read mode, following an instruction and data train, the DI can be a don't care, while the data is being outputted i.e., for next 17 bits or clocks. The same is true for other instructions after the instruction and data has been fed in.
10. The data-out train starts with a dummy bit 0 and is terminated by chip deselect. Any extra SK cycle after 16 bits is not essential. If CS is held on after all 16 of the data bits have been outputted, the DO will output the state of DI till another CS LO-HI transition starts a new instruction cycle.
11. When a common line is used for DI and DO , a probable overlap occurs between the last bit on DI and start bit on DO.
12. After a read cycle, the CS must be brought low for 1 SK clock cycle before another instruction cycle can start.
All commands, data in, and data out are shifted in/out on rising edge of SK clock.
Write/erase is then done by pulsing CS low for 10 ms .
All instructions are initiated by a LO-HI transition on CS followed by a LO-HI transition on DI.
READ - After read command is shifted in DI becomes don't care and data can be read out on data out, starting with dummy bit zero.
WRITE - Write command shifted in followed by data in (16 bits) then CS pulsed low for 10 ms minimum.

## INSTRUCTION SET

| Instruction | SB | Opcode | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :---: | :--- |
| READ | 01 | $10 x x$ | A3A2A1A0 |  | Read Register A3A2A1AO |
| WRITE | 01 | $01 x x$ | A3A2A1A0 | D15-D0 | Write Register A3A2A1AO |
| ERASE | 01 | $11 x x$ | A3A2A1A0 |  | Erase Register A3A2A1A0 |
| EWEN | 01 | 0011 | XXXX |  | Erase/Write Enable |
| EWDS | 01 | 0000 | XXXX |  | Erase/Write Disable |
| ERAL | 01 | 0010 | XXXX |  | Erase All Registers |
| WRAL | 01 | 0001 | XXXX | D15-D0 | Write All Registers |

NM93C06 has 7 instructions as shown. Note that MSB of any given instruction is a " 1 " and is viewed as a start bit in the interface sequence. The next 8 bits carry the op code and the 4 -bit address for 1 of 16, 16-bit registers. X is a don't care state.

The following is a list of various systems that could use a
NM93C06
A. Airline terminal

Alarm system
Analog switch network
Auto calibration system
Automobile odometer
Auto engine control
Avionics fire control
B. Bathroom scale

Blood analyzer
Bus interface
C. Cable T.V. tuner

CAD graphics
Calibration device
Calculator-user programmable
Camera system
Code identifier
Communications controller
Computer terminal
Control panel
Crystal oscillator
D. Data acquisition system

Data terminal
E. Electronic circuit breaker

Electronic DIP switch
Electronic potentiometer
Emissions analyzer
Encryption system
Energy management system
F. Flow computer

Frequency synthesizer
Fuel computer
G. Gas analyzer

Gasoline pump
H. Home energy management Hotel lock
I. Industrial control Instrumentation
J. Joulemeter
K. Keyboard -softkey
L. Laser machine tool
M. Machine control

Machine process control
Medical imaging
Memory bank selection
Message center control
Mobile telephone

Modem
Motion picture projector
N. Navigation receiver

Network system
Number comparison
O. Oilfield equipment
P. PABX

Patient monitoring
Plasma display driver
Postal scale
Process control
Programmable communications
Protocol converter
Q. Quiescent current meter
R. Radio tuner Radar dectector
Refinery controller
Repeater
Repertory dialer
S. Secure communications system

Self diagnostic test equipment
Sona-Bouy
Spectral scanner
Spectrum analyzer
T. Telecommunications switching system

Teleconferencing system
Telephone dialing system
T.V. tuner

Terminal
Test equipment
Test system
TouchTone dialers
Traffic signal controller
U. Ultrasound diagnostics Utility telemetering
V. Video games

Video tape system
Voice/data phone switch
W. Winchester disk controller
X. X-ray machine Xenon lamp system
Y. YAG-laser controller
Z. Zone/perimeter alarm system

## The NM93C46—An Amazing Device

Question: What has 8 pins, runs on 5 V and can store any one of more than 10300 unique bit patterns?
Answer: The NM93C46-a 1024-bit serial EEPROM.
Surprised? It is easy to check:

$$
\begin{aligned}
& 2^{1024}=\text { number of possible combinations } \\
& 2^{10}=10^{3} \\
& 2^{1024} \cong\left(2^{10}\right)^{102}=\left(10^{3}\right)^{102}=10^{306}
\end{aligned}
$$

10306 combinations are more than enough for any conceivable security application, serial number, or station I.D. many times over. Although the NM93C46 is a small part both physically and in memory size, its capacity to store unique codes is boundless.
Figure 1 shows the pin assignments and pin names for the NM93C46. Pins 6 and 7 are not connected, leaving only 6 active pins on the device. The DO pin is not active while data is being loaded through the DI pin. DI and DO can be tied together, creating a device that requires a 5 -wire interface. This interface may be useful in security applications. The EEPROM could be built into a module that could be used as a "smart key" in electronic security systems. The key would be read whenever it was inserted into a 5-contact keyhole and access would be granted or denied as determined by the stored code. If only 256 bits of the EEPROM were to be used to store the code, this would still provide $10^{77}$ possible combinations. The remainder of the memory in the key could be used for data collection or to keep a record of where the key had been. It should be noted that ability to write data into the key allows the key to be immediately erased if it is misused.

Dual-In-Line Package


TL/D/8611-1
Pin Names

| CS | Chip Select |
| :--- | :--- |
| SK | Serial Clock |
| DI | Data Input |
| DO | Data Output |
| VCC | +5 V |
| GND | Ground |
| NC | No Connection |

FIGURE 1

National Semiconductor
Application Note 423
Stacy Deming


The 5-contact key is nice, but a 4-contact key is at least $20 \%$ better. Figure 2 shows how the addition of a retriggerable one-shot can achieve this reduction. This circuit puts some timing constraints on the serial clock signal, but these are easily met. The output pulse of the one-shot should remain high for a period that is slightly longer than one serial clock cycle to prevent the NM93C46 from being reset. (The falling edge of CS must occur before the rising edge of the serial clock after the last bit of a write command is transmitted.)


TL/D/8611-2
One-shot is retriggerable MM74HC123

## FIGURE 2

A circuit for a 3-contact key is shown in Figure 3. A filter capacitor, diode and one-shot have been added. Both oneshots are triggered whenever a pulse to ground occurs on the power supply contact. The capacitor and diode provide power to the NM93C46 and the one-shots during this brief power interruption. An operational amplifier can be used as the power source and can easily generate the required waveform. Both the serial clock and chip select signals are recovered from this waveform.


TL/D/8611-3
One-Shot A- $1 / 2$ MM74HC123 One-Shot B-1/2 MM74HC123
FIGURE 3
By adding more circuitry to the key, it is possible to achieve a 2-contact interface. A circuit for this interface is shown in Figure 4.
Commands and data are transmitted to the key by superimposing a pulse-width-modulated code on the power supply contact. The voltage swings between 8 V and 16 V at point 1 . A regulated 5 V is supplied to the circuits in the key by a local regulator. Resistors R1 and R2 form a divider to create a 3V reference for the operational amplifier. R3 and R4 are used as a divider that converts the 8 V to 16 V signal at point 1 to a signal at point 2 that swings between 2 V and 4 V . The output of the operational amplifier now follows the signal at point 1 but swings from 0 V to 5 V . This signal is used to trigger the one-shots as in the 3-contact circuit, and appears
at the DI pin as a pulse-width-modulated signal. Command and data signals may now be entered. Data is read from the key by monitoring the power supply current. When the DO pin is in TRI-STATE ${ }^{@}$ or outputs a one, transistor T2 is turned off. When DO outputs a zero, T2 is turned on and current flows through R5. The value of R5 may be chosen to create whatever current change is needed to detect the state of DO. The current should be tested when the voltage at point 1 is 16 V . The resistor in this example will produce a 10 mA change.
Figure 5 shows a typical read sequence for the circuit shown in Figure 4.

## CONCLUSION

This application note describes a number of circuits that are useful in security and data collection systems. These circuits should be considered only the beginning. It no longer makes sense to install DIP switches to select access codes in garage door openers, cordless and mobile phones, or any other microcontroller-based system. "Smart keys" can be used to gain access to databases and can be invalidated over normal communication lines if they are abused. It boggles the mind to consider what can be done with so many unique codes.
Note: The circuits in this application note feature the NM93C46. The NM93C06 is a pin-compatible part that stores 256 bits. The NM93C46 was used because it has a self-timing write cycle and the NM93C06 does not. Additional circuitry is not required to use the NM93C06, but an additional chip select signal must occur at the CS pin to terminate a write cycle.

$$
\begin{array}{ll}
\mathrm{R} 1=20 \mathrm{~K} & \text { One-Shot } B=1 / 2 \mathrm{MM} 74 \mathrm{HC} 123 \\
\mathrm{R} 2=30 \mathrm{~K} & \mathrm{~V} \cdot \mathrm{R}=\mathrm{LM} 2930 \mathrm{Z} \cdot 5.0 \\
\mathrm{R} 3=15 \mathrm{~K} & \mathrm{OA}=\mathrm{LM} 358 \\
\mathrm{R} 4=5 \mathrm{~K} & \mathrm{R} 5=1600 \Omega
\end{array}
$$



TL/D/8611-4

One-Shot $A=1 / 2$ MM74HC123

FIGURE 4


FIGURE 5

## Using the NM93CSxx Family

## INTRODUCTION

This application note is intended for system designers interested in using the NM93CSxx family of CMOS serial EEPROM devices. These devices are well-suited for applications that call for non-volatile, writeable memory. The NM93CSxx devices offer the additional benefit of selective write-protection by use of an on-chip protect register. This allows the device to perform both read-only memory (ROM) and EEPROM functions on the same chip.
EEPROMs are useful in a wide variety of applications because of their non-volatile, writeable characteristics. The devices can be used for applications that store configuration values, such as feature telephones, station presets on radios, and PC boards with configuration DIP switches and jumpers. Adaptive, closed-loop systems, such as environment controllers and motor controllers, can use EEPROMs to store loop control variables. Data logging is another of the many application areas of EEPROMS.
The NM93CSxx family can support a new set of applications because of their additional capability to perform selective ROM functions. ROM is a requirement when the integrity of data stored in a device must be guaranteed. Applications can make use of this feature while at the same time allocating other locations in the device to operate as EEPROM.
The NM93CSxx family devices exhibit extremely low power consumption due to the low drive requirements of their serial interface and the use of CMOS technology. The serial interface also provides the designer with a flexible interface mechanism allowing the devices to be easily designed into microcontroller and microprocessor systems. In microcontroller systems, or those with a serial bus, the devices can be connected with little or no support logic. The serial interface allows the device to fit in a smaller package, resulting in minimal board space requirements.

National Semiconductor
Application Note 507

TABLE I. NM93CSxx Family

| Device | Memory Size |
| :---: | :---: |
| NM93CS06 | $16 \times 16$ |
| NM93CS26 | $32 \times 16$ |
| NM93CS46 | $64 \times 16$ |
| NM93CS56 | $128 \times 16$ |
| NM93CS66 | $256 \times 16$ |

## NM93CSXx FAMILY DESCRIPTION

The NM93CSxx family is a set of 5 CMOS serial EEPROM devices with on-chip write-protection logic. The members of the family are differentiated by their memory array size, which ranges from 256 to 4096 bits organized 16 bits wide (see Table I). Because the devices use a serial interface, the pinout for each family member is identical. The devices conform to the MICROWIRE interface and are backwards compatible with previous National serial EEPROM devices (see Figure 1).
A set of 10 instructions are provided to control device operation. The general format of the instructions is a start bit (logic 1) followed by opcode, register address and data fields. The register address for the NM93CS06/26/46 is 6 bits, while the register address for the NM93CS56/66 is 8 bits. Data is shifted into the device on the D1 pin, and out on the DO pin following a low to high transition of SK. CS must be high to access the device (see Table 2).
A read operation is performed by issuing the start bit, the appropriate opcode (10), and the desired register address. The device responds by shifting out a dummy bit (logic 0 ) followed by the data in the selected register. The device will continue to shift data from subsequent registers as long as SK is active (non-volatile shift register mode). Write operations are performed by issuing the start bit, opcode (01), register address, and 16 bits of data. CS must be brought low to initiate the self-timed programming cycle, which includes an automatic erase cycle. CS can then be brought high to monitor DO (low to high transition) for completion of the cycle.

DIP


SO


Pin Names

| CS | Chip Select |
| :--- | :--- |
| SK | Serial Clock |
| DI | Serial In |
| DO | Serial Out |
| GND | Ground |
| PE | Program Enable |
| PRE | Protect Register |
|  | Enable |
| $V_{C C}$ | Power Supply |

FIGURE 1. NMC93CSxx Device Pinout

TABLE II. NM93CSxx Instruction Set

| Instruction | SB | Op Code | Address | Data | PRE | PR | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| READ | 1 | 10 | $\mathrm{A}_{\mathrm{x}}-\mathrm{A}_{0}$ |  | 0 | X | Reads data stored in memory, starting at specified address. |
| WEN | 1 | 00 | 11XXXX |  | 0 | 1 | Write enable must precede all programming modes. |
| WRITE | 1 | 01 | $A_{X}-A_{0}$ | D15-D0 | 0 | 1 | Write register if address is unprotected. |
| WRALL | 1 | 00 | 01XXXX | D15-D0 | 0 | 1 | Write all register. Valid only when "protect register" is cleared. |
| WDS | 1 | 00 | 00XXXX |  | 0 | $x$ | Disables all programming instructions. |
| PRREAD | 1 | 10 | XXXXXX |  | 1 | X | Reads address stored in "protect register". |
| PREN | 1 | 00 | 11XXXX |  | 1 | 1 | Must immediately precede PRCLEAR, PRWRITE, and PRDS instructions. |
| PRCLEAR | 1 | 11 | 111111 |  | 1 | 1 | Clears the "protect register" so that no registers are protected from WRITE. |
| PRWRITE | 1 | 01 | $A_{X}-A_{0}$ |  | 1 | 1 | Programs address into "protect register". Thereafter, memory address < the address in "protect register" are protected from WRITE. |
| PRDS | 1 | 00 | 000000 |  | 1 | 1 | One time only instruction after which the address in the "protect register" cannot be altered. |

The protect register is used to write protect a segment of registers. The value contained in the protect register designates the first address of the protected segment. All subsequent register locations are write-protected.

## USING THE PROTECT REGISTER

The incorporation of the protect register in NM93CSxx devices sets the family apart from other CMOS serial EEPROMs. Including a protect register allows the devices to function as EEPROM and ROM simultaneously. The distribution of EEPROM and ROM in a device is determined by the value in the protect register. The distribution of EEPROM and ROM can be changed in the system by changing the protect register value.
ROM applications typically require that data storage be nonvolatile so that no changes will occur when power is turned off and read-only so that changes won't occur under any other circumstances. EEPROMs are non-volatile, but aren't read-only. An EEPROM will function as a ROM if write operations are never attempted or if any attempted write fails.
The protect register is valuable when an application requires a mix of EEPROM and ROM. A NM93CSxx device can be made less susceptible to write problems without using the protect register. The entire device may be made read-only by grounding PE. System software can be implemented to avoid writing to read-only locations and limit when write instructions may be performed by making use of the write enable (WEN) and disable (WDS) instructions. The device would only be susceptible to a write problem if a system failure caused an illegal write or some external source with access to the device abused its write privileges. Use of the protect register under system control would be somewhat safer, but the device would still be subject to the abovementioned problems. Write access to the protect register must be inhibited for the protected locations to be truly read-only.


FIGURE 2a. Protect Register Disabled


FIGURE 2b. Protect Register Enabled with Pulldown


FIGURE 2c. Protect Register Enabled

ROM devices are most often programmed with data before insertion into a PC board. This approach is applicable to NM93CSxx devices. In a microcontroller system, program code or data could be off-loaded from the internal ROM of the microcontroller into a ROM section in an NM93CSxx device. An EEPROM section could be allocated for any writeable data, such as configuration data values. ROM is desirable in this application because any spurious writes that could corrupt the program will be prevented, a smaller internal microcontroller ROM is possible and if ROM code or data needed alteration, it would be much easier and cheaper to reprogram a NM93CSxx device than the internal ROM of the microcontroller. In manufacturing, the ROM data and the protect register value would be programmed into the device, and the protect register enabled before PC board insertion. The PRE pin would be tied low on the board to prevent write access to the protect register (see Figure 2a). Another application for these devices is in systems that support automated production. Production information, such as date codes and status, would be programmed into the NM93CSxx on a board as it progressed through each step of the production process. Board identification (serial number) and fixed configuration information could also be programmed into the device as a last step. The PRE pin would be pulled low with a resistor to allow production test equipment to drive it high to write data into the device and set the protect register, but prevent any writes to the protected locations during normal operations. The EEPROM section could be used to allow the application to support automated system configuration. Once all boards are placed in the system, any system configuration dependent variables could be programmed (see Figure 2b).
In data logging applications, the protect register is programmed as the data is gathered to reduce the likelihood of modification. When the protect register is accessed regularly by the software, PRE must be accorded an interface line, usually a port pin that is controlled by software. The protect register disable (PRDS) instruction must be used upon completion of logging to fully protect the data. PRDS will prevent any further writing to the protect register, even if the device is removed from the board. Extreme care should be exercised when considering use of PRDS. Data should be written into the device from high locations to low to protect the
data as it is read in. In addition, the protect register then serves the dual purpose of being a pointer to the last location written, simplifying software and saving a variable location (see Figure 2c).

## INTERFACING TO THE NM93CSXx FAMILY COP800 Interface

The COP800 family is a set of 8 -bit CMOS microcontrollers. The family members differ by program and data memory, on-chip peripherals, and package size. Some members have on-chip EEPROM for program or data memory. The devices with EEPROM for program memory are only intended for development purposes. All members of the family have an on-chip MICROWIRETM interface.


FIGURE 3. MICROWIRE Interface
The COP800 family provides three options when interfacing to a NM93CSxx device. The interface could be designed by using the COP800 device parallel port pins under software control, on-chip UART if available, or the MICROWIRE interface port. The most attractive option for the interface is the MICROWIRE because NM93CSxx devices connect directly to it.
The MICROWIRE port provides a serial clock (SK), serial input (SI), and serial output (SO). These lines are directly connected to SK, DO and DI of the EEPROM. COP800 parallel port pins can be used for providing CS, PE and PRE. If PE or PRE are static in the application, they can be tied low or high. No other hardware is required for the interface (see Figure 3). In a system with multiple devices on the MICROWIRE, additional logic may be required to perform chip selection. If available, parallel port pins could be used for additional chip selects. Otherwise, a PAL device could be designed so that chip selects are set serially preceding any serial device operations.

```
;WREEPROM-WRITE DATA TO EEPROM
;
;THIS ROUTINE WILL WRITE A SPECIFIED NUMBER OF BYTES
;TO THE EEPROM USING THE MICROWIRE INTERFACE. THIS CODE
;ASSUMES THE SHIFT CLOCK RATE IS 1/2 THE XTAL FREQUENCY.
;THE ARGUMENT STRING CONSISTS OF A BYTE COUNT, OPCODE,
;REGISTER ADDRESS, FOLLOWED BY A DATA STREAM.
;
WREEPROM: LD A,[B+] ;COPY BYTE COUNT
    X A,X'FO ;
    SBIT 1,x'D4 ;CHIP SELECT
    SBIT 7,x'E9 ;SEND START BIT
    SBIT 2,x'EF ;
    RBIT 2,x'EF ;
SLOOP: LD A,[B+] ;SEND DATA BYTES
    X A,x'E9 ;
    SBIT 2,x'EF ;
BIT_TST: IFBIT 2,x'EF ;STILL BUSY?
    JMP BIT_TST ;
    DRSZ x'FO ;DONE SENDING?
    JMP SLOOP ;
    RBIT 1,x'D4 ;DROP CS
    RET
```

FIGURE 4. COP800 MICROWIRE Write Routine

```
;RDEEPROM-READ DATA FROM EEPROM
;
;THIS ROUTINE WILL READ A SPECIFIED NUMBER OF BYTES FROM
;THE EEPROM USING THE MICROWIRE. THE CODE ASSUMES THAT THE
;SHIFT CLOCK IS PROGRAMMED AT 1/2 THE INSTRUCTION CLOCK RATE.
;THE ARGUMENTS PASSED TO THIS ROUTINE ARE A BYTE COUNT, OPCODE,
;AND REGISTER ADDRESS, POINTED TO BY B.
;THE BYTE COUNT AND DATA READ ARE POINTED AT BY B ON RETURN.
;
RDEEPROM: LD A,X'FE ;SAVE POINTER
    X A,x'F1 ;
    LD A,[B+] ;COPY BYTE COUNT
        X A,X'FO ;
        SBIT 1,x'D4 ;CHIP SELECT
        SBIT 7,x'E9 ;SEND START BIT
        SBIT 2,x'EF ;
        RBIT 2,x'EF ;
        LD A,[B] ;SEND INSTRUCTION
        X A,x'E9 ;
        SBIT 2,x'EF ;
TSTl: IFBIT 2,x'EF ;BUSY?
        JMP TSTl ;
        SBIT 2,x'EF ;GET DUMMY BIT?
        RBIT 2,x'EF ;
RLOOP: CLRA ;GET DATA BYTES
        SBIT 2,x'EF ;
TST2: IFBIT 2,x'EF ;BUSY?
        JMP TST2 ;
        X A,x'E9 ;
        X A,[B+] ;
        DRSZ x'FO ;DONE GETTING?
        JMP RLOOP ;
        LD A,x'Fl ;RESTORE POINTER
        X A,X'FE ;
        RBIT 1,x'D4 ;DROP CHIP SELECT
        RET
```

FIGURE 5. COP800 MICROWIRE Read Routine

Inside a COP800 device the MICROWIRE hardware consists of an 8-bit shift register (SIO), a control bit (BUSY) in the program status word (PSW), and a control register (CNTRL), BUSY is set by the control program to initiate a shift operation and is automatically reset when eight bits have been shifted. BUSY can be reset by the program for shift operations of less than eight bits. CNTRL is used to set the MICROWIRE mode and rate of SK. SK can be set to a divide by 2,4 , or 8 of the instruction clock rate. The MSEL bit of CNTRL sets the MICROWIRE to Master mode or Slave mode. In Master mode, a device will generate SK and in Slave mode it will receive SK. Master mode is used to interface to an NM93CSxx device.

In addition to initializing the interface, software rountines are required to control data transfers to and from the EEPROM through the MICROWIRE port. The same routines used to read and write to the EEPROM can be used to execute the NM93CSxx instructions, including accessing the protect register. The only extra step required to access the protect register is that PRE must be set high.
A routine must access SIO to perform an NM93CSxx instruction. Since the MICROWIRE shift register is only eight bits wide, multiple accesses are required to complete an instruction. In addition, instructions aren't byte-aligned; routines must align the operation. Instructions can be bytealigned by sending a single start bit followed by a byte of opcode and address. A start bit can be sent by using the set
bit (SBIT) instruction to set BUSY, followed by the rest bit (RBIT) instruction when SK is being divided by two, or by sending a byte with seven leading zeros as dummy bits and a single one for the start bit. The NMC83CS56/66 devices require two more bits to be sent for alignment because of their larger address space. In this case it is easier to send the byte with leading zeros.
The write routine, WREEPROM, sets CS to select the device, then writes a single start bit, followed by a byte of opcode and address, and two bytes of data. The bytes sent are stored as a string preceeded by a byte-count. The byte count must, obviously, be three for a write. This routine can be used to perform the other write-only NM93CSxx instructions by setting the byte-count and data string appropriately. CS is brought low to initiate the automatic erase/write cycle. The routine doesn't bring CS back high to check for completion of the cycle. This allows the routine to be used to perform the other NM93CSxx instructions and the control program to perform other tasks during the cycle. If the program is unsure of cycle completion, DO should be checked before initiating another instruction (see Figure 4).
The read routine, RDEEPROM, sets CS and sends the start bit, opcode and address in the same manner as the write routine. The routine then reads a dummy bit (logic 0 ) from
the EEPROM and the number of bytes of data specified by the byte-count. The dummy bit is read in exactly the same way as a start bit is sent (see Figure 5).
HPC Interface
The HPC family is a set of high performance 16 -bit microcontrollers. Like the COPS microcontrollers, the HPC devices are MICROWIRE compatible, providing an excellent means of interfacing to NM93CSxx devices. Though, a software controlled interface using parallel port pins could be used, as well as an on-chip UART.


FIGURE 7. 8051 Interface

```
#define SET_CS *_iporta|=0x40 /* set chip select*/
#define DROP_CS *_iporta & = OxFB/* lower chip select*/
#define SIO OxD6 /* SIO register location*/
#define PORTA 0xC8 /* PORT A location*/
#define IRPD 0xD2 /* IRPD register location*/
#define NOT_DONE I(*_Irpd & Ox04) /* DONE Plag set if true*/
#define BFUN 0xF4 /* BFUN register*/
#define SK
    *_bfun & = 0xBF \
    *_bfun | = 0x40;
#define WR_EE (bytes, data) I
I int i; \
    SK; \
    for(I=0; I < bytes; I+ +)\
    I
        *_sio = *data++; \
        wh1le(NOT_DONE) ; \
        *_irpd & = OxFB; \
        }
}
/* Global Definitions*/
char *_sio = SIO;
char *_iporta = PORTA;
char *_irpd = IRPD;
char *_bufn = BFUN;
wr_eeprom(bytes,data)
int bytes; /* byte count*/
char *data; /* data buffer*/
{
    SET_CS;
    WR_EE;
    DROP_CS;
}
rd_eeprom(bytes, data)
int bytes; /* byte count*/
char *data; /* buffer pointer*/
{
    SET_CS;
    WR_EE (1, data);
    SK; /* get dummy bit*/
    for (i = 0; i < bytes; I ++)(
        *data ++ = *_sio;
        while(NOT_DONE) ;
        *_irpd & = 0xFB;
        }
        DROP_CS;
}
```

FIGURE 6. HPC C Language Interface Routine

```
;
;SNDBYT - SHIFTS 8 BITS OF DATA TO EEPROM
;
;THIS ROUTINE SHIFTS A BYTE POINTED AT BY RO
;ASSUMES CHIP SELECT ALREADY ACTIVE (HIGH)
;
SNDBYT MOV B,#8 ;LOAD SHIFT COUNT
    MOV A,@RO ;GET BYTE
S_LOOP: RLC A ;SHIFT
    MOV P2.O,C ;SEND BIT
    CLR P2.2 ;SK
    SETB P2.2 ;
    DJNZ B,S_LOOP;DONE?
    RET
;
;WREEPROM - WRITE DATA TO EEPROM
;
;THIS ROUTINE WRITES A SPECIFIED NUMBER OF BYTES TO THE
;EEPROM USING SNDBYT UTILITY ROUTINE. THE DATA IS POINTED AT
;BY THE RO REGISTER AND CONSISTS OF BYTE COUNT, OPCODE/REG ADDR
;AND DATA BYTES. DO IS SET HIGH TO AVOID CONTENTION.
;
WREEPROM: MOV R2,@RO ;COPY BYTE COUNT
    INC RO ;
    SETB P2.1 ;CHIP SELECT
    CLR P2.2 ;START BIT
    SETB P2.2 ;
WR_LOOP: LCALL SNDBYT ;WRITE DATA BYTES
    INC RO ;
    DJNZ R2,WR_IOOP;
    SETB P2.0 ;DEFAULT DO HIGH
    CLR P.21 ;DESELECT/PROGRAM
    RET
```

FIGURE 8. 8051 Parallel Port Pin Interface-Write Routines

The MICROWIRE interface provides signals for SK, SI and SO. CS, PE and PRE signals can be provided by using parallel port pins. Port A on the HPC is allocated for general use and is ideal for this function. When used in Master mode, the clock rate for the MICROWIRE is set by programming the appropriate value into the DIVBY register. The 8 -bit SIO register is used as a buffer for serial operations.

Unlike the COP800 microcontrollers, the HPC does not use a BUSY bit to control shifting. The DONE flag in the IRPD register is polled to determine completion of a shift operation. A single bit can be transferred by changing the mode of the SK pin back to a general purpose port pin (B.6). This is accomplished by clearing bit six of the port B function register (BFUN). If port $B$ bit six is high, the pin will go high immediately clocking the EEPROM.

```
;RCVBYT - READ A BYTE OF SERIAL DATA
;
;THIS ROUTINE WILL SERIALLY READ 8 BITS OF DATA FROM THE PORT PIN
;AND STORE THE DATA IN THE LOCATION POINTED AT BY RO
;
RCVBYT: MOV B,#8 ;LOAD SHIFT COUNT
R_LOOP: CLR P2.2 ;SK
    SETB P2.2 ;
    MOV C,P2.0 ;GET BIT
    RLC A ;SHIFT
    DJNZ B,R_LOOP ;DONE?
    MOV @RO,A ;STORE DATA
    RET
;RDEEPROM - READ DATA FROM EEPROM
;
;THIS ROUTINE WILL READ A SPECIFIED NUMBER OF BYTES FROM
;THE EEPROM USING THE RCVBYT ROUTINE. INPUT ARGUMENT STRING IS
;A BYTE COUNT, AND OPCODE/REGISTER ADDRESS. ON RETURN, RO POINTS
;TO A STRING CONTAINING THE BYTE COUNT FOLLOWED BY DATA BYTES
;
RDEEPROM: MOV R2,@RO ;COPY BYTE COUNT
    PUSH RO ;SAVE POINTER
    INC RO ;
    SETB P2.1 ;CHIP SELECT
    CLR P2.2 ;START BIT
    SETB P2.2 ;
    LCALL SNDBYT ;SEND INSTRUCTION
    SETB P2.0 ;DEFAULT DO HIGH
    CLR P2.2 ;DUMMY BIT
    SETB P2.2 ;
RD_LOOP LCALL RCVBYT ;GET DATA BYTES
    INC RO ;
    DJNZ R2,RD_LOOP;DONE?
    POP RO ;RESTORE POINTER
    CLR P2.1 ;DESELECT
    RET
```

FIGURE 9. 8051 Parallel Port Pin Interface Read Routines

The HPC supports program development in the C language. The software routines to support an HPC interface are similar to those for the COP800, except that they are written in C (see Figure 6). The main difference is how the start bit and dummy read bit are handled. Since the HPC supports the C language, core routines are written utilizing macros, eliminating the overhead of an extra level of subroutine calls.

## 8051 Interface

The 8051 offers two interface alternatives for the NM93CSxx family; the first uses parallel port pins under software control and the second is based on using the onchip serial port. Both interfaces require a minimum number of device pins and no support logic. The main differences are that the serial port is faster and requires less software. The first choice for discussion is the use of the port pins. The 8051 has four 8 -bit bidirectional I/O ports. The ports
are accessed through a special function register. The port registers are bit addressable which facilitates their use in this application. The minimum interface requires the use of only three port pins. A pin for CS, SK, and one connected to both DI and DO (see Figure 7). A two wire interface is possible by tying CS active, but this leaves the device in the active (high power) state and prevents the device programming cycle from being executed.
It is not necessary to have separate lines for DI and DO because DO is placed in a high-Z condition during write operations. During a read operation the DI pin is driven to send the instruction to the EEPROM and DO outputs the dummy bit ( 0 ) and data. To prevent contention DI has to stop driving a high before DO can output the dummy bit. The 8051 doesn't drive a high, it uses internal pull-ups to obtain a high, so there is no contention problem. This may be a con-
cern in other designs. The DO pin is driven when CS is brought high following a write operation to time completion of programming Contention will occur on the operation following a write if programming completion isn't checked. A dummy check can be used.
When using the port pins, one must consider that some of the port pins have alternate functions. For example, Port 3 pins 0 and 1 are also allocated for the serial port. Similarly, if the program being executed on the 8051 resides in external memory, then Ports 0 and 2 will serve as the system bus during external memory access.
The software support routines are primarily concerned with controlling the flow of data to/from the EEPROM. Because
the 8051 is an 8 -bit machine, two utility routines, SNDBYT and RCVBYT, are used to shift a byte of data to and from the NM93CSxx.
The write routine, WREEPROM, raises CS to access the device, shifts out a start bit, then calls SNDBYT to shift out the opcode/register address byte, and other data bytes, as specified by the byte-count (see Figure 8).
The read routine, RDEEPROM, starts out by raising CS, sending a start bit, and using SNDBYT for the opcode/register address byte. The dummy bit is then shifted from the device and RCVBYT is called to shift in the number of bytes of data specified by the byte-count (see Figure 9).

```
;RDEEPROM - READS DATA FROM NMC93CSXX DEVICE
;
;THE ROUTINE READS A SPECIFIED NUMBER OF BYTES FROM
;THE EEPROM USING THE SERIAL PORT. RO POINTS TO AN ARGUMENT STRING
;CONTAINING THE BYTE COUNT AND THE OPCODE/REGISTER BYTE
;A STRING IS RETURNED CONTAINING THE BYTE COUNT FOLLOWED BY DATA.
RDEEPROM:
```

```
            PUSH RO ;SAVE POINTER
```

            PUSH RO ;SAVE POINTER
            MOV R2,@RO ;COPY BYTE COUNT
            MOV R2,@RO ;COPY BYTE COUNT
                INC RO ;
                INC RO ;
                SETB P2.1 ;CHIP SELECT
                SETB P2.1 ;CHIP SELECT
                CLR P3.1 ;SEND START BIT
                CLR P3.1 ;SEND START BIT
                SETB P3.1 ;
                SETB P3.1 ;
                    MOV SBUF ;SEND INSTRUCTION
                    MOV SBUF ;SEND INSTRUCTION
                    JBC TI$ ;DONE?
                    JBC TI$ ;DONE?
                    CLR TI ;
                    CLR TI ;
                    CLR P3.1 ;GET DUMMY BIT
                    CLR P3.1 ;GET DUMMY BIT
                    SETB P3.1 ;
                    SETB P3.1 ;
                    SETB REN ;GET DATA BYTES
                    SETB REN ;GET DATA BYTES
    RLOOP; JBC RI,\$ ;DONE?
RLOOP; JBC RI,\$ ;DONE?
CLR RI ;
CLR RI ;
MOV @RO,SBUF ;
MOV @RO,SBUF ;
INC RO ;
INC RO ;
DJNZ R2,RLOOP ;
DJNZ R2,RLOOP ;
CLR REN ;
CLR REN ;
CLR P2.1 ;DESELECT
CLR P2.1 ;DESELECT
POP RO ;RESTORE POINTER
POP RO ;RESTORE POINTER
RET
RET
;WREEPROM - WRITE DATA TO EEPROM
;WREEPROM - WRITE DATA TO EEPROM
;
;
;THE ROUTINE WRITES A SPECIFIED NUMBER OF BYTES TO EEPROM
;THE ROUTINE WRITES A SPECIFIED NUMBER OF BYTES TO EEPROM
;POINTED AT BY RO. ARGUMENTS INCLUDE BYTE COUNT AND OPCODE/ADDRESS
;POINTED AT BY RO. ARGUMENTS INCLUDE BYTE COUNT AND OPCODE/ADDRESS
;
;
WREEPROM: MOV R2,@RO ;COPY BYTE COUNT
WREEPROM: MOV R2,@RO ;COPY BYTE COUNT
INC RO ;
INC RO ;
SETB P2.1 ;CHIP SELECT
SETB P2.1 ;CHIP SELECT
SETB P3.0 ;START BIT
SETB P3.0 ;START BIT
CLR P3.1 ;
CLR P3.1 ;
SETB P3.1 ;
SETB P3.1 ;
SLOOP: MOV SBUF,@RO ;SEND DATA BYTES
SLOOP: MOV SBUF,@RO ;SEND DATA BYTES
INC RO ;
INC RO ;
JBC TI,\$ ;DONE?
JBC TI,\$ ;DONE?
DJNZ R2,SLOOP ;
DJNZ R2,SLOOP ;
CLR P2.1 ;DESELECT
CLR P2.1 ;DESELECT
RET

```
    RET
```

FIGURE 10. 8051 Serial Port Read and Write Routines

## 8051 INTERFACE-SERIAL PORT

The 8051 serial port operates in one of four modes: 8 -bit shift register, 8 -bit UART and two different 9 bit UART modes. The 8 -bit shift register mode (Mode 0 ) is preferred because it operates with no protocol, as opposed to the UART modes which send and receive packeted data. When in Mode 0 , the 8051 RxD pin is used as a serial in/out pin and the shift clock is provided on the TxD pin. The TxD pin would be connected to SK and RxD would be connected to DI and DO on the NM93CSxx device. CS, PE and PRE would be connected the same way as in the port pin interface.
When using the serial port in Mode 0 , the serial port control register (SCON) must be programmed by setting the SMO and SM1 bits (bits 7 and 6) to 0 . The serial clock runs at a fixed rate of $1 / 12$ of the oscillator frequency. The maximum frequency for the serial clock on NM93CSxx devices is 1 MHz . This means the 8051 can run with an oscillator frequency up to 12 MHz . After every eighth bit is received or transmitted the 8051 hardware will set either the receive interrupt (RI) or transmit interrupt (TI) bit in SCON. These bits may be polled, or used to generate interrupts.
The software routines for the serial port interface are virtually the same as those for the previous example. The only differences are that the 8051 serial port performs the same functions as the SNDBYT and RCVBYT routines. Instead of calling these routines, the REN bit is enabled to initiate reception and the data is read from the serial buffer (SBUF). For writing, the data is written into SBUF to perform the transfer. The routines poll the RI or Tl bits. Because data transactions are synchronous, interrupts are not applicable (see Figure 10).

## 8096 INTERFACE

The 8096 is a 16 -bit microcontroller. Like other microcontrollers, it interfaces easily to the NM93CSxx devices. The use of parallel port pins or the on-chip serial port provide two interface options.

When implementing the parallel port pin interface, the choice of the port pins used is more critical because more of these pins have alternate functions. If the 8096 must perform external memory accesses, the use of Ports 3 and 4 becomes a problem because these two 8-bit ports make up the address/data bus. Port 0 pins are used for the analog input channels. Port 2 pins have alternate functions such as the serial port. Port 1 pins do not have alternate functions and may be preferred for use.
The 8096 provides an on-chip serial port which may be used for interfacing the NM93CSxx devices. The serial port has 4 modes of operation. The mode of interest for this application is the shift register mode (Mode 0). The 8096 shift register mode serial clock rate is not a fixed rate. It is therefore the responsibility of the support software to program the baud rate appropriately.

## INTERFACING NM93CSxx WITH HIGH PERFORMANCE MICROPROCESSORS

High performance microprocessors like the NS32000, iAPX386 and the MC680x0 are usually implemented as central processor in computers and aren't directly involved with peripheral devices. Rather, these machines communicate over a backplane bus. These processors are designed for high speed, parallel data transfers. The NM93CSxx devices could be used with these processors if a serial bus is implemented as part of the backplane bus. Typically, a serial bus would be used for system configuration or diagnostic purposes. Both the VME bus and Multibus II supply serial communication signals that may be used to interface NM93CSxx devices to a high performance processor.

## SUMMARY

The NM93CSxx family can be used in a wide variety of applications. The devices provide a non-volatile, writeable memory that requires the least amount of board space, support logic and power. The protect register allows for a flexible mix of RAM and ROM. The previous examples illustrate that the NM93CSxx family easily interfaces to microcontrollers and systems with a serial bus.

```
;RCYBYT - READ UTILITY ROUTINE
;
;THIS ROUTINE WILL READ 8 BITS OF DATA FROM THE SERIAL PORT
;THE DATA IS STORED IN THE LOCATION POINTED AT BY THE DX REGISTER.
;
RCVBYT: LDB AH,#8 ;LOAD SHIFT COUNT
BOP_SK: ANDB P2,#FBH ;STROBE SK
    ORB P2,#O4H ;
    JBS P2,3,BIT_1 ;READ BIT
    ANDB AL,#FEH ;
    SJMP R_SHIFT ;
BIT_l: ORB AL,#O1H ;
R_SHIFT: SHLB AL,I ;
    DECB AH ;DONE?
    JNE BOP_SK ;
    LDB (DX),AL ;SAVE DATA
    RET
;RDEEPROM - READ DATA FROM EEPROM
;
;SI, SK, CS, SO = P2[3 . . . O]
;THIS ROUTINE WILL READ A SPECIFIED NUMBER OF BYTES FROM THE
;EEPROM AND STORE THE DATA. ARGUMENTS SUPPLIED TO THIS ROUTINE
;ARE A BYTE COUNT, OPCODE/REGISTER ADDRESS, AND ADDRESS FOR
;STORING THE DATA.
;
RDEEPROM: PUSH DX ;SAVE POINTER
    LDB BL,(DX)+ ;COPY BYTE COUNT
    ANDB P2,#FOH ;CHIP SELECT,START BIT
    ORB P2,#03 ;
    ORB P2,#04 ;
    LCALL SNDBYT ;SEND INSTRUCTION
    ANDB P2,#FBH ;GET DUMMY BIT
    ORB P2, #04H ;
RD_LOOP: LCALL RCVBYT ;GET DATA BYTES
    INC DX ;
    DECB BL ;DONE?
    JNE RD_LOOP ;
    ANDB P2,#FDH ;DESELECT
    POP DX ;RESTORE POINTER
    RET
```

FIGURE 11. 8096 Port Pin Interface Read Routines

```
;SNDBYT - WRITE 8 BITS OF DATA TO PORT PIN
;
;THIS ROUTINE WILL WRITE 8 BITS OF DATA TO THE PORT PIN. THE
;DATA BYTE IS POINTED AT BY THE DX REGISTER.
;
SNDBYT: LDB AH,#8 ;LOAD SHIFT COUNT
    LDB AL,(DX) ;GET DATA BYTE
SLOOP: JBS AL,7,BIT_l ;SEND BIT
    ANDB P2,#FEH ;
    SJMP TOG_SK ;
BIT1: ORB P2,#O1H ;
TOG_SK: ANDB P2,#FBH ;
    ORB P2,#04H ;
    SHLB AL ;
    DECB AH ;DONE?
    JNE SLOOP
    RET
;WREEPROM - WRITE DATA TO EEPROM
;
;SI, SK, CS, SO = P2[3..0]
;THIS ROUTINE WILL WRITE A SPECIFIED AMOUNT OF BYTES TO THE
;EEPROM. THE DATA TO BE WRITTEN IS POINTED AT BY THE DX REGISTER.
;THE ARGUMENTS INCLUDE THE BYTE COUNT, OPCODE/REGISTER ADDRESS,
;AND I OR MORE DATA BYTES.
;
WREEPROM: LDB BL,(DX)+ ;COPY BYTE COUNT
    ANDB P2,#FOH ;CHIP SELECT, START BIT
    ORB P2,#03H ;
    ORB P2,#04H ;
WR_LOOP: LCALL SNDBYT ;SEND DATA BYTES
    INC DX ;
    DECB BL ;DONE?
    JNE WR_LOOP ;
WR_EXIT: ANDB P2#FDH ;DESELECT/PROGRAM
    RET
```

FIGURE 12. 8096 Parallel Port Pin Interface Write Routines

## Using the NM93CS EEPROM Family Features

The NM93CS Family consists of four members as shown in Table I. Each of these members is available in a variety of temperature ranges, operating voltage ranges, and packaging options. These EEPROMs are a superset of the industry standard NM93C Family. The differentiating features of the NM93CS Family are the Sequential Register Read and the Memory Protect Register. The purpose of this application note is to more fully describe these features.

TABLE I. NM93CS Family Members

| Part <br> Number | Memory <br> Size | Internal <br> Organization |
| :---: | :---: | :---: |
| NM93CS06 | 256 -bit | $16 \times 16$ |
| NM93CS46 | 1024 -bit | $64 \times 16$ |
| NM93CS56 | 2048 -bit | $128 \times 16$ |
| NM93CS66 | 4096 -bit | $256 \times 16$ |

## SEQUENTIAL REGISTER READ

This read mode is entered the same way as the standard word read. First a start bit is transmitted, followed by the op code for a read cycle and then the first address to be read. It is always necessary to define the first address to be read since the address register's state is not guaranteed.
Up until this point, the data out (DO) will remain in TRISTATE®, but beginning with the same rising edge of the clock (SK) that clocks in address bit AO, the data out will drive a low level. This first bit is always a zero. Starting with the next clock, valid data will appear on the data out pin. The leading zero in the data field will only appear in the first word read in a sequential read sequence, all subsequent data words will be clocked out on the data out pin in an uninterrupted stream. Refer to Figure 1 for the timing sequence.
Any number of data words may be read with a single sequential read instruction. When the top of memory is reached it will automatically wrap around to address 0 and continue in the sequential read mode. Using this feature it

National Semiconductor Application Note 716 Paul Lubeck

would be possible to read the entire memory in an endless loop if desired.
The Memory Protect Register has no effect on Sequential Read. The Sequential Read will cross the write protection boundary and read to the top of the memory and cycle back to address 0 (possibly in the unprotected field) regardless of the Protect Register status.
To terminate a sequential read operation, the host must drop chip select (low). At any time CS is transitioned to a low, the current instruction will be terminated. It is not necessary to observe word boundaries when terminating a read or sequential read operation. It may be terminated at any time without affect on the EEPROM.

## MEMORY PROTECT REGISTER

The protect register is a unique method of write protecting the contents of a variable number of memory registers. The basic concept is shown in Figure 2 using the NM93CS66 4096-bit EEPROM. For the other family members everything remains the same except the memory size and the corresponding maximum address that can be set in the protect register. One other difference that needs to be noted is the address length for the NM93CS06 and NM93CS46 is 6 bits and for the NM93CS56 and NM93CS66, 8 bits. The difference in address length produces a corresponding difference in length of the protect register.


TL/D/11056-2
FIGURE 2. Memory Protect Register


TL/D/11056-1
FIGURE 1. Sequential Read Instruction Sequence

There are two basic elements to the protection scheme, the Protect Register and the Disable Cell. Both the Protect Register and the Disable Cell are implemented in EEPROM latches, therefore do not require the introduction of additional technologies onto the die. The purpose of the Protect Register is to contain the address of the first write protected location in memory. The location in memory defined by the address written into the protect register and all others above that location, to the maximum address in memory are write protected.
The Protect Register is writable from the serial bus in a manner similar to writing a memory register, the only difference being the input PRE (Protect Register Enable) must be high and the instruction immediately preceding the write to the protect register must be a Protect Register Enable (PREN) instruction. By requiring this specific sequence and set of conditions, both hardware and software oriented, the chances of inadvertently changing the contents of the protect register or an unauthorized user changing the data without specific knowledge of the operation of the EEPROM are very remote.
The Disable Cell is a single EEPROM latch that may be set via a Protect Register Disable (PRDS) instruction. Like the Protect Register Write (PRWRITE) instruction, it must be executed with the input PRE high and immediately preceded by a PREN instruction. Once the Disable Cell is written, it cannot be cleared because the PRDS instruction is a one time only instruction. Once the PRDS instruction has been executed, the Protect Register cannot be updated again in the life of the part and the defined portion of memory is permanently protected.
A typical instruction sequence for storing manufacturing and factory calibration information in a NM93CS family part is shown as follows:

Instruction
1.
2. WEN
3. WRITE A(max)
4. WRITE A(max-1)
5. WRITE A(max-2) :
:
6. WRITE A(max-y)
7. PREN
8. PRWRITE (A(max-y)) Write address (max-y) to Protect Register.
9. PREN Enable programming of the Disable Cell.
10. PRDS Disable all future programming of the protect register and protected memory.
11. WDS Disable all programming instructions.
It is not necessary to do steps 9 and 10. The PRDS instruction makes the protection permanent. Without executing the PRDS instruction the option remains to remove the write protection thus allowing changing the data in the formerly protected portion of memory. The following sequence will remove the write protection and clear the contents of the Protect Register:
Instruction Description

1. WEN Enable all programming instruction.
2. PREN Enable programming of the Protect Register.
3. PRCLEAR Enable writing of all memory locations and clear the Protect Register.
4. WDS Disable all programming instruction.

In both examples above the final step is a Write Disable (WDS) instruction. This instruction would normally be delayed until all programming is complete, but should be included as a minimal level of data protection for otherwise unprotected memory locations.

## Using National's NMC87C257 256K EPROM with On-Chip Latches

## INTRODUCTION

The standard EPROM available from most manufacturers limits the on-chip circuitry to just the minimum needed to operate the EPROM and the minimum of user interface handles. Users of standard EPROMs are forced to include latches in their design to interface with most microcontrollers and microprocessors.
Probably one of the most desirable user-interface features is the ability to directly interface the EPROM to a host device that has a multiplexed address and data port. This type of interface is present on many microcontrollers and microprocessors such as the HPC, 80C51 and many of the Intel and Motorola microcontrollers. National is now manufacturing an EPROM that can directly interface with a host de-vice-the NMC87C257.

## NATIONAL'S NMC87C257 SOLUTION

The NMC87C257 is pin-compatible with the standard 27 C 256 ( 1 Megabit EPROM, organized as $128 \mathrm{~K} \times 8$ bits), shown in Figure 1. In fact, the NMC87C257 can be directly substituted into the many existing 27C256 sockets when used in the unlatched mode. The internal latches are trans-

National Semiconductor Application Note 731
Sean Pitonak

parent and the Address Latch Enable (ALE) is on a shared pin with $\mathrm{V}_{\mathrm{Pp}}$. By tying $\mathrm{V}_{\mathrm{PP}}$ to $\mathrm{V}_{\mathrm{CC}}$, the NMC87C257 behaves exactly like the 27C256. The NMC87C257 is available in both quartz-windowed Ceramic DIP and Plastic LCC packages as is the 27 C 256 .
National's latched EPROM is useful because the same ALE used for the 74F373 latch can be tied to the ALE of the NMC87C257, eliminating the need for the 74F373 latch. As shown in Figure 2, it is as simple as removing the two octal latches and routing the appropriate bus and control line to the EPROM.

## SUMMARY

The NMC87C257 allows the user the combination of familiar functionality, pinout and programmability (due to its compatibility with existing 27C256 EPROMs) and the advantages of saved board space, cost of the octal latches and their insertion and system power consumption. The NMC87C257 gives the system designer the needed flexibility of interfacing directly with microcontrollers and microprocessors that have multiplexed address and data ports.


FIGURE 1. Socket Compatible 27C256 EPROM Pin Configuration is Shown in the Block Adjacent to the NMC87C257 Pins.


FIGURE 2. A common HPC Microcontroller application using two NM27C256 EPROMs and two 74F373 external latches (left) and the same application using only two NMC87C257 EPROMs with on-chip latches (right).

## Understanding National's NM95C12 EEPROM with Programmable Switches



## INTRODUCTION

National's NM95C12 is a 1024-bit Serial EEPROM with 8 programmable switches. These outputs can provide logic and analog switch inputs and outputs on a parallel bus, allowing this device to perform functions such as polling via the serial bus, interrupts via the serial bus and converting parallel data onto the serial bus.

## FUNCTIONAL DESCRIPTION

Figure 1 is a block diagram of the NM95C12. It consists of a 61-word x 16 -bit EEPROM array, a 16 -bit Initial Switch Register (ISR), a 16 -bit Switch Configuration Register (SCR), a 16-bit Switch Readback Register (SRR), four identical blocks of switch logic, programming and power-up circuits and control logic.
Addresses 0-60 of the EEPROM are available to the user as general purpose non-volatile memory. Data may be read or programmed into this memory using the appropriate instructions.
Address 61 is also an EEPROM location, but it is used as the ISR to provide the initial switch configuration information automatically on power-up.

Address 62 is the location of the SCR, which controls the switch logic of the output terminals. This address contains a volatile memory and therefore does not have endurance or programming time limits associated with it, allowing the outputs to be reconfigured an unlimited number of times.
Address 63 contains the SRR. This is a read-only register that reads back the logic levels present on the switch terminals. Only 8 -bits of the SRR are used.
The NM95C12 also includes a Sequential Register Read function that allows the user to obtain an endless loop of data by entering the read mode and leaving the CS high.

## SWITCH CONFIGURATIONS

The 16-bit SCR format is shown in Figure 2. It consists of four 4 -bit fields. Each field controls its corresponding switch control logic. The individual bits in each field are labelled $W$, $\mathrm{X}, \mathrm{Y}$ and Z . Table I shows the relationship between these bit values and the resulting behavior of the terminals.
Each switch pair can be individually configured to 1 of 14 modes. Therefore both logic and analog switches can be implemented simultaneously.
The logic switch configurations are at standard TTL levels.


TL/D/11097-1
FIGURE 1. NM95C12 Block Diagram


TL/D/11097-2
FIGURE 2. Switch Configuration Register (SCR)

TABLE I. Switch Configurations

| MODE* | Z | $Y$ | $X$ | W | SWITCH CONFIGURATION | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | $\pm \sim$ - | $A=0, B=0$ |
| 1 | 0 | 0 | 0 | 1 |  | $A=0, B=1$ |
| 2 | 0 | 0 | 1 | 0 |  | $\mathrm{A}=1, \mathrm{~B}=0$ |
| 3 | 0 | 0 | 1 | 1 |  | $A=1, B=1$ |
| 4 | 0 | 1 | 0 | 0 |  | $\mathrm{A}=0, \mathrm{~B}=$ Tristate |
| 5 | 0 | 1 | 0 | 1 |  | $\mathrm{A}=\mathrm{B}$ |
| 6 | 0 | 1 | 1 | 0 | $\longrightarrow-\mathrm{OB}$ | $\mathrm{A}=\overline{\mathrm{B}}$ |
| 7 | 0 | 1 | 1 | 1 |  | $A=1, B=$ Tristate |
| 8 | 1 | 0 | 0 | 0 | $\stackrel{O B}{O}$ | $\mathrm{A}=$ Tristate, $\mathrm{B}=0$ |
| 9 | 1 | 0 | 0 | 1 |  | $B=A$ |
| 10 | 1 | 0 | 1 | 0 |  | $\mathrm{B}=\overline{\mathrm{A}}$ |
| 11 | 1 | 0 | 1 | 1 |  | $A=$ Tristate , $B=1$ |
| 12 | 1 | 1 | 0 | X |  | Analog Switch Open |
| 13 | 1 | 1 | 1 | X |  | Analog Switch Closed |

TL/D/11097-3
*Modes 0 thru 11 are logic level functions. Modes 12 and 13 are Analog switch functions.

For example, in Mode 1, Terminal A would be driving $V_{\mathrm{OL}}$ and Terminal $B$ would be driving $\mathrm{V}_{\mathrm{OH}}$. In Mode 5 , where an input and output structure exists, Terminal A would be driving $V_{I L}$ or $V_{I H}$. The switches also include a TRI-STATE ${ }^{( }$ mode to represent an open terminal.
Each switch pair can also function as input/output terminals in Modes 5, 6, 9, 10 and 13. Modes 4, 7, 8, 11 and 12 represent the same input/output functions, but with the switch in the "open" configuration.

## POWER-UP MODE

When the NM95C12 is powered-up:

1. The data previously stored in the ISR is automatically transferred to the SCR.
2. The SCR controls the switch logic, producing the switch configuration of the terminals A1 through A4 and B1 through B4.
The switch configuration is valid 1 ms after the device power supply reaches 4.5 V or greater.


FIGURE 3. Power-Up Mode

## UPDATE MODE

To update the information that is contained in the SCR and therefore on the output terminals:

1. The SCR is updated via the serial bus by writing to address 62.
2. The switch logic updates the outputs by selecting the 1 of 14 modes detailed in Table I. The configuration change becomes effective at the terminals after a brief propagation delay (tSWPD), referenced to the falling edge of CS.


FIGURE 4. Update Mode


FIGURE 5. SCR Write (Update Mode) Timing Diagram

## INPUT MODE

The SRR allows the current logic level present at the switch terminals to be read back on the MICROWIRETM bus:

1. The states of the output terminals are loaded into the SRR by reading address 63.
2. The control logic allows the 8 -bit parallel input to be converted to serial output on the DO pin.
The bit assignments and the conceptual function of the SRR are shown in Figure 7. Only bits 15 through 8 are used; Bits 7 through 0 are always read as logical 0.
The SRR Read Timing diagram is shown in Figure 8. Note that it is valid to terminate any read cycle early, allowing the
user to avoid reading Bits 7 through 0 if that is desired. It is also valid to include leading zeros after the CS has gone high and before sending the start bit. Combining leading zeros and terminating the read cycle early may help simplify device control and speed read cycles.
Mode 12, Analog switch open, is valid for SRR input mode. For switch mode 13 (Analog switch closed), the SRR will not report the actual levels present at the terminals due to the analog levels. As a default, bits 15 through 8 of the SRR will be all 0's to indicate a closed analog switch. This is done to avoid ambiguous logic levels which could exist when the device is used in the Analog switch mode.


FIGURE 6. Input Mode


FIGURE 7. BIt Assignments and Conceptual Function of the Switch Readback Register


## SEQUENTIAL REGISTER READ FUNCTION

In a read mode, normally the CS input is made LOW after the last data bit is shifted out. However, if the CS input is left HIGH and clocking continues, data from the next address location will be delivered on the DO pin. This sequential read can continue indefinitely whereby the address is automatically incremented after delivering 16 bits of data. In this mode the address count will continue through the ISR, SCR and SRR and then wrap around to Address 0.
During a sequential register read there will be a dummy bit preceding the first word read, after which, the bit stream will be continuous without any dummy bit separating the data words.

## WRITE CYCLE CONSIDERATIONS

After loading the WRITE instruction and the 16-bit data, the chip enters into a self-timed programming cycle when CS is forced LOW before the next rising edge of the SK clock (refer to Figure 9). The timer status is available on the DO pin if the CS input is forced HIGH within 1 ms of starting the programming cycle. LOW on the DO pin indicates that programming is still in progress (BUSY), while HIGH indicates that the device is READY for the next instruction.

If the CS input is made HIGH for status observation, it must be made LOW when READY is indicated before loading the next instruction.

## CONCLUSION

National's NM95C12 offers users the standard functionality of a 1024-bit EEPROM and includes 8 programmable terminals that can be used to implement both logic and Analog switch functions simultaneously. These switches can be used, for example, to replace mechanical DIP and SPST switches, as well as allow interrupt polling via the serial bus. When the device is powered-up, the switch configuration is automatically transferred to the output terminals. The terminals can be updated easily by executing a write cycle. In the input mode, the current logic level at the output terminals is read into the device and output onto the serial bus.
The NM95C12 combines unique and useable features with the simplicity of standard EEPROM functionality.


FIGURE 9. WRITE Timing Diagram

## NM95C12 Flexibility in Industrial Control Applications

## INTRODUCTION

This application note describes a general purpose industrial controller and details how a NM95C12 can be used to integrate a number of different functions typically found in such a design.
General purpose application examples of the use of the NM95C12 are presented rather than a specific design. Each design idea and software can be incorporated into the designer's required application.
The basic building blocks of an industrial controller (for example, heating, process control, etc.) are a microcontroller, an Analogue to Digital Converter (ADC), an EEPROM, a dis-

National Semiconductor
Application Note 755
Sean Long

play (LCD, LED, etc.), I/O interfaces, and power driver/control circuits. The NM95C12 forms the basis of this design performing the non-volatile parameter storage, a low cost ADC, an I/O expander, and providing a simple control interface.
Figure 1 shows the basic block diagram with the shaded parts representing the functions performed by the NM95C12.
This application note will describe the theory of operation behind the design and give detailed software examples to show how to interface a popular microcontroller to the NM95C12.


TL/D/11160-1
FIGURE 1. Typical Industrial Controller Block Diagram


## THE NM95C12 1024-BIT CMOS EEPROM WITH DIP SWITCHES

The NM95C12 features 1 K-bit EEPROM memory with 8 switch logic terminals. These switch logic terminals are individually programmable outputs which may be used as DIP switch positions or as SPST switch positions.
The NM5C12 uses the MICROWIRETM serial I/O interface which is fully compatible with COPSTM microcontrollers via 4 simple control lines:

```
SK - Serial Clock
```

CS - Chip Select
DI- Data In
DO- Data Out
The EPROM array (addresses 0 to 60) is addressed via five instructions:

READ - Read Data from register
WEN - Write enable
WRITE - Writes data to register
WRALL - Writes to all registers
WDS - Disables all programming instructions
This area of memory is used for the normal EEPROM applications such as the storage of user changeable, non-volatile parameters such as time on/off, temperature on/off limits, etc.

## CONTROLLING THE SWITCH LOGIC

Address locations 61 to 63 control the switch operation.

| Address | Name | Description |
| :---: | :---: | :--- |
| 61 | ISS | Provides the initial switch <br> configuration automatically on <br> power-up. Controlled via a WRITE <br> operation. |
| 62 | SCR | The SCR is not an E2 location and <br> hence is volatile. The SCR is loaded <br> automatically from address 61 on <br> power-up. The SCR controls the <br> switch terminals A1-A4 and <br> B1-B4. |
| 63 | SRR | The SRR allows the current logic <br> levels of the switch terminals to be <br> read back via the MICROWIRE bus. |

## THEORY OF OPERATION

The relationship for charge of a capacitor is as follows:

$$
\begin{aligned}
\text { Charge }(\mathrm{Q}) & =\text { Voltage }(\mathrm{V}) \times \text { Capacitance }(\mathrm{C}) \\
& =\text { Current }(1) \times \text { Time }(\mathrm{T})
\end{aligned}
$$

Therefore the voltage across the capacitor, $\mathrm{V}_{\mathrm{CAP}}$
$V_{\text {CAP }}=(I \times T) / C$
Assuming that the current $I$ is a constant source, and the capacitance value C does not vary gives:
$V_{\text {CAP }}$ is proportional to $T$.

## Mode of Operation

- initially switch S 1 is closed to short out $\mathrm{V}_{\mathrm{CAP}}$ to measure input voltage $\mathrm{V}_{\text {IN }}$
To Measure $\mathrm{V}_{\mathrm{IN}}$ :
- microcontroller opens S1 and starts internal timer at T1
- $V_{\text {CAP }}$ is proportional to time $T$
- when $V_{\text {CAP }}>V_{I N}$ then comparator output $V_{\text {COMP }}$ goes high
- microcontroller stops internal timer at T2
- $\mathrm{V}_{\text {IN }}$ is proportional to time $\mathrm{T}=\mathrm{T} 2-\mathrm{T} 1$
- microcontroller closes S1 ready for next measurement


## CURRENT SOURCE/VOLTAGE COMPARATOR FOR ADC

This is based on a LM932 which has an Operational Amplifier and a Voltage Comparator in the same 8-pin package. This device operates from a single +5 V supply.
Refer to the National Semiconductor General Purpose Linear Databook for further details of the LM392.

## INPUT SENSOR

For this example assume temperature needs to be controlled.
LM335: This is a precision, low-cost, easily calibrated two terminal temperature sensor that behaves like a zener diode with a voltage of $+10 \mathrm{mV} /$ degree Kelvin. The initial accuracy is $\pm 1^{\circ}$ and can be externally trimmed with a potentiometer connected to the ADJ pin.
Refer to the National Semiconductor Linear Databook 2 for further details of the LM335 Temperature Sensors.

## NM95C12 SWITCH LOGIC APPLICATIONS/ CONFIGURATIONS

$A_{1}, B_{1}$-Control the Charge/Discharge of Capacitor for ADC
Switch Configuration:
Analog Switch Open: Mode 12, ZYXW = 110 ?
(? = don't care)
Analog Switch Closed: Mode 13, ZYXW = 111?
To change the state of the switch terminals $\mathrm{A}_{1}, \mathrm{~B}_{1}$, follow the flowchart in Figure 3.


TL/D/11160-3
FIGURE 2. Single Slope Analogue to Digital Converter


FIGURE 3. Controiling Switch Terminals A1, B1

## $A_{2}, B_{2}$ and $A_{3}, B_{3}$ - Switch Debouncing

The switch logic configuration is shown in Figure 4. When either of the mechanical switches SW1 or SW2 are pressed, this causes the interrupt line (INT) to be pulled low signalling to the microcontroller that a switch has been pressed. As part of the interrupt service routine the microcontroller can generate a delay to allow time for mechanical switch debouncing, before reading the NM95C12 SRR to determine which mechanical switch was pressed.


TL/D/11160-5
$A_{2}, B_{2}, A_{3}, B_{3}$ Configured in mode 5, $Z Y X W=0101$
FIGURE 4. Switching Conditioning

The advantage of this design is that it saves input pins on the microcontroller and means that the software does not have to perform periodic polling of the inputs to determine the mechanical switch status since the circuit is interrupt driven.
Switch Configuration: both $A_{2}, B_{2}$ and $A_{3}, B_{3}$ will be configured in mode $5 ; Z Y X W=0101$.
To change the state of the switch terminals $A_{2}, B_{2}$ and $A_{3}, B_{3}$ follow the flowchart in Figure 5.


FIGURE 5. Controlling Switch Terminals $\mathrm{A}_{\mathbf{2}}, \mathrm{B}_{2}, \mathrm{~A}_{3}, \mathrm{~B}_{\mathbf{3}}$

## $\mathrm{A}_{4}, \mathbf{B}_{\mathbf{4}}$ Programmable I/O

These two terminals use mode 1 to 4 according to the logic level required on the output. In this example $A_{4}$ is used for the Display Chip Select signal and $\mathrm{B}_{4}$ is used for the Display On/Off control signal.
In order to update and display the contents of the Display then both terminals $A_{4}$ and $B_{4}$ need to be set to a logic " 1 " therefore $\mathrm{A}_{4}, \mathrm{~B}_{4}$ are configured in mode 3 with $\mathrm{ZYXW}=$ 0011.

To change the state of the switch terminals $A_{2}, B_{2}$ and $A_{3}, B_{3}$ follow the flowchart in Figure 6.

## SOFTWARE TO INTERFACING THE NM95C12 TO THE COP820 MICROCONTROLLER

This section includes a number of subroutines to interface to a NM95C12 as described in the design example above. There are subroutines to implement each of the basic instructions together with routines for configuring and controlling the switch logic. These subroutines can be used as the basis for a design and be tailored to meet the individual application requirements.

## CONCLUSION

The NM95C12 is an extremely versatile and inexpensive device which allows simple interfacing to all popular microcontrollers and microprocessors via a 4 -wire serial bus. The complete operation of the NM95C12 can be controlled by a few simple instructions.
The design outlined offers an inexpensive solution for industrial control applications with the key benefits of:

- simple interfacing between microcontroller, EEPROM, "ADC"
- low part count
- fully software controlled and changeable

This has highlighted the flexibility of the NM95C12 and how the switch terminals can be configured for a wide range of applications including: mechanical switch replacement, programmable Address Decoder, programmable I/O expander and a programmable interrupt controller. The NM95C12 offers greater reliability than mechanical switches with the benefits of software control and lower cost.
Plus you still get the 1 K -bit EEPROM memory as well!; together with the 8 switch terminals it forms a truly remarkable device.


FIGURE 6. Controlling Switch Terminals $A_{4}, B_{4}$
;
; THIS FILE PREDECLARES ITEMS FREQUENTLY USED BY THE
COP820 PROGRAMMER.
REGISTER NAMES, CONTROL BITS, ETC. ARE NAMED THE SAME WAY
; AS IN THE DATA-SHEETS.
; *************************************************
; * PORT~ , CONFIGURATION- AND CONTROL REGISTERS *
; *************************************************
PORTLD $=000$; PORT L DATA
PORTLC $=$ ODI ; PORT I CONFIGURATION
PORTLP $=0$ OD2 ; PORT L PIN
PORTGD $=0004$; PORT G DATA
PORTGC $=$ OD5 PORT G CONFIGURATION
PORTGP $=$ OD6 ; PORT G PIN
PORTD $=$ ODC ; PORT D
PORTI $=00 D 7$; PORT I
;
SIOR $=$ OE9 9 SID SHIFT REGISTER
TMRLO $=$ OEA ; TIMER LOW BYTE
TMRHI $=$ OEB ; TIMER HIGH BYTE
TAULO $=$ OEC ; TIMER REGISTER LOW BYTE
TAUHI = OED ; TIMER REGISTER HIGH BYTE
;
CNTROL = OEE ; CONTROL REGISTER
PSW $\quad$ - 0 PF PS REGISTER
********************
* CONSTANT DECLARE
********************
CNTRL - REGISTER BITS ----
TSEL $=7$
CSEL $=6$
TEDG $=5$
TRUN $=4$
MSEL $=3$
IEDG $=2$
$\begin{array}{lll}\text { S1 } & =1 \\ \text { SO } & = & 0\end{array}$
;
; -ー-- PSW- REGISTER BITS ----
HCARRY $=7$
CARRY $=6$
TPND $=5$
ENTI $=4$
IPND $=3$
BUSY $=2$
ENI $=1$
GIE $\quad=0$
; I/O - SIGNALS ----
;
TMRINP $=3$
INTR $=0$
TIO $=3$
SO $=4$
$\mathrm{SK}=5$
SI $=6$
$\mathrm{CKO}=7$
;
. CHIP 820
LD SP,\#02F ; DEFAULT INITIALIZATION OF SP

```
;INCLD COP82O.INC
;
; This program provides in the form of subroutines, the ability to enable,
; disable, read and write to the NM95Cl2 EEPROM with DIP switches.
;
; *************************************************
; * PROGRAM VARIABLE MEMORY LOCATION DEFINITIONS
; ****************************************************
SNDBUF = 0 ;CONTAINS THE COMMAND BYTE TO BE WRITTEN TO NM95Cl2
RDATL = 1 ;LOWER BYTE OF THE NM95Cl2 REGISTER DATA READ
RDATH = 2 ;UPPER BYTE OF THE NM95CI2 REGISTER DATA READ
WDATL = 3 ;LOWER BYTE OF THE DATA TO BE WRITTEN TO NM95Cl2 REGISTER
WDATH = 4 ;UPPER BYTE OF THE DATA TO BE WRITTEN TO NM95Cl2 REGISTER
ADDRESS = 5 ;THE LOWER 6-BITS OF THIS LOCATION CONTAIN THE ADDRESS
                    ;OF THE NM95Cl2 REGISTER TO BE READ/WRITTEN
FLAGS = 6 ;USED FOR SETTING UP FLAGS
    ; FLAG VALUE ACTION
            O0 WRITE ENABLE,DISABLE,WRITE ALL
            01 READ CONTENTS OF NM95C12 REGISTER
            03 WRITE TO NM95Cl2 MEMORY REGISTER
            07 WRITE NM95Cl2 SCR REGISTER
            OTHERS ILLEGAL COMBINATION
;
THE INTERFACE BETWEEN THE COP820C/840C AND THE NM95Cl2 (1024-BIT EEPROM)
CONSISTS OF FOUR LINES. THE Gl (CHIP SELECT LINE), G4 (SERIAL OUT SO),
G5 (SERIAL CLOCK SK) AND G6 (SERIAL IN SI).
ANOTHER PINS USED BY THIS DESIGN IS GO (INTERRUPT INTR)
;
;
* ********************
    * INITIALIZATION *
    ******************
    LD PORTGC,032 ;Setup G1,G4,G5 as outputs
    LD PORTGD,00 ;Initialize G data reg to zero
    LD CNTROL,08 ;Enable MSEL, select MW rate of 2tc
    LD B,PPSW ;Load B with address of PSW
    LD X,fSIOR ;Load X with address of Serial I/O Register
;
;
**********************
    * WEN INSTRUCTION *
    ***********************
THIS ROUTINE ENABLES PROGRAMMING OF THE NM95Cl2. PROGRAMMING MUST
BE PRECEDED ONCE BY A PROGRAMMING ENABLE (WEN).
;
WEN:
            LD SNDBUF,fO3O ; LOAD OP CODE AND 'ADDRESS'
            LD FLAGS,fO
                JSR INIT
                RET
;
;
;
; * WDS INSTRUCTION *
; ********************
```

```
;
; THIS ROUTINE DISABLES PROGRAMMING OF THE NM95Cl2.
;
WDS:
            LD SNDBUF,fO ; LOAD OP CODE AND 'ADDRESS'
            LD FLAGS,fO
            JSR INIT
            RET
;
;
***********************
* READ INSTRUCTION
***********************
THIS ROUTINE READS THE CONTENTS OF THE NM95Cl2 REGISTER.
THE NM95Cl2 ADDRESS IS SPECIFIED IN THE LOWER 6-BITS OF
; LOCATION "ADDRESS". THE UPPER 2-BITS SHOULD BE SET TO ZERO.
THE l6-BIT CONTENTS OF THE NM95Cl2 REGISTER ARE STORED IN
; RDATL AND RDATH.
;
READ: LD A,ADRESS ; LOAD ADDRESS A5-AO INTO ACCUMULATOR
            OR A,P080 ; SET OP CODE BITS TO '10'
            X A,SNDBUF ; TRANSFER COMMAND BYTE TO SERIAL I/O VARIABLE
            ID FLAGS,fl
            JSR INIT
            RET
;
;
;
* WRITE INSTRUCTION *
    ************************
THIS ROUTINE WRITES A l6-BIT VALUE STORED IN WDATL AND WDATH
TO THE NM95Cl2 REGISTER WHOSE ADDRESS IS CONTAINED IN THE
LOWER 6-BITS OF THE LOCATION "ADDRESS". THE UPPER 2-BITS OF
ADDRESS LOCATION SHOULD BE SET TO ZERO.
;
WRITE: LD A,ADRESS ; LOAD ADDRESS A5-AO INTO ACCUMULATOR
    OR A,PO40 ; SET OP CODE BITS TO 'Ol'
    X A,SNDBUF ; TRANSFER COMMAND BYTE TO SERIAL I/O VARIABLE
        LD FLAGS,93
        JSR INIT
        RET
;
;
;
***********************
    * WRALL INSTRUCTION *
    ***********************
    THIS ROUTINE WRITES A l6-BIT VALUE STORED IN WDATL AND WDATH
TO ALI THE NM95Cl2 REGISTERS
;
WRALL: LD SNDBUF,P040 ; LOAD OP CODE AND ADDRESS'
    LD FLAGS,f3
    JSR INIT
    RET
;
;
```

```
; *************************
    * WRSCR 'INSTRUCTION'
    *************************
THIS ROUTINE WRITES A 16-BIT VALUE STORED IN WDATL AND WDATH
TO THE NM95Cl2 SCR (SWITCH CONTROL REGISTER) WHOSE ADDRESS IS 62 DECIMAL
WHICH EQUALS PO3E HEXADECIMAL. OP CODE = 'Ol'
A WRITE TO THE SCR DOES NOT REQUIRE A PROGRAMMING CYCLE
;
WRSCR: LD SNDBUF,PO7E ; LOAD OP CODE AND ADDRESS
        LD FLAGS,f7
        JSR INIT
        RET
;
;
;
*************************************
    * EXECUTE INSTRUCTION SUBROUTINES *
    ***********************************
THIS ROUTINE SENDS OUT THE START BIT AND THE COMMAND BYTE.
IT ALSO DECIPHERS THE CONTENTS OF THE FLAG LOCATION AND TAKES
A DECISION REGARDING WRITE, WRITE SCR, READ OR RETURN TO THE
CALLING_ROUTINE.
;
INIT: SBIT 1,PORTGD ;SET CHIP SELECT HIGH
    LD SIOR,fOO1 ;LOAD SIOR WITH START BIT
    SBIT BUSY,[B] ;SEND OUT THE START BIT
PUNTI: IFBIT BUSY,[B]
    JP PUNTI
    LD A,SNDBUF
    X A,[X]
    SBIT BUSY,[B]
PUNT2: IFBIT BUSY,[B]
    JP PUNT2
    IFBIT O,FLAGS
    JP NOTDON
    RBIT 1,PORTGD ;NO, RESET CS AND RETURN
    RET
;
NOTDON:
    IFBIT l,FLAGS
    JP WR95Cl2
    LD SOIR,POOO
    SBIT BUSY,PSW
;NO, READ NM95Cl2
    RBIT BUSY,[B]
    SBIT BUSY,[B]
PUNT3: IFBIT BUSY,[B]
    JP PUNT3
    X A,[X]
    SBIT BUSY,[B]
    X A,RDATH
```

```
PUNT4: IFBIT BUSY,[B]
    JP PUNT4
    LD A,[X]
    X A,RDATL
    RBIT 1,PORTGD
    RET
;
WR95Cl2:
    LD A,WDATH
    X A,[X]
    SBIT BUSY,[B]
PUNT5: IFBIT BUSY,[B]
    JP PUNT5
    LD A,WDATL
    X A,[X]
    SBIT BUSY,[B]
PUNT6: IFBIT BUSY,[B]
    JP PUNT6 ; FINISHED CLOCKING OUT DATA
    RBIT 1,PORTGD ; RESET CHIP SELECT
    IFBIT 2, FLAGS ; WRITE/WRALL OR WRSCR?
    RET ; WRSCR , NO PROGRAMMING TIME SO RETURN
    SBIT l,PORTGD ; SET CHIP SELECT TO ALLOW TO POLL DO FOR BUSY/READY
POLL: IFBIT SI,PORTGP ; IS NM95CI2 DO = SI LOW?
    JP ENDTWP ; DO HAS GONE HIGH, SO END PROGRAMMING CYCLE
    JP POLL ; DO IS STILL LOW, SO KEEP POLLING
;
ENDTWP;
    BIT 1, FLAGS ; RESET CHIP SELECT
    RET
;
    .END
```


## Using the NM95C12 to Solve Common Manufacturing Problems

## INTRODUCTION

This application note describes how the NM95C12 E2PROM + Dip Switches is utilized to reduce manufacturing costs and increase reliability.

## PROBLEM

The application described herein is a factory programmable power supply. The existing system (Figure 1) requires one of three different power supplies, depending on the options installed in the final unit. The design engineer has presented two solutions:

1. Three different assemblies, one for each output configuration, or,
2. One assembly with a dip switch (or jumpers) to select the configuration.
The manufacturing engineer would prefer to have one assembly that would satisfy all three needs. Dip switches are undesirable because they are difficult to flow solder when on the PCB (and later clean the PCB) as well as posing a threat to the final system should an untrained technician choose to change a switch setting (thus altering the output voltage). Jumpers are undesirable since they require hand soldering-an additional step.
The manufacturing engineer would prefer to have one final test program-not three.

National Semiconductor
Application Note 756
Kent Brooten


## THE SOLUTION

The NM95C12 provides the solution. It enables the power supply module to be configured for any of the three output voltages. There only needs to be one assembly. No dip switches or jumpers are used. The Automatic Test Equipment (ATE) used at final test can check all three configurations. The test program can set the final configuration as well as assign a serial number and date of manufacture which is stored in the EEPROM.

## THE DESIGN

The power supply is designed using an LM2577 switching regulator ("the Simple Switcher') in the flyback mode (Figure 2). The resistor divider $R_{1} / R_{2}$ set the output voltages $V_{\text {OUT1 }}$ and $V_{\text {OUT2 }}$. All three output voltages can be set by merely selecting which combination of $R_{1} / R_{2}$ is connected to the feedback pin of the switching regulator. When the switches in the NM95C12 are configured for the analog switch mode, they can be used to connect the appropriate switch to the feedback pin of the Simple SwitcherTM.
The manufacturing group need only produce one assembly which is electronically configured either at final test or during final assembly. An increase in manufacturing efficiency results.


TL/D/11161-1
FIGURE 1. Modules A, B, C Each Require Slightly Different Power Supply Modules

During final test, the ATE can check each switch position by sending serial commands via the serial $\mu$ WIRE interface of the NM95C12. The serial number and date of manufacture can be stored at this time. Output configuration can be selected at final test or the power supply modules can be stored and the output voltage programmed at a later time. Note that there is no microcontroller necessary in the system. While the NM95C12 is typically utilized in a $\mu$ Controller based system, it can also be used in non- $\mu$ Controller applications. The ATE provides programming and control of the NM95C12 and connects to pads on the PCB via a bed-ofnails test fixture. Alternatively, the Clock, Data IN, Data OUT and Chip Select lines can be routed to fingers on an edge connector.

## PROGRAMMING

The programming example is written in the popular Z80 assembly language. An NSC800 is used for this example. Flow charts are shown for each module.

## SUMMARY

The NM95C12 is used in this application to replace a dip switch. The user benefits in many ways:

1. Increased efficiency by manufacturing 1 large lot of subassemblies rather than 3 smaller ones,
2. Ease of manufacturing since neither mechanical dip switches have to be treated with extra care nor jumpers specially installed,
3. Only 1 sub-assembly needs to be inventoried, cutting costs,
4. Increased reliability because mechanical devices are not used,
5. Increased efficiency at final test since only 1 test program can check all three configurations,
6. Inventory costs are reduced because 1 assembly will satisty any of 3 different functions, and
7. A history of the module can be stored in the EEPROM portion of the device including serial number, date of manufacture, date of last repair, etc.


Edge Connector
TL/D/11161-2
FIGURE 2



TL/D/11161-4


THIS ROUTINE SHIFTS OUT 8 BITS OF COMMAND (+ START BIT)
IT WRITES TO A PARALLEL PORT WHOSE OUTPUTS ARE CONFIGURED AS:
BIT $0=$ DATA
BIT $1=$ CLOCK
BIT $2=$ CHIP SELECT (ACTIVE HI)
IT ASSUMES CS IS ACTIVE
IT SENDS A START BIT (LOW TO HI TRANSITION)
THEN IT SENDS DATA MSB FIRST
IT EXPECTS PORT DATA IN C REG
IT DESTROYS H,L,B
SHIFT8:
PUSH AF ;SAVE

CALL STRTBT ;SEND START BIT
LD B,7 ;LOOP COUNTER
LD A,L ;ADDRESS
OR H ;COMBINE WITH OPCODE
LD L.A ;SAVE IN L
SNDBIT:
LD A,C
;GET PORT CONTENTS
AND OFDH
LD C,A ;MASK CLK AND DATA LOW
; SAVE
;CK MSB OF DATA ;IF O, DO NOTHING ; ELSE SET DATA BIT HI
SHBLP:
JP NC, SH8LP
OR 1
OUT (EE),A ;SEND DATA WITH CLK=0
OR 2
OUT (EE),A
; CLK=1
;SEND IT
AND OFDH ;CLK=0
OUT (EE),A ;SEND IT
DEC B ;LOOP ONE FEWER TIMES
JP NZ,SNDBIT ;LOOP UNTILL DONE
ELSE, WE HAVE SENT 8 BITS
POP AF ;RESTORE
RET ;
TL/D/11161-6

```
;
;
;
;
;
; BIT O = DATA
; BIT 1 = CLOCK
;
;
; IT ASSUMES CS IS ACTIVE
; <DE> HOLDS DATA TO BE SENT (MSB FIRST)
;
SHIFT16:
    PUSH AF
    MUSH
    MUSH
SNDBT:
    LD A,C ;GET PORT CONTENTS
    AND OFDH ;MASK CLK AND DATA LOW
    LD C,A ;SAVE
    RLC D ;CK MSB OF FIRST BYTE OF DATA
    JP NC,SH16LP ;IF O, DO NOTHING
    OR 1 ;ELSE SET DATA BIT HI
SH16LP:
    OUT (EE),A ;SEND DATA WITH CLK=0
    OR 2 ;CLK=1
    OUT (EE),A ;SEND IT
    AND OFDH ;CLK=O
    OUT (EE),A ;SEND IT
    DEC B ;LOOP ONE FEWER TIMES
    JP NZ,SNDBT ;LOOP UNTILL DONE
:
; ELSE, WE HAVE SENT FIRST 8 BITS
;
SNDBT1:
    LD A,C ;GET PORT CONTENTS
    AND OFDH ;MASK CLK AND DATA LOW
    LD C,A ;SAVE
    RLC E ;CK MSB OF SECOND BYTE OF DATA
    JP NC,SH16LP1 ;IF O, DO NOTHING
    OR 1
SH16LP1:
    OUT (EE),A ;SEND DATA WITH CLK=0
    OR 2 ;CLK=1
    OUT (EE),A ;SEND IT
    AND OFDH ;CLK=O
    OUT (EE),A ;SEND IT
    DEC B ;LOOP ONE FEWER TIMES
    JP NZ,SNDBT1 ;LOOP UNTILL DONE
;
; ELSE, WE HAVE SENT ALL 16 bItS
    POP
RET ;
IT WRITES TO A PARALLEL PORT WHOSE OUTPUTS ARE CONFIGURED AS:
BIT 2 = CHIP SELECT (ACTIVE HI)
    ;
    B,7 ;LOOP COUNTER
    THIS ROUTINE SHIFTS OUT 16 BITS OF DATA
    LD B,7 ;LOOP COUNTER
;ELSE SET DATA BIT HI
```

; SEND A START BIT
STRTBT:
PUSH A

LD AN OUT (EE),A
OR OUT (EE),A
OR 2
OUT
(EE), A
AND OFDH
OUT (EE),A
LD C,A
POP
RET
: SET CS LOW (INACTIVE)
; ALTERS C REG
CSLOW:

| PUSH | AF | ;SAVE |
| :--- | :--- | :--- |
| LD | A,C | ;GET PORT DATA |
| AND | OFBH | ;SET CS LOW (AND DATA AND CLK) |
| LD | C,A | ;SAVE |
| OUT | (EE),A | ;WRITE TO PORT |
| POP | AF | ;RESTORE |
| RET |  | ;DONE |

LD A,C
AND OF8H
LD C.A
RET ;DONE

```
;WRITE TO PORT
;RESTORE
;SAVE ACC
;GET PORT CONTENTS
;MASK CLK & DATA LOW
;SEND IT
;DATA = 1
;SET UP DATA
;CLK = 1
;SEND
;CLK = 0
;SEND
;SAVE NEW CONTENTS IN C
;RESTORE ACC
;
```

;

END


Write Command to NM95C12


TL/D/11161-10


TL/D/11161-11
*Pre-check of NM95C12 sets CS active. Returns when NM95C12 not busy.


TL/D/11161-12

Write Data (16 Bits) to NM95C12


Send Start Bit to NM95C12


TL/D/11161-14

Shifts 8 Bits into the NM95C12 via the Data IN Pin


TL/D/11161-15

Shift 16 Bits of Data to NM95C12


TL/D/11161-16

## Using National's MICROWIRE ${ }^{\text {™ }}$ EEPROM

National Semiconductor manufactures a wide range of low density serial EEPROMs that use the MICROWIRE interface as a means of communication. Although all of these devices use the MICROWIRE interface, there are slight variations in interfacing due to differences in memory sizes, features, and technology used to implement the device. Additionally, the MICROWIRE interface does not specifically define any protocol, it only defines a basic set of signal lines to interconnect two or more devices. Due to these reasons, additional information is necessary to fully understand how to best interface to National's family of MICROWIRE EEPROM.
The goal of this application guide is to cover a diversity of information in regard to basic timing, interfacing options, and functionality of different EEPROMs. I will use an outline approach, so the appropriate heading can be located easily. Each section attempts to be stand alone so the information can be easily extracted. The outline appears below:

```
OUTLINE
1.0 Description of EEPROM Families
    1.1 CMOS EEPROM
        1.1.1 NM93C Family
        1.1.2 NM93CS Family
        1.1.3 Variations
2.0 HARDWARE CONNECTIONS
    2.1. INTERFACE PIN DESCRIPTIONS
        2.1.1 Chip Select
        2.1.2 Serial Clock
        2.1.3 Data-In (DI)
        2.1.4 Data-Out (DO)
        2.1.5 Program Enable (PE)
        2.1.6 Protect Register Enable (PRE)
        2.1.7 Organization (ORG)
        2.1.8 Status (RDY/BUSY)
    2.2. FOUR WIRE BUS
    2.3. THREE WIRE BUS
3.0 TIMING CONSIDERATIONS
    3.1 BUS TIMING
    3.2 INSTRUCTION SEQUENCE DESCRIPTIONS
        3.2.1 Read Cycle
        3.2.2 Sequential Read
        3.2.3 Erase and Erase All
        3.2.4 Write and Write All
        3.2.5 Program Enable and Program Disable
        3.2.6 Protect Register Read
        3.2.7 Protect Register Enable
        3.2.8 Protect Register Disable
        3.2.9 Protect Register Clear
        3.2.10 Protect Register Write
        3.3. INTERFACING SOLUTIONS
4.0 CONCLUSION
```


### 1.0 Description of EEPROM Families

### 1.1 CMOS EEPROM

National builds a range of MICROWIRE CMOS EEPROMs in memory sizes ranging from 256 -bit to 4906 -bit. The NM93C family is the base family and the NM93CS is a similar family with additional features, there are also other devices with slight variations on the interface. All these devices are available with certain "standard" options such as operating temperature ranges and operating voltage ranges, packaging options and test options. These options being fairly standard variations for semiconductor devices, will not be addressed beyond this. The purpose of this article is to address basic functionality and interfacing, including various tricks to simplify or modify the interface.

### 1.2 NM93C Family

The NM93C family of EEPROM is available in 256-, 1024-, 2048-, and 4096-bit sizes. All of these are internally organized in 16-bit words, therefore all data transactions deal with 16 bits. This family of EEPROMs has 7 instructions that deal with read, write, and a basic level of data protection. The instructions are listed in Table I. It is important to note that there is a basic difference in length of the instruction between the NM93C06 or NM93C46 and the NM93C56 or NM93C66. This is due to the larger devices needing additional address bits.
The NM93C family of EEPROM, like all of National's serial EEPROMs have a basic level of write protection that can be turned on or off by the use of the ERASE/WRITE DISABLE (EWDS) and ERASE/WRITE ENABLE (EWEN) instructions. Although there are two erase instructions included in the NM93C family, these are included only for compatibility with older EEPROMs that require erase before write. These EEPROMs don't require erase before write and it is recommended that in application the erase not be used as this adversely affects endurance.

### 1.3 NM93CS Family

The NM93CS EEPROMs are identical to the NM93C family in memory sizes and organization. Making them different, they have two additional functions, sequential read and user configurable write protection, and don't have either of the erase functions, ERASE and ERASE-ALL as they are not needed. Like all of the CMOS EEPROMs, these have self timed programming cycles and operate from a single external supply of either 4.5 V to 5.5 V or 2.0 V to 5.5 V . In these devices it is necessary to eliminate the erase cycles from the code as they may adversely affect the performance of the device.
As these have additional functions, the instruction set includes a total of 10 instructions, 3 that operate on the memory array, 2 that deal with the basic write protection and 5 that deal with the user configurable write protection. Refer
to the NM93CS instruction set table (Table II) for definitions of these instructions. As with the NM93C family, there is a basic difference in instruction length depending on memory size.

To further increase data security in these EEPROMs there are also two additional input signals defined, Program Enable (PE) and Protect Register Enable (PRE). These signals are on pins that are unused on the NM93C family providing upward compatibility to the NM93CS devices.

TABLE I. NM93C Family Instruction Set Table

| Instruction | SB | Op Code | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :---: | :--- |
| READ | 1 | 10 | A7/A5-A0 |  | Reads data stored in memory. |
| EWEN | 1 | 00 | $11 X X X X$ |  | Write enable must precede all programming modes. |
| ERASE | 1 | 11 | A5-AO |  | Erase register A5A4A3A2A1AO. |
| WRITE | 1 | 01 | A5-A0 | D15-D0 | Writes register. |
| ERAL | 1 | 00 | $10 X X X X$ |  | Erase all registers. |
| WRAL | 1 | 00 | $01 X X X X$ | D15-D0 | Writes all registers. |
| EWDS | 1 | 00 | $00 X X X X$ |  | Disables all programming instructions. |

TABLE II. NM93CS Family Instruction Set Table

| Instruction | SB | Op Code | Address | Data | PRE | PE | Comments |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| READ | 1 | 10 | A5-A0 |  | 0 | X | Reads data stored in memory, starting at specified address. |
| WEN | 1 | 00 | 11 XXXX |  | 0 | 1 | Write enable must precede all programming modes. |
| WRITE | 1 | 01 | A5-A0 | D15-D0 | 0 | 1 | Writes register if address is unprotected. |
| WRALL | 1 | 00 | $01 X X X X$ | D15-D0 | 0 | 1 | Writes all registers. Valid only when Protect Register is <br> cleared. |
| WDS | 1 | 00 | $00 X X X X$ |  | 0 | $X$ | Disables all programming instructions. |
| PRREAD | 1 | 10 | XXXXXX |  | 1 | $X$ | Reads address stored in Protect Register. |
| PREN | 1 | 00 | $11 X X X X$ |  | 1 | 1 | Must immediately precede PRCLEAR, PRWRITE, and PRDS <br> instructions. |
| PRCLEAR | 1 | 11 | 111111 |  | 1 | 1 | Clears the Protect Register so that no registers are protected <br> from WRITE. |
| PRWRITE | 1 | 01 | A5-A0 |  | 1 | 1 | Program address into Protect Register. Thereafter, memory <br> addresses 2 the address in Protect Register are protected <br> from WRITE. |
| PRDS | 1 | 00 | 000000 |  | 1 | 1 | One time only instruction after which the address in the <br> Protect Register cannot be altered. |

### 1.1.3 Variations

There are two variations on the standard implementation of the Microwire bus. Both variations can be viewed as enhancements. The first enhancement is a Organization (ORG) input that allows the user to select the internal configuration of the memory as either 8 bits wide or 16 bits wide. When the input is high or unconnected, the device is configured as 16 bits wide, when the ORG input is at a low level, the memory is configured as 8 bits wide, but twice as deep. The feature is present on both the NM93C46A and the NM59C11.

The second variation is the STATUS output. This is the Busy/Ready polling to indicate programming status. All other devices have this feature on the Data-Out (DO) output, the NM59C11 alone has status available as a separate output and not on the Data-Out output. This can simplify interfacing to a bidirectional data bus.

### 2.0 Hardware Connection

### 2.1 INTERFACE PIN DESCRIPTIONS

In this section, each possible input or output will be described followed by the most popular variations of bus connections. Not all devices have all of the described I/Os. The I/Os are available according to Table III, I/O Functionality.

### 2.1.1 CHIP SELECT (CS)

Chip Select is used to differentiate between various devices on the same Microwire bus. In the case of EEPROM it cannot be tied high even if it is the only device on the bus as it performs several additional functions. As it applies to any of the Microwire EEPROMs, the rising edge resets the internal circuitry of the device, a function necessary prior to initiating any new cycle. As shown in the functional block diagram (Figure 1) chip select also gates the data input and clock input, thus disabling these functions.

During the course of clocking in the start bit, op-code address and data-in or data-out, chip select must be held high continuously, otherwise the internal circuits will be reset and the cycle will have to be started again with a new start bit.
During programming cycles chip select initiates the internal programming cycle. The falling edge of chip select will start the internal programming cycle when a programming opcode has been entered (Erase, Write, Erase All, Write All) and then, in conjunction with Data-Out (DO), will indicate if programming is complete (except the NMOS NMC9306). If programming is complete, Data-Out will drive high, if incomplete it will drive low. In the case of the NMC9306, the user must provide the programming time and in this case chip select must be held low for a minimum of 10 ms , then brought high and clocked to end the programming cycle.
Several additional notes in regard to chip select:
If a programming cycle is partially clocked in and then chip select dropped, the EEPROM may enter into a programming mode. This is determined by how many bits have been clocked in when chip select is dropped. If the start bit, opcode, and all of the address has been clocked in, a programming cycle will be initiated with no or partial data. If less than a complete address has been clocked in, the programming cycle will not be initiated. Refer to Figure 2, reference line 1.
In the case of the NM59C11, a programming cycle will not be entered unless a full data field has been clocked in. A full data field may be either 8 or 16 bits depending on the logic level present at the ORG input. A programming cycle will be entered at reference line 2 in Figure 2 for the NM59C11.
Chip select hold time at the end of a cycle is referenced to the last rising edge of clock (SK). The hold time from the rising edge is the same as the minimum SK high time for the particular device. This is stated in the datasheets as 0 ns hold time from the falling edge of SK which assumes that SK high time is always minimum. In this case SK can be left in the high state or taken low at a later time. Internally chip select gates SK, therefore SK is not critical.

TABLE III. I/O Functionality by Device

|  | CS | SK | DI | DO | PE | PRE | ORG | STAT |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NM93C Family | X | X | X | X |  |  |  |  |
| NM93CS Family | X | X | X | X | X | X |  |  |
| NM93C46A | X | X | X | X |  |  | X |  |
| NM59C11 | X | X | X | X |  |  | X | X |




FIGURE 2. Programming Cycle Point of No Return

### 2.1.2 SERIAL CLOCK (SK)

The clock input is used to clock all data, address, op-code, and start bits into or out of the EEPROMs. SK clocks both input and output on the rising edge only, the falling edge has no effect on the devices. The only function it is not necessary for is the Busy/Ready Polling which is an asynchronous function.
Since SK is gated by ship select, it is a "Don't Care" any time chip select is low. It is also don't care prior to a start bit being clocked in and during Busy/Ready Polling. During these conditions Data-In (DI) must be held at a low level, otherwise a start bit will be interpreted.
If it is desirable to insert additional clock cycles during a instruction sequence for the purpose of byte aligning the data, there are several places in the data stream they may be inserted as described below:

- On any instruction, zeros can be clocked into the DI input before the start bit. Any number of clock cycles may be added if Data-In (DI) is held at zero. The first 1 clocked in will be interpreted as the start bit. This requires special precautions if a bidirectional data bus is used (Data-In tied to Data-Out) as the Busy/Ready Polling will interfere with the Data-In if it is not cleared out at the end of each programming cycle. See Section 2.3, THREE WIRE BUS, for more information.
- During a Read instruction, it is allowable to continue to clock the device after the 16 bits of data has been clocked out. In the case of the NM93CS family this will cause the memory to increment to the next register and present its contents on the Data-Out pin. In the case of all other devices, whatever was present on the Data-In pin will become present on the Data-Out pin (Fall thru). Refer to Figure 1, Block Diagram.
- During a Write or Write-All, additional clock cycles may be added after address AO and before the valid data. The EEPROM will write into the memory the most recent 16 bits, or in the case of the NM93C46A, the most recent 8 bits or 16 bits depending on the status of the ORG input. Adding additional clocks after the valid data will cause the data to be misaligned. In the case of the NM59C11, the device counts the data bits clocked in and automatically enters the programming mode when it receives a full data field, therefore bits cannot be inserted between AO and valid data.
- During the EWEN, Erase, Erase All, EWDS, WEN, WDS cycles, it is not necessary to clock in a data field, although it is mandatory to clock in a complete address field, even if the addresses are "Don't Care". Additional clocks can be added after the address field.


### 2.1.3 DATA-IN (DI)

The Data-In input receives the Start-Bit, Address, and input data in a serial stream, each bit clocked in on the rising edge of SK. DI is gated by the chip select to provide a high degree of noise immunity. As shown in the block diagram, Data-In is routed to both the instruction shift register and the data shift register. When the start bit is clocked into the last bit of the instruction register, the clock is switched to the data register to receive input data and clock data out simultaneous. The Data-Out remains in high impedance unless a read cycle or Busy/Ready status is being done. The safest state is to keep the Data-In pin in a low level as a start bit is a high level.

### 2.1.4 DATA-OUT (DO)

The Data-Out (DO) output sends read data onto the microwire bus and is clocked out on the rising edge of SK. It also carries the programming status after a programming cycle which is an asynchronous function that does not require the clock. At all other times the Data-Out is in the high impedance state. During a Read cycle, the Data-Out output begins to drive actively after the last address bit (AO) is clocked in. During the Busy/Ready polling it begins to drive active after chip select is raised to a high level.
During the Busy/Ready Polling, the Data-Out output drives low while the device is still in the internal programming cycle. After the EEPROM has completed the internal programming cycle, the Data-Out pin will drive high when chip select is high. Subsequently, if chip select is brought high again, Data-Out will again drive high indicating it has completed the programming cycle. To clear the Busy/Ready Polling it is necessary to raise chip select and clock in a start bit. Once the start bit is clocked in, Data-Out will return to the high impedance state. It is not necessary to continue with a cycle after this start bit has been clocked in, although it is permissible to start a new cycle with this start bit. This clearing of the Busy/Ready status may be necessary if a bidirectional data bus is used (Data-In tied to Data-Out) as the Data-Out output will interfere with the new data being presented on the Data-In input.

### 2.1.5 PROGRAM ENABLE (PE)

The program enable (PE) input will enable all programming cycles when it is held at a high level during the duration of a programming cycle. Conversely, it will disable all programming, including programming of the protect register, while it is held low. This input has no affect on any other cycle, so it may be permanently tied high or low, or may be used in an active mode. This input is available on the NM93CS family only.

### 2.1.6 PROTECT REGISTER ENABLE (PRE)

The protect register enable (PRE) input is used to switch between memory operations and protect register operations since the same op-codes are used for both. With the PRE input high, the op-codes define operations in the protect register, with the PRE input low, the op-codes define operations in the memory. This pin may be tied high or low, or used in the active mode. This input is available on the NM93CS family only.

### 2.1.7 ORGANIZATION (ORG)

The Organization input (ORG) is used to control the internal organization of the memory. The two selectable organizations are 16 -bit words and 8 -bit words. Simply by holding the ORG pin at a high level, 16 -bit words are selected, by holding the input at a low level 8 -bit words are selected. When in the 8 -bit mode, one additional address bit is required in the instruction sequence since the depth of the memory is doubled. This input is available only on certain device types, refer to the individual datasheets.

### 2.1.8 STATUS (RDY/BUSY)

The status output indicates the programming cycle status after a programming cycle. When the device is in the programming mode and therefore cannot accept any other cycles, this pin will be low. After completion of the cycle the STATUS pin will be driven high. When this function is present, the Busy/Ready Polling is not available on the Data-Out

output. In some systems, particularly those using a bi-directional data bus, this can simplify interfacing by eliminating the possible contention between the Ready indication and the incoming data from the host device. This output is available only on certain device types, refer to the individual datasheets.

### 2.2 FOUR WIRE BUS

The 4 wire bus is the simplest interconnection between the EEPROM and the host device. In most cases the only signals necessary to provide are clock, chip select, Data-In and Data-Out as shown in Figure 5. The PRE, PE, ORG, and STATUS pins are not shown as they are variations on this and the 3 wire bus connection. Multiple devices can be connected to the microwire bus, the only limitations being loading and available chip select means. In some systems it is necessary to have a bi-directional data line as described below in 3 wire bus.


TL/D/11169-7
FIGURE 5. Four Wire Connection

### 2.3 THREE WIRE BUS

The 3 wire bus operates in the same mode as the 4 wire bus with the exception that the Data-In and Data-Out pins on the EEPROM are tied together. When using this connection, there are two precautions that need to be observed.

- When Data-In is tied to Data-Out, there is a possible conflict between address AO in the instruction sequence
and the dummy bit. This only occurs during a READ cycle. This is not harmful to the device and the internal circuitry of the EEPROM guarantees that the device will function properly under this condition. To decrease the noise created by the condition, a resistor may be placed in the locations indicated in Figure 6. The timing diagram in Figure 7 shows the bus conflict.
- The second possible area of conflict occurs when the Busy/Ready status is on the Data-Out output. Since the device will continue to indicate a Ready status indefinitely after a programming cycle (until a start-bit is clocked in), this can conflict with the beginning of the next cycle if leading zeros are clocked in (See Figure 7). The solution is to either use a separate cycle to clear the Ready bit or to eliminate any leading zeros from the instruction sequence. If the Busy/Ready Polling is not used in the application, the easiest solution is to use the NM59C11 that does not have the polling on Data-Out but has it on a separate output.


TL/D/11169-8
FIGURE 6. Three Wire Connection Showing Optional Resistor


FIGURE 7. Three Wire Connection Bus Conflict Areas

### 3.0 Timing Considerations

The following information describing the Microwire bus timing must be used in conjunction with the datasheet as it is an expansion and clarification of the datasheet. First, the basic timings with respect to the clock (SK) will be described, followed by instruction sequence timing, and finally, specific information in each instruction sequence.

### 3.1. BUS TIMING

The synchronous data timing shown in Figure 8 is similar to that shown in the various datasheets. There is one significant modification to the timing specification though, the chip select (CS) hold time is referenced to the rising edge of the clock rather than the falling edge. With this modification, the hold time specification must be changed to be the same as
the minimum clock (SK) high time. Other significant points are:

- The only active edge of the clock is the rising edge.
- The only time the clock is necessary is when clocking data into or out of the EEPROM. It is not necessary during Busy/Ready Polling.
- The clock may be left in either the high state or low state between cycles. It is safer to leave the clock in the low state.
- When chip select (CS) is high, clock (SK) is a critical signal. With the exceptions noted in Section 2.1.2 tilted SERIAL CLOCK (SK), no additional clock cycles or noise that crosses the $\mathrm{V}_{\mathrm{IH}}$ or $\mathrm{V}_{\mathrm{IL}}$ thresholds can be tolerated.


FIGURE 8. Synchronous Timing

### 3.2 INSTRUCTION SEQUENCE DESCRIPTIONS

### 3.2.1 READ CYCLE

The READ cycle requires the host to raise chip select (CS) and then clock in thru the Data-In (DI) pin a start-bit, opcode, and address. Following clocking in the last address bit, the Data-Out (DO) output comes out of the high impedance state and drives a low level on the output. This is referred to as the dummy bit and is a good indication that a READ mode has been successfully entered if difficulty is encountered during initial debug of a system. The dummy bit is clocked out of the EEPROM on the same rising edge of SK that clocks in the last address bit, A0. This is shown in Figure 9.

### 3.2.2 SEQUENTIAL READ

Sequential read is a read mode available only on the NM93CS family. It is entered by entering a READ cycle and clocking out the first 16 -bit word. After reading the first 16 -bit word if chip select (CS) is kept high, address $A+1$ may be clocked out followed by address A +2 and so on. When the maximum address is reached, the memory continues in the sequential read mode at address 0 . In this manner, the host may operate the memory in a continuous loop read. When initiating a SEQUENTIAL READ, the first data
word is proceeded by a dummy bit as in a standard READ, although the dummy bit is supressed in all subsequent data words as shown in Figure 9.

### 3.2.3 ERASE AND ERASE ALL

The ERASE cycles return the contents of the EEPROM to a clear state which is read as 1 's. It is not necessary for any of the CMOS EEPROM described in this article, and is included in the NM93C family, NM93C46A, and NM59C11 only for compatibility with older devices that require erasing. It is recommended that the erase cycles be eliminated from the instructions to simplify the code, speed up writing and to improve the endurance obtained in the application. These modes are entered by clocking in a start-bit, op-code, and address. It is not necessary to clock in the data field as it is assumed to be all 1's. It is necessary to clock in the address, even in the case of ERASE-ALL where it is "don't care" in all except the first two bits of the address field which is used as additional op-code bits. After the full address field has been clocked in, chip select must be returned to a low level in initiate the erase cycle. In all devices, except the NMC9306, programming completion can be determined by Polling as shown in Figure 4, or a simple 10 ms timeout will guarantee programming is complete if polling is not used.


TL/D/11169-12
FIGURE 9. Sequential Read Sequence


TL/D/11169-6
FIGURE 4. Busy/Ready Polling Sequence

### 3.2.4 WRITE AND WRITE ALL

The Write and Write All cycles will write a specified data word into the specified address, or in the case of Write All, the same data pattern will be written into all locations. In all devices a new data pattern may be directly written over an existing data pattern without erasing the first data pattern. The write mode is entered by clocking in a start-bit, opcode, address, and data. The full address field must be clocked in for the Write All even though it is don't care in all but the first 2 bits. It is also necessary to clock in a full data field to assure correct alignment of data. The write cycle will be initiated after 8 - or 16 -bit have been clocked into the device in some of the devices and in other devices after chip select is brought low regardless of how many data bits have been clocked in. Refer to the specific datasheets to determine which method is used.

### 3.2.5 PROGRAM ENABLE AND PROGRAM DISABLE

Program enable and program disable are the instructions that enable or disable writing and, where included, erasing. The instruction name varies depending on the specific device but includes EWEN, EWDS, WEN, and WDS. These instructions enable or disable the entire memory array with a single instruction. All devices power up in the disable mode and once placed in the enabled mode remain enabled until a disable instruction is performed or $\mathrm{V}_{\mathrm{CC}}$ is cycled. These instructions provide the most basic level of data protection. Although since most lost data is the result of the host device becoming uncontrolled and performing the "Program Subroutine" it may be helpful to structure the software such that the enable command is not included in the "Program Subroutine" but is in a separate subroutine. If a greater degree of data security is needed, a NM93CS family device is recommended, or other more elaborate schemes involving redundant data storage and polling.

### 3.2.6 PROTECT REGISTER READ

The protect register read (PRREAD) command is the same as a word read command except the input PRE must be held at a high level and the address is don't care. In spite of the address being don't care, the entire address field must be clocked in. On the Data-Out pin the contents of the protect register will be clocked out MSB first descending to LSB.

### 3.2.7 PROTECT REGISTER ENABLE

Similar to the programming enable instructions described above, the PREN instruction is necessary to perform any programming instruction the affects the Protect Register. Unlike the enable instructions described above, a PREN must immediately proceed each programming instruction that involves the protect register. The Protect Register programming instructions are PRCLEAR, PRWRITE, and PRDS.

### 3.2.8 PROTECT REGISTER DISABLE

The protect register disable instruction permanently disables any further programming instructions to the protect register. Therefore it can only be performed once in the lifetime of a NM93CS device. The purpose of it is to permanently configure a portion of the EEPROM as true ROM and a portion as Read/Write EEPROM. Great caution should be exercised prior to executing this instruction as there is no second chance. It is performed by sending a start-bit, op-
code and an address field of all 0's while both the PRE and PE inputs are at a high level. This instruction must be immediately proceeded by a PREN instruction.

### 3.2.9 PROTECT REGISTER CLEAR

The protect register clear instruction will clear the contents of the Protect Register making the entire contents of the EEPROM alterable only if the PRDS instruction has not previously been executed. This is done by clocking in a startbit, op-code, and address field of all ones. This instruction must be immediately proceeded by PREN instruction and requires that both PRE and PE inputs be held at a high level.

### 3.2.10 PROTECT REGISTER WRITE

The Protect Register write command (PRWRITE) allows the host to write the protect register with the address where the memory is to be segmented into ROM and EEPROM. The defined address is the first ROM address and the ROM field then continues to the top of memory. To execute this command a start-bit, op-code, and address must be clocked in, the address field containing the memory address that defines the ROM/EEPROM boundary. The PRE and PE inputs must be held at a high level.

### 3.3 INTERFACING SOLUTIONS

When interfacing serial microwire EEPROMs to microcontrollers there is an apparent conflict that occurs when selecting clock polarity and phase. This can be easily overcome in most situations, although when using some microcontrollers that do not allow selection of either clock polarity or clock phase, the only solution may be to resort to bit set and bit reset instructions to interface to the EEPROM rather than use of the serial interface provided on the microcontroller.
In the instance where there is a dedicated serial interface provided, the conflict typically occurs as follows. Figure 10 demonstrates an EEPROM READ as this involves data being transferred from the micro to the EEPROM (Start bit, opcode, and address) and data transferred from the EEPROM to the micro (address contents). The conflict occurs in this example when the micros clock sets data up on the falling edge of SK and expects the EEPROM to accept it on the rising edge, but then expects the EEPROM to do the same when it sends data back to the micro.

1. The micro sets up a data bit. A propagation delay after the falling edge the data bit is valid at the EEPROM DI pin.
2. The EEPROM uses the rising edge of SK to clock the data bit into its internal register.
3. When the data direction changes the EEPROM sets the data up starting at the rising edge of SK.
4. The micro attempts to clock the data bit in that was set up on clock edge 3.
This example will work if the micro requires 20 ns or less data hold time after edge 4 . If greater than 20 ns is required, an alternate strategy is needed.
1a. The micro sets up the data bit on the rising edge and a propagation delay later it is valid at the EEPROM.
2a. The EEPROM clocks the data into its internal register. The EEPROM requires only 10 ns data hold time, which can normally be guaranteed.

3a. The EEPROM sets the Data-Out up on the rising edge.
4a. The micro clocks the data into it's internal registers on the falling edge of the clock and a minimum data setup and hold time is guaranteed for the micro based on the minimum high and low time of the SK clock used in the application.
It should be noted that in the second example, CS (chip select) is asserted when SK is low. If this cannot be done, the DI input should be low when CS is asserted. If both DI and SK are high when CS is asserted the EEPROM will
recognize this as a rising edge of SK. To accommodate this in a design, it is allowable to clock in any number of logic zeros prior to the start bit.

### 4.0 Conclusion

The serial EEPROM offered by National all share a common structure. Separating them are various features that give benefit to various applications such as the need for a bi-directional data bus or need for one byte word width. There are a number of "tricks" that may simplify interfacing to these which can easily be understood with the help of a functional block diagram. Given this information the overall job of using a serial interface EEPROM will be simpler.


TL/D/11169-13


FIGURE 10

# Using the NM95C12 CMOS EEPROM with <br> Programmable Switches for Analog Applications 

## INTRODUCTION

National's NM95C12 EEPROM programmable switch occupies a unique niche in the switch marketplace. Consisting of a 1024-bit serial input EEPROM with 8 programmable switches, the output can provide either an analog switch or TTL compatible logic functions.
The combination of switch performance and the flexibility offered in the ability to software reconfigure the switching function makes the NM95C12 an excellent device for analog systems requiring switching or multiplexing. Often calibration sequences or multiplexing functions have either required using several IC's or manually shorting and opening printed circuit board connections, until the availability of the NM95C12.

However, the limited analog range of the NM95C12 makes it difficult to use for general analog functions. In order to capitalize on the full capabilities of programmable switches, it is important to understand the appropriate design techniques in level shifting, increasing the output drive capability, and increasing the output signal range. The focus of this application note is to summarize general circuits that perform this function, and thereafter provide a practical transducer measurement system example. The discussion will be solely devoted to extending the use of the NM95C12's switches function, and not on the actual software programming or operation of the IC.

## GENERAL DESCRIPTION

A detailed description of the overall operation of the NM95C12 can be found in AN-735, "Understanding National's NM95C12 EEPROM with Programmable Switches", or the NM95C12 data sheet. However, for the sake of completeness, the NM95C12 consists of a 61-word $\times 16$-bit EEPROM array, a 16 -bit Initial Switch Register, a 16 -bit Switch Configuration Register, a 16-bit Switch Readback Register, four identical blocks of switch logic, programming and power-up circuits and control logic. Essentially, the NM95C12 programmable switch can be easily configured, and reconfigured, for applications including both analog and digital switching functions. 60 internal addresses are available to reconfigure the switch settings on the fly. Upon pow-er-up the Initial Switch Register, address 61, provides a defined set-up state. This operational feature is extremely valuable since it provides an established initial condition for the system.

## SWITCH DETAILS

Each switch pair can be configured for either logic functions, or as an analog switch. Functional block details relating control of the switches to the input control logic can be found in Table I of the NM95C12 data sheet. Basically, the
logic switch configurations are at standard TTL levels. Also, the analog switch configurations can be looked at as standard MUX switches. Since this note specifically focuses on extending the operating voltage range of the analog switches, the emphasis will be on the analog switches. Figure 1 summarizes the salient operating features of the switch pairs.


TL/D/11188-1
Input Leakage $\pm 2.5 \mu \mathrm{~A}$ max
TTL Level Input/Output
Switch Functions


TL/D/11188-2
Ron $200 \Omega$ max
$R_{\text {OFF }} 10 \mathrm{M} \Omega$ min
$(+0.7) \geq V_{\text {OUT }} \geq\left(V_{C C}-0.7 \mathrm{~V}\right)$
FIGURE 1. The NM95C12 can be Programmed to Configure either Logic Function or an Analog Switch

## LEVEL SHIFTING AND EXTENDING THE SWITCHES RANGE

In considering level switching and enhancement of the voltage range for the NM95C12, it is logical to examine some simple level translations that can be solved with commercially available IC's. Examples of simple translation circuits includes the DS1630B Hex CMOS Compatible Buffer shown in Figure 2. Where simple translation of TTL output signals to higher levels of output voltage is required (such as CMOS compatible signals), used at the output of logic configured NM95C12 switch, the DS1630B represents a simple solution.


Equivalent Circuit
FIGURE 2. The DS1630B/DS3630B is a Hex CMOS Buffer Amplifler. It Features Low Power Consumption, and an Output Voltage that can go to $16 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{Cc}}\right)$.
An example of a voltage translation is the DS8800 Dual Voltage Level Translator which can be found in Figure 3. Custom control of output swing can be established over a 31 V range by setting V3, and V2 to the appropriate values. Additional information can be found in the DS8800 data sheet.


TL/D/11188-6
FIGURE 3. The DS8800 is a Dual Voltage Translator that Is useful for Programming MOS Type Memory, Establishing Blas Voltages, and Driving Transducers. Output Swing is Limited to 31V.
Figures 4 through 10 illustrate some useful translation circuits that use discrete components to achieve higher output drive than typical monolithic IC's. The circuit in Figure 4 is similar in functionality to the DS8800. However, wider output swings (limited to BVCeo of the output transistor), and larger sink/source current ability is achieved.


FIGURE 4. $-\mathbf{V}$ to $+\mathbf{V}$ Voltage Translation, from TTL Input Signal


TL/D/11188-8
FIGURE 5. A Simple $0 \rightarrow+V(+V$ Typically is $3 V \rightarrow+18 V)$ Level Translation Stage. ISOURCE $>$ ISINK $^{2}$

$I_{\text {SINK }}>\left.\right|_{\text {SOURCE }}$
TL/D/11188-9
FIGURE 6. High Output Current Sink Level Translation Stage-Excellent for Transducer Bridge Drive


TL/D/11188-10
FIGURE 7. A Simple OV $\rightarrow+V$ Switch, from TTL Input


FIGURE 8. OV to High Voltage Translation Circuit, from TTL Input


FIGURE 10. TTL Control of Power FET

## TWO PRACTICAL EXAMPLES

Bridge circuits play a dominant role in many measurement applications. Typically, providing a trimmed, calibrated output response is usually the goal of a bridge transducer signal processing system. Often this requires calibration, switching for it's operation, and adjustments for operating conditions related to available supply voltage. The NM95C12 provides a software reconfigurable analog system, where manual shorting and opening circuit board traces is not required for either altering the operation of the system, or performing calibration.
Figure 9 shows how the NM95C12 can be used to control a transducer measurement system. By shifting through the 61 -word sequence of the NM95C12 operation of the bridge-pulsing or exciting the bridge, sampling with the LF398, and strobing the A/D converter can be performed with the switches, which are configured in the TTL output mode.
Figure 10 illustrates the inherent flexibility in using the NM95C12 for controlling analog applications. One NM95C12 is used as a switch to directly control both the excitation voltage output level and enable to the bridge, provide TTL control signals for nulling the bridge-amplifier off-
set voltage, and strobe the LF398 sample/hold. Complete control of the transducer measurement system can now be controlled by the recontigurable memory contents of the NM95C12.
A stable LM185-2.5 reference is used to generate an accurate 2.5 V voltage. The $1 \mathrm{~K}, 0.001 \mu \mathrm{~F}, 20 \mathrm{~K}$ circuit provides a soft-start to the transducer bridge. This prevents potential damage to metal-foil type 350 bridge transducers. SW1 must be programmed to either enable or disable the bridge drive. A single-supply, low-power dual op-amp is used to drive Q1 which provides the appropriate bridge drive. Reliability is enhanced by including a 100 mA short circuit current limit.
The circuit is compatible with positive supply voltages extending from +5 V to +15 V . SW2 can be enabled to alter the output voltage range of the bridge drive. SW3 and SW4, in combination with the LF11333 can be programmed to provide a short to the instrumentation amplifier to null the amplifiers offset.
Since the output range of the NM95C12 switch is limited to a diode drop from the +5 V supply line, a LF13333 multiplexer is used to provide switching the bridge output voltage, which will probably exceed this limited voltage range.


TL/D/11188-14
FIGURE 11. Using the NM95C12 in the TTL Output Switch Mode to Control Transducer Bridge Operation


TL/D/11188-15
SWX are Internal Switches to the NM95C12
FIGURE 12. Transducer Measurement System


FIGURE 12. Transducer Measurement System (Continued)

## Using the NM95C12 in a Stand Alone Metering Device

## ABSTRACT

This application gives a detailed description of the use of the NM95C12 in electronic metering key applications where it is desirable to have a status display without having the key connected to any device. By using the NM95C12 such functionality can be obtained without using a microcontroller in the key. This can have significant cost, size and power impact.

## INTRODUCTION

Metering keys are becoming quite common now for use on copying machines in large corporations for departmental accounting purposes as well as in the flood of neighborhood copy centers and resource facilities shared by a number of businesses. The simplest implementation of such a device is a simple mechanical counter with an advance solenoidas each copy is made a pulse advances the counter. This approach suffers a number of drawbacks including low reliability, easy to tamper with, bulky and unable to itemize between different uses or equipment. These types of devices are no longer just used for copying machines-fax machine usage, word processor usage, plotters, and laser printers are now becoming part of the shared resources of a corporation or among a number of businesses as well as such services being incorporated into the neighborhood copy center. While the mechanical counter could still be used in such applications where the device under use could increment the counter at different rates depending on the type of usage, a different counter could be used for each service; generating an itemized receipt for the user becomes very cumbersome.
By using a non-volatile memory in the key device an itemized list can be kept of the services used. The value of the services used could also be tracked and the key terminated when a certain limit is reached. The key device could function like a debit card where the user gets a certain amount of credit stored in his card-when it is all used up he must go back for more at which point a cash register or other device with a printer and a receptacle for the key device would print an itemized list of usage and optionally erase the memory and store a new credit amount. The disadvantage of this approach when compared to the mechanical counter is the lack of an indication of the remaining credit or usage to the user. One way to solve this problem is to include a display on the device being used to display the current credit information. This has the disadvantage that the user must have the key device plugged into a service device to find his credit status. Another approach is to include a microcontroller in the key device along with a display, a battery and a switch to activate the display. If the battery fails, information in the key is lost. By using serial E2PROM memory devices such as the NM9306, NM93Cxx or NM93CSxx families solves the information retention problem when the battery fails, but we still need the microcontroller if the key device is to have an active display without connection to another device.

Enter the NM95C12 serial E2PROM with eight programmable outputs which are set to their stored values on power up. This device is not only non-volatile, but is small, inexpensive, simple to use and does not require a microcontroller in the key device.

## THE NM95C12

The NM95C12 is a 1024 -bit, CMOS E2PROM with 8 programmable outputs. The 1024 bits of memory are divided into 60 registers of 16 bits each and each register can be individually accessed. Registers 61-63 are dedicated to storing the programmable output settings. Each output may be programmed to provide either a HIGH or a LOW output level or these outputs may also be programmed to form four individual pairs of SPST switches. In this application we will only be programming these pins as HIGH or LOW outputs but there are many other applications where a SPST switch or switches would be useful.
Other features of the NM95C12 include a very low operating current (less than 4 mA ), software write protection, self timed write cycle (erase cycles not necessary) with an endurance of over 40,000 writes per register and at least 10 year data retention.
Interfacing to the NM95C12 is done through the on-board MICROWIRETM port; this port consists of four signal lines: a serial clock (SK), serial data input (SI), serial data output (SO), and chip select (CS). MICROWIRE is supported in hardware in the COP400, COP800 and HPCTM microcontroller families. MICROWIRE can also be easily implemented on most microncontrollers and microprocessors in software. The TP3064 and TP3065 implement a MICROWIRE hardware interface to various standard microprocessors.

## DISPLAY INTERFACE

'The NM95C12 has 8 programmable outputs. The switch configuration register (SCR) controls these outputs in pairs, four bits per pair. Table I shows the different switch configurations possible for each pair. In this application we are only interested in modes 0,1,2 and 3. Because the NM95C12 has a much greater current sinking capability than sourcing we will configure our LED displays with their cathodes to the output port. A LOW output results in a lit LED. Figure 1 shows a bar graph display being driven by the NM95C12. A single resistor SIP can be used to limit the current to the LEDs. The configuration register looks like Figure 2 with a, b, c . . . h representing the LED segments. To light a particular segment the appropriate bit in the SCR register must be set to 0 . This register is set to the contents of the word stored in the E2PROM's location 61 at power-up. The SCR register itself is located at address 62 and can be written to directly without affecting the E2PROM location 61 and the new contents of the SCR register will be lost on powerdown. At the next power-up the contents of location 61 will again be stored in the SCR.


TL/D/11189-1
FIGURE 1


FIGURE 2. SCR Configured to Drive Bar Graph (a $\mathbf{0}$ in $\mathrm{a}, \mathrm{b} \ldots \mathrm{h}$ turns on appropriate segment)

The circuit in Figure 1 uses some tricks to maximize the battery life. The LM2936 (low dropout; ultra-low quiescent current 5 V regulator) was used to regulate the battery voltage down to 5 V for the NM95C12. By bypassing the regulator for the $+V$ connection to the resistor SIP the current through the regulator only feeds the NM95C12 which in its quiescent state (with all inputs at CMOS logic levels) is $<50 \mu \mathrm{~A}$ the dropout voltage of the LM2936 is $<0.1 \mathrm{~V}$. To have the LEDs operate correctly it is important to keep
the battery voltage under 8 V to 9 V otherwise the LEDs which should be off will get turned on through the protection diodes (see modes 12 and 13 of Table I) not to mention the increase in current discharging the battery. Another approach would be to power the LEDs from the regulated +5 V . Now the thing to watch out for is the current limit of the LM2936; exceeding 65 mA could force the regulator to go into current limit.

TABLE I. Switch Configurations

| MODE* | z | $Y$ | x | W | SWITCH CONFIGURATION | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | $\underset{\sim}{\sim}$ | $A=0, B=0$ |
| 1 | 0 | 0 | 0 | 1 | $\xrightarrow[=]{\square}$ | $A=0, B=1$ |
| 2 | 0 | 0 | 1 | 0 |  | $A=1, B=0$ |
| 3 | 0 | 0 | 1 | 1 | $\text { }^{V_{c c}} \sim \longrightarrow \text { - }$ | $A=1, B=1$ |
| 4 | 0 | 1 | 0 | 0 | $\stackrel{\Gamma}{\square}$ | $\mathrm{A}=0, \mathrm{~B}=$ TRI-STATE |
| 5 | 0 | 1 | 0 | 1 |  | $\mathrm{A}=\mathrm{B}$ |
| 6 | 0 | 1 | 1 | 0 | $\square \longrightarrow_{-}$ | $A=\bar{B}$ |
| 7 | 0 | 1 | 1 | 1 | $\xrightarrow{+V_{C C}}$ | $\mathrm{A}=1, \mathrm{~B}=$ TRI-STATE |
| 8 | 1 | 0 | 0 | 0 | $\begin{aligned} & \mathrm{O} \\ & =1 \end{aligned}$ | $A=T R L-S T A T E, ~ B=0$ |
| 9 | 1 | 0 | 0 | 1 |  | $\mathrm{B}=\mathrm{A}$ |
| 10 | 1 | 0 | 1 | 0 | $\square O B$ | $B=\bar{A}$ |
| 11 | 1 | 0 | 1 | 1 |  | $A=T R 1-S T A T E, B=1$ |
| 12 | 1 | 1 | 0 | x |  | Analog Switch Open |
| 13 | 1 | 1 | 1 | x |  | Analog Switch Closed |

*Modes 0 thru 11 are logic level functions. Modes 12 and 13 are Analog switch functions.

All the circuits in this application note use very low current Hewlett Packard displays (they are specified for operation at 1 mA per segment) to maximize battery life. Other displays at higher currents can be used but care must be exercised not to exceed the current capabilities of the LM2936 as well as the power dissipation capabilities of the NM95C12 especially if the surface mount package is used at higher temperatures. Another side effect of higher currents in the LEDs is the $\mathrm{V}_{\mathrm{OL}}$ specification is 0.4 V at an $\mathrm{I}_{\mathrm{OL}}$ of 2.1 mA but will rise with higher lols (typically stays well under 1 V at 10 mA ).
Instead of using a bar graph individual LEDs could be used in much the same manner. The length of bar graph lit or number of LEDs lit would show the amount of credit remaining. Another approach would be to use a 7 segment display. Figure 3 shows such a circuit. The button is pressed when the user wishes to see the display. There is a diode bypass of the push button switch so the display is active while the key is plugged into the device under use. The user can monitor his remaining credit while operating the device. The battery is being charged whenever the key is plugged into a device. If the battery should ever go too low to operate, the user just plugs the key into a device for a while to re-
charge-the contents of the E2PROM are not lost. The rechargeable battery could be replaced with a 9 V transistor battery (typical voltage on these is 7 V to 8 V ) which will give operating life of multiple months if checked only intermittently. No data would be lost during battery changes. Figure 3 shows how the key would be configured using the transistor battery. Table li shows the bit combinations for the SCR register to generate the digits 0 to 9 . Notice with the 7 segment display we no longer can use a resistor SIP because segment LEDs are all tied to a common cathode. Resistors in this configuration are available in DIPs as well as SOIC.
Applications desiring two digits (credit can now be displayed as percent remaining) can be implemented with two MM74HC4511 display decoder/drivers as shown in Figure 4. The MM74HC4511s have a quiescent current of $<80 \mu \mathrm{~A}$ maximizing battery life and are available both in DIP as well as SOIC packages. The MM74HC4511 has a maximum supply voltage of 6 V so it should be operated from +5 V regulated supply as shown in Figure 5. Table III shows how the BCD (binary coded decimal) data is configured in the SCR register to display the two digits.


TL/D/11189-2
FIGURE 3


TL/D/11189-4
FIGURE 4


If there is a need to display the number 100 as well, this can be accomplished with the addition of just one quad NOR gate as shown in Figure 6. Here we get a little tricky. By adding some gating to the two most significant bits of the most significant digit a coding can be worked out that gives a zero code to the most significant digit driver at the same time as driving through another gate the hundreds digit. Figure 7 shows the logic along with a table of the states. If the 2 most significant bits of the most significant digit are inverted before going to the SCR register the right numbers will be displayed. To display 100 the SRC is loaded with all zeros. Table IV shows some example numbers.'

## MODULE INTERFACE

The metering device or key must connect to the service device through some type of connector. The simplest approach is to bring out the MICROWIRE port through a connector to a processor or microcontroller in the service device. The MICROWIRE port consists of four signal lines; a serial clock (SK), serial data input (SI), serial data output (SO), and the chip select (CS). When CS is LOW the chip is powered down into standby mode (outputs A1 through A4 and outputs B1 through B4 are still driven even while in standby) and accesses on the MICROWIRE port are dis-
abled. So while the metering device is unplugged from the service device we want this signal low, therefor this signal has a pull down resistor. To begin an access to the NM95C12 the CS is first set high by the service device then a high start bit is on DI and clocked into the NM95C12 by a low to high transition on SK (see Figure 8) the start bit is then followed by opcode and address (see Table V) with SK low to high transitions for each bit. In the case of a read instruction, subsequent toggling of the SK line causes the addressed data to be shifted out on DO. Data should not be sampled on DO on the low to high transition of SK as this is when the bit is shifted out. On write operations they must be preceded by the write enable instruction (WEN). In the write instruction (WRITE) the data follows right after the address. (see Figure 9).
The MICROWIRE interface is supported in hardware on the COP400, COP800 and HPC microcontroller families. MICROWIRE can also be easily implemented on most microcontrollers and processors in software. Application Note AN-507 "Using the NMC93CSxx family" covers the details of how to communicate with these types of serial memory devices from various microcontrollers. The TP3464 and TP3465 implement a MICROWIRE hardware interface to various standard microprocessors.


TL/D/11189-7
FIGURE 6

If there is a need to minimize the number of contacts in the connector from the metering device to the service device, Application Note AN-423 "The NMC9346-An Amazing Device" gives the details to implementing power and MICROWIRE signals over just two connections.

## CONCLUSION

This application note describes a number of approaches to metering devices from the very simple to the complex. If more E2PROM is required it is available in the NM93Cxx family in 8 -pin DIPs and SOIC in various sizes. With the features of very low power, small size, and low cost as well as the simplicity of interface to most processors and controllers already part of the panel interface of most server devices, the implementation of this type of product is very easy.


FIGURE 7

TABLE IV



TL/D/11189-13

TABLE V. NMC95C12 Instructions

| Instruction | SB | Op Code | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :---: | :--- |
| READ | 1 | 10 | A5-A0 |  | Reads data stored in memory, starting at specified address |
| WEN | 1 | 00 | $11 X X X X$ |  | Write enable must precede all programming modes |
| WRITE | 1 | 01 | A5-A0 | D15-D0 | Writes register |
| WRALL | 1 | 00 | $01 X X X X$ | D15-D0 | Writes all registers |
| WDS | 1 | 00 | $00 X X X X$ |  | Disables all programming instructions |



Instruction Sequence


FIGURE 9

# NM95C12 Memory Mapping Solution for PC ${ }^{\circledR}$ Applications 

## INTRODUCTION

The design of an adapter card for a PC requires some knowledge of the different mechanisms used by the PC to access or exchange data with the adapter card.
The complexity of the mechanism used depends upon the level of functionality one wishes to implement on his design. At the low-end, the PC will access the adapter card as a simple I/O location, where for the more sophisticated cards, a BIOS will be incorporated onto the adapter card which may also use memory, I/O, interrupts and DMA channels from the PC .
This note discusses how to use the NM95C12 as a low cost solution for the implementation of high-end features on a general purpose adapter card for a PC.

### 1.0 OVERVIEW OF THE PC AND THE ADAPTER CARDS

In order to fully understand the possibilities offered by using an NM95C12 at the interface level between the PC and its adapter card, let's review the characteristics of that interface.
1.1 The PC has a certain amount of memory available for adapter cards. Both the location and space occupied by this memory vary depending on the type of PC (XT, AT). The XT reserves memory locations for 8 -bit data transfers onto the adapter cards. The AT reserves the same locations for 8 -bit data transfers but also reserves additional space for 16 -bit data transfers.
1.2 The same mechanism applies to the I/O locations on the PC that are reserved for accesses onto an adapter card. A certain amount of I/O addresses will allow the PC to perform 8-bit data transfers with the adapter card on an XT system and some more locations will additionally be made available for 16-bit data transfers with the adapter card on an AT system.
1.3 Any adapter card you install into a PC is allowed to request interrupt service from the main PC card. An XT system offers the adapter card 6 interrupt lines where an AT system offers an additional 5 lines. (Not all of these lines are directly available for the adapter cards since some of them will be used by other cards on the PC.)
1.4 Finally, some DMA channels on the PC main board can be used by the adapter card through proper handling of DMA REQUEST and DMA ACKNOWLEDGE lines available on the PC connector. As for the other mechanisms, 8 -bit DMA data transfers are allowed on an XT system where both 8 - and 16 -bit DMA data transfers are allowed on an AT-based system.

### 2.0 POSITIONING THE ADAPTER CARD

Any designer which intends to use one or more of the data transfer paths described above is aware that his card will have to carry the ability to be mapped into the available areas on the system, since other cards already installed into the PC probably make use of a part of the space reserved for the adapter cards.

National Semiconductor Application Note 767 Christian Plourde

2.1 If the adapter card contains memory accessible from the PC main board, up to two different levels of mapping may take place depending on the size of the memory. For a small memory size (let's say 8 K or less), the entire area will be linearly accessible from the PC but its location will have to be mappable at different places into the range reserved for the adapter cards, thus ensuring that it will not interfere with any other cards using parts of this range. For larger memory, a second level of mapping is required, partitioning the memory into software selectable windows of $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$, etc. which location will still be mappable into available areas as described above (see Figure 1).
2.2 The same procedure applies to I/O locations on the adapter card. Any peripheral address has to have the possibility to be accessed at different selectable locations into the I/O address range reserved for adapter cards, thus ensuring that there won't be any address conflict with peripherals from other cards already installed into the system.
2.3 If the adapter card has the ability to request interrupt service from the PC main board, it also has to have the possibility to select the interrupt line it will use among those not being used by other adapter cards.
2.4 Finally, as for the interrupt lines, an adapter card using DMA channels must be able to select channels not used by other adapter cards.

### 3.0 TWO ISSUES: POSITIONING AND INITIALIZING

The most widely used way of implementing all of the above options is to install jumpers on the adapter card which setting will allow the end user to position its card into the available areas (see Figure 2). Even though this method has some disadvantages, like the fact that the user has to open the PC and remove the adapter card each time he has to modify the setting and the fact that a description of the settings allowed has to be carried along with the adapter card, it remains one of the cheaper and most easy to implement methods of positioning an adapter card into a PC.
Let's now consider some other interesting features that could be implemented on an adapter card. Once the application software is loaded from a diskette usually provided with the card, it may be possible to initialize and then to configure the card. For example, if the card is a data communication product, its on-board peripherals first have to be properly initialized and then the overall configuration of the link has to be defined (the parity and stop bits, the baud rate and such parameters as flow control, echoing, DCE or DTE arrangement, split clocking, etc. for either asynchronous or synchronous data transmission). Once all these parameters have been defined, the card should be operational as long as the power feeds the system.
An interesting step further in functionality would then be the implementation of some non-volatile data storage area on board into which the actual initialization and configuration of the adapter would be stored and referred to at any subsequent call of the application software following a power-up.

(1) FIRST LEVEL: an 8 K window has to be positioned into one of the two avallable areas in the PC memory map.
(2) SECOND LEVEL: 8 different pages of 8 K can be software selected to appear in the window.
PC memory map
FIGURE 1. Partitioning of 64K of Memory through an 8 k Window Positioned into One of Two Available Areas in the PC Memory Map

If a BIOS is installed on the adapter card, the user could even be prompted to verify and modify (if required) the configuration of the card right away at power-up, since the BIOS signatures are scanned and given control after the usual diagnostics executions, graphic card, floppy and hard-disk recognition.

### 4.0 USE OF AN NM95C12 ADDS POWERFUL FEATURES TO YOUR ADAPTER CARD

The proposed application is to provide the PC with the possibility to access an NM95C12 located on the adapter card. The BIOS on the adapter card would instruct the PC to verify the status of a configuration flag stored in the NM95C12. If the status indicates that the card hasn't been initialized and configured yet, the user will be requested to accomplish these tasks prior to any further operation of the adapter card. Once the initialization has been properly loaded and saved, the BIOS, at any subsequent power-up, will simply instruct the user of the current configuration and ask if any modification is required.
The initialization portion of the card would make use of both the non-volatile memory and the dip switch's replacement features on the NM95C12. The positioning of the memory, the selection of the I/O addresses range and the interrupt lines or DMA channels (if required) would be set using the dip switch's replacement according to the user selection at first initialization. The other bytes or words used to initialize the peripherals on the adapter card would be stored in the NM95C12. All the configuration parameters related to the software operation of the card would also be saved into the NM95C12.

It is understood that such a solution does not eliminate all the jumpers or dip switches' on the adapter card. The location of the BIOS implemented on the card and the I/O address used to access the NM95C12 both have to be determined and set prior to the installation of the card into the PC. There is no easy way, if any, to work around such restrictions.
The circuit on Figure 3 shows a simple way to implement an interface to the PC that will allow the user to position an 8 K window of memory into one of eight possible locations in the adapter card's reserved area. He will have the possibility to select one of eight possible ranges of addresses for the I/O address of the peripherals on board and he will also be able to select one of four interrupt lines available on the PC connector. The memory on the adapter card consists of 32 K of RAM divided into four pages of 8 K . The selection of the page is performed through a write operation of 2 bits in a register whose I/O location has been determined by the setting of the NM95C12.
At power-up, before the system has been initialized, the PC must have the possibility to access at least the BIOS on the adapter card (ROM BIOS on Figure 3). LK1 on Figure 3 allows eight different locations for that BIOS in the PC memory range reserved for that purpose. Since that BIOS will verify the configuration byte or word into the NM95C12, the I/O addresses of the circuit that accesses the NM95C12 also have to be selected prior to the installation of the adapter card into the PC. This is done via LK2 on Figure 3. The circuit that allows the accesses to the NMC9512 is very simple. A sequence of writes to a latch (Itch A on Figure 3)


FIGURE 2. Using Jumpers (or Dip Switches) to Position Both Memory and I/O Addresses on an Adapter Card
enables CS on the NM95C12, presents the data to be written to pin DI and latches this data into the NM95C12 by toggling the pin SK. The same principle applies to the read operation except that the bit output at pin DO of the NM95C12 is sent to the PC via a buffer (buff A on Figure 3). The clock of latch $A$, the enable of buff $A$ and the select and output enable of the ROM BIOS are all controlled by control A on Figure 3 which may be a GAL.
The user is then allowed to position and configure its card. On the example of Figure 3, three lines of the NM95C12 are
connected to the memory decoder. The status of these lines will position a window of 8 K of RAM into one of eight possible locations in the PC memory area reserved for adapter cards. Three other lines of the NM95C12, connected to control B on Figure 3, will allow the same possibility for the I/O address of the peripherals on the adapter card. One of these peripherals is latch B into which the PC is now allowed to write two bits whose value will select one of the four pages of RAM to appear on the 8 K window positioned by the first three lines of the NM95C12.

Finally, the two remaining lines of the NM95C12 are connected to the interrupt encoder on Figure 3, thus allowing the user to determine which interrupt line, out of four possible lines, he will select for his application.
Additional precautions should be added by the designer to ensure that a non-initialized card will not interfere with existing cards already plugged into the PC. A latch which status at power-up disables the interrupt encoder, the I/O and memory decoders, for example, could be reset by the PC
once the proper configuration has been loaded or confirmed by the BIOS.

## CONCLUSION

The implementation of similar features on a PC adapter card without the use of a NM95C12 would still require an EEP-ROM-like type of device in addition to some non-volatile latch mechanism. For such an application, the NM95C12 represents a simpler, cost-effective solution.


FIGURE 3. A Powerful Use of the NM95C12 for a PC Interface

## Integrated Manufacturing Control-NM95C12

## INTRODUCTION

Manufacturing methods and testing techniques have become increasingly automated over the past few years. Of current interest are techniques which allow automated access to manufacturing information which, in turn, is used to tailor test and set up for individual manufactured assemblies. This note explores the application of the latest generation of memory devices to manufacturing control situations and integrating access schemes for test, in system programming and manufacturing control.

## WHAT INFORMATION?

The first question raised in manufacturing control applications is what information needs to be accessable. In most cases information like serial number, date of manufacture, and revision number need to be written once during initial manufacture. Ideally, this information should be secure (i.e., read only). As a product passes through test additional data may be recorded such as calibration constants or configuration data. If an assembly should fail, the type of failure and number of recurrences may be recorded at the repair depot to determine, for example, if this assembly should be scrapped.
All of this data does not require a large memory device. National Semiconductor's family of serial access E2PROMs are ideal candidates because of low cost, small footprint and ease of access.

## SECURITY

The issue of data security is addressed by the 93CSXX family of devices. In these units a portion (or all) of the memory area may be set up to appear as ROM (once desired data has been loaded into the device). The amount of ROM vs PROM is determined by a value in the protection register which delimits the portion of the device that is write protected. For details refer to AN-507 - Using the 93CSXX MICROWIRETM family.

National Semiconductor Application Note 789 Jan Ladiges

Some of the synchronous bus devices (24CXX ${ }^{2} \mathrm{C}$ family) have write protection of the upper half of the memory space by bringing a control line (WP) high.

## ACCESS

In the most basic form of automated manufacturing control, an E2PROM is simply added to a circuit assembly as an isolated block. There may be no electrical connection between the memory and any portion of the circuit assembly. A means of accessing the pins of the memory device must be considered. This may involve adding extra contacts to a card edge, creating a separate pin-type connector area or simply providing BON (Bed Of Nails) access. The latter may prove impractical with the increased use of surface mount. A more promising and efficient use of board resource can be realized if the memory device shares I/O pins and power supply with the host assembly. The number of access points required for varying applications schemes ranges from 2 (for synchbus with no security) to 5 (for microwire with full security).
To take maximum advantage of the E2PROM it is often desirable to allow access both externally (like the isolated case) and internally by the system resident on the circuit assembly.
An example of shared functionality is given in Figure 1 which allows the resident system to flag a fault condition. The unique feature of this is the fault flag will be valid even if system power is cycled on and off or the board removed from the system. The visible flag (an LED) allows a technician to quickly identify a problem board. Additional information (i.e., a fault code) can be written into the E2PROM as well. The module, when returned for repair, contains all the traditional manufacturing information as well as the fault code.


TL/D/11262-1
FIGURE 1. Shared Access with Non-Volatile Fault Flag

## INTEGRATION WITH OTHER FUNCTIONS

The trend towards more electronics in smaller packages has led to the acceptance of surface mount technology. Traditional test access methods (BON) has become impractical at present density levels and virtually impossible when SMD's are mounted on both sides of the board.
To facilitate surface mount board testing, electronic rather than mechanical techniques have evolved. The solution often consists of boundary scan and some form of built in self test (BIST).
JTAG (Joint Test Action Group), sponsored by the IEEE P1149-1 Working Group, has defined a boundary scan standard which has become widely endorsed. This JTAG standard specifies that each conforming IC have a Test Access Port (TAP) which allows devices to be connected in series and minimizes interconnect overhead (Figure 2). The boundary scan register (double buffered) gives access to
the device pins for testing. The rest of the structure provides an instruction decode, a bypass function and any product specific requirements through additional registers (shown in dashed lines).
Surveying current programmable logic trends, GAL type devices are extremely popular to replace small blocks of random logic. One disadvantage is that traditionally each different "pattern" would have to be programmed, tested and identified prior to being installed on the assembly. With SMT versions of these devices, handling alone poses a significant inconvenience.
The concept of programming devices after they have been installed (ISP - In System Programming) is beginning to attract interest.
What do these test and ISP techniques have in common with manufacturing control? - serial board access.


FIGURE 2. JTAG Test Access Port

Let's consider a typical high density PCB assembly (Figure 3). This assembly requires boundary scan testing, uses ISP GALS and implements a serial E2PROM for manufacturing control data.
All 3 functions require a serial access scheme. If each is considered independently, a considerable number of pins would have to be dedicated to these functions (at least 12 connection points). One common bus and a common protocol to access management information, provide test access, and perform incircuit PLD programming would be ideal.

## AN EXAMPLE COMMON ACCESS SYSTEM

The circuit of Figure 3 uses a COP 822 microcontroller to create a JTAG to MICROWIRE converter with added sup-
port for an ISP PLD loop and an E2PROM with security for manufacturing control. The combined test, manufacturing data and PLD programming requires only 5 access pins.
Because JTAG test access often requires high speed, this system has been broken down as two JTAG loops (hence two TMS pins), one high speed dedicted to the test loop and a slower speed loop dedicated to E2PROM and PLD access through the COP 822. The speed of this JTAG loop is limited by COP processing speed in translation to MICROWIRE.
This approach represents a solution for common access using devices available today. As standards take hold (like JTAG) then non-volatile memories and ISP PLD's may appear supporting a standard serial protocol and further reducing the overheads in a common access scheme.


FIGURE 3. Common JTAG Access for Test, ISP, and Manufacturing Control

## NM95C12 EEPROM Controls Amplifier Gain

## BACKGROUND

Electrically Erasable PROM or EEPROM finds wide application in analog data acquisition. When using sensors, some possibilities include storing calibration constants (gain, nonlinearities, temperature effects and offset), the engineering units of measurements, and even keeping serial numbers. In Figure 1 for example, after an A/D converter converts the analog sensor output, the processor can use correction factors from the EEPROM to get a final value. By keeping these corrections with the sensor assembly, one can effectively get a more accurate sensor.
There are several ways to achieve a wide input range when required. One way is to use an A/D with more bits than needed and then use the extra bits for ranging. In other words, if 8 bits are needed for the output by using a 10 -bit converter a full scale resolution of 8 bits is still provided even if the input range is only $1 / 4$ of the converter range. This can get expensive quickly since the price of accurate A/Ds goes up substantially with the number of bits! Even so, with advances in audio parts of 16 to 18 bits, this could be viable in some instances.
A more common way to cover wide range inputs is to scale the incoming levels to close to the maximum rated input range of the A/D. If the input range is $0 \rightarrow 0.2 \mathrm{~V}$ and the

National Semiconductor Application Note 790
Harry W. Lewis

converter is rated $0 \rightarrow 5 \mathrm{~V}$, a gain of 25 in front of the $A / D$ will give the full resolution over the reduced range. Additionally, the input range can be offset from zero. While many A/Ds have range and offset options, there are limits if the accuracy is to be kept. A circuit to use both scaling and offset is Figure 2. The gain and offset are mostly determined by the reference and the resistor ratios.

$$
\begin{aligned}
V(A / D)=V_{I N} & (1+R 3 *(R 1+R 2) /(R 1 * R 2)) \\
& -V_{R E F} * R 3 / R 1
\end{aligned}
$$

Common metal film resistors are widely sourced and have good temperature coefficients. Type RN55 T-2 are rated at $\pm 50 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$. The difficulty comes with their resistance specification of $\pm 1 \%$. Since most gain stages require at least 2 resistors to determine gain, the system accuracy is already reduced to, at best, $2 \%$. Multiple stages and other error sources compound the problem. Some 10-bit serial A/Ds have $0.1 \%$ accuracy! Even the lowly 8 -bit converter can be $1 / 2 \%$. For the circuit in Figure 2, EEPROM is a very handy way to store the calibration of the low cost resistors to get more of the full accuracy capability of the A/D. Even when not using a sensor, EEPROM can be useful for calibrating a scaling and offset circuit. This is especially true now that low cost A/D converters have gotten so accurate.


$V_{\text {OUT }}=V_{A I D}=V_{I N}\left(1+\frac{R 3(R 1+R 2)}{(R 1 * R 2)}\right)-\frac{R 3}{R 1} V_{\text {REF }}$
$=12.5^{*} V_{\mathbb{I N}}-2.5 \mathrm{~V}$

## FIGURE 2. Scaling and Offset CIrcuit

## DON'T BE A DIP

For storing data, EEPROM can generally beat DIP switches. However, there were some other things that DIP switches could do better. One case was having external access to logic levels without needing an additional port chip. Another area was switching analog voltages. To replace an analog DIP switch, a designer often had to add an output port and a separate CMOS or other switch to do the actual switching. The NMC95C12 1024-bit CMOS EEPROM with DIP switches attacks both these areas. When first glancing at the data sheet, the title "EEPROM with DIP switches" can conjure up visions of the data being stored in 1024 tiny levers on top of the package! Of course that is not the case, see Figure 3 for the real block diagram. Actually the part has 61 words of 16 bits of EEPROM for general use. That totals 976 bits. The DIP switches referenced in the title are 8 pins with switch logic to allow several different modes of operation as controlled by the switch configuration register. There is a nonvolatile Initial Switch Setting Register of 16 bits. And, finally, a Switch Readback Register allows the pins to be used as a digital input port. Processor interface is by a serial MICROWIRETM port.

## THE BIG SWITCH

Switches are the main difference between the NM95C12 and other EEPROMs. They can be thought of as four independent switches each having two pins, A and B. Each switch has four control bits labeled $\mathrm{W}, \mathrm{X}, \mathrm{Y}$ and Z to set it to one of its 14 modes. Table I shows all the modes. The Switch Configuration Register (SCR Figure 4) is 16 bits long to hold all four bits of each of the four switches. It is not made from EEPROM cells so it can be written faster and there is no wearout mechanism. Being volatile, the SCR is reloaded at each powerup from the EEPROM Initial Switch Setting Register.

## WHERE DID THE PARALLEL PORT COME FROM?

Switch modes $0-3$ allow the 2 pins to be digital outputs. When bits $Y$ and $Z$ are set to $0, A=X$ and $B=W$. Other modes allow $A$ and/or $B$ to be TRI-STATE ${ }^{\circledR}$ for use as digital inputs or I/O. Figure 5 shows the switches being used for
general input and output, to set gain controls, and to drive analog multiplexers. In Figure 5, the port of U4 selects the input channel of the A/D via the multiplexer U3. Input channel 7 has a selectable gain preamplifier (U1) whose gain is controlled by U2 selecting the proper feedback tap. The resistor values for R1, R2, R3 and R4 are standard 1\% values. Ideally the values would be $48 \mathrm{~K}, 12 \mathrm{~K}, 3 \mathrm{~K}$ and 1 K . Although they are not quite correct for the gains desired, calibration values stored in the EEPROM can correct for this while fixing the other errors. One thing to keep in mind when selecting the standard values, make sure the A/D stays in its active range during the whole range of expected signal input. If the A/D needed to exceed the maximum count, the error generated is not correctable. This implies making the gains on the low side.

## MODES 12 AND 13?

Mode 12 is an open ( $10+\mathrm{M} \Omega$ ) between pins $A$ and $B$. Mode 13 is an ANALOG short ( $200 \Omega$ or less) between the same pins. In Figure 6, analog switches give variable gains and do analog multiplexing. Switches 1 and 2 select the input to the A/D. Switches 3 and 4 control gain. Although the pins used for a closed analog switch can not be read as an input, the input function of the Switch Readback Register will still work for the other pins, so mixed analog and digital operation is possible. Of course, errors in the amplifier gains will be corrected by storing calibration constants in the EEPROM section of the part.

## FINALLY!

The NM95C12 can accomplish what a DIP switch used to do without the extra parts. You have external access to logic levels and you can even switch analog voltages. All without needing additional port or multiplexer chips.

Table I. Switch Configurations

| MODE* | Z | $Y$ | X | W | SWITCH CONFIGURATION | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | $\underset{\sim}{\sim}$ | $A=0, B=0$ |
| 1 | 0 | 0 | 0 | 1 | $\underset{\sim}{\perp}$ | $A=0, B=1$ |
| 2 | 0 | 0 | 1 | 0 |  | $A=1, B=0$ |
| 3 | 0 | 0 | 1 | 1 |  | $A=1, B=1$ |
| 4 | 0 | 1 | 0 | 0 | $\frac{1}{2}-\infty$ | $A=0, B=T R I-S T A T E ~$ |
| 5 | 0 | 1 | 0 | 1 |  | $A=B$ |
| 6 | 0 | 1 | 1 | 0 | $\longrightarrow \text { - }$ | $A=\bar{B}$ |
| 7 | 0 | 1 | 1 | 1 | $\xrightarrow{\mathrm{P}^{\mathrm{V} C \mathrm{C}}}$ | $A=1, B=T R 1-S T A T E$ |
| 8 | 1 | 0 | 0 | 0 | $\stackrel{\square}{\square}$ | $A=T R 1-S T A T E, B=0$ |
| 9 | 1 | 0 | 0 | 1 |  | $\mathrm{B}=\mathrm{A}$ |
| 10 | 1 | 0 | 1 | 0 | $\square \mathrm{DO}^{-\infty}$ | $\mathrm{B}=\overline{\mathrm{A}}$ |
| 11 | 1 | 0 | 1 | 1 | ${ }^{\mathrm{V}_{C C}} \sim \text { OB }$ | $A=T R 1-S T A T E, ~ B=1$ |
| 12 | 1 | 1 | 0 | $x$ |  | Analog Switch Open |
| 13 | 1 | 1 | 1 | X |  | Analog Switch Closed |

*Modes 0 thru 11 are logic level functions. Modes 12 and 13 are Analog switch functions.


TL/D/11263-4
FIGURE 3. Block Diagram


FIGURE 4. Switch Configuration Register (SCR)



# Stand Alone Control of MICROWIRETM Peripherals Using the NMC87C257 

## INTENT

This note describes the implementation and use of a standard memory element in the realization of state machine control for the purpose of generating serial data. The applications shown here employ serial data streams to control and program peripheral devices which would otherwise require CPU support for use.
The benefit to the user of the demonstrated techniques is the low cost, low effort, implementation of tasks normally allocated to more sophisticated and more engineering intensive methods. These solutions expand the range of systems and applications in which a variety of National Semiconductor's MICROWIRE devices may be used.

## MICROWIRE

The MICROWIRE standard is an interface technique first developed at National in the 1970's in an effort to reduce the component pin count (and hence package size and cost) required for the interfacing of microcontrollers to peripheral components. Over the ensuing years a wide variety of devices employing this interface technique have been introduced to the market. They include display drivers, analog to digital converters, phase lock loop frequency synthesizers, memories and complex analog devices. A full list of all but the most recent devices using the MICROWIRE interface can be found in the Master Selection Guide.
A MICROWIRE connection is a straight forward serial hookup consisting of data and clock. Generally, input and output data are presented on separate lines. The clock to data relationship resembles that of a TTL or CMOS 7400 series shift register with the positive edge of the clock performing the active transfer of data into and out of the device. Care must be taken to examine the data sheet for a device under consideration as there may be deviations from this general description. A more complete description of this interface method is available in National Semiconductor Application Note 452 by Abdul Aleaf.

## STATE SEQUENCERS

State machines or sequencers in their simplest form consist of a current state memory element and a next state determination network. Upon a clock edge the next state information is converted and held as a new current state while a

National Semiconductor
Application Note 791
Charlie Mitchell

fresh next state logical determination takes place. One way of implementing this state sequencer is by utilizing a register or latch as the memory element and a Read Only Memory to supply the logic function for the next state. Because a ROM is a "rectangular" or complete logic array (i.e., for every input combination there exists a unique output), this next state logic is a lookup table.

## THE NMC87C257 UV ERASABLE CMOS PROM WITH LATCHES

The NMC87C257 is a device first conceived to reduce the chip count in microprocessor systems which had a multiplexed address/data bus. As such, the latches required to capture the address while return data occupied the bus were put on board the device. Intended for this microprocessor application, the NMC87C257 does not have the speed of some of the bipolar "logic" PROMs (nor the power dissipation), but it's large memory array would be exceedingly expensive in a bipolar device. The $32 \mathrm{k} \times 8$ memory means that in a state machine application fifteen inputs can define over 32,000 states, represented in eight output pins.

## GENERATING A SERIAL OUTPUT WORD FROM THE NMC87C257 BASED STATE MACHINE

Figure 1 depicts a state machine capable of generating 128 different 128 -bit serial data streams. DIP switches $0-7$ select the specific data stream program. Seven bits of output data are fed back to inputs to define the next state in the serial data sequence. Bit 08 is the serial data output. A CMOS oscillator generates the clock. It is important to note that the clock drives both the ALE (Address Latch Enable) and $\overline{O E}$ (Output Enable) inputs. ALE is the signal which activates the "open" state of the input latch, as such, unlike an edge triggered register, the outputs follow the inputs until its (ALE's) fall. To avoid a high speed feedback phenomenon while the latches are open it is necessary to break the feedback loop and "freeze" the data at the desired output/input state. This is accomplished by disabling the TRI-STATE® ${ }^{\circledR}$ outputs. As long as the outputs are loaded only by the high impedance inputs of the CMOS device, the next state information will be transferred into the latches. Resistive or bipolar logic loads should not be attached to lines operating in this manner.


Note: Refer to AN 140 for R \& C values.
TL/D/11274-1
FIGURE 1. State Machine for Serial Word Generation

TABLE I. PROM Addresses and Data

| Address | Data <br> (7 Bits) | Serial <br> Output | Comments |
| :---: | :---: | :---: | :---: |
| nn 7F | 00 | 0 | Startup Address Generates <br> 1st Word |
| nn 00 | 01 | 1 |  |
| nn 01 | 02 | 1 |  |
| nn B4 | B4 | 0 |  |
| $\bullet$ | 03 | 1 | Loop to Self - Stop |
| $\bullet$ |  |  |  |

Table I shows an example of the PROM code which generates the serial output. The address includes a leading byte " nn " which will determine which of the bit streams will be selected. Notice that the 7 -bit data is in fact the next state information reflected in the next address.

APPLICATIONS FOR A SERIAL WORD GENERATOR USING THE NMC87C257

## A Power Supply Sequencer

The ADC0854 is a comparator circuit with a MICROWIRE controlled four input multiplexer and a settable 8-bit reference divider which drives the second compare input. A block diagram is depicted in Figure 2.



Many voltage regulators feature an on-off input. Couple these linear components along with the serial word generator and a sophisticated power supply sequencer can be built.
The ADC0854 requires a 12-bit serial word to provide setup information. A start bit is required, which is followed by one bit to select four single ended or two differential inputs. A two bit channel selection and the eight bit reference data byte complete the serial word. It is depicted in Figure 3.
Referencing the simplified schematic in Figure 4, analog input signals are presented to the multiple inputs of the com-
parator from the voltage sources, in this case Simple Switcher ${ }^{T M}$ Regulators are used.
The serial word is presented to the ADC0854 is generated from the sequence shown in Figure 5A. The Chip Select input which acts to latch the data word into the comparator is generated by a diode AND gate from the four output/input lines controlling the count. All diodes depicted in the schematic are in a single FSA2619P 16 -pin dual-in-line package. An MM74C14 hex Schmitt trigger circuit provides the necessary clock wave form and an MM74C244 contributes buffering for the diode gates.


Note: Valid Output can change only on Falling Edge of CLK.
FIGURE 3. ADC0854 Clock, Control Data and Output Data Relationships


TL/D/11274-4
Note: Refer to AN 140 for R \& C values.
Note: As resistive and capacitive values in this circuit will vary with application, consult the datasheets of the associated devices for component selection.

Each regulator output is sequentially selected by the PROM generated MICROWIRE and tested for compliance to a voltage level also set via the MICROWIRE. When Voltage A reaches its terminal value, the sequencer delays for a defined period while voltage settles as determined here by the RC network at the comparator input and then raises the control voltage to the regulator B ON/OFF input and, after monitoring that regulator's voltage rise, continues to regulator C. A stable and fixed reference is supplied for the comparisons by an LM385.
A similar control procedure allows an orderly shutdown. During operation the controller monitors the sum of the
three supply voltages. A drop from the proper sum will commence the controlled shutdown. These procedures are delineated by the state diagram in Figure 5b. In order to differentiate the state defining the condition of the voltages when powering up and the state produced when shutting down a "history circuit" consisting of four diodes and a capacitor records the "all supplies on" condition. The ON/OFF switch must be recycled for the system to power up once again. A Zener diode regulated output is provided from the ADC0854 permitting the PROM and the Schmitt Trigger oscillator to be powered from the primary source.

## PRODUCTION LINE PROGRAMMING OF MICROWIRE EEPROMS

EEPROMs are frequently programmed prior to board insertion on the production line. This programming may reflect the revision level of the system software and the engineering change level of the printed circuit board.
In this case an NM93C06 256-bit device has been selected. In a production line situation it is desirable to write a segment of memory with the parameters described above.

In order to perform this task the memory must receive a series of MICROWIRE commands. Each of the commands is itself a state ordered sequence. The command sequences first enable the write capability, write 16 bits of information to the specified address and then turn off the write enable. Table II lists the inputs and outputs of the NMC87C257 for a sequence to write a sixteen bit word.
The logic diagram in Figure 6 depicts a circuit which includes keypad entry capability such that an operator can select up to 20 different such commands.


TL/D/11274-6
*Consult MM74C923 datasheet for component values appropriate to the specific application.
FIGURE 6. Logic Diagram for EEPROM Programmer

TABLE II. PROM Listing for EEPROM Programming

| Address <br> (Hex) | $00-04$ <br> (Hex) | EN | $74 \mathrm{HC173}$ <br> (Hex) | CS | DI | DO | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

## FILTER PARAMETER CONTROL

The LMC835 provides the complete resistor and switch set to implement a stereo 7 band equalizer or a mono 14 band system. While control of this device is usually provided from a microcontroller there are instances where that expense and effort are not necessary to achieve a complex filtering function.
To program the LMC835 one of fourteen frequency bands must be selected and the gain for that band entered. This band gain setting requires a minimum of 18 states. All fourteen bands must be preset and various control states must be implemented. Because of the large number of states involved in setting each of the fourteen bands a wider word is needed than can be implemented in a single PROM. There
are several methods of dealing with this, however the most straight forward (for purposes of illustration) is to employ two PROMs.
The MICROWIRE interface used with the LMC835 differs slightly from those implemented above in that it uses a strobe to transfer data from the internal shift register to the latch for the addressed switch matrix. This permits the reprogramming of individual bands without the necessity of rewriting the entire machine state.
A complete logic diagram for the word generator is shown in Figure 7. The schematics for the implementation of the linear portions of the circuit can be obtained by referencing the LMC835 datasheet. A template for the PROM listing is also shown in Figure 8.


FIGURE 7. Logic Diagram for Equalizer Controller
 s.ax

strobe

data

| $w$ | $w$ | $w$ | $w$ | $w$ |
| :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | 0 |
| $r$ | $r$ | $r$ | $r$ | $r$ |
| $d$ | $d$ | $d$ | $d$ | $d$ |
| 1 | 2 | 3 | 4 | 5 |

$w$
0
$\mathbf{r}$
$d$
$w$
0
$r$
$d$
7
$w$
$o$
$r$
$d$

$$
\begin{aligned}
& \text { w } \\
& 0 \\
& \mathbf{r} \\
& \mathbf{d}
\end{aligned}
$$

$$
\begin{aligned}
& w \\
& o \\
& r \\
& d \\
& 10
\end{aligned}
$$

$$
\begin{aligned}
& w \\
& 0 \\
& r \\
& d \\
& 11
\end{aligned}
$$

$$
\begin{aligned}
& w \\
& 0 \\
& r \\
& d \\
& 12
\end{aligned}
$$

$$
\begin{array}{ll}
w & w \\
0 & 0 \\
r & r \\
d & d \\
13 & 14
\end{array}
$$


FIGURE 8. Template for PROM Program for Filter Controller

## SUMMARY

The use of the NMC87C257 CMOS PROM with latches has been shown to be an effective element in the implementation of several MICROWIRE interfaces. This use allows the designer to implement systems with devices necessitating a MICROWIRE interface without the use of a microcontroller or microprocessor.


FIGURE A1. A Ramp Transfer Characteristic. Refer to Table A1 for program Inputs.

TABLE A1. Program Inputs for Ramp Transfer Characteristic

| Frequency (Hz) | Level (dB) |
| :---: | :---: |
| 40 | -7 |
| 63 | -6 |
| 100 | -5 |
| 160 | -4 |
| 250 | -3 |
| 400 | -2 |
| 630 | -1 |
| 1 k | 0 |
| 1.6 k | +1 |
| 2.5 k | +2 |
| 4 k | +3 |
| 6.3 k | +4 |
| 10 k | +5 |
| 16 k | +6 |

Frequency (Hz) Level (dB)

In constructing or adapting any of the circuits described in this note the reader is advised to obtain copies of the Na tional Semiconductor data sheets for the components included and to review their operation for applicability to their system requirements.

Figures A1 and A2 are gain vs. frequency plots of specimen filters realized using the logic of Figure 7 and PROM code generated with SM835.c.

```
/*****************************************************************
*
* File: SM835.C
* Author: Bob Moses, Rane Corporation, Mukilteo, WA *
* Revision: }18\mathrm{ June 1991 *
* Compiler: Borland Turboc *
* *
* Description: Generates Intel Hex file for NMC87C257 based *
* LMC835 state machine loader. *
* *
* File Input: void *
* File Output: SML835.HEX *
* *
*******************************************************************/
#include "stdio.h"
/*------------*/
/* Data Types */
/*------------**/
struct LMC835_RECORD
{
    int chAbands[7]; /* gains for chan A bands */
    int chArng; /* chan A range */
    int chBbands[7]; /* gains for chan B bands */
    int chBrng; /* chan B range */
};
/*--------------------**
/* Function Prototypes*/
/*---------------------*/
void say_howdy(void);
void get_parameters(struct LMC835_RECORD *eq);
void compile_state_mach(struct LMC835_RECORD *eq, unsigned int states[]);
void output_data(unsigned int states[]);
void wr_ihex_data_rec(FILE *outfile, unsigned int addr, unsigned char recsize,
                                    unsigned char data[]);
/*--------------* /
/* Main Program */
/*--------------*/
main()
l
    /* declare one LMC835 equalizer */
    struct LMC835_RECORD eql;
```

```
    /* 14 bands * 2 blocks/band * 9 states/block + final state = 253 states */
    unsigned int states[253];
    say_howdy();
    get_parameters(&eql);
    compile_state_mach(&eql,states) ;
    output_data(states);
}
/*------------*/
/* Functions */
/*------------*/
void say_howdy(void)
{
    clrscr();
    fprintf(stdout,"\nSM835 - NMC87C257 LM835 State Machine Loader.");
    fprintf(stdout,"\n\nThis Program accepts parameters for an LMC835-based");
    fprintf(stdout,"\nequalizer and generates an Intel Hex file ( SML835.HEX )");
    fprintf(stdout,"\nfor the NMC87C257 State Machine Loader. This file can be");
    fprintf(stdout,"\nloaded into most EPROM programmers and split-programmed");
    fprintf(stdout,"\n(even and odd bytes) into two EPROMs.");
    fprintf(stdout,"\n\nThe LMC835 graphic equalizer consists of two channels");
    fprintf(stdout,"\n(chan A & chan B), each channel has 7 bands. The range of");
    fprintf(stdout,"\neach band is selectable for }\pm12\textrm{dB}\mathrm{ in l dB steps, or");
    fprintf(stdout,"\n\pm 6 dB in 1/2 dB steps.\n");
}
void get_parameters(struct LMC835_RECORD *eq)
l
    unsigned int i,currng;
    int tempint;
    char chan;
    float tempfloat;
    /* get range for chan A */
    fprintf(stdout,"\nPlease enter range of chan A (0 = \pm12dB, 1 = \pm6dB): n);
    fscanf(stdin,"%d",&tempint);
    eq-> chArng = tempint&0x0001;
    /* get range for chan B */
    fprintf(stdout,"Please enter range of chan B (0= =12dB, l = \pm6dB): ");
    iscanf(stdin,"%d",&tempint);
    eq-> chBrng = tempint&0x0001;
```

```
    /* get EQ bands */
    for(1 = 0,chan = 'A',currng = 12-6*(eq-> chArng);1< 14;)
    I
        /* if start of chan B, modify chan flag and chan range variables */
        if(i== 7)
        l
            chan = 'B';
            currng = 12-6*(eq-> chBrng);
        }
        /* get a band value */
        fprintf(stdout,"Gain of chan %c band #%di %,chan,(i%7)+1);
        fscanf(stdin,"%g",&tempfloat);
        /* scale for range */
        if(currng == 6) tempint = (int)(tempfloat*2.0);
        else tempint = (int)tempfloat;
        /* check limits */
        if((tempint > 12) || (tempint < -12))
        {
            fprintf(stderr,"...err! value must be between -%d and +%d\n",currng,currng);
            continue;
        }
        /* save band */
        if(chan == 'A') eq->chAbands[i] = tempint;
        else eq->chBbands[1-7] = tempint;
        i++; /* band counter */
    }
}
void compile_state_mach(struct LMC835_RECORD *eq, unsigned int states[])
l
LMC835 CONTROL CODES
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline  & & & \multicolumn{2}{|l|}{DATA I} & & & & & & & \multicolumn{2}{|l|}{DATA II} & \multicolumn{3}{|r|}{} \\
\hline bit: 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 0 & 1 & 2. & 3 & 4 & 5 & 6 & 7 \\
\hline bo & b1 & b2 & b3 & rB & rA & X & 1 & g0 & \(g 1\) & \(g 2\) & g3 & 94 & 95 & be & 0 \\
\hline
\end{tabular}
```



NMC87C257 pin connections:

unsigned int band, substate, stateimg, curstate;
unsigned char LMC835GainCodeTable[] = [0x2F,0x2D,0x29,0x01,0x16,0x2A, $0 \times 12,0 \times 02,0 \times 04,0 \times 08,0 \times 10,0 \times 20$, $0 \times 00$, $0 \times 20,0 \times 10,0 \times 08,0 \times 04,0 \times 02,0 \times 12$, 0x2A,0x16,0x01,0x29,0x2D,0x2F\};

## /*--------*/

/* chan A */
/*--------*/

```
for(band = 0,curstate = 0;band < 7;band++)
```

1
for(substate $=0$; substate $<18$; substate++)
1
/* next state $=$ current state +1 */
stateimg $=$ (curstate +1 ) $\& 0 \times 1$ FFF;
/*. CLK Enable */
stateimg $\&=0 \times \mathrm{DFFF}$;
/* Prestrobe */
if((substate $==7) \|($ substate $==16))$ stateimg $+=0 \times 8000$;
/* Data */
switch(substate)
1
case 0: /* DATA I bO */
stateimg += (( band+l)\&0x0001)<<14);
break;
case 1: /* DATA I bl */
stateimg += (( band +1$) \& 0 \times 0002) \ll 13)$;
break;
case 2: /* DATA I b2 */
stateimg += (( band+l)\%0x0004)<<12);
break;
case 3: /* DATA I b3 */
stateimg += (( band+l) \%0x0008) \ll ll) ;
break;
case 4: /* DATA I rB */
stateimg $+=(((e q->$ chBrng $) \& 0 x 0001) \ll 14)$;
break;
case 5: /* DATA I rA */
stateimg $+=(((e q->c h A r n g) \& 0 x 0001) \ll 14)$;
break;
case 6: /* DATA I don't care */
break;
case 7: /* DATA I 1 */
stateimg $+=0 \times 4000$;
break;
*/

```
        case 8: /* rest for strobe */
        break;
        case 9: /* DATA II g0 */
        stateimg += ((LMC835GainCodeTable[eq->chAbands[band]+12]&0x0001)<<14);
        break;
        case 10: /* DATA II gl */
        stateimg += ((LMC835GainCodeTable[eq->chAbands[band]+12]&0x0002)<<l3);
        break;
        case ll: /* DATA II gO */
        stateimg += ((LMC835GainCodeTable[eq-> chAbands[band]+12]&0x0004)<<l12);
        break;
        case 12: /* DATA II g3 */
        stateimg += ((LMC835GainCodeTable[eq-> chAbands[band]+12]&0x0008)<<ll);
        break;
case 13: /* DATA II g4 */
    stateimg += ((LMC835GainCodeTable[eq->chAbands[band]+12]&0x0010)<<l0);
    break;
case 14: /* DATA II g5 */
    stateimg += ((LMC835GainCodeTable[eq->chAbands[band]+12]&0x0020)<<9);
    break;
case 15: /* DATA II bc ( O = cut, l = boost) */
    if(eq->chAbands[band] < 0) stateimg &= 0xBFFF;
    else stateimg += 0x4000;
    break;
case 16: /* DATA II 0 */
    stateimg &= 0xBFFF;
    break;
case l7: /* rest for strobe */
            break;
        | /* switch... */
        /* write this state to states array */
        states[curstate++] = stateimg;
    } /* for(substate... */
) /* for(band... */
/*--------*/
/* chan B */
/*--------*/
for(band = 7;band < 14;band++)
{
    for(substate = 0;substate < 18;substate++)
    {
            /* next state = current state +l */
            stateimg = (curstate+l)&0xlFFF;
            /* CLK Enable */
            stateimg &= 0xDFFF;
```

```
/* Prestrobe */
if((substate == 7)|(substate == l6)) stateimg += 0x8000;
/* Data */
switch(substate)
l
    case 0: /* DATA I bO */
        stateimg += (((band+1)&0x0001)<<14);
        break;
    case l: /* DATA I bl */
        stateimg += (((band+l)&0x0002)<<l3);
        break;
    case 2: /* DATA I b2 */
        stateimg += (((band+1)&0x0004)<<l2);
        break;
    case 3: /* DATA I b3 */
        stateimg t= (((band+l)&0x0008)<<ll);
        break;
    case 4: /* DATA I rB */
        Stateimg += (((eq->chBrng)&0x0001)<<<14);
        break;
    case 5: /* DATA I rA */
        stateimg += (((eq-> chArng)&0x0001)<<l4);
        break;
    case 6: /* DATA I don't care */
        break;
    case 7: /* DATA I l */
        stateimg += 0x4000;
        break;
    case 8: /* rest for strobe */
        break;
    case 9: /* DATA II gO */
        stateimg += ((LMC835GainCodeTable[eq-> chBbands[band-7]+12]&0x0001)<< <14);
        break;
    case 10: /* DATA II gl */
        stateimg += ((LMC835GainCodeTable[eq-> chBbands[band-7]+12]&0x0002)<<13);
        break;
    case 1l: /* DATA II g2 */
        stateimg += ((LMC835GainCodeTable[eq-> chBbands[band-7]+12]&0x0004)<<12);
        break;
    case 12: /* DATA II g3 */
        stateimg += ((LMC835GainCodeTable[eq->chBbands[band-7]+12]&0x0008)<<ll);
        break;
    case 13: /* DATA II g4 */
        stateimg += ((LMC835GainCodeTable[eq->chBbands[band-7]+12]&0x0010)<<l10);
        break;
```

```
                case 14: /* DATA II g5 */
stateimg +=((LMC835GainCodeTable[eq-> chBbands[band-7]+12]&0x0020)<< < );
                break;
            case 15: /* DATA II bc ( 0 = cut, 1 = boost) */
                if(eq->chBbands[band-7] < 0) stateimg &= 0xBFFF;
                else stateimg += 0x4000;
                break;
                case 16: /* DATA II 0 */
                stateimg &= 0xBFFF;
                break;
            case 17: /* rest for strobe */
                break;
            } /* switch... */
            /* write this state to states array */
            states[curstate++] = stateimg;
        } /* for(substate... */
    } /* for(band... */
    /* final state: "jump 0" with clock disabled */
    states[252] = 252+0x2000;
}
void output_data(unsigned int states[])
l
    unsigned int i,addr,bitmask;
    unsigned char csum,data[l6];
    FILE *outfile;
    /* open output file */
    if((outfile = fopen("sml835.hex","w")) == NULL )
    |
        fprintf(stderr,"can't open file SML835.HEX");
        exit(0) ;
    }
    /* write states to stdout */
    /*-------------------------*/
    for(i = 0;i < 253;i++)
l
    if(i== 252) fprintf(stdout,"\n\nFinal state...");
        else if (!(i&l8)) fprintf(stdout,"\n\nBand %d...",(i/18)+1);
        fprintf(stdout,"\nState %d: ",i);
        /* write each state as a binary image */
        for(bitmask = 0;bitmask < 16;bitmask++)
        l
            if((states[i]<<bitmask)&0x8000) fprintf(stdout,"l");
            else fprintf(stdout,"O");
        }
    }
```

```
    /* write states to Intel Hex file */
    /*----------------------------------*/
    fprintf(stdout,"\n\nWriting Intex Hex file: SML835.HEX...\n");
    /* write first 252 states */
    for(addr = 0;addr < 252;addr += 8)
    {
        /* copy 8 states (l6 bytes) to temp data buffer */
        for(i = 0;i < 16;i += 2)
        {
            data[i] = (char)(states[addr+(1/2)]&0x00FF);
            data[1+1] = (char)((states[addr+(1/2)]>>8)*0x00FF);
        }
        /* write data to Intex Hex record */
        wr_ihex_data_rec(outfile,addr*2,16,data);
    }
    /* write last state */
    data[0] = (char)(states[252]&0x00FF);
    data[l] = (char)((states[252]>>8)&0x00FF);
    wr_ihex_data_rec(outfile,252*2,2,data);
    /* EOF record */
    fprintf(outfile,"\n:00000001FF");
    /* close file */
fclose(outfile);
}
void wr_ihex_data_rec(FILE *outfile, unsigned int addr, unsigned char recsize, unsigned char
data[])
l
    unsigned int i;
    unsigned char csum;
    /* record mark, record length, record address, and record type fields */
    fprintf(outfile;"\n:%2.2X%4.4X00",recsize,addr);
    csum = recsize + (char))addr&0x00FF) + (char) ((addr>>8)&0x00FF);
    /* data field */
    for(i = 0;i < recsize;i++)
    |
        fprintf(outfile,"%2.2X",data[i]);
        csum += data[i];
    }
/* checksum field */
csum &= 0x00FF;
csum *= -l;
fprintf(outfile,"%2.2X",csum);
}
```

BIBLIOGRAPHY
NMC87C257 - CMOS PROM with Address Latches
ADC0854 - Multiplexed Comparator with 8-bit Refer- ence Divider
FSA2619 - Monolithic Diode Array
MM74C14 — Hex CMOS Schmitt Trigger
NM93C06 - 256-bit Electrically Erasable Programmable Memory

## Appendix

## ACKNOWLEDGEMENTS

The author would like to express his gratitude to the engineering staff at Rane Corporation in Mukilteo, Washington for providing expert assistance and breadboarding of the LMC835 application and to Bob Moses for contributing a C program (see Appendix) to generate the ROM map.

## MM74C923 - 20 Key Encoder

LMC35 - Digital Controlled Graphic Equalizer
AN-452 - MICROWIRE Serial Interface
AN-140 — CMOS Schmift Trigger

## NM95C12 Applications in a PC-AT ${ }^{\circledR}$ Ethernet ${ }^{\circledR}$ Adapter

## INTRODUCTION

This application describes a typical Ethernet adapter card designed to be plugged into a PC-AT expansion slot. The board is designed around the National Semiconductor DP83932 SONICTM Network Controller device. This application note will detail the system design and focus on the functions performed by the NM95C12 EEPROM.
This application note assumes that the reader is familiar with the PC-AT architecture, the DP83932 device, the NM95C12 EEPROM and designing with GAL© Programmable Logic Devices (PLDs).

National Semiconductor
Application Note 792 Sean Long

## SYSTEM DESCRIPTION

The network controller card has been designed to meet the following specifications:

- Designed around high performance 32-bit DP83932 Ethernet Controller
- 16-Bit bus master operation to give higher performance
- Fully software configurable (no jumpers or mechanical DIP switches)
- Extensive test and configuration capabilities
- Supports different media interfaces
- Bootrom option

The system block diagram is shown in Figure 1.


TL/D/11265-1
Denotes an active low signal.

FIGURE 1. System Block Dlagram

## FUNCTIONAL DESCRIPTION OF THE BOARD

The system contains the following logical functions:

1. Network controller (DP83932)
2. Cable interfaces
3. Busmaster interface logic, including data and address buffers
4. EPROM option for remote boot loader

This system uses both the EEPROM locations and the switch logic terminals of the NM95C12 to perform various functions within the system as detailed below.

## FUNCTIONAL DESCRIPTION OF NM95C12 EEPROM

## Use of the Switches:

The switch terminals of the NM95C12 EEPROM are used as part of the memory map address decoding and the I/O map decoding circuitry, feeding as inputs to a GAL20V8 which performs the address decoding logic from the system address inputs.
The NM95C12 switches control:

1. The base I/O address of the network controller board.
2. The base memory address of the bootrom EPROM option on the board.

## ADDRESS DECODING

The address decoding is controlled by a GAL20V8 PLD (refer to the 1990 National Semiconductor PLD Databook and Design Guide for further information) as shown in Figure 2. The inputs to the GAL20V8 are the system address lines, the memory and I/O control signals, and the switch termi-
nals from the NM95C12. The outputs from the GAL20V8 are the various chip select signals for the memory and I/O ports. The system address bus transmits the current address value and the $\mathrm{M} / \sim 10$ signal determines if a memory or I/O cycle is in progress.
Address lines AO-A19 allow up to 1 Meg (0-FFFFF) of memory to be addressed, while address lines AO-A15 allow up to 64 K ( $0-\mathrm{FFFF}$ ) of I/O ports to be addressed. If the control signal $\mathrm{M} / \sim 10$ is logical " 1 " (high) then the processor is performing a memory cycle and if the $M / \sim 10$ signal is logical " 0 " then an I/O cycle is in operation.
For a PC-AT various memory and I/O locations are reserved for standard functions such as system memory and I/O (refer to PC-AT documentation to determine which memory and I/O locations are free for add-in boards).
The switch outputs from the NM95C12 are connected as inputs to the GAL address decode logic and are used to determine the base memory and I/O locations for the add-in card. Figure 2 shows the typical use of a GAL for address decoding.
The advantage of using a PLD for the address decoding is that it is an easy way to implement different address decode functions by logic equations. The logic equations can be implemented with a standard PLD design compiler such as OPALTM from National Semiconductor or a third party software package such as ABELTM from Data I/O. The PLD compiler will take the logic equations and convert them into the GAL fuse map which can be used for programming on a wide range of device programmers. A typical set of logic equations using National Semiconductors OPAL software package is shown in Figure 3.


FIGURE 2. Address Decoding

```
BEGIN HEADER
TITLE Address decoding for PC AT Ethernet adapter card
PATTERN Addr_Dec
REVISION Rev O
AUTHOR Dave Engineer
COMPANY National Semiconductor
DATE June 1991
```

Everything in the header command is copied directly into the JEDEC map as a comment field for
easy documentation
END HEADER

## BEGIN DEFINITIONS

```
device G2OV8; { specify the device used }
inputs s0, s1, s2, s3, s4, s5; {define the inputs }
inputs m_~io, a0, al, a2, a3, a4, a5;
outputs(com) bootroom, portpage; {define the outputs}
{ OPAL will perform automatic pin assignment }
set ioselect=[s2,sl,s0], memselect=[s5,s4,s3]; { define the switch sets }
set address=[a5,a4,a3,a2,a1,a0];
END DEFINITIONS
```

begin equations
( $n /{ }^{n}=$ logical NOT function (i.e. logical 0)
n \& . ${ }^{n}=$ logical AND function
$n+n=$ logical or function )
( if $m_{-} \sim$ io is logical 0 , then decode switch set $s 2$, $s l, s 0$ and address lines for the various
base I/O locations.
Refer to PC-AT system I/O address map before selecting free I/O ports, the decodes shown are
for example only - change for specific applications as required.)
bootrom $=/ m_{-} \sim 10 \&($ (loselect $==0) \&($ address $==\uparrow h 00)$
$+($ ioselect $==1) \&($ address $==\uparrow$ hol)
$+($ 1oselect $==2) \&($ address $==\uparrow$ hoZ $)$
$+($ ioselect $==3) \&($ address $==\uparrow$ ho3 $)$
$+($ ioselect $=4) \&($ address $==\uparrow$ ho4 $)$
$+($ ioselect $=5) \&($ address $==\uparrow$ h05 $)$
$+($ ioselect $=6) \&($ address $==\uparrow$ h06) );
( if $m_{-} \sim i o$ is logical 1, then decode switch set $s 5,54, s 3$ and address line for the various
base memory locations.
Refer to PC-AT system I/O address map before selecting free Memory locations, the decodes
shown are for example purposes only - change for specific applications as required. \}
portpage $=m_{-} \sim 10 \&(($ memselect $==0) \&($ address $==\uparrow \mathrm{hl}$ )
$+($ memselect $==1) \&($ address $==\uparrow h 20)$
$+($ memselect $==2) \&($ address $==\uparrow h 28)$
$+($ memselect $==3) \&($ address $==\uparrow h 30)$
$+($ memselect $=4) \&($ address $==\uparrow h 38)$;

END EQUATIONS
FIGURE 3. GAL® Logic Equations

## USE OF THE NM95C12 EEPROM LOCATIONS

1. Three locations are used to store the ethernet address of the card.
2. One location is used to store the interrupt number and the DMA channel of the board.
3. One location is used to store the busmaster speed setting of the card.
4. Two locations are used to store information about the production flow of the board e.g.; the version number of the out-going inspection, and serialization program which stores a unique ethernet address in the EEPROM.
5. There are also some EEPROM locations used to enable some special features in the network driver such as protocol, DMA priority, etc.

Figure 4 below shows the memory usage of the NM95C12.

| 63 | SWITCH READBACK REGISTER |
| :---: | :---: |
| 62 | INITIAL SWITCH SETTINGS |
| 61 | INITIAL SWITCH SETTING |
| 60 | LOCATION 8-60 FREE FOR |
| 4 | STORING NON-VOLATILE PARAMETERS |
| 7 | TwO LOCATIONS USED |
| 6 |  |
| 5 | ONE LOCATION STORES DMA CHANNEL USED |
| 4 | ONE LOCATION STORES BUSMASTER SPEED SETTING |
| 3 | ONE LOCATION STORES INTERRUPT NUMBER |
| 2 |  |
| 1 | THREE LOCATIONS (48 BITS) STORE ETHERNET ADDRESS |
| 0 | TL/D/11 |

FIGURE 4. Memory Locations Used in NM95C12

## FUNCTIONAL DESCRIPTION OF THE SOFTWARE

The driver for the card can be supplied in two ways:

1. As a driver which is loaded from the disk.
2. As a bootrom which is located at the card.

The driver determines the base I/O address of the card. This is done by scanning the possible I/O map where the card can be located (seven possible locations) and testing if the NM95C12 EEPROM can be found.
The EEPROM is found if, after an address is shifted in the EEPROM, the DO output from the NM95C12 has become logical "zero". Then the CS pin will be disabled and there will be a check if the DO output pin will become high (this pin is pulled up with a 47 K resistor).

When the software finds the base address of the card, it reads the locations which contain the DMA and IRQ number to use and programs these values into the corresponding output latches. These latches will enable and/or multiplex the corresponding DMA (DACKx, DRQx) and INT (IRQx) to the busmaster logic and interrupt logic.
The same operation is done for the busmaster speed, one location in the EEPROM determines the active low and high time for busmaster cycles, the output of this latch will go to the busmaster state machine (implemented in a GAL22V10).
The ethernet address will be read by the driver and copied to a private location in the driver data area for use with the network software.
The bootrom can be located at five locations in memory (controlled by the NM95C12 switch logic) and can be disabled if required.

## CONCLUSION

This application has shown the many advantages of the NM95C12 EEPROM with DIP Switches. In this example the NM95C12 replaces the functions typically performed by a Bipolar PROM (store ethernet address), mechanical DIP switches/jumpers (select options), and general read/write logic (software testing of the hardware configuration). The use of the switch terminals as part of the address decode logic makes the address decode function more flexible and allows for software control.
The easy interfacing to the NM95C12 (just four pins) and the simple, but powerful instruction set allows the NM95C12 to give the system designer:

- Greater flexibility
- Fully software controllable and testable
- Greater reliability (no mechanical switches or jumpers)
- Reduced component count
- Lower component cost


## Using an EEPROM— ${ }^{12} \mathrm{C}$ Interface NM24C02/03/04/05/08/09/ <br> 16/17

## introduction

National Semiconductor's NM24C EEPROMs are designed to interface with Inter-Integrated Circuit $\left({ }^{2} \mathrm{C}\right.$ ) buses and hardware. NSC's electrically erasable programmable read only memories (EEPROMs) offer valuable security features (write protection), two write modes, three read modes and a wide variety of memory sizes. Applications for the $\mathrm{I}^{2} \mathrm{C}$ bus and NM24C memories are included in SANs (small-area networks), stereos, televisions, automobiles and other scaled-down systems that don't require tremendous speeds but instead cost efficiency and design simplicity.

## I2C BACKGROUND

The $I^{2} C$ bus configuration is an amalgam of microcontrollers and peripheral controllers. By definition: a device that transmits signals onto the I2 C bus is the "transmitter" and a device that receives signals is the "receiver"; a device that controls signal transfers on the line in addition to controlling the clock frequency is the "master" and a device that is controlled by the master is the "slave". The master can transmit or receive signals to or from a slave, respectively, or control signal transfers between two slaves, where one is the transmitter and the other is the receiver. It is possible to combine several masters, in addition to several slaves, onto an $I^{2} \mathrm{C}$ bus to form a multimaster system. If more than one master simultaneously tries to control the line, an arbitration procedure decides which master gets priority. The maximum number of devices connected to the bus is dictated by the maximum allowable capacitance on the lines, 400 pF , and the protocol's addressing limit of 16 k ; typical device capacitance is 10 pF . Up to eight E2PROMs can be connected to an $I^{2} \mathrm{C}$ bus, depending on the size of the memory device implemented.
Simplicity of the $\mathrm{I}^{2} \mathrm{C}$ system is primarily due to the bidirectional 2-wire design, a serial data line (SDA) and serial clock line (SKL), and to the protocol format. Because of the effi-

National Semiconductor
Application Note 794
N. Brian Underwood

cient 2 -wire configuration used by the $1^{2} \mathrm{C}$ interface compared to that of the MICROWIRETM and SPI interface, reduced board space and pin count allows the designer to have more creative flexibility while reducing interconnecting cost.

## OPERATING NATIONAL SEMICONDUCTOR'S NM24Cs

The NM24C E2PROMs require only six simple operating codes for transmitting or receiving bits of information over the 2 -wire $\mathrm{I}^{2} \mathrm{C}$ bus. These fields are explained in greater detail below and briefly described hereafter: a start bit, a 7 bit slave address, a read/write bit which defines whether the slave is a transmitter or receiver, an acknowledge bit, message bits divided into 8 -bit segments and a stop bit.
For efficient and faster serial communication between devices, the NM24C Family features page write and sequential read.
The NM24C03/C05/C09/C17 Family offers a security feature in addition to standard features found in the NM24C02/C04/C08/C16 Family. The security feature is beneficial in that it allows Read Only Memory (ROM) to be implemented in the upper half of the memory to prevent any future programming in that particular chip section; the remaining memory that has not been write protected can still be programmed. The security feature in the NM24C03/ C05/C09/C17 Family does not require immediate implementation when the device is interfaced to the $I^{2} C$ bus, which gives the designer the option to choose this feature at a later date. Table I displays the following parameters: memory content, write protect and the maximum number of individual $I^{2} \mathrm{C} E^{2}$ PROMs allowed on an $I^{2} \mathrm{C}$ bus at one time if the total line capacitance is kept below 400 pF .
Code used to interface the NM24Cs with National Semiconductor's COP8 Microcontroller Family is listed in a latter section of this application note for further information to the reader.

TABLE I

| Part No. | Number of <br> 256x8 Page Blocks | Write Protect <br> Feature | Max. <br> Parts |
| :---: | :---: | :---: | :---: |
| NM24C02 | 1 | No | 8 |
| NM24C03 | 1 | Yes | 8 |
| NM24C04 | 2 | No | 4 |
| NM24C05 | 2 | Yes | 4 |
| NM24C08 | 4 | No | 2 |
| NM24C09 | 4 | Yes | 2 |
| NM24C16 | 8 | No | 1 |
| NM24C17 | 8 | Yes | 1 |



FIGURE 1. ${ }^{2} \mathrm{C}$-Bus Configurations


TL/D/11268-2
FIGURE 2. $1^{2} \mathrm{C}$ Bus Timing

## Start Condition

- Clock and Data line high (Bus free)
- Change Data line from high to low
- After $t_{\mathrm{HS}(\mathrm{Min})}=4 \mu \mathrm{~s}$ the master supplies the clock


## Acknowledge

- Transmitting device releases the Data line
- The receiving device pulls the Data line low during the ACK-clock if there is no error
- If there is no ACK, the master will generate a Stop Condition to abort the transfer


## Stop Condition

- Clock line goes high
- After $\mathrm{t}_{\mathrm{HP}(\mathrm{Min})}=4.7 \mu \mathrm{~s}$ the Data lines go high
- The master maintains the Data and Clock line high
- Next Start Condition after $\mathrm{t}_{\mathrm{FB}(\text { Min })}=$ $4.7 \mu \mathrm{~s}$ is possible


## START/STOP CONDITIONS

If both the data and clock lines are HIGH, the bus is not busy. To attain control of the bus, a start condition is needed from a master; and to release the lines, a stop condition is required.
Start Condition: HIGH-to-LOW transition of the data line while the clock line is in a HIGH state.
Stop Condition: LOW-to-HIGH transition of the data line while the clock line is in a HIGH state.
The master always generates the start and stop conditions. After the start condition the bus is in the busy state. The bus becomes free after the stop condition.

## DATA BIT TRANSFER

After a start condition " S " one databit is transferred during each clock pulse. The data must be stable during the HIGHperiod of the clock. The data line can only change when the clock line is at a LOW level.
Normally each data transfer is done with 8 data bits and 1 acknowledge bit (byte format with acknowledge).

## ACKNOWLEDGE

Each data transfer needs to be acknowledged. The master generates the acknowledge clock pulse. The transmitter releases the data line (SDA = HIGH) during the acknowledge clock pulse. If there was no error detected, the receiver will pull down the SDA-line during the HIGH period of the acknowledge clock pulse.
If a slave receiver is not able to acknowledge, the slave will keep the SDA line HIGH and the master can then generate a STOP condition to abort the transfer.
If a master receiver keeps the SDA line HIGH, during the acknowledge clock pulse the master signals the end of data transmission and the slave transmitter release the data line to allow the master to generate a STOP-condition.

## ARBITRATION

Only in multimaster systems.
If more than one device are potential masters and more than one desires access to the bus, an arbitration procedure takes place: if a master transmits a HIGH level and another master transmits a LOW level, the master with the LOW level will get the bus and the other master will release the bus; and the clock line switches immediately to the slave receiver mode. This arbitration could carry on through many bits (address bits and data bits are used for arbitration).

## FORMATS

There are three data transfer formats supported:

- Master transmitter writes to slave receiver; no direction change
- Master reads immediately after sending the address byte
- Combined format with multiple read or write tranfers.


## ADDRESSING

The 7 -bit address of an ${ }^{2} \mathrm{C}$ device and the direction of the following data is coded in the first byte after the start condition:


TL/D/11268-3
A " 0 " on the least significant bit indicates that the master will write information to the selected Slave address device; a " 1 " indicates that the master will read data from the slave.
Some slave addresses are reserved for future use. These are all addresses with the bit combinations 1111XXX and 0000 XXX . The address 00000000 is used for a general call address, for example, to initialize all $\mathrm{I}^{2} \mathrm{C}$ devices (refer to $\mathrm{I}^{2} \mathrm{C}$ bus specification for detailed information).

## TIMING

The master can generate a maximum clock frequency of 100 KHz . The minimum LOW period is defined as $4.7 \mu \mathrm{~S}$; the minimum HIGH period width is $4 \mu \mathrm{~s}$; the maximum rise
time on SDA and SCL is $1 \mu \mathrm{~s}$; and the maximum fall time on SDA and SCL is 300 ns .
Figure 4 shows the detailed timing requirements.

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{SCL}}$ | SCL Clock Frequency | 0 | 100 | kHz |
| $\mathrm{t}_{\text {BUF }}$ | Time the Bus Must Be Free before a New Transmission Can Start | 4.7 |  | $\mu \mathrm{S}$ |
| thd; STA | Hold Time Start Condition. After this Period the First Clock Pulse is Generated | 4.0 |  | $\mu \mathrm{S}$ |
| tLow | The LOW Period of the Clock | 4.7 |  | $\mu \mathrm{s}$ |
| tsu; STA | Setup Time for Start Condition (Only Relevant for a Repeated Start Condition) | 4.7 |  | $\mu \mathrm{S}$ |
| $t_{\text {HD }}$ DAT | Data in Hold Time | $\begin{gathered} 5 \\ 0^{*} \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| tsu; DAT | Setup Time Data | 250 |  | ns |
| $\mathrm{t}_{\mathrm{r}}$ | Rise Time of Both SDA and SCL Lines |  | 1 | $\mu \mathrm{s}$ |
| $t_{f}$ | Fall time of Both SDA and SCL Lines |  | 300 | ns |
| tsu; STO | Setup Time for Stop Condition | 4.7 |  | $\mu \mathrm{s}$ |

*Note that a transmitter must internally provide at least a hold time to bridge the undefined region (max. 300 ns ) of the falling edge of SCL.
FIGURE 4. ${ }^{2} \mathrm{C}$-Bus Timing Requirements


TL/D/11268-7
FIGURE 5. I2C Bus EEPROM/ $\mu$ Controller Configuration Used for Sample Code

## SOFTWARE TASKS

I. Write fixed values to E2PROM cells
II. Read values back from E2PROM and save in RAM locations from COP
Note: ICC Bus Modes Used:

> Master Transmitter SDA $\rightarrow$ Slave Receiver
> Master Receiver $\underset{\text { SCL }}{\leftarrow} \rightarrow$ Slave Receiver

## REMARKS

- The I2C bus, 2-wire serial interface generally requires a pull-up resistor on the SDA line and the SCL line, depending on whether TTL or CMOS hardware interfacing exists.
- I2C bus compatible $\mu$ C's or peripherals have OPEN DRAIN outputs at SDA and SCL.
- COP800 does not have OPEN DRAIN outputs, but the "bus requirements" can be met by switching SDA and SCL connections into TRI-STATE for the following cases:
The bus is not accessed
A slave has to send an acknowledge bit.
- MICROWIRE can not be used for I2C bus operations.
- Current sink capability on SDA and SCL must be 3 mA to maintain "Low Level" (an I2C bus spec.).

```
TITLE|IC-EEPROM ROUTINES'
INCLD COP800.INC
CHIP }84
LIST X'21
    * * *TASK RELATED RAM - DECLARE* **
```

| EEADR | $=002$ | ;ADDRESS OF EEPROM |
| :--- | :--- | :--- |
| EEWRD | $=003$ | ;WORD ADDRESS EEPR. |
| EEDAT1 | $=004$ | ;DATA TO EECEL |
| EEDAT2 | $=005$ | ;SECOND BYTE |
| FLAG | $=010$ | iFLAG-WORD |
| EEREAD | $=012$ | ;READ-DATA FROM EE |
|  | $=013$ | ;SECONDBYTE |
|  | $=014$ | ;THIRD BYTE |
| BITCO | $=015$ | ;FOURTH BYTE |
|  | $=0 F 0$ | ;COUNTER FOR BITSHFT |

INIT:
LD SP,
LD B,
LD $[B+]$,
LD [B],
LD B,
LD [B-],
LD [B-],
LD [B-],
LD [B]


LD PSW,
LD CNTRL,
\# 00
\# 00
LD FLAG,
.FOPM
\#06F
PORTLD ; INIT LS, L3 FOR EE\#OOC ;OPERATIONS \#00C \#EEDAT2 ; INIT RAMS \#034 ;FIXEED VALUES FOR \#012 ; EEWRITE (2 BYTES) \#0A0 ; MIRROR OF \#05 \#025 ; MIRROR OF "A5"
;LOAD PSW ;AND CNTRLREG.

SBIT 0 ,
LD B,
RBIT 2 [B],
JSRSTACON
JSR WAIT

FLAG ; SET FLAG FOR WRITE PORTLD ; POINT LPORT DAT REG. ; TO MODIFY "SDA, SCL" ; PREPARE FOR START ; CONDITION.
; AFTER WRITE TO EE. ; WAIT FOR > THAT 40

STACON:
RBIT 3,
LD B,
LOPA:
LD BITCO,
LOPA 1:
IFBIT 0 , [B]
JP ONE,
RBIT 2,
JP CLK
ONE:
SBIT 2,
JP CLK

CLK:
SBIT 3,
PORTL ;DOCLOCK PULSE
NoP
NOP
RBIT 3,
RBIT 2,
FORM
LD A, [B]
RRCA,
$X \mathrm{~A},[\mathrm{~B}]$
DRSZBITCO
JP LOPA1,
LD A, [B+],
IFBIT 1 ,
JMP,
JSR ACK,

IFBIT 0 ,
JP CEC1,
IFBNE
JMP LOPA,
RET

| PORTLD PORTL | ; ENSURE 4USEC ;SWITCH ALSO SDA LOW |
| :---: | :---: |
|  | ; ROTATE BYTE ONE <br> ;BIT POS. RIGHT <br> ; AND SAVE <br> ; CHECK IF 8 BITS <br> ; SHIFTED |
| FLAG | DECREMENT 8 CHECK IF READ |
| GEIDAT | ; 3RD BYTE IS NEXT? <br> ;IF SO, THEN READ. <br> ;GETACKNOWLEDGED <br> ; WHEN 8 BITS ARE <br> ; SHIFTED. |
| FLAG | ; CHECK IF READ <br> - OR WRITE OPERATION |
| \# 04 | ; ON READ (HERE) <br> ; IF NOT 2 BYTES YET <br> ; AFTER EE-ADDRESS AND <br> ;WORD ADDRESS ARE SHFI |
| \# 06 | 1ST AND 2ND DATA. BYTE (3RD + 4TH) |

TL/D/11268-9
;NSEC TO PROPERLY
;ERASE WRITE.

LD B,
LD [B-],
LD [B-],
LD [B-],
LD [B],
LD B,
; TOMODIFY "SDA, SCL"
RBIT 2, [B], JSR STACON, JSR WAIT,
\#EEDAT2 ; INIT RAMS
\#078 ;ANOTHER 2 BYTES \#056 ;OF FIXED DATA \#0E0 ; MIRROR OF \#07 \#025 ; MIRROR OF "A5" PORTLD ; POINT LPORT DAT REG.
;PREPARE FOR START ; CONDITION.
; AFTER WRITE TO EE. ; WAIT FOR > THAN 40 ; MSEC TO PROPERLY ; ERASE WRITE.
.FORM
(READ 4 SUCCESSIVE BYTES)
RBIT 0
LD B,
LD [B-],
LD [B],

| FLAG | ; INDICATE READ |
| :--- | :--- |
| \#EEWRD | ; INIT RAMS |
| \#0AO | MIRROR OF \#05 |
| \#025 | ;MIRROR OF "A5" |

STP:
SBIT 3,
NOP,
SBIT 2,
RET,
.FORM

| PORTLD | ;ESTABLISH STOP. |
| :--- | :--- |
| PORTL | ;CONDITION |

* GET 8BIT OF DATA FROM EE-PROM *

GETDAT:
JSR ACK,
LD B,
JP
GETDAT:
JSR ACK,

GETDAT1:
LD BITCO,
RBIT 2,
RBIT 2,
LOPB:
SBIT 3,
RBIT 7, [B]
IFBIT 2 ,
SBIT 7, [B]
RBIT 3,
DRSZ BITCO,
JP SHFT
LD A, [B+].
IFBNE
JMP GETDT,
SBIT 2,
JMP STP
.FORM
SHFT:
LD A, [B]
RRC A
$\mathrm{XA},[\mathrm{B}]$
JP LOPB
** SIMPLE ROUTING TO DO 40 MSEC DELAY**
; **SIMPLE ROUTING TO DO 40 MSEC DELAY **
;GET ACKNOWLEDGMENT \#EEREAD ; POINT FIRST READ RAM GETDT1 ; AND READ IN
;ACKNOWLEDGMENTTO EE-
; PROM WHEN 8 BITS
;ARE SHIFTED IN.
\#008 ; INIT BIT COUNTER PORTLC ;BEFORE READING, PUT PORTLD ;'SDA' INTO HIGH-Z.

| PORTLD | ;DOCLOCK HIGH |
| :--- | :--- |
| PORTLD | ;READ IN EEDATA |
| ;IN SETS OF 8 BITS |  |

PORTLD ;DOCLOCKLOW ;CHECK IF 8 BITS ;ARE SHIFTED ; INCREMENT B ;CHECK IF 4 BYTES ; ARE SHIFTED IN? ; PUT L2=0 ;WHEN TRUE, DO STOP ;CONDITION AND ;RETURN
; ROTATE BITS ONE ;POSITION RIGHT

WAIT:
LD 0F1
LOPD:
LD 0F2,
LOPC:
DRSZ OF2, JP LOPC, DRSZOF1, JP LOPD RET

ACK1:
SBIT 2,
JP ACLK,
ACK:
RBIT 2,
ACLK:
SBIT 3,
NOP
NOP
NOP
RBIT 3,
SBIT 2,
RET
.END
\#OFF
;TO PRODUCE 40 MSEC
; TIMEOUT
\#0.20 ; SIMPLE WAIT LOOP
;TO PROPERLY PROGRAM ; EEPROM. TIME REQUIRED ;TO ERASE/WRITE ;THE EEPART.

## PORTLC ; INDICATE TO EE-PROM

 ; (PUT DATA LINE LOW)PORTLC ; PUT DATA-LINE HI-Z
;AND GET ACKNOWLEDGE ; 8 BITS ARE SHIFTED, ;DO A DUMMY CLOCK

PORTLD ; (FOR ACKNOWLEDGE)
PORTLC

Section 5

## Quality and Reliability

Section 5 Contents
EPROM and EEPROM Reliability Information ...................................................... 5-3

Reliability testing of National Semiconductor's EPROMs and EEPROMs has been on the basis of accept on zero, reject on one. Sampling has typically been on the basis of 77 units. Since the qualification for hermetic and plastic devices is somewhat different, they are separated into two sections below.

## HERMETIC DEVICES (EPROMs)

Typical packages for EPROMs are the Cer-DIP and Ceramic Leadless Chip Carrier, CLCC. Both meet industry standard hermeticity tests and are monitored as part of the assembly process. The following 3 principal tests are used for qualification of a new device or revision of an existing qualified device:

1. The Operating Life test is at $150^{\circ} \mathrm{C}$ with $V_{C C}$ at specification maximum-which in most cases is 5.5 V . Release is given after 3 lots have completed 500 hours.
Note: The 3 lots are from 3 distinct wafer fabrication and assembly lots. This helps verify the reliability and reproducibility of the device. The stress is continued for at least 1,000 hours to insure the long term performance of NSC EPROMs. The devices are typically programmed to a checkerboard type pattern.
2. The Static Bake test is at $250^{\circ} \mathrm{C}$ with no power applied. The purpose of this test is to insure the pattern remains correct for many years in customer applications. Acceptance of the pattern is done after 168 hours with no sample failure on 3 separate wafer and assembly lots. The most common pattern utilized is checkerboard, although variations are used depending on the final test flow. Our goal is to verify that no loss of pattern or pattern sensitivity has occurred. The testing is continued beyond 168 hours to determine performance margin and initial durability. The devices are tested for total electrical performance with emphasis on any charge change characteristic.
3. The Temperature Cycling test is done from $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ for 1,000 cycles. The devices are checked for electrical performance. Any degradation is considered a defect. Again, 3 wafer lots are sampled.

## PLASTIC DEVICES (EPROMs and EEPROMs)

In addition to the Operating Life, Storage Life, and Temperature Cycling tests mentioned above, Autoclave and Temperature Humidity Bias testing (85:85) are also done.

1. The Operating Life is identical to that of the hermetic testing described above, i.e., $150^{\circ} \mathrm{C}$ for EPROMs and 1000 hours at $125^{\circ} \mathrm{C}$ for EEPROMs.
2. Static Bake does not exceed $150^{\circ} \mathrm{C}$ for both EPROMs and EEPROMs since the plastic molding compounds cannot withstand higher temperatures for an extended period of time. To partially compensate for this, the stress is extended to 1,000 hours at or below $150^{\circ} \mathrm{C}$. Again, the pattern is usually checkerboard.
3. The Temperature Cycling is identical to that of the hermetic testing $\left(-65^{\circ} \mathrm{C}\right.$ to $+150^{\circ} \mathrm{C}$ for 1,000 cycles).
4. Temperature Humidity Bias testing is done at $85^{\circ} \mathrm{C}$ and $85 \%$ relative humidity. The part is programmed and biased in a non-functioning mode with only DC power applied, at 5.5 V . The power application is chosen to minimize power consumption to avoid heating the part and to maximize internal fields. The stress is continued for 1,000 hours. Any shift beyond datasheet limits is considered a failure. Any electrical failure prevents qualification.
5. Autoclave is also done on patterned devices. Any shift in electrical characteristics beyond datasheet limits is considered a failure. 168 hours for EPROMs and 500 hours for EEPROMs are minimum duration times. This stress is normally continued beyond 168 hours for both EPROMs and EEPROMs to determine device margins.

## EPROM AND EEPROM RELIABILITY AUDITS

Quarterly audits are conducted to make certain there are no changes in the reliability of the product going to customers. The accept criteria is zero for these audits.
Graphs of the 168 and 1000 hour test data are forwarded to corporate management each month to verify that the EPROMs and EEPROMs meet expected standards.

## WAFER LEVEL RELIABILITY

In addition to the classic reliability described above, National Semiconductor has a program in place that monitors performance of the dielectrics, metal and poly layers. This program is termed WLR (Wafer Level Reliability), and its purpose is to insure that the layers are processed correctly and perform at their designed values. Examples of dielectric relability are $Q_{b d}$ (charge to break down), step coverage, and pinhole testing. Examples of metal testing include step coverage, thickness, and hillock control.

## EPROM Qualification/Audit Criteria

QUALIFICATION CRITERIA

| Test | Conditions |  | Duration | Accept |
| :---: | :---: | :---: | :---: | :---: |
| Operating Life | $\mathrm{V}_{\mathrm{CC}}$ : <br> Temperature: | $\begin{aligned} & 5.5 \mathrm{~V} \\ & +125^{\circ} \mathrm{C} \end{aligned}$ | 1,000 Hours | 0 |
| Temperature/Humidity Bias | $V_{C C}$ : <br> Temperature: Humidity: | $\begin{aligned} & 5.5 \mathrm{~V} \\ & +85^{\circ} \mathrm{C} \\ & 85 \% \mathrm{RH} \end{aligned}$ | 1,000 Hours | 0 |
| Temperature Cycle | $-65^{\circ} \mathrm{C} \longleftrightarrow+150^{\circ} \mathrm{C}$ |  | 1,000 Cycles | 0 |
| Autoclave (Unbiased) | Temperature: Pressure: | $\begin{aligned} & 121^{\circ} \mathrm{C} \\ & 15 \mathrm{PSIG} \end{aligned}$ | 168 Hours | 0 |
| High Temperature Storage Life | Plastic Temperature: | $150^{\circ} \mathrm{C}$ | 1,000 Hours | 0 |
| High Temperature Storage Life | Ceramic Temperature: | $250^{\circ} \mathrm{C}$ | 168 Hours | 0 |
| Electrostatic Discharge (ESD) | Voltage: | $\pm 2000 \mathrm{~V}$ |  |  |
| EPROM PERIODIC AUDIT CRITERIA |  |  |  |  |


| Test | Conditions |  | Duration | Accept |
| :---: | :---: | :---: | :---: | :---: |
| Operating Life | $\mathrm{V}_{\mathrm{CC}}$ : <br> Temperature: | $\begin{aligned} & 5.5 \mathrm{~V} \\ & +125^{\circ} \mathrm{C} \end{aligned}$ | 1,000 Hours | 0 |
| Temperature/Humidity Bias | $\mathrm{V}_{\mathrm{CC}}$ : <br> Temperature: Humidity: | $\begin{aligned} & 5.5 \mathrm{~V} \\ & +85^{\circ} \mathrm{C} \\ & 85 \% \mathrm{RH} \end{aligned}$ | 1,000 Hours | 0 |
| Temperature Cycle (Unbiased) | $-65^{\circ} \mathrm{C} \longleftrightarrow+150^{\circ} \mathrm{C}$ |  | 1,000 Cycles | 0 |
| Autoclave (Unbiased) | Temperature: Pressure: | $\begin{aligned} & +121^{\circ} \mathrm{C} \\ & 15 \mathrm{PSIG} \end{aligned}$ | 168 Hours | 0 |

## EEPROM Qualification/Audit Criteria

QUALIFICATION CRITERIA

| Test | Conditions |  | Duration | Accept |
| :---: | :---: | :---: | :---: | :---: |
| Operating Life Dynamic Burn-In | $V_{c c}$ : <br> Temperature: | $\begin{aligned} & 5.5 \mathrm{~V} \\ & +125^{\circ} \mathrm{C} \end{aligned}$ | 1,000 Hours | 0 |
| Temperature/Humidity Bias | VCC: <br> Temperature: Humidity: | $\begin{aligned} & 5.5 \mathrm{~V} \\ & +85^{\circ} \mathrm{C} \\ & 85 \% \mathrm{RH} \end{aligned}$ | 1,000 Hours | 0 |
| Temperature Cycle (Unbiased) | $-65^{\circ} \mathrm{C} \longleftrightarrow+150^{\circ} \mathrm{C}$ |  | 1,000 Cycles | 0 |
| Autoclave (Unbiased) | Temperature: Pressure: | $\begin{aligned} & 121^{\circ} \mathrm{C} \\ & 15 \mathrm{PSIG} \end{aligned}$ | 500 Hours | 0 |
| High Temperature Storage Life | Temperature: | $150^{\circ} \mathrm{C}$ | 1,000 Hours | 0 |
| Electrostatic Discharge (ESD) | Voltage: | $\pm 2000 \mathrm{~V}$ |  |  |

EEPROM PERIODIC AUDIT CRITERIA

| Test | Conditions |  | Duration | Accept |
| :---: | :---: | :---: | :---: | :---: |
| Operating Life (Dynamic Burn-In) | $\mathrm{V}_{\mathrm{CC}}$ : <br> Temperature: | $\begin{aligned} & 6.0 \mathrm{~V} \\ & +125^{\circ} \mathrm{C} \end{aligned}$ | 1,000 Hours | 0 |
| Temperature/Humidity Bias | $V_{C C}$ : <br> Temperature: Humidity: | $\begin{aligned} & 5.5 \mathrm{~V} \\ & +85^{\circ} \mathrm{C} \\ & 85 \% \mathrm{RH} \end{aligned}$ | 1,000 Hours | 0 |
| Temperature Cycle (Unbiased) | $-40^{\circ} \mathrm{C} \longleftrightarrow+150^{\circ} \mathrm{C}$ |  | 1,000 Cycles | 0 |
| Temperature Cycle (Unbiased) | $-65^{\circ} \mathrm{C} \longleftrightarrow+150^{\circ} \mathrm{C}$ |  | 1,000 Cycles | 0 |
| Autoclave (Unbiased) | Temperature: Pressure: | $\begin{aligned} & +121^{\circ} \mathrm{C} \\ & 15 \mathrm{PSIG} \end{aligned}$ | 500 Hours | 0 |

Note: Except for MIL-AERO parts, all EEPROMs are shipped in plastic packages.

## Section 6 Physical Dimensions

Section 6 Contents

Bookshelf
Distributors

## 16 Lead Ceramic Dual-In-Line Package (J) NS Package Number J16A



## 18 Lead Ceramic Dual-In-Line Package (J) NS Package Number J18A



## 20 Lead Ceramic Dual-In-Line Package (J) NS Package Number J20A



## 24 Lead EPROM Ceramic Dual-In-Line Package (JQ) (Small Window) NS Package Number J24AQ



## 28 Lead EPROM Ceramic Dual-In-Line Package (JQ) (Small Window) NS Package Number J28AQ



## 28 Lead EPROM Ceramic Dual-In-Line Package (JQ) (Medium Window) NS Package Number J28CQ



## 32 Lead EPROM Ceramic Dual-In-Line Package (JQ) NS Package Number J32AQ



## 40 Lead EPROM Ceramic Dual-In-Line Package (JQ) NS Package Number J40AQ



## 40 Lead EPROM Ceramic Dual-In-Line Package (JQ) NS Package Number J40BQ



## 8 Lead (0.150" Wide) Molded Small Outline Package (M) NS Package Number M08A



## 14 Lead (0.150" Wide) Molded Small Outline Package (M)

 NS Package Number M14A

## 14 Lead ( 0.300 " Wide) Molded Small Outline Package (M) NS Package Number M14B



## 32 Lead TSOP, EIAJ Type I (M) NS Package Number MBH32A



## 8 Lead Molded Dual-In-Line Package (N) <br> NS Package Number N08E



14 Lead Molded Dual-In-Line Package (N) NS Package Number N14A


OPTION 02


## 16 Lead Molded Dual-In-Line Package (N) NS Package Number N16A



## 18 Lead Molded Dual-In-Line Package (N)

 NS Package Number N18A

## 20 Lead Molded Dual-In-Line Package (N) NS Package Number N20A



N2OA (REV G)

## 28 Lead Molded Dual-In-Line Package (N) NS Package Number N28B



## 40 Lead Molded Dual-In-Line Package (N) NS Package Number N40A



NaOA (REVE)

## 20 Lead Plastic Chip Carrier (V) NS Package Number V20A



## 28 Lead Plastic Chip Carrier (V) NS Package Number V28A



## 44 Lead Plastic Chip Carrier (V) NS Package Number V44A



VASA (REV H)

## 32 Lead Plastic Chip Carrier (V) NS Package Number VA32A



## NOTES

Bookshelf of Technical Support Information<br>National Semiconductor Corporation recognizes the need to keep you informed about the availability of current technical literature.<br>This bookshelf is a compilation of books that are currently available. The listing that follows shows the publication year and section contents for each book.<br>Please contact your local National sales office for possible complimentary copies. A listing of sales offices follows this bookshelf.<br>We are interested in your comments on our technical literature and your suggestions for improvement.<br>Please send them to:<br>Technical Communications Dept. M/S 16-300<br>2900 Semiconductor Drive<br>P.O. Box 58090<br>Santa Clara, CA 95052-8090

ALS/AS LOGIC DATABOOK—1990<br>Introduction to Advanced Bipolar Logic • Advanced Low Power Schottky • Advanced Schottky

# ASIC DESIGN MANUAL/GATE ARRAYS \& STANDARD CELLS—1987 <br> SSI/MSI Functions • Peripheral Functions • LSI/VLSI Functions • Design Guidelines • Packaging 

## CMOS LOGIC DATABOOK—1988

CMOS AC Switching Test Circuits and Timing Waveforms • CMOS Application Notes • MM54HC/MM74HC MM54HCT/MM74HCT • CD4XXX • MM54CXXX/MM74CXXX • Surface Mount

## DATA ACQUISITION LINEAR DEVICES—1989

Active Filters • Analog Switches/Multiplexers • Analog-to-Digital Converters • Digital-to-Analog Converters Sample and Hold • Temperature Sensors • Voltage Regulators • Surface Mount

## DATA ACQUISITION DATABOOK SUPPLEMENT-1992

New devices released since the printing of the 1989 Data Acquisition Linear Devices Databook.

## DISCRETE SEMICONDUCTOR PRODUCTS DATABOOK—1989

Selection Guide and Cross Reference Guides • Diodes • Bipolar NPN Transistors Bipolar PNP Transistors • JFET Transistors • Surface Mount Products • Pro-Electron Series Consumer Series • Power Components • Transistor Datasheets • Process Characteristics

## DRAM MANAGEMENT HANDBOOK—1991

Dynamic Memory Control • Error Detection and Correction • Microprocessor Applications for the DP8408A/09A/17/18/19/28/29 • Microprocessor Applications for the DP8420A/21A/22A Microprocessor Applications for the NS32CG821

## EMBEDDED CONTROLLERS DATABOOK—1992

COP400 Family • COP800 Family • COPS Applications • HPC Family • HPC Applications
MICROWIRE and MICROWIRE/PLUS Peripherals • Microcontroller Development Tools

## EMBEDDED SYSTEM PROCESSOR DATABOOK—1989

Embedded System Processor Overview • Central Processing Units • Slave Processors • Peripherals Development Systems and Software Tools

## FDDI DATABOOK—1991

FDDI Overview • DP83200 FDDI Chip Set • Development Support • Application Notes and System Briefs
F100K ECL LOGIC DATABOOK \& DESIGN GUIDE—1990
Family Overview • 300 Series (Low-Power) Datasheets • 100 Series Datasheets •11C Datasheets ECL BiCMOS SRAM, ECL PAL, and ECL ASIC Datasheets • Design Guide • Circuit Basics • Logic Design Transmission Line Concepts • System Considerations • Power Distribution and Thermal Considerations Testing Techniques • Quality Assurance and Reliability • Application Notes
FACTTM ADVANCED CMOS LOGIC DATABOOK—1990
Description and Family Characteristics • Ratings, Specifications and Waveforms Design Considerations • 54AC/74ACXXX • 54ACT/74ACTXXX • Quiet Series: 54ACQ/74ACQXXX Quiet Series: 54ACTQ/74ACTQXXX • 54FCT/74FCTXXX • FCTA: 54FCTXXXA/74FCTXXXA
FAST® ADVANCED SCHOTTKY TTL LOGIC DATABOOK-1990
Circuit Characteristics • Ratings, Specifications and Waveforms • Design Considerations•54F/74FXXX
FAST® ${ }^{\circledR}$ APPLICATIONS HANDBOOK—1990
Reprint of 1987 Falrchlld FAST Applications HandbookContains application information on the FAST family: Introduction • Multiplexers • Decoders • EncodersOperators • FIFOs • Counters • TTL Small Scale Integration • Line Driving and System DesignFAST Characteristics and Testing • Packaging Characteristics
GENERAL PURPOSE LINEAR DEVICES DATABOOK—1989
Continuous Voltage Regulators • Switching Voltage Regulators • Operational Amplifiers • Buffers • Voltage Comparators Instrumentation Amplifiers - Surface Mount
GRAPHICS HANDBOOK—1989Advanced Graphics Chipset • DP8500 Development Tools • Application Notes
IBM DATA COMMUNICATIONS HANDBOOK—1992IBM Data Communications • Application Notes
INTERFACE: LINE DRIVERS AND RECEIVERS DATABOOK—1992EIA-232 • EIA-422/423 • EIA-485 • Line Drivers • Receivers • Repeaters • Transceivers • Application Notes
LINEAR APPLICATIONS HANDBOOK-1991The purpose of this handbook is to provide a fully indexed and cross-referenced collection of linear integrated circuitapplications using both monolithic and hybrid circuits from National Semiconductor.Individual application notes are normally written to explain the operation and use of one particular device or to detail variousmethods of accomplishing a given function. The organization of this handbook takes advantage of this innate coherence bykeeping each application note intact, arranging them in numerical order, and providing a detailed Subject Index.LOCAL AREA NETWORK DATABOOK—1992Integrated Ethernet Network Interface Controller Products • Ethernet Physical Layer TransceiversEthernet Repeater Interface Controller Products • Hardware and Software Support Products • FDDI Products • Glossary
MASS STORAGE HANDBOOK-1989
Rigid Disk Pulse Detectors • Rigid Disk Data Separators/Synchronizers and ENDECsRigid Disk Data Controller • SCSI Bus Interface Circuits • Floppy Disk Controllers • Disk Drive Interface CircuitsRigid Disk Preamplifiers and Servo Control Circuits • Rigid Disk Microcontroller Circuits • Disk Interface Design GuideMEMORY DATABOOK—1992CMOS EPROMs • CMOS EEPROMs • PROMs • Application Notes
MICROPROCESSOR DATABOOK—1989Series 32000 Overview • Central Processing Units • Slave Processors • PeripheralsDevelopment Systems and Software Tools • Application Notes • NSC800 Family

## REAL TIME CLOCK HANDBOOK—1991 <br> Real Time Clocks and Timer Clock Peripherals • Application Notes

## RELIABILITY HANDBOOK—1986

Reliability and the Die • Internal Construction • Finished Package • MIL-STD-883 • MIL-M-38510 The Specification Development Process • Reliability and the Hybrid Device • VLSI/VHSIC Devices Radiation Environment • Electrostatic Discharge • Discrete Device • Standardization Quality Assurance and Reliability Engineering • Reliability and Documentation • Commercial Grade Device European Reliability Programs • Reliability and the Cost of Semiconductor Ownership Reliability Testing at National Semiconductor • The Total Military/Aerospace Standardization Program 883B/RETSTM Products • MILS/RETSTM Products • 883/RETSTM Hybrids • MIL-M-38510 Class B Products Radiation Hardened Technology • Wafer Fabrication • Semiconductor Assembly and Packaging Semiconductor Packages • Glossary of Terms • Key Government Agencies • AN/ Numbers and Acronyms Bibliography • MIL-M-38510 and DESC Drawing Cross Listing

## SPECIAL PURPOSE LINEAR DEVICES DATABOOK—1989

Audio Circuits • Radio Circuits • Video Circuits • Motion Control Circuits • Special Function Circuits Surface Mount

## TELECOMMUNICATIONS—1992

COMBO and SLIC Devices • ISDN • Digital Loop Devices • Analog Telephone Components • Software Application Notes

## NATIONAL SEMICONDUCTOR CORPORATION DISTRIBUTORS

ALABAMA
Huntsville
Arrow Electronics
(205) 837-6955

Bell Industries
(205) 837-1074

Hamilton/Avnet
(205) 837.7210

Pioneer Technology
(205) 837-9300

Time Electronics
(205) 721-1 133

ARIZONA
Chandler
Hamilton/Avnet
(602) 961-1211

Phoenix
Arrow Electronics (602) 437-0750

Tempe
Anthem Electronics
(602) 966-6600

Bell Industries
(602) 966-7800

Time Electronics
(602) 967-2000

CALIFORNIA
Agora Hills
Bell Industries
(818) 706-2608

Time Electronics
(818) 707-2890

Zeus Components
(818) 889-3838

Burbank
Elmo Semiconductor (818) 768-7400

Calabasas
F/X Electronics (818) 592-0120

Chatsworth
Anthem Electronics
(818) 775-1333

Arrow Electronics
(818) 701-7500

Time Electronics
(B18) 998-7200
Costa Mesa
Hamilton Electro Sales
(714) 641-4100

Cypress
Bell Industries
(714) 895-7801

Gardena
Hamilton/Avnet
(213) 516-8600

Irvine
Anthem Electronics
(714) 768-4444

Rocklin
Anthem Electronics
(916) 624-9744

Bell Industries
(916) 652-0414

Roseville
Hamilton/Avnet
(916) 925-2216

San Diego
Anthem Electronics
(619) 453-9005 Arrow Electronics (619) 565-4800 Hamilton/Avnet (619) 571-1900 Time Electronics (619) 586-0129

San Jose
Anthem Electronics
(408) 453-1200

Arrow Electronics
(408) 441-9700

Pioneer Technology (408) 954-9100 Zeus Components (408) 629-4789

Sunnyvale Bell Industries
(408) 734-8570

Hamilton/Avnet
(408) 743-3300

Time Electronics
(408) 734-9888

Torrance
Time Electronics
(213) $320-0880$

Tustin
Arrow Electronics
(714) 838-5422 Time Electronics (714) 669-0100

Woodland Hills
Hamilton/Avnet (818) 594-0404

Yorba Linda Zeus Components (714) 921-9000

COLORADO
Aurora
Arrow Electronics (303) 373-5616

Denver
Bell Industries
(303) 691-9010

Englewood
Anthem Electronics
(303) 790-4500

Hamilton/Avnet
(303) $799-7800$

Time Electronics
(303) 721-8882

CONNECTICUT
Danbury
Hamilton/Avnet (203) 743-6077

Shelton
Pioneer Standard
(203) 929-5600

Wallingford
Arrow Electronics
(203) 265-7741

Waterbury
Anthem Electronics
(203) 575-1575

FLORIDA
Altamonte Springs
Bell Industries
(407) 339-0078

Pioneer Technology
(407) 834-9090

Zeus Components
(407) 788-9100

Deerfield Beach
Arrow Electronics
(305) 429-8200

Bell Industries
(305) 421-1997

Pioneer Technology
(305) 428-8877

Fort Lauderdale
Hamilton/Avnet
(305) 767-6377

Time Electronics
(305) 484-7778

Lake Mary Arrow Electronics (407) 333-9300

Orlando
Chip Supply
(407) 298-7100

Time Electronics
(407) 841-6565

St. Petersburg
Hamilton/Avnet (813) 572-4329

Winter Park Hamilton/Avnet (407) 657-3300

## GEORGIA

Duluth
Arrow Electronics (404) 497-1300 Hamilton/Avnet (404) 446-0611 Pioneer Technology (404) 623-1003

Norcross Bell Industries (404) 662-0923 Time Electronics (404) 368-0969
illinois
Addison
Pioneer Electronics (708) 495-9680

Bensenville Hamilton/Avnet (708) 860-7700

Elk Grove Village Bell Industries (708) 640-1910

Itasca
Arrow Electronics (708) 250-0500

Schaumburg Anthem Electronics (708) 884-0200 Time Electronics (708) 303-3000

## indiana

Carmel
Hamilton/Avnet
(317) 844-9333

Fort Wayne Bell Industries (219) 423-3422

Indianapolis Advent Electronics Inc. (317) 872-4910 Arrow Electronics (317) 299-2071 Bell Industries (317) 875-8200 Pioneer Standard (317) 573-0880

IOWA
Cedar Rapids Advent Electronics (319) 363-0221 Arrow Electronics (319) 395-7230 Hamilton/Avnet (319) 362-4757

## KANSAS

Lenexa
Arrow Electronics
(913) 541-9542

Hamilton/Avnet
(913) 888-8900

MARYLAND
Columbia
Anthem Electronics
(301) 995-6840

Arrow Electronics
(301) 596-7800

Time Electronics
(301) 964-3090 Zeus Components (301) 997-1118

Gaithersburg
Pioneer Technology (301) 921-0660

MASSACHUSETTS
Andover
Bell Industries (508) 474-8880

Beverly
Sertech Laboratories (508) 927-5820

Lexington Pioneer Standard (617) 861-9200

Norwood Gerber Electronics (617) 769-6000

Peabody
Hamilton/Avnet
(508) 531-7430

Time Electronics (508) 532-9900

Tyngsboro Port Electronics (508) 649-4880

Wakefield Zeus Components (617) 246-8200

Wilmington Anthem Electronics (508) 657-5170 Arrow Electronics (508) 658-0900

MICHIGAN
Grand Rapids Pioneer Standard (616) 698-1800

Grandville Hamilton/Avnet (616) 243-8805

Livonia
Arrow Electronics
(313) 462-2290 Pioneer Standard (313) 525-1800

Novi
Hamilton/Avnet
(313) 347-4720

Wyoming
R. M. Electronics, Inc. (616) 531-9300

MINNESOTA
Eden Prairie Anthem Electronics (612) 944-5454 Arrow Electronics (612) $828-7140$ Pioneer Standard (612) $944-3355$

Edina
Arrow Electronics (612) 830-1800 Time Electronics (612) 943-2433

Minnetonka
Hamilton/Avnet (612) 932-0600

## NATIONAL SEMICONDUCTOR CORPORATION DISTRIBUTORS (Continued)

MISSOURI
Chesterfield
Hamilton/Avnet (314) 537-1600

St. Louis
Arrow Electronics
(314) 567-6888

Time Electronics
(314) 391-6444

NEW JERSEY
Cherry Hill
Hamilton/Avnet
(609) 424-0100

Fairfield
Hamilton/Avnet
(201) 575-3390

Pioneer Standard
(201) 575-3510

Marlton
Arrow Electronics
(609) 596-8000

Time Electronics (609) 596-6700

Pine Brook
Anthem Electronics
(201) 227-7960

Arrow Electronics
(201) 227-7880

Wayne
Time Electronics
(201) 758-8250

NEW MEXICO
Albuquerque
Alliance Electronics Inc.
(505) 292-3360

Bell Industries
(505) 292-2700

Hamilton/Avnet
(505) 345-0001

NEW YORK
Binghamton Pioneer 607) 722-9300

Buffalo Summit Electronics (716) 887-2800

Commack Anthem Electronics (516) 864-6600

Fairport
ioneer Standard
(716) 381-7070

Hauppauge
Arrow Electronics
516) 231-1000

Hamilton/Avnet
(516) 231-9444

Time Electronics (516) 273-0100

Port Chester Zeus Components (914) 937-7400

Rochester
Arrow Electronics (716) 427-0300 Hamilton/Avnet (716) 292-0730 Summit Electronics (716) 334-8110

Ronkonkoma Zous Components (516) 737-4500

Syracuse Hamilton/Avnet (315) 437-2641 Time Electronics (315) 432-0355

Westbury
Hamilton/Avnet Export Div. (516) 997-6868

Woodbury
Pioneer Electronics
(516) 921-8700

NORTH CAROLINA
Charlotte
Hamilton/Avnet
(704) 527-2485

Pioneer Technology (704) 527-8188

Durham
Pioneer Technology (919) 544-5400

Raleigh
Arrow Electronics
(919) 876-3132

Hamilton/Avnet
(919) $878-0810$ Time Electronics (919) 874-9650

OHIO
Centerville Arrow Electronics (513) 435-5563

Cleveland Pioneer (216) 587-3600

Columbus Time Electronics (614) 794-3301

Dayton
Bell Industries (513) 435-8660 Bell Industries-Military (513) 434-8231 Hamilton/Avnet (513) 439-6700 Pioneer Standard (513) 236-9900 Zeus Components (513) 293-6162 Solon Arrow Electronics (216) 248-3990 Hamilton/Avnet (216) 349-5100

Westerville Hamilton/Avnet (614) 882-7004

OKLAHOMA
Tulsa Arrow Electronics (918) 252-7537 Hamilton/Avnet (918) 664-0444 Pioneer Standard (918) 665-7840 Radio Inc. (918) 587-9123

OREGON Beaverton Anthem Electronics (503) 643-1114 Arrow Electronics (503) 626.7667 Hamilton/Avnet (503) 627-0201

Lake Oswego Bell Industries (503) 635-6500

Portland Time Electronics (503) 684-3780

PENNSYLVANIA
Horsham
Anthem Electronics (215) 443-5150 Pioneer Technology (215) 674-4000

Mars
Hamilton/Avnet (412) 281-4150

Pittsburgh Pioneer (412) $782-2300$

TEXAS
Austin Arrow Electronics (512) 835-4180 Hamilton/Avnet (512) 837-8911 Minco Technology Labs. (512) 834-2022 Pioneer Standard (512) $835-4000$ Time Electronics (512) 346-7346

Carrollton
Arrow Electronics (214) 380-6464

Dallas Hamilton/Avnet (214) 308-8111 Pioneer Standard (214) 386-7300

Houston
Arrow Electronics (713) 530-4700 Hamilton/Avnet (713) 240-7733 Pioneer Standard (713) 495-4700

Richardson Anthem Electronics (214) 238-7100 Time Electronics (214) 644-4644 Zeus Components (214) 783-7010

UTAH
Midvale Bell Industries (801) 255-9611

Salt Lake City Anthem Electronics (801) 973-8555 Arrow Electronics (801) 973-6913 Hamilton/Avnet (801) 972-2800

West Valley Time Electronics (801) 973-8494

WASHINGTON
Bellevue Arrow Electronics (206) 643-4800

Bothell Anthem Electronics (206) 483-1700

Kirkland Time Electronics (206) 820-1525

Redmond Bell Industries (206) 867-5410 Hamilton/Avnet (206) 241-8555

WISCONSIN
Brookfield Arrow Electronics (414) 792-0150 Pioneer Electronics (414) 784-3480

Mequon
Taylor Electric (414) 241-4321

Waukesha Bell Industries (414) 547-8879 Hamilton/Avnet (414) 784-8205

## CANADA

WESTERN PROVINCES
Burnaby
Hamilton/Avnet
(604) 420-4 101

Semad Electronics
(604) 420-9889

Calgary
Electro Sonic Inc.
(403) 255-9550

Semad Electronics
(403) 252-5664

Zentronics
(403) 295-8838

Edmonton
Zentronics
(403) 468-9306

Markham Semad Electronics Ltd. (416) 475-3922

Richmond Electro Sonic Inc. (604) 273-2911 Zentronics
(604) 273-5575

Saskatoon Zentronics (306) 955-2207

Winnipeg Zentronics (204) 694-1957

EASTERN PROVINCES
Mississauga Hamilton/Avnet (416) 795-3825 Time Electronics (416) 672-5300 Zentronics (416) 564-9600

Nepean Hamilton/Avnet (613) 226-1700 Zentronics (613) 226-8840

Ottawa Electro Sonic Inc. (613) 728-8333 Semad Electronics (613) 727-8325

Pointe Claire Semad Electronics (514) 694-0860

St. Laurent Hamilton/Avnet (514) 335-1000 Zentronics (514) 737-9700

Willowdale ElectroSonic Inc. (416) 494-1666

Winnipeg Electro Sonic Inc. (204) 783-3105

## National Semiconductor Corporation

2900 Semiconductor Drive
P.O. Box 58090

Santa Clara, CA 95052-8090
Tel: 1-800-272-9959
TWX: (910) 339-9240

SALES OFFICES (Continued)

## INTERNATIONAL OFFICES

Electronica NSC de Mexico SA
Juventino Rosas No. 118-2
Col Guadalupe inn
Mexico, 01020 D.F. Mexico
Tel: 52-5-524-9402
Fax: 52-5-524-9342
National Semicondutores
Do Brasil Ltda.
Av. Brig. Faria Lima, 1409 6.0 Andar

Cep. 01451 J. Paulistano
Sao Paulo, SP. Brasil
Tel: (55/11) 212-5066
Telex: 3911131931
Fax: (55/11) 212-1181 NSBR BR
National Semiconductor GmbH
Eschborner Lanstr. 130-132
D-6000 Frankfurt 90
Germany
Tel: (069) 7891 09-0
Fax: (069) 78943.83
National Semiconductor GmbH
ndustriestrasse 10
D-8080 Furstenfeldbruck Germany
Tel: (0.81-41) 103-0
Telex: 527-649
Fax: (08141) 103554
National Semiconductor GmbH
Misburger Strasse 81D
D3000 Hannover 61
Germany
Tel: (0511) 560040
Fax: (0511) 561740
National Semiconductor GmbH
Untere Waldplatze 37
D-7000 Stuttgart 80
Germany
Tel: 711686511
Fax: 7116865260
National Semiconductor (UK) Ltd.
The Maple, Kembrey Park
Swindon. Wiltshire SN2 6UT
United Kingdom
Tel: (07-93) 61-41-41
Telex: 444-674
Fax: $(07-93)$ 69.75-22

National Semiconductor Benelux
Vorstlaan 100
B-1170 Brussels
Belgium
Tel: (02) 6-61-06-80
Telex: 61007
Fax: (02) 6-60-28-95
National Semiconductor (UK) Ltd.
Ringager 4A, 3
DK-2605 Brandy
Denmark
Tel: (02) 43-32-11
Telex: 15-179
Fax: (02) 43-31-11
National Semiconductor S.A.
Centre d'Affares-La Boursidiere
Bâtiment Champagne, B.P. 90
Route Nationale 186
F-92357 Le Plessis Robinson
Paris. France
Tel: (1) 40-94-88-88
Telex: 631065
Fax: (1) 40-94-88-11
National Semiconductor (UK) Ltd. Unit 2A
Clonskeagh Square
Clonskeagh Road
Dublin 14
Ireland
Tel: (01) 269-55-89
Telex: 91047
Fax: (01) 2830650
National Semiconductor S.p.A
Strada 7. Palazzo R/3
1-20089 Rozzano
Milanofiori
Italy
Tel: (02) 57500300
Twx: 352647
Fax: (02) 57500400
National Semiconductor S.p.A.
Via del Cararaggio, 107
1-00147 Rome
Italy
Tel: (06) 5-13-48-80
Fax: (06) 5-13-79-47
National Semiconductor (UK) Ltd.
Isveien 45
Postboks 57
N -1393 Ostenstad
Norway
Tel: (2) 796500
Fax: (2) 796040

National Semiconductor AB
P. O. Box 1009

Grosshandlarvaegen 7
S-121 23 Johanneshov
Sweden
Tel: 46-8-7228050
fax: 46-8-7229095
Telex: 10731 NSC S
National Semiconductor GmbH
Calle Agustin de Foxa. 27 (9D)
E-28036 Madrid
Spain
Tel: (01) 733-2958
Telex: 46133
Fax: (01) 733-8018
National Semiconductor
Switzerland
Alte Winterthurerstrasse 53
Posttach 567
Ch-8304 Wallisellen-Zurich
Switzerland
el: (01) 830-2727
Telex: 828-444
Fax: (01) 830-1900
National Semiconductor
Kauppakartanonkatu 7 A2?
SF-00930 Helsinki
Finland
Tel: (90) 33-80-33
Telex: 126116
Fax: (90) 33-81-30
National Semiconductor Postbus 90
NL1380 AB Weesp
The Netherlands
Tel: (0-29-40) 3-04-48
Telex: 10.956
Fax: (0-29-40) 3-04-30
National Semiconductor Japan Ltd.
Sanseido Bldg. 5F
4-15-3 Nishi Shinjuku
Shinjuku-ku
Tokyo 160 Japan
Tel: (03) 3299-7001
Fax: (03) 3299-7000

National Semiconductor Hong Kong Ltd.
13th Floor, Straight Block
Ocean Centre
5 Canton Road. Tsimshatsui East.
Kowloon. Hong Kong
Tel: (852) 737-1600
Telex: 51292 NSHKL
Fax: (852) 736-9960
National Semiconductor
(Australia) PTY, Ltd.
Bldg. 16, Business Park Dr
Melbourne. 3168
Victoria. Australia
Tel: (03) 558-9999
Fax: 61-3-558-9998
National Semiconductor (PTE),
Ltd.
200 Cantonment Road 13-02
Southpoint 200
Singapore 0208
Tel: 2252229
Telex: RS 50808
Fax: (65) 225-7080
National Semiconductor (Far East)
Ltd.
Taiwan Branch
9th Floor. No. 18
Sec. 1. Chang An East Road
Taipei, Taiwan R.O.C.
Tel: (86) 521-3288
Telex: 22837 NSTW
Fax: 02 561-3054
National Semiconductor (Far East)
Ltd.
Korea Branch
13th Floor. Dai Han Life Insurance
63 Building.
60, Yoido-dong, Youngdeungpo-ku,
Seoul. Korea 150-763
Tel: (02) 784-8051
Telex: 24942 NSPKLO
Fax: (02) 784-8054


[^0]:    Note 1: $X$ can be $V_{I L}$ or $V_{I H}$.

[^1]:    "It is necessary to clock in the "Don't Care" address bits.

[^2]:    "It is necessary to clock in the "Don't Care" Address Bits

[^3]:    *Modes 0 thru 11 are logic level functions. Modes 12 and 13 are Analog switch functions.

[^4]:    TL/D/9712-1

