# MICROCHIP DATA BOOK 



Microchip

## Microchip Data Book

## Second Edition

"Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. No representation or warranty is given and no liability is assumed by Microchip Technology Inc. with respect to the accuracy or use of such information, or infringement of patents arising from such use or otherwise. Use of Microchip's products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights."

DEC, VAX, VMS, and ULTRIX are trademarks of Digital Equipment Corp.
MACINTOSH is a trademark of Apple Computer, Inc.
IBM and IBM PC are trademarks of IBM Corp.
SMC is a trademark of Standard Microsystems Corp.
PICPAK, PIC-ICE, PICPRO, PICALC, and PICSIM are trademarks of Microchip Technology Inc.
PIC is a registered trademark of Microchip Technology Inc.
The Microchip logo and name is a registered trademark of Microchip Technology Incorporated.
All rights reserved. Copyright © 1990, Microchip Technology Inc.
SECTION 1 SERIAL EEPROM PRODUCT SPECIFICATIONS
24C01A $\quad 1 \mathrm{~K}(128 \times 8)$ CMOS Serial Electrically Erasable PROM ..... 1- 1
24C01A Dice $\quad 1 \mathrm{~K}(128 \times 8)$ CMOS Serial Electrically Erasable PROM Die Form ..... 1- 9
24C02A 2K (256 X 8) CMOS Serial Electrically Erasable PROM ..... 1- 17
24C02A Dice 2K (256 X 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1-25
24C04A 4K (512 x 8) CMOS Serial Electrically Erasable PROM ..... 1-33
24C04A Dice $\quad 4 \mathrm{~K}(512 \times 8)$ CMOS Serial Electrically Erasable PROM Die Form ..... 1-41
59C11 1K (128 $\times 8$ or $64 \times 16$ ) CMOS Serial Electrically Erasable PROM ..... 1- 49
59C11 Dice $\quad 1 \mathrm{~K}(128 \times 8$ or $64 \times 16)$ CMOS Serial Electrically Erasable PROM Die Form ..... 1- 57
85C72 1K ( $128 \times 8$ ) CMOS Serial Electrically Erasable PROM ..... 1- 65
85C72 Dice 1K (128 x 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1-73
85C82 2K (256 x 8) CMOS Serial Electrically Erasable PROM ..... 1-81
85 C 82 Dic 2K (256 x 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1- 89
85C92 4K (512 x 8) CMOS Serial Electrically Erasable PROM ..... 1-97
85C92 Dice $\quad 4 \mathrm{~K}(512 \times 8)$ CMOS Serial Electrically Erasable PROM Die Form ..... 1-105
93C06 256 Bits (16 x 16) CMOS Serial Electrically Erasable PROM ..... 1-113
93C06 Dice 256 Bits ( $16 \times 16$ ) CMOS Serial Electrically Erasable PROM Die Form ..... 1-121
93C46 1K (64 x 16) CMOS Serial Electrically Erasable PROM ..... 1-129
93C46 Dice $\quad 1 \mathrm{~K}(64 \times 16)$ CMOS Serial Electrically Erasable PROM Die Form ..... 1-137
24CXX/85CXX 24CXX/85CXX To Microcontroller Communication ..... 1-145
ER59256/93C06 ER59256/93C06 And NMC9306/NMC93C06 Compatibility Issue ..... 1-155
24C01A 24C01A Compatibility Issue And Its Mobility For Memory Upgrade ..... 1-159

## SECTION 2 EEPROM PRODUCT SPECIFICATIONS

28C04A $4 \mathrm{~K}(512 \times 8)$ CMOS Electrically Erasable PROM ...................................................2- 1
28C16A 16K (2K x 8) CMOS Electrically Erasable PROM ..... 2- 9
28C17A 16K (2K x 8) CMOS Electrically Erasable PROM ..... 2- 17
28C17A Dice 16K (2K x 8) CMOS Electrically Erasable PROM Die Form ..... 2- 25
28C64A 64K (8K x 8) CMOS Electrically Erasable PROM ..... 2- 33
28C64A Dice 64K (8K x 8) CMOS Electrically Erasable PROM Die Form ..... 2- 41
SECTION 3 EPROM PRODUCT SPECIFICATIONS
27C64 64K (8K x 8) CMOS UV Erasable PROM ..... 3- 1
27C128 128K (16K x 8) CMOS UV Erasable PROM ..... 3- 9
27C256 256K (32K x 8) CMOS UV Erasable PROM ..... 3- 17
27C512 512K (64K x 8) CMOS UV Erasable PROM ..... 3- 25
27HC64 64 K ( $8 \mathrm{~K} \times 8$ ) High Speed CMOS UV Erasable PROM ..... 3- 33
27HC256 256K (32K x 8) High Speed CMOS UV Erasable PROM ..... 3- 41
27HC1616 256K (16K x 16) High Speed CMOS UV Erasable PROM ..... 3- 49
27HC641 64K (8K x 8) High Speed CMOS UV Erasable PROM ..... 3- 57
27Cxxx 27Cxxx EPROM Family Programming Algorithm ..... 3- 65

## Table of Contents

## SECTION 4 MICROCONTROLLER PRODUCT SPECIFICATIONS

PIC PIC 16xxx Series Microcontroller Family ..... 4- 1
PIC16C5X EPROM-Based 8-Bit CMOS Microcontroller Series ..... 4- 5
PIC1654S 8-Bit Microcontroller ..... 4- 35
PIC1655 8-Bit Microcontroller ..... 4- 51
PIC1670 8 Bit Microcontroller ..... 4- 67
SECTION 5 LOGIC PRODUCT SPECIFICATIONS
AY2661 Enhanced Programmable Communication Interface ..... 5- 1
AY3-1015D UAR/T: Universal Asynchronous Receiver/Transmitter ..... 5-17
AY58116/36 Dual Baud Rate Generator ..... 5- 29
AY58126/46 Single Baud Rate Generator ..... 5-37
AY38910A/12A Programmable Sound Generator ..... 5-45
AY8930 Enhanced Programmable Sound Generator ..... 5-61
AY0438-I 32-Segment CMOS LCD Driver ..... 5- 81
SECTION 6 DIGITAL SIGNAL PROCESSING PRODUCT SPECIFICATIONS
DSP Product Portfolio ..... 6- 1
DSP320C10 CMOS Digital Signal Processor (B Version) ..... 6- 5
DSP320C10 Development Tools ..... 6- 23
SECTION 7 QUALITY AND RELIABILITY
QA Quality Without Compromise ..... 7- 1
27Cxxx EPROM Plastic Package Reliability Bulletin ..... 7-11
SECTION 8 PACKAGING

## APPENDIX OFFICE LOCATIONS

Factory Representatives ..... A- 1
Distributors ..... A- 5
Field Offices ..... A- 12

Microchip

## Company Profile

## FEATURES

- Fully integrated manufacturing
- A global network of plants and facilities
- A history of innovation
- Strategic marketing focus
- A product family of shared strengths
- Quality without compromise
- Research and development of high performance products
- Performance alliance with customers
- A solid executive team with an eye towards innovation


## BUSINESS SCOPE

Microchip Technology manufactures and markets very large scale integrated circuits (VLSI). The Company's strong experience in CMOS nonvolatile memories, programmable microcontrollers and peripheral devices has positioned the firm as a leading supplier to manufacturers of computer peripheral, automotive, consumer, military and telecommunication products.


Company headquarters in Chandler, Arizona; executive offices, R \& D, and two wafer fabrication units occupy this 142,000 square-foot facility.

## Microchip Technology Incorporated



## GUIDING VALUES

## Customers Are Our Focus

We establish successful customer partnerships by exceeding customer expectations for products, services and attitude. We earn our credibility through meeting commitments and producing quality products and services in a timely fashion. We believe each employee must effectively serve their internal customers in order for Microchip's external customers to be properly served.

## Quality Comes First

We will perform correctly the first time, maintain customer satisfaction and measure our quality against requirements. We practice effective and standardized improvement methods, such as statistical process control to anticipate problems and implement root cause solutions. We believe that when quality comes first, reduced costs follow.

## Continuous Improvement Is Essential

We utilize the concept of "Vital Few" to establish our priorities. We concentrate our resources on continuously improving the Vital Few while empowering each employee to make continuous improvements in their area of responsibility. We strive for constructive and honest self-criticism to identify improvement opportunities.

## Employees Are Our Greatest Strength

We design jobs and provide opportunities in a fashion which clearly promotes pride in work, integrity, trust, teamwork, creativity, employee involvement and development, fairness, and productivity. We base recognition, advancementand compensation on an employee's achievement of excellence inteam and individual performance. We provide for employee health and welfare by offering a competitive, comprehensive employee benefits program.

## Shareholders Are The Owners Of Our Business

We understand that shareholders have invested in the Microchip team and will be provided with continuously increasing company net worth.

## Technology Is Our Foundation

We commit to ongoing investments and advancements in the design and development of our manufacturing process, device and circuit technologies, which are the basis for our products.

## Products Are The Result of Our Efforts

We develop technologies which provide reliable, innovative, and cost effective products to support current and future market opportunities. We understand that customers primarily view Microchip through the quality, service, cost, and technological leadership of our products.

## Total Cycle Times Are Competitive

We focus resources to optimize cycle times to our customers by empowering employees to achieve efficient cycle times in their area of responsibility. We believe that cycle time reduction is achieved by streamlining processes through the systematic removal of barriers to productivity.

## Safety Is Never Compromised

We place our concern for safety of our community and employees at the forefront of our decisions, policies and actions. Each employee is responsible for safety.

## Profits Provide For Everything We Do

We strive to maintain competitive pretax profits as they allow continued investments and future growth, and indicate the overall success of Microchip.

## Communication Is Vital

We encourage open, honest, constructive, and ongoing communication in all company and community relationships to resolve issues, exchange information and share knowledge.

## Suppliers, Representatives, And Distributors Are Our Partners

We maintain mutually beneficial partnerships with suppliers, representatives and distributors who are an integral link in the achievement of our mission and guiding values.

## Professional Ethics Are Practiced

We manage our business and treat customers, employees, shareholders, investors, suppliers, distributors, representatives, community and government in a manner that exemplifies our honesty, ethics and integrity. We recognize our responsibility to the community and are proud to serve as an equal opportunity employer.

## MICROCHIP: <br> A FULLY INTEGRATED COMPANY SERVING A GLOBAL MARKET

"Microchip Technology draws its impetus from the technology expectations of a large base of longstanding customers. Microchip is small enough to respond quickly with technology to equate the customer's need. Moreover, as a fully integrated IC Manufacturer, Microchip deploys its panoply of resources to act timely and efficiently, and on a worldwide scale: Design, Technology Development, Mask Shop, Wafer Fabrication, Assembly and Test, Customer Support.
"World-wide competition leaves no room for divergence or mediocrity. Therefore, Microchip Technology is committed to focus and to continuously improve all the vital aspects of its business. To improve performance, our employees are encouraged to analyze their methods continually. Personal empowerment trespasses the limits of personal responsibility to act in anticipation.
"Our industry's life-line is innovation. The fast pace of technological change is inherent in our industry. Microchip Technology has accelerated the rate of change of its technology and products to the forefront of the economical feasibility.
"Change is our ally. Driving and managing change is our winning strategy."


President

## Microchip Technology Incorporated

## A PRODUCT FAMILY OF SHARED STRENGTHS

## MICROCONTROLLERS

## SERIAL EEPROMs

## EEPROMs

The $1.2^{*}$ micron CMOS EEPROM devices from Microchip are available in $4 \mathrm{~K}, 16 \mathrm{~K}$, and 64 K densities. The manufacturing process used for these EEPROMs ensures 10,000 to 100,000 write and erase cycles. Data retention is over 10 years. Short write times are less than $200 \mu \mathrm{sec}$. These EEPROMs work reliably under demanding conditions and have been proven to operate efficiently at temperatures from $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$.

[^0]Common applications include computer peripherals, engine control, pattern recognition and telecommunications.

## EPROMs

## MILITARY PRODUCTS

## OTHER MICROCHIP <br> PRODUCTS

Microchip's CMOS EPROM devices are produced in densities from 64 K to 512 K . High Speed EPROMs have access times range as low as 45 nano-seconds. Microchip's process flow uniqueness lies in its simplicity. A minimum number of steps allow to offer a reliable family of commodity EPROMs, single metal EPROMs, and double metal EPROMs. Typical applications include computer peripheral, military, instrumentation, and automotive devices.

Microchip's expertise in Plastic Packaging, combined with its previous leadership in the ROM market, led to the development of the Plastic OTP EPROM market where Microchip the \#1 supplier today.

Microchip delivers military devices that conscientious engineers can use with confidence. Our 883C compliant parts cover all quality fronts: DESC standard military drawing approval, high speed performance and quick turn availability.

Microchip's military products include CMOS memories, CMOS/ NMOS digital signal processors and microcontrollers - all with high reliability, fast access times and proven retention. Endurance is guaranteed in both dual in-line cerdip packages and leadless chip carriers.

Other Microchip products, such as DSPs, ICs for serial data communications and sound generation, are mature products with proven track record, and a large, repeat customer base.

Microchip provides a wide package selection of single-chip DSPs that can be programmed for a wide variety of applications. Several variants of the industry standard 32010 and 320 C 10 are offered at speeds up to 25 MHz . The 320 DSP family is often found in commercial and military applications were medium and high performance parts are required.

The Company's reputation as a quality supplier of DSPs is evidenced by a license agreement with Texas Instruments to second-source the TMS 32010 and TMS 320C10.

FULLY INTEGRATED MANUFACTURING

## A GLOBAL NETWORK OF PLANTS AND FACILITIES

## A HISTORY OF INNOVATION

## STRATEGIC MARKETING FOCUS

Microchip delivers fast turnaround through total control over all phases of production. Design, product development, mask making, wafer fabrication, assembly and quality assurance testing are conducted at facilities owned and operated by Microchip. Our integrated approach to manufacturing along with rigorous use of statistical process control, continuous improvement and implementation of root cause fixes, has brought forth tight product consistency levels and high yields which enable Microchip to compete successfully in world markets.

Microchip is a global competitor providing local service to the world's technology centers. The Company's focal point is the design and technology advancement facility in Chandler, Arizona. Most military and high performance parts emanate from here, as well as front end wafer fabrication and electrical probing.
Microchip's assembly and test facility in Kaohsiung, Taiwan houses the technology and modern assembly methods necessary for plastic and ceramic packaging. Select quality conscious firms who fabricate wafers in the Pacific Rim use our Kaohsiung plant for assembly.
Sales and application offices are located in key cities throughout the Western Hemisphere, Pacific Rim and Europe. Offices are staffed to meet the high quality expectations of our customers, and can be accessed for technical support, purchasing information and failure analysis.

Microchip's history of innovation in the semiconductor industry is as old as the industry itself. For over a quarter century Microchip and its former parent company General Instruments have been developers of cost-effective logic and memory technology and products.
Microchip is credited with a number of firsts: The Metal-OxideSilcon (MOS) Integrated Circuit, DRAM, serial EEPROM, Reduced Instruction Set Computer (RISC) microcontroller product family, UART, CMOS 64K EEPROM, and CMOS single chip DSP are all innovations that were originally developed and introduced by our engineers.

Microchip targets selected markets where our advanced designs, progressive process technology and industry leading operating speeds enable us to deliver decidedly superior performance. The firm has recently positioned itself to play a dominant role as a supplier of high performance reprogrammable microcontrollers, and CMOS nonvolatile memories.

FUTURE PRODUCTS

New process technology is constantly being developed for EEPROM, High Speed EPROM, and microcontroller products. Many advanced process technology modules are being developed that will be integrated into our present product lines to achieve a range of compatible processes. Current production technology is attaining 1.2 micron densities. Substantial progress
toward 1 micron and submicron technologies are under development, as well as new CMOS EEPROM, High Speed CMOS EPROM and advanced CMOS RISC-based microcontroller products.

## QUALITY WITHOUT COMPROMISE

## Microchip Technology Incorporated

## NOTES:

## SECTION 1 SERIAL EEPROM PRODUCT SPECIFICATIONS

24C01A 1K (128 x 8) CMOS Serial Electrically Erasable PROM ..... 1- 1
24C01A Dice 1K (128 x 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1- 9
24C02A 2K (256 X 8) CMOS Serial Electrically Erasable PROM ..... 1-17
24C02A Dice 2K (256 X 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1-25
24C04A 4K (512 x 8) CMOS Serial Electrically Erasable PROM ..... 1-33
24C04A Dice 4K (512 x 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1-41
59 C 11 1K ( $128 \times 8$ or $64 \times 16$ ) CMOS Serial Electrically Erasable PROM ..... 1-49
59C11 Dice 1K (128 x 8 or $64 \times 16$ ) CMOS Serial Electrically Erasable PROM Die Form ..... 1-57
85 C 72 1K (128 x 8) CMOS Serial Electrically Erasable PROM ..... 1-65
85 C 72 Dice 1K (128 x 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1-73
85 C 82 2K (256 x 8) CMOS Serial Electrically Erasable PROM ..... 1-81
85C82 Dice 2K (256 x 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1- 89
85C92 4K (512 x 8) CMOS Serial Electrically Erasable PROM ..... 1-97
85C92 Dice 4K (512 x 8) CMOS Serial Electrically Erasable PROM Die Form ..... 1-105
93C06 256 Bits (16 x 16) CMOS Serial Electrically Erasable PROM ..... 1-113
93C06 Dice 256 Bits (16 x 16) CMOS Serial Electrically Erasable PROM Die Form ..... 1-121
93 C 46 $1 \mathrm{~K}(64 \times 16)$ CMOS Serial Electrically Erasable PROM ..... 1-129
93 C 46 Dice 1K ( $64 \times 16$ ) CMOS Serial Electrically Erasable PROM Die Form ..... 1-137
24CXX/85CXX 24CXX/85CXX To Microcontroller Communication ..... 1-145
ER59256/93C06 ER59256/93C06 And NMC9306/NMC93C06 Compatibility Issue ..... 1-155
24C01A 24C01A Compatibility Issue And Its Mobility For Memory Upgrade ..... 1-159

## 1K ( $128 \times 8$ ) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as one block of 128 bytes (128 x 8)
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 2 bytes
- 1ms write cycle time for single byte
- 100,000 erase/write cycles
- Data retention >10 years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
-Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$



## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss ................... -0.3 V to +7 V
Storage temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient temp. with power applied ....... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering temperature of leads ( 10 seconds) $\ldots .+300^{\circ} \mathrm{C}$ ESD protection on all pins 4 kV
*Notice:Stresses abovethose listedunder "Maximum ratings" may cause permanent damage to the device. This is astress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| DC CHARACTERISTICS |  |  |  | VcC $=+5 \mathrm{~V}( \pm 10 \%)$Commercial (C):Indumb $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$(I): $\operatorname{Tamb}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$Automotive (E): $\operatorname{Tamb}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH <br> VIL <br> VoL | $\begin{gathered} \text { Vcc } \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V c c+1 \\ V c c \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | $\mathrm{IOL}=3.2 \mathrm{~mA}$ (SDA only) |
| A0, A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \mathrm{Vcc}-0.5 \\ -0.3 \end{gathered}$ | $\begin{gathered} \mathrm{VCC}+0.5 \\ 0.5 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CINT |  | 7.0 | pF | $\begin{aligned} & \text { VIN/Vout }=0 \mathrm{~V}(\text { Note } 1) \\ & \text { Tamb }=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Operating current <br> program cycle <br> read cycle | Icco <br> Iccw <br> ICCR |  | $\begin{aligned} & 3.5 \\ & 4.25 \\ & \\ & 7.0 \\ & 8.5 \\ & 750 \end{aligned}$ | mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ | $\begin{aligned} & \text { FcLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{Vcc}=5 \mathrm{~V}, \\ & \text { Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \text { FcLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VcC}=5 \mathrm{~V}, \\ & \text { Tamb }=(\mathrm{I}) \text { and }(\mathrm{E}) \\ & \mathrm{Vcc}=5 \mathrm{~V}, \operatorname{Tamb}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \mathrm{Vcc}=5 \mathrm{~V}, \operatorname{Tamb}=(I) \text { and (E) } \\ & \mathrm{Vcc}=5 \mathrm{~V}, \operatorname{Tamb}=(\mathrm{C}), \text { (I) and (E) } \end{aligned}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | $S D A=S C L=V C C=5 V$ (no PROGRAM active) |

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

## BUS TIMING START/STOP



AC CHARACTERISTICS

| Párameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | ThilGH | 4000 |  |  | ns |  |
| Clock low time | TLOw | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | TSU:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TSu:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | Tsu:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Input filter time constant <br> (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | TwC |  | .7 N | N | ms | Byte or Page mode N = \# of <br> bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 24C01A supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 24C01A works as slave. Both, master and slave can operate as trans-
mitter or receiver but the master device determines which mode is activated.

Up to eight 24C01As can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Other devices can be connected to the bus but require different device codes than the 24C01A (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.

Accordingly, the following bus conditions have been defined (see Figure 1):

## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse pèr bit of data.
Each data transfer is initiated with a START condition and terminated with aSTOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge afterthe reception of eachbyte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.
Note: The 24C01A does not generate any acknowledge bits if an internal programming cycle is in progress.
The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave mustleave the dataline HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS


## SLAVE ADDRESS

The chip address inputs A0, A1 and A2 of each 24C01A must be externally connected to either Vcc or ground (Vss), assigning to each 24C01A a unique 3-bit address. Up to eight 24C01As may be connected to the bus. Chip selectionisthen accomplishedthroughsoftwarebysetting the bits A0, A1 and A2 of the slave address to the corresponding hardwired logic levels of the selected 24C01A.
Aftergenerating aSTART condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 24C01A, followed by the chip address bits A0, A1 and A2.

The eighth bit of slave address determines if the master device wants to reador writeto the 24C01A. (SeeFigure2.)
The 24C01A monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.


## BYTE PROGRAM MODE

In this mode the master sends addresses and one data byte to the 24C01A.

Following the START condition, the device code (4-bit), the slave address (3-bit), and the $\mathrm{R} \bar{W}$ bit, which is logic LOW, areplacedontothebusbythemaster. Thisindicates to the addressed 24C01A that a byte with a word address will follow after it has generated an acknowledge bit. Therefore, the next byte transmitted by the master is the
word address and will be written into the address pointer of the 24C01A. Themostsignificantbit of the wordaddress is a "Do Not Care" value for the 24C01A. After receiving the acknowledge of the 24C01A, the master device transmitsthedatawordtobewrittenintothe addressedmemory location. The 24C01A acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 24C01A. (See Figure $3)$.

## PAGE PROGRAM MODE

Toprogramthe24C01A, themastersends addresses and data tothe24C01A which is the slave, (see Figure3). This is done by supplying a START condition followed by the 4bit device code, the 3-bit slave address, and the R $\bar{W}$ bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 24C01A, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (One do not care bit and seven address bits.) The 24C01A will generate an acknowledge after every 8-bits received and store them consecutively in a 2-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 2 bytes are transmitted by the master, the 24C01A will terminate the write cycle. This does not affect erase/write cycles of the EEPROM array.
If the master generates a STOP condition after transmittingthefirstdataword (Point'P'onFigure3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the masterandallreceived (uptotwo) databytes will be written in a serial manner.
The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( N max = 2 ).


## READ MODE

This mode illustrates master device reading data from the 24C01A.

As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode, the address pointer must be written to.) During this period the 24C01A generates the necessary acknowledge bits as defined in the appropriate section.
The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the data
from the addressed location on to the SDA pin, increments the addresspointerand, ifitreceives anacknowledgefrom the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.
In all modes, the address pointer will automatically increment from the end of the memory block ( 128 byte) back to the first location in that block.

FIGURE 4 - READ MODE


## PIN DESCRIPTION

## A0, A1 and A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.
Up to eight 24C01As can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pin used to transfer addresses and data into and data out of the device. It is an open drain terminal.

For normal data transfer, SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## NF No Function

Must be connected to either Vss or Vcc.

## Notes:

1) A "page" is defined as the maximum number of bytes that can be programmed in a single write cycle. The $24 \mathrm{C01A}$ page is 2 bytes long.
2) A "block" is defined as a continuous area of memory with distinct boundaries. The address pointer can not cross the boundary from one block to another. It will however, wrap around from the end of a block to the first location in the same block. The 24C01A has only one block (128 bytes).

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 24C01A

## 1K ( $128 \times 8$ ) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as one block of 128 bytes ( $128 \times 8$ )
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 2 bytes
- 1 ms write cycle time for single byte
- Available in wafer or wafflepack
- Temperature range:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc. 24C01A is a 1K bit Electrically Erasable PROM. The device is organized as $128 \times 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. Up to eight 24C01As may be connected to the two wire bus. The 24C01A dice are available in wafer or wafflepack package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss .................. -0.3 V to +7 V
Storage temperature ....................... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$
ESD protection on all pins $\qquad$ .4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PAD FUNCTION TABLE |  |
| :---: | :--- |
| Name | Function |
| A0, A1, A2 | Chip Address Inputs |
| Vss | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| NF | No Function |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS | $\begin{aligned} & \mathrm{Vcc}=+5 \mathrm{~V}( \pm 10 \%) \\ & \text { Commercial }(\mathrm{C}): \text { Tamb }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \end{aligned}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH <br> VIL <br> Vol | $\begin{gathered} \operatorname{Vcc} \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V c c+1 \\ V c c \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | $\mathrm{IOL}=3.2 \mathrm{~mA}$ (SDA only) |
| A0, A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \mathrm{Vcc}-0.5 \\ -0.3 \end{gathered}$ | $\begin{gathered} V C C+0.5 \\ 0.5 \end{gathered}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CINT |  | 7.0 | pF | $\begin{aligned} & \text { Vin } / \text { Vout }=0 \mathrm{~V} \text { (Note 1) } \\ & \text { Tamb }=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Operating current <br> program cycle <br> read cycle | IcCO <br> Iccw <br> ICCR |  | $\begin{aligned} & 3.5 \\ & 7.0 \\ & 750 \end{aligned}$ | mA <br> mA <br> $\mu \mathrm{A}$ | $\begin{aligned} & \text { FcLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VcC}=5 \mathrm{~V}, \\ & \mathrm{VCC}=5 \mathrm{~V} \\ & \mathrm{VCC}=5 \mathrm{~V} \end{aligned}$ |
| Standby current | ICCS |  | 100 | $\mu \mathrm{A}$ | $S D A=S C L=V C C=5 \mathrm{~V}$ (no PROGRAM active) |

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


| AC CHARACTERISTICS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| Clock Frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | Thigh | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first clock pulse is generated |
| START condition setup time | Tsu:Sta | 4700 |  |  | ns | Only relevant for repeated START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TSU:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | Tsu:sto | 4700 |  |  | ns |  |
| Bus free time | TbuF | 4700 |  |  | ns | Time the bus must be free before a new transmission can start |
| Noise suppression time constant (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | Twc |  | . 7 N | N | ms | Byte or Page mode $\mathrm{N}=$ \# of bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 24C01A supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 24C01A works as slave. Both, master and slave can operate as
transmitter or receiver but the master device determines which mode is activated.
Up to eight 24C01As can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Other devices can be connected to the bus but require different device codes than the 24C01A (refer to section Slave Address).

## BUS CHARACTERISTICS

## The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.
Accordingly, the following bus conditions have been defined (see Figure 1):


## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.
Each data transfer is initiated with a START condition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.
Note: The 24C01A does not generate any acknowledge bits if an internal programming cycle is in progress.
The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER ON THE SERIAL BUS


SLAVE ADDRESS

The chip address inputs A0, A1 and A2 of each 24C01A must be externally connected to either Vcc or ground (Vss), assigning to each 24C01A a unique 3-bit address. Up to eight 24C01As may be connected to the bus. Chip selection is then accomplished through software by setting the bits A0, A1 and A2 of the slave address to the corresponding hardwired logic levels of the selected 24C01A.
After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 24C01A, followed by the chip address bits A0, A1 and A2.

The eighth bit of slave address determines if the master device wants to read or write to the 24C01A. (See Figure 2.)

The 24C01A monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.

FIGURE 2 - SLAVE ADDRESS ALLOCATION


## BYTE PROGRAM MODE

In this mode, the master sends addresses and one data byte to the 24C01A.
Following the START condition, the device code (4-bit), the slave address (3-bit), and the R/W bit, which is logic LOW, are placed onto the bus by the master. This
indicates to the addressed 24C01A that a byte with a word address will follow after it has generated an acknowledge bit. Therefore the next byte transmitted by the master is the word address and will be written into the address pointer of the 24C01A. The most significant bit of the word address is a "Do Not Care" value for the $24 \mathrm{C01A}$. After receiving the acknowledge of the 24C01A, the master device transmits the data word to be written into the addressed memory location. The 24C01A acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 24 C 01 A . (See Figure 3.)

## PAGE PROGRAM MODE

To program the 24C01A, the master sends addresses and data to the 24C01A which is the slave (see Figure 3 ). This is done by supplying a START condition followed by the 4-bit device code, the 3-bit slave address, and the $\mathrm{R} \bar{W}$ bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 24C01A, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (One do not care bit and seven address bits.) The 24C01A will generate an acknowledge after every 8-bits received and store them consecutively in a 2 -byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 2 bytes are transmitted by the master, the 24C01A will terminate the write cycle. This does not affect erase/write cycles of the EEPROM array.
If the master generates a STOP condition after transmitting the first data word (Point ' P ' on Figure 3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to two) data bytes will be written in a serial manner.

The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( N max $=2$ ).


## READ MODE

This mode illustrates master device reading data from the 24C01A.

As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode, the address pointer must be written to.) During this period the 24C01A generates the necessary acknowledge bits as defined in the appropriate section.

The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the
slave generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pad, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.

FIGURE 4 - READ MODE


## PAD DESCRIPTION

## A0, A1 and A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.
Up to eight 24C01As can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pad used to transfer addresses and data into and data out of the device. It is an open drain terminal.

For normal data transfer, SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## NF No Function

Must be connected to either Vss or Vcc.

## NOTES:

## 24C01A DICE FORM

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



# 2K (256 x 8) CMOS Serial Electrically Erasable PROM 

## FEATURES

- Low power CMOS technology
- Organized as one block of 256 bytes ( $256 \times 8$ )
- Hardware write protect for upper $1 \mathrm{~K}(128 \times 8)$
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 2 bytes
- 1 ms write cycle time for single byte
- 100,000 erase/write cycles
- Data retention >10 years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
- Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc. 24C02A is a 2 K bit Electrically Erasable PROM. The device is organized as 256 $x 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. A special feature allows a write protection for the upper $1 \mathrm{~K}(128 \times 8)$. The 24C02A also has a page-write capability for up to 2 bytes of data. Up to eight 24C02As may be connected to the two wire bus. The 24C02A is available in the standard 8-pin DIP and a surface mount SOIC package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss $\qquad$ . 0.3 V to +7 V
Storage temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$ ESD protection on all pins $\qquad$ .4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PIN FUNCTION TABLE |  |
| :---: | :--- |
| Name | Function |
| A0, A1, A2 | Chip Address Inputs |
| Vss | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| WP | Write Protect Input |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS | $\mathrm{VcC}=+5 \mathrm{~V}( \pm 10 \%)$ <br> Commercial (C): Tamb $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ <br> Industrial <br> (I): Tamb $=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Automotive <br> (E): Tamb $=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH <br> VIL <br> Vol | $\begin{gathered} \text { Vcc } \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V c c+1 \\ V c c \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | $\mathrm{loL}=3.2 \mathrm{~mA}$ (SDA only) |
| A0, A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \mathrm{Vcc}-0.5 \\ -0.3 \end{gathered}$ | $\begin{gathered} \mathrm{VCC}+0.5 \\ 0.5 \end{gathered}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CINT |  | 7.0 | pF | VIn/Vout $=0 \mathrm{~V}($ Note 1$)$ TAMB $=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ |
| Operating current <br> program cycle <br> read cycle | Icco <br> Iccw <br> ICCR |  | $\begin{array}{r} 3.5 \\ \\ 4.25 \\ \\ 7.0 \\ 8.5 \\ 750 \end{array}$ | mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ | $\begin{aligned} & \text { FCLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VcC}=5 \mathrm{~V}, \\ & \text { Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \text { FcLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{Vcc}=5 \mathrm{~V}, \\ & \text { Tamb }=(\mathrm{I}) \text { and }(\mathrm{E}) \\ & \mathrm{VcC}=5 \mathrm{~V}, \operatorname{Tamb}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \mathrm{VcC}=5 \mathrm{~V} \text {, Tamb }=(1) \text { and }(\mathrm{E}) \\ & \text { Vcc }=5 \mathrm{~V}, \text { Tamb }=(\mathrm{C}),(\mathrm{I}) \text { and }(\mathrm{E}) \end{aligned}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | $\mathrm{SDA}=\mathrm{SCL}=\mathrm{VCC}=5 \mathrm{~V}$ (no PROGRAM active) |

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

## BUS TIMING START/STOP



| AC CHARACTERISTICS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | Thigh | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first clock pulse is generated |
| START condition setup time | Tsu:STA | 4700 |  |  | ns | Only relevant for repeated START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TSu:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | Tsu:sto | 4700 |  |  | ns |  |
| Bus free time | TbuF | 4700 |  |  | ns | Time the bus must be free before a new transmission can start |
| Input filter time constant (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | Twc |  | .7N | N | ms | Byte or Page mode N = \# of bytes to be written |

Note 1: As transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 24C02A supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 24C02A works as slave. Both, master and slave can operate as trans-
mitter or receiver but the master device determines which mode is activated.

Up to eight 24C02As can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Other devices can be connected to the bus, but require different device codes than the 24C02A (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.
Accordingly, the following bus conditions have been defined (see Figure 1):


## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.

Each data transfer is initiated with a STARTcondition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.
Note: The 24C02A does not generate any acknowledge bits if an internal programming cycle is in progress.

The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS


## SLAVE ADDRESS

The chip address inputs A0, A1 and A2 of each 24C02A must be externally connected to either Vcc or ground (Vss), assigning to each 24C02A a unique 3-bit address. Up to eight 24C02As may be connected to the bus. Chip selection is then accomplished through software by setting the bits A0, A1 and A2 of the transmitted slave address to the corresponding hardwired logic levels of the selected 24C02A.
After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 24C02A, followed by the chip address bits A0, A1 and A2.
The eighth bit of slave address determines if the master device wants to read or write to the 24C02A. (See Figure 2.)

The 24C02A monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.

## FIGURE 2 - SLAVE ADDRESS

 ALLOCATION

## BYTE PROGRAM MODE

In this mode the master sends addresses and one data byte to the 24C02A.

Following the START condition, the device code (4-bit), the slave address (3-bit), and the R $\bar{W}$ bit, which is logic LOW, are placed onto the bus by the master. This
indicates to the addressed 24C02A that a byte with a word address will follow after it has generated an acknowledge bit. Therefore, the next byte transmitted by the master is the word address and will be written into the address pointer of the 24C02A. After receiving the acknowledge of the 24C02A, the master device transmits the data word to be written into the addressed memory location. The 24C02A acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 24C02A. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 24C02A, the master sends addresses and data to the 24C02A which is the slave. (See Figure
3.) This is done by supplying a START condition followed by the 4 -bit device code, the 3-bit slave address, and the $R / \bar{W}$ bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 24C02A, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. The 24C02A will generate an acknowledge after every 8 bits received and store them consecutively in a 2-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 2 bytes are transmitted by the master, the 24C02A will terminate the write cycle. This does not affect erase/write cycles of the EEPROM array.

If the master generates a STOP condition after transmitting the first data word (Point ' $P$ ' on Figure 3), byte programming mode is entered.

The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to two) data bytes will be written in a serial manner.
The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( N max $=2$ ).

FIGURE 3 - PROGRAM MODE (ERASE/WRITE)


## WRITE PROTECTION

Programming of the upper half of the memory will not take place if the WP pin of the 24C02A is connected to Vcc ( +5 V ). The 24C02A will accept slave and word addresses but if the memory accessed is write protected by the WP pin, the 24C02A 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 MODE

This mode illustrates master device reading data from the 24C02A.
As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: although this is a read mode the address pointer must be written to.) During this period the 24C02A generates the necessary acknowledge bits as defined in the appropriate section.

The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pin, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.
Note: In all modes, the address pointer will automatically increment from the end of the memory block ( 256 byte) back to the first location in that block.


## PIN DESCRIPTION

## A0, A1 and A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.
Up to eight 24C02As can be connected to the bus. These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pin used to transfer addresses and data into and data out of the device. It is an open drain terminal.

For normal data transfer SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## WP Write Protection

This pin must be connected to either Vss or Vcc.
If tied to Vcc, PROGRAM operations onto the upper half
of memory (addresses 080-0FF) will not be executed. Read operations are possible.
If tied to Vss, normal memory operation is enabled (read/ write the entire memory 000-0FF).

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.

## Notes:

1) A "page" is defined as the maximum number of bytes that can be programmed in a single write cycle. The 24 C02A page is 2 bytes long.
2) A "block" is defined as a continuous area of memory with distinct boundaries. The address pointer can not cross the boundary from one block to another. It will however, wrap around from the end of a block to the first location in the same block. The 24C02A has only one block (256 bytes).

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 24C02A

## 2K ( $256 \times 8$ ) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as one block of 256 bytes ( $256 \times 8$ )
- Hardware write protect for upper $1 \mathrm{k}(128 \times 8)$
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 2 bytes
- 1 ms write cycle time for single byte
- Available in wafer or wafflepack
- Temperature range:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc 24C02A is a 2K bit Electrically Erasable PROM. The device is organized as $256 \times 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. A special feature allows a write protection for the upper 1 k ( 128 x 8). The 24C02A also has a page-write capability for up to 2 bytes of data. Up to eight 24C02As may be connected to the two wire bus. The 24C02A dice are available in wafer or wafflepack package.


## ELECTRICAL CHARACTERISTICS MAXIMUM RATINGS*

All inputs and outputs w.r.t. Vss $\qquad$ -0.3 V to +7 V Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$ ESD protection on all pins $\qquad$
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PAD FUNCTION TABLE |  |
| :---: | :---: |
| Name | Function |
| A0, A1, A2 | Chip Address Inputs |
| Vss | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| WP | Write Protect Input |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS | $\begin{aligned} & \text { Vcc }=+5 \mathrm{~V}( \pm 10 \%) \\ & \text { Commercial }(\mathrm{C}): \text { Tamb }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \end{aligned}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH <br> VIL <br> Vol | $\begin{gathered} \operatorname{Vcc} \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V c c+1 \\ V c c \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\mathrm{lOL}=3.2 \mathrm{~mA}$ (SDA only) |
| A0, A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \mathrm{Vcc}-0.5 \\ -0.3 \end{gathered}$ | $\begin{gathered} \mathrm{Vcc}+0.5 \\ 0.5 \end{gathered}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
| Input leakage current | 1 IL |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CINT |  | 7.0 | pF | Vin/Vout $=0 \mathrm{~V}$ (Note 1) Tamb $=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ |
| Operating current <br> program cycle <br> read cycle | $\begin{aligned} & \text { Icco } \\ & \text { Iccw } \\ & \text { ICCR } \end{aligned}$ |  | $\begin{aligned} & 3.5 \\ & 7.0 \\ & 750 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \text { FCLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VcC}=5 \mathrm{~V}, \\ & \mathrm{VCC}=5 \mathrm{~V} \\ & \mathrm{Vcc}=5 \mathrm{~V} \end{aligned}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | $S D A=S C L=V C C=5 V$ (no PROGRAM active) |

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


| AC CHARACTERISTICS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | Thigh | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first clock pulse is generated |
| START condition setup time | Tsu:Sta | 4700 |  |  | ns | Only relevant for repeated START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | Tsu:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | Tsu:Sto | 4700 |  |  | ns |  |
| Bus free time | Tbuf | 4700 |  |  | ns | Time the bus must be free before a new transmission can start |
| Noise suppression time constant (SDA and SCL pins) | Tı |  |  | 100 | ns |  |
| Program cycle time | Twc |  | .7N | N | ms | Byte or Page mode $\mathrm{N}=$ \# of bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 24C02A supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 24C02A works as slave. Both, master and slave can operate as
transmitter or receiver but the master device determines which mode is activated.

Up to eight 24C02As can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Other devices can be connected to the bus but require different device codes than the 24C02A (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During the data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.
Accordingly, the following bus conditions have been defined (see Figure 1):


## Bus not busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.
Each data transfer is initiated with a START condition and terminated with a STOPp condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.
Note: The 24C02A does not generate any acknowledge bits if an internal programming cycle is in progress.
The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS


## SLAVE ADDRESS

The chip address inputs A0, A1 and A2 of each 24C02A must be externally connected to either Vcc or ground (Vss), assigning to each 24C02A a unique 3-bit address. Up to eight 24C02As may be connected to the bus. Chip selection is then accomplished through software by setting the bits A0, A1 and A2 of the transmitted slave address to the corresponding hardwired logic levels of the selected 24C02A.
After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 24C02A, followed by the chip address bits A0, A1 and A2.
The eighth bit of slave address determines if the master device wants to read or write to the 24C02A. (See Figure 2.)

The 24C02A monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.

FIGURE 2 - SLAVE ADDRESS ALLOCATION


## BYTE PROGRAM MODE

In this mode, the master sends addresses and one data byte to the 24C02A.
Following the START condition, the device code (4-bit), the slave address (3-bit), and the $\mathrm{R} / \bar{W}$ bit, which is logic LOW, are placed onto the bus by the master. This indicates to the addressed 24C02A that a byte with a
word address will follow after it has generated an acknowledge bit. Therefore, the next byte transmitted by the master is the word address and will be written into the address pointer of the 24C02A. After receiving the acknowledge of the 24C02A, the master device transmits the data word to be written into the addressed memory location. The 24C02A acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 24C02A. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 24C02A, the master sends addresses and data to the 24C02A which is the slave (see Figure 3). This is done by supplying a START condition followed by the 4-bit device code, the 3-bit slave address, and the R/W bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 24C02A, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. The 24C02A will generate an acknowledge after every 8 -bits received and store them consecutively in a 2-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 2 bytes are transmitted by the master, the 24C02A will terminate the write cycle. This does not affect erase/write cycles of the EEPROM array.
If the master generates a STOP condition after transmitting the first data word (Point ' $P$ ' on Figure 3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to 2) data bytes will be written in a serial manner.
The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( $\mathrm{N} \max =2$ ).


## WRITE PROTECTION

Programming of the upper half of the memory will not take place if the WP pad of the 24C02A is connected to Vcc ( +5 V ). The 24C02A will accept slave and word addresses but if the memory accessed is write protected by the WP pad, the 24C02A 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 MODE

This mode illustrates master device reading data from the 24C02A.
As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode, the address pointer must be written to.) During this period the 24C02A generates the necessary acknowledge bits as defined in the appropriate section.

The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pad, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.

Note: In all modes, the address pointer will automatically increment from the end of the memory block ( 256 bytes) back to the first location in that block.


## PAD DESCRIPTION

## A0, A1 and A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.

Up to eight 24C02As can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pad used to transfer addresses and data into and data out of the device. It is an open drain terminal.
For normal data transfer, SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## WP Write Protection

This pad must be connected to either VCC or VSS.
If tied to Vcc, PROGRAM operations onto the upper memory page (addresses 080-0FF) will not be executed. READ operations are possible.
If tied to Vss, normal memory operation is enabled (read/ write the entire memory $000-0 \mathrm{FF}$ ).
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.

NOTES:

## 24C02A DICE FORM

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 4K (512 x 8) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as two blocks of 256 bytes ( $2 \times 256 \times 8$ )
- Hardware write protect for upper block
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 8 bytes
- 1 ms write cycle time for single byte
- 100,000 erase/write cycles
- Data retention $>10$ years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
-Automotive: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc. 24C04A is a 4 K bit Electrically Erasable PROM. The device is organized as two blocks of $256 \times 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. A special feature allows a write protection for the upper 256 byte block. The 24C04A also has a page-write capability for up to 8 bytes of data. Up to four 24C04As may be connected to the two wire bus. The 24C04A is available in the standard 8-pin DIP and a surface mount SOIC package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss ............... -0.3 V to +7 V
Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$ ESD protection on all pins .................................... 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PIN FUNCTION TABLE |  |
| :---: | :---: |
| Name | Function |
| A0 | No Function, Must he <br> connected to Vcc or Vss <br> Chip Address Inputs <br> Ground |
| A1, A2 | Serial Address/Data I/O <br> Vss <br> SDA <br> SCL |
| WP | Write Protect Input |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS | $\mathrm{Vcc}=+5 \mathrm{~V}( \pm 10 \%)$ <br> Commercial (C): Tamb $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ <br> Industrial <br> (I): Tamb $=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Automotive: (E): $\quad$ Tamb $=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH <br> VIL <br> Vol | $\begin{gathered} \mathrm{Vcc} \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V c c+1 \\ V c c \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\mathrm{IOL}=3.2 \mathrm{~mA}$ (SDA only) |
| A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \mathrm{Vcc}-0.5 \\ -0.3 \end{gathered}$ | $\begin{gathered} \mathrm{VCC}+0.5 \\ 0.5 \end{gathered}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CINT |  | 7.0 | pF | $\begin{aligned} & \text { Vin } / \text { Vout }=0 \mathrm{~V}(\text { Note 1) } \\ & \text { Tamb }=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Operating current <br> program cycle read cycle | Icco <br> Iccw <br> ICCR |  | $\begin{array}{r} 3.5 \\ \\ 4.25 \\ \\ 7.0 \\ 8.5 \\ 750 \end{array}$ | mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ | $\begin{aligned} & \text { FCLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VCC}=5 \mathrm{~V}, \\ & \text { Tamb }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \text { FcLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VcC}=5 \mathrm{~V}, \\ & \operatorname{Tamb}=(\mathrm{I}) \text { and }(\mathrm{E}) \\ & \mathrm{VCC}=5 \mathrm{~V}, \mathrm{Tamb}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \mathrm{VCC}=5 \mathrm{~V}, \operatorname{Tamb}=(\mathrm{I}) \text { and (E) } \\ & \mathrm{VCC}=5 \mathrm{~V}, \mathrm{Tamb}=(\mathrm{C}), \text { (I) and }(\mathrm{E}) \end{aligned}$ |
| Standby current | ICCS |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{SDA}=\mathrm{SCL}=\mathrm{VcC}=5 \mathrm{~V} \\ & \text { (no PROGRAM active) } \end{aligned}$ |

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


## AC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | THIGH | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | TSU:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TSU:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | TSU:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Input filter time constant |  |  |  |  |  |  |
| (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | TwC |  | .7 N | N | ms | Byte or Page mode N = \# <br> of bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 24C04A supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 24C04A works as slave. Both, master and slave can operate as trans-
mitter or receiver but the master device determines which mode is activated.
Up to four 24C04As can be connected to the bus, selected by the A1 and A2 chip address inputs. A0 must be tied to Vcc or Vss. Other devices can be connected to the bus but require different device codes than the 24C04A (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus prctocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.
Accordingly, the following bus conditions have been defined (see Figure 1):


## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.

Each data transfer is initiated with a START condition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.
Note: The 24C04A does not generate any acknowledge bits if an internal programming cycle is in progress.

The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS


## SLAVE ADDRESS

The chip address inputs A1 and A2 of each 24C04A must be externally connected to either Vcc or ground (Vss), assigning to each 24C04A a unique2-bit address. Up to four 24C04As may be connected to the bus. Chip selection is then accomplished through software by setting the bits A1 and A2 of the slave address to the corresponding hardwired logic levels of the selected 24C04A. A0 is not used and must be connected to either Vcc or Vss.
After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 24C04A, followed by the chip address bits A1 and A2. The seventh bit of that byte (BA) is used to select the upper block (addresses 100-1FF) or lower page (addresses 000-OFF) of the 24C04A.
The eighth bit of slave address determines if the master device wants to read or write to the 24C04A. (See Figure 2.)

The 24C04A monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.


## BYTE PROGRAM MODE

In this mode, the master sends addresses and one data byte to the 24C04A.

Following the START condition, the device code (4-bit), the slave address (3-bit), and the $R \bar{W}$ bit, which is logic LOW, are placed onto the bus by the master. This indicates to the addressed 24C04A that a byte with a
word address will follow after it has generat ${ }^{-1}$ an acknowledge bit. Therefore the next byte tranamitted by the master is the word address and will be writtei into the address pointer of the 24C04A. After rece ving the acknowledge of the 24C04A, the master device transmits the data word to be written into the addressed memory location. The 24C04A acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 24C04A. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 24C04A, the master sends addresses and data to the 24C04A which is the slave (see Figure 3 ). This is done by supplying a START condition followed by the 4-bit device code, the 3-bit slave address, and the $\mathrm{R} / \bar{W}$ bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 24C04A, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (The BA bit transmitted with the slave address is the ninth bit of the address pointer.) The 24C04A will generate an acknowledge after every 8 -bits received and store them consecutively in an 8-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 8 bytes are transmitted by the master, the 24C04A will roll over and overwrite the data beginning with the first received byte. This does not affect erase/write cycles of the EEPROM array and is accomplished as a result of only allowing the address registers bottom 3 bits to increment while the upper 5 bits remain unchanged.

If the master generates a STOP condition after transmitting the first data word (Point ' $P$ ' on Figure 3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to eight) data bytes will be written in a serial manner.
The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( N max $=8$ ).

## WRITE PROTECTION

Programming of the upper half of the memory will not take place if the WP pin of the 24C04A is connected to Vcc ( +5 V ). The 24C04A will accept slave and word addresses butif the memory accessed is write protected by the WP pin, the 24C04A 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 MODE

This mode illustrates master device reading data from the 24C04A.

As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode, the address pointer must be written to.) During this period the 24C04A generates the necessary acknowledge bits as defined in the appropriate section.

The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pin, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.
Note: In all modes, the address pointer will not increment through a block ( 256 byte) boundary, but will rotate back to the first location in that block.


## PIN DESCRIPTION

## AO

This pin must be connected to either Vcc or Vss.

## A1, A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.
Up to four 24C04As can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pin used to transfer addresses and data into and data out of the device. It is an open drain terminal.
For normal data transfer, SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## WP Write Protection

This pin must be connected to either Vcc or Vss.
If tied to Vcc, PROGRAM operations onto the upper memory block (addresses 100-1FF) will not be executed. Read operations are possible.
If tied to Vss, normal memory operation is enabled (read/ write the entire memory 000-1FF).

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.

## Notes:

1) A "page" is defined as the maximum number of bytes that can be programmed in a single write cycle. The 24 C 04 A page is 8 bytes long.
2) A "block" is defined as a continuous area of memory with distinct boundaries. The address pointer can not cross the boundary from one block to another. It will however, wrap around from the end of a block to the first location in the same block. The 24C04A has two blocks, 256 bytes each.

NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 24C04A

## 4K (512 x 8) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as two blocks of 256 bytes $(2 \times 256 \times 8)$
- Hardware write protect for upper block
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 8 bytes
- 1 ms write cycle time for single byte
- Available in wafer or wafflepack
- Temperature range:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$


## DIE CONFIGURATION

Die Size: $113 \times 76$ mils


1. AO
2. Vcc
3. A 1
4. WP
5. A 2
6. SCL
7. Vss
8. SDA

## DESCRIPTION

The Microchip Technology Inc. 24C04A is a 4 K bit Electrically Erasable PROM. The device is organized as two blocks of $256 \times 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. A special feature allows a write protection for the upper 256 byte block. The 24C04A also has a page-write capability for up to 8 bytes of data. Up to four 24C04As may be connected to the two wire bus. The 24C04A dice are available in wafer or wafflepack package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss $\qquad$ -0.3 V to +7 V Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$ ESD protection on all pins $\qquad$ 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PAD FUNCTION TABLE |  |
| :---: | :---: |
| Name | Function |
| A0, A1, A2 | Chip Address Inputs |
| Vss | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| WP | Write Protect Input |
| VCC |  |
|  |  |



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


AC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Clock frequency | FcLK |  |  | 100 | kHz |  |
| Clock high time | THIGH | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | Tsu:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TsU:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | TSU:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Noise suppression time constant <br> (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | TWC |  | .7 N | N | ms | Byte or Page mode N = \# <br> of bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 24C04A supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 24C04A works as slave. Both, master and slave can operate as
transmitter or receiver but the master device determines which mode is activated.
Up to four 24C04A can be connected to the bus, selected by the A1 and A2 chip address inputs. A0 must be tied to Vcc or Vss. Other devices can be connected to the bus but require different device codes than the 24C04A (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Datatransfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.

Accordingly, the following bus conditions have been defined (see Figure 1):

## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Tansfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a start condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.

Each data transfer is initiated with a START condition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.
Note: The 24C04A does not generate any acknowledge bits if an internal programming cycle is in progress.
The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE


## SLAVE ADDRESS

The chip address inputs A1 and A2 of each 24C04A must be externally connected to either Vcc or ground (Vss), assigning to each 24C04A a unique 2-bit address. Up to four 24C04As may be connected to the bus. Chip selection is then accomplished through software by setting the bits A1 and A2 of the slave address to the corresponding hardwired logic levels of the selected 24C04A. AO is not used and must be connected to Vcc or Vss.
After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 24C04A, followed by the chip address bits A1 and A2. The seventh bit of that byte (PA) is used to select the upper page (addresses 100-1FF) or lower page (addresses 000-0FF) of the 24C04A.
The eighth bit of slave address determines if the master device wants to read or write to the 24C04A. (See Figure 2.)

The 24C04A monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.


## BYTE PROGRAM MODE

In this mode the master sends addresses and one data byte to the 24C04A.

Following the START condition, the device code (4-bit), the slave address (3-bit), and the R $\bar{W}$ bit, which is logic LOW, are placed onto the bus by the master. This
indicates to the addressed 24C04A that a byte with a word address will follow after it has generated an acknowledge bit. Therefore, the next byte transmitted by the master is the word address and will be written into the address pointer of the 24C04A. After receiving the acknowledge of the 24C04A, the master device transmits the data word to be written into the addressed memory location. The 24C04A acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 24C04A. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 24C04A, the master sends addresses and data to the 24C04A which is the slave (see Figure 3 ). This is done by supplying a START condition followed by the 4 -iit device code, the 3-bit slave address, and the $R / \bar{W}$ bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 24C04A, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (The PA bit transmitted with the slave address is the ninth bit of the address pointer.) The 24C04A will generate an acknowledge after every 8 -bits received and store them consecutively in an 8-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 8 bytes are transmitted by the master, the 24C04A will roll over and overwrite the data beginning with the first received byte. This does not affect erase/write cycles of the EEPROM array and is accomplished as a result of only allowing the address registers bottom 3 bits to increment while the upper 5 bits remain unchanged.
If the master generates a STOP condition after transmitting the first data word (Point ' $P$ ' on Figure 3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to eight) data bytes will be written in a serial manner.
The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( N max $=8$ ).

## WRITE PROTECTION

Programming of the upper half of the memory will not take place if the WP pad of the 24C04A is connected to Vcc ( +5 V ). The 24C04A will accept slave and word addresses but if the memory accessed is write protected by the WP pad, the 24C04A 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 MODE

This mode illustrates master device reading data from the 24C04A.

As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode, the address pointer must be written to.) During this period the 24C04A generates the necessary acknowledge bits as defined in the appropriate section.

The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pad, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.

Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.

Note: In all modes, the address pointer will never automatically increment through a block (256 byte) boundary but will rotate back to the first location in that block.

FIGURE 4 - READ MODE


## PAD DESCRIPTION

## AO

This pad must be connected to either Vcc or Vss.

## A1, A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.
Up to four 24C04As can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pad used to transfer addresses and data into and data out of the device. It is an open drain terminal.

For normal data transfer SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## WP Write Protection

This pad must be connected to either Vcc or Vss.
If tied to Vcc, PROGRAM operations onto the upper memory block (addresses 100-1FF) will not be executed. Read operations are possible.
If tied to Vss, normal memory operation is enabled (read/ write the entire memory 000-1FF).

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.

## NOTES:

## 24C04A DICE FORM

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## FEATURES

- Low power CMOS technology
- Pin selectable memory organization
- $128 \times 8$ or $64 \times 16$ bit organization
- Single 5 volt only operation
- Self timed WRITE, ERAL and WRAL cycles
- Automatic erase before WRITE
- RDY/ $\overline{\mathrm{BSY}}$ status information during WRITE
- Power on/off data protection circuitry
- 100,000 ERASE/WRITE cycles
- Data Retention > 10 Years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
- Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc. 59 C 11 is a 1 K bit Electrically Erasable PROM. The device is configured as $128 \times 8$ or $64 \times 16$, selectable externally by means of the control pin ORG. Advanced CMOS technology makes this device ideal for low power non-volatile memory applications. The 59C11 is available in the standard 8-pin DIP and a surface mount SOIC package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss
-0.3 V to +7.0 V
Storage temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient temperature with power applied $\qquad$ $65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering temperature of leads ( 10 seconds) $\ldots .+300^{\circ} \mathrm{C}$ ESD protection on all pins $\qquad$ .4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| CS | Chip Select |
| CLK | Serial Clock |
| DI | Data In |
| DO | Data Out |
| Vss | Ground |
| ORG | Memory Array Organization |
| RDY/BSY | Ready/Busy Status |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS |  |  | $V c c=+5 \mathrm{~V}( \pm 10 \%)$ <br> Commercial: $\mathrm{Tamb}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ <br> Industrial: $\quad$ Tamb $=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Automotive: $\mathrm{Tamb}=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| High level input voltage | VIH | 2.0 | $V C C+1$ | V |  |
| Low level input voltage | VIL | -0.3 | 0.8 | V |  |
| High level output voltage | VOH | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| Low level output voltage | Vol |  | 0.4 | V | $\mathrm{IOL}=3.2 \mathrm{~mA}$ |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc (Note 1) |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc (Note 1) |
| Internal capacitance (all inputs/outputs) | CINT |  | 7 | pF | VIn/Vout $=0 \mathrm{~V}$ (Note 2) <br> Tamb $=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ |
| Operating current (all modes) | Icco |  | 4 | mA | FCLK $=1 \mathrm{MHz}, \mathrm{VCc}=5.5 \mathrm{~V}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | $\mathrm{CS}=0 \mathrm{~V}, \mathrm{Vcc}=5.5 \mathrm{~V}$ |

Note 1: Internal resister pull-up at Pin 6. Active output at Pin 7.
Note 2: This parameter is periodically sampled and not $100 \%$ tested.
SYNCHRONOUS DATA TIMING


| AC CHARACTERISTICS |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Clock frequency | FCLK |  | 1 | MHz |  |
| Clock high time | TCKH | 500 |  | ns |  |
| Clock low time | TCKL | 500 |  | ns |  |
| Chip select setup time | TCss | 50 |  | ns |  |
| Chip select hold time | TCSH | 0 |  | ns |  |
| Chip select low time | TCs | 100 |  | ns |  |
| Data input setup time | TDIS | 100 |  | ns |  |
| Data input hold time | TDIH | 100 |  | ns |  |
| Data output delay time | TPD |  | 400 | ns | CL $=100 \mathrm{pF}$ |
| Data output disable time (from CS = low) | Tcz | 0 | 100 | ns | CL $=100 \mathrm{pF}$ |
| Data output disable time (from last clock) | TDDZ | 0 | 400 | ns | CL $=100 \mathrm{pF}$ |
| RDY/BSY delay time | TRBD |  | 400 | ns |  |
| Program cycle time (Auto Erase \& Write) | TWC |  | 1 | ms | for 8-bit mode <br> for ERAL and WRAL <br> in 8/16-bit modes |

## PIN DESCRIPTION

## Chip Select (CS)

A HIGH level selects the device. A LOW level deselects the device and forces it into standby mode. However, a WRITE cycle which is already initiated and/or in progress will be completed, regardless of the CS input signal. If CS is brought LOW during a WRITE cycle, the device will go into standby mode as soon as the WRITE cycle is completed.

CS must be LOW for 100 ns (TCSL) minimum between consecutive instructions. If CS is LOW, the internal control logic is held in a RESET status.

## Serial Clock (CLK)

The Serial Clock is used to synchronize the communication between a master device and the 59C11. Opcode, address, and data bits are clocked in on the positive edge of CLK. Data bits are also clocked out on the positive edge of CLK.

CLK can be stopped anywhere in the transmission sequence (at HIGH or LOW level) and can be continued anytime (with respect to clock high time (TCKH) and clock low time (TCKL)). This gives freedom in preparing opcode, address and data for the controlling master.
CLK is a "Don't Care" if CS is LOW (device deselected). If CS is HIGH, but a START condition has not been detected, any number of clock cycles can be received by the device without changing its status (i.e., waiting for START condition).

CLK cycles are not required during the self-timed WRITE (i.e., auto erase/write) cycle.

After detection of a START condition the specified number of clock cycles (respectively LOW to HIGH transitions of CLK) must be provided. These clock cycles are required to clock in all required opcode, address, and data bits before an instruction is executed (see instruction set truth table). When that limit has been reached, CLK and DI become "Don't Care" inputs until CS is brought LOW for at least chip select low time (TCSL) and brought HIGH again and a WRITE cycle (if any) is completed.

## Data In (DI)

Data In is used to clock in START bit, opcode, address and data synchronously with the CLK input.

## Data Out (DO)

Data Out is used in the READ mode to output data synchronously with the CLK input (TPD after the positive edge of CLK). This output is in HIGH-Z mode except if data is clocked out as a result of a READ instruction.

DI and DO can be connected together to perform a 3wire interface (CS, CLK, DI/DO).
Care must be taken with the leading dummy zero which is output after a READ command has been detected. Also, the controlling device must not drive the DI/DO bus during WRITE cycles.

## Organization (ORG)

This input selects the memory array organization. When the ORG pin is connected to +5 V the $64 \times 16$ organization is selected. When it is connected to ground, the 128 $x 8$ organization is selected. If the ORG pin is left unconnected, then an internal pullup device will select the 64 x 16 organization.

## Ready/Busy (RDY/BSY)

Pin 7 provides RDY/ $\overline{\mathrm{BSY}}$ status information. RDY/ $\overline{\mathrm{BSY}}$ is low if the device is performing a WRITE, ERAL, or WRAL operation. When it is HIGH the internal, selftimed WRITE, ERAL or WRAL operation has been completed and the device is ready to receive a new instruction.

## DATA PROTECTION

During power-up, all modes of operation are inhibited until Vcc has reached a level of between 2.8 V and 4.5 V . During power-down, the source data protection circuitry acts to inhibit all modes when VCC has fallen below the voltage range of 2.8 V to 4.5 V .
The EWEN and EWDS commands give additional protection against accidentally programming during normal operation.
After power-up, the device is automatically in the EWDS mode. Therefore, EWEN instruction must be performed before any WRITE, ERAL or WRAL instruction can be executed.


## FUNCTIONAL DESCRIPTION

## START Condition

The START bit is detected by the device if CS and DI are both High with respect to the positive edge of CLK for the first time.

Before a START condition is detected, CS, CLK, and DI may change in any combination (except to that of a START condition) without resulting in any device operation (READ, WRITE, EWEN, EWDS, ERAL, and WRAL). As soon as CS is HIGH, the device is no longer in the standby mode.
An instruction following a START condition will only be executed if the required amount of opcode, address and data bits for any particular instruction is clocked in.
After execution of an instruction (i.e. clock in or out of the
last required address or data bit) CLK and DI become don't care bits until a new start condition is detected.

Note: CS must go LOW between consecutive instructions.

## DI/DO Pins

It is possible to connect the Data In and Data Out pins together. However, with this configuration it is possible for a "bus conflict" to occur during the "dummy zero" that precedes the READ operation, if AO is a logic high level. Under such a condition the voltage level seen at Data Out is undefined and will depend upon the relative impedances of Data Out and the signal source driving $A 0$. The higher the current sourcing capability of $A 0$, the higher the voltage at the Data Out pin.

## READ Mode

The READ instruction outputs the serial data of the addressed memory location on the DO pin. A dummy bit (logical 0 ) precedes the 8 - or 16 -bit output string. The output data changes during the high state of the system clock (CLK). The dummy bit is output TPD after the positive edge of CLK, which was used to clock in the last address bit (AO). Therefore, care must be taken if $D$ land DO are connected together as a bus contention will occur for one clock cycle if AO is a one.

DO will go into HIGH-Z mode with the positive edge of the next CLK cycle. This follows the output of the last data bit DO or the negative edge of CS, whichever occurs first. DO remains stable between CLK cycles for an unlimited time as long as CS stays HIGH.
The most significant data bit (D15 or D7) is always output first, followed by the lower significant bits (D14-D0 or D6 - DO).

READ MODE


## WRITE

The WRITE instruction is followed by 8 or 16 bits of data which are written into the specified address. The most significant data bit (D15 or D7) has to be clocked in first followed by the lower significant data bits (D14 - D0 or D6 - D0). If a WRITE instruction is recognized by the device and all data bits have been clocked in, the device
performs an automatic erase cycle on the specified address before the data are written. The WRITE cycle is completely self timed and commences automatically after the rising edge of the CLK signal for the last data bit (D0).
The WRITE cycle takes 1 ms max for 8 -bit mode and 2 ms max for 16-bit mode.


## ERASE/WRITE Enable/Disable (EWEN, EWDS)

The device is automatically in the ERASE/WRITE Disable mode (EWDS) after power-up. Therefore, EWEN
instruction has to be performed before any WRITE, ERAL, or WRAL instruction is executed by the device.


## ERASE All (ERAL)

The entire chip will be erased to logical "1s" if this instruction is received by the device and it is in the EWEN
mode. The ERAL cycle is completely self-timed and commences after the rising edge of the CLK signal for the last dummy address bit. ERAL takes 15 ms max.


## WRITE AII (WRAL)

The entire chip will be written with the data specified in that command. The WRAL cycle is completely selftimed and commences after the last data bit (D0) has been clocked in. WRAL takes 15 ms max.

Note: The WRAL does not include an automatic ERASE cycle for the chip. Therefore, the WRAL instruction must be preceded by an ERAL instruction and the chip must be in the EWEN status in both cases. The WRAL instruction is used for testing and/or device initialization.


## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## FEATURES

- Low power CMOS technology
- Pad selectable memory organization
- $128 \times 8$ or $64 \times 16$ bit organization
- Single 5 volt only operation
- Self-timed write, ERAL and WRAL cycles
- Automatic erase before write
- RDY/ $\overline{\mathrm{BSY}}$ status information during write
- Power on/off data protection circuitry
- Available in wafer or wafflepack
- Temperature range:
- Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc. 59C11 is a 1 K bit Electrically Erasable PROM. The device is configured as $128 \times 8$ or $64 \times 16$, selectable externally by means of the control pad ORG. Advanced CMOS technology makes this device ideal for low power non-volatile memory applications. The 59C11 dice are available in wafer or wafflepack.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss ............. -0.3 V to +7.0 V
Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temperature with
power applied $\qquad$ .. $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering temperature of leads ( 10 seconds) $\ldots .+300^{\circ} \mathrm{C}$
ESD protection on all pins ...................................... 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

## PAD FUNCTION TABLE

| Name | Function |
| :--- | :--- |
| CS | Chip Select |
| CLK | Serial Clock |
| DI | Data In |
| DO | Data Out |
| Vss | Ground |
| ORG | Memory Array Organization |
| RDY/BSY | Ready/Busy Status |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS | $\mathrm{Vcc}=+5 \mathrm{~V}( \pm 10 \%)$ <br> Commercial: $\mathrm{Tamb}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| High level input voltage | VIH | 2.0 | $V c c+1$ | V |  |
| Low level input voltage | VIL | -0.3 | 0.8 | V |  |
| High level output voltage | VOH | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| Low level output voltage | Vol |  | 0.4 | V | $\mathrm{lOL}=3.2 \mathrm{~mA}$ |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc (Note 1) |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc (Note 1) |
| Internal capacitance (all inputs/outputs) | CINT |  | 7 | pF | VIN/Vout $=0 \mathrm{~V}$ (Note 2) <br> Tamb $=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ |
| Operating current (all modes) | ICCO |  | 4 | mA | FCLK $=1 \mathrm{MHz}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| Standby current | Iccs |  | 100 | uA | $\mathrm{CS}=0 \mathrm{~V}, \mathrm{Vcc}=5.5 \mathrm{~V}$ |

Note 1: Internal resistor pull-up at Pin 6. Active output at Pin 7.
Note 2: This parameter is periodically sampled and not $100 \%$ tested.

## SYNCHRONOUS DATA TIMING



## AC CHARACTERISTICS

| Parameter | Symbol | Min | Max | Units | Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Clock frequency | FCLK |  | 1 | MHz |  |
| Clock high time | TCKH | 500 |  | ns |  |
| Clock low time | TCKL | 500 |  | ns |  |
| Chip select setup time | Tcss | 50 |  | ns |  |
| Chip select hold time | TcSH | 0 |  | ns |  |
| Chip select low time | Tcs | 100 |  | ns |  |
| Data input setup time | TDIS | 100 |  | ns |  |
| Data input hold time | TDIH | 100 |  | ns |  |
| Data output delay time | TPD |  | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Data output disable time (from CS = low) | Tcz | 0 | 100 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Data output disable time (from last clock) | TDDZ | 0 | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| RDY/BSY delay time | TRBD |  | 400 | ns |  |
| Program cycle time (Auto Erase \& Write) | TwC |  | 1 <br> 15 | ms <br> ms | for 8-bit mode <br> for ERAL and WRAL in <br> $8 / 16-b i t ~ m o d e s ~$ |

## PAD DESCRIPTION

## Chip Select (CS)

A HIGH level selects the device. A LOW level deselects the device and forces it into standby mode. However, a WRITE cycle which is already initiated and/or in progress will be completed, regardless of the CS input signal. If CS is brought LOW during a WRITE cycle, the device will go into standby mode as soon as the WRITE cycle is completed.
CS must be LOW for 100 ns (TCSL) minimum between consecutive instructions. If CS is LOW, the internal control logic is held in a RESET status.

## Serial Clock (CLK)

The Serial Clock is used to synchronize the communication between a master device and the 59C11. Opcode, address, and data bits are clocked in on the positive edge of CLK. Data bits are also clocked out on the positive edge of CLK.
CLK can be stopped anywhere in the transmission sequence (at HIGH or LOW level) and can be continued anytime (with respect to clock HIGH time (TCKH) and clock LOW time (TckL)). This gives freedom in preparing opcode, address and data for the controlling master.
CLK is a "Don't Care" if CS is LOW (device deselected). If CS is HIGH, but a start condition has not been detected, any number of clock cycles can be received by
the device without changing its status (i.e., waiting for START condition).

CLK cycles are not required during the self-timed WRITE (i.e. auto erase/write) cycle.

After detection of a START condition the specified number of clock cycles (respectively LOW to HIGH transitions of CLK) must be provided. These clock cycles are required to clock in all required opcode, address, and data bits before an instruction is executed (see instruction set truth table). When that limit has been reached, CLK and DI become don't care inputs until CS is brought LOW for at least chip select low time (TCSL) and brought HIGH again and a WRITE cycle (if any) is completed.

## Data $\ln$ (DI)

Data In is used to clock in START bit, opcode, address and data synchronously with the CLK input.

## Data Out (DO)

Data Out is used in the READ mode to output data synchronously with the CLK input (TPD after the positive edge of CLK). This output is in HIGH-Z mode except if data is clocked out as a result of a READ instruction.
DI and DO can be connected together to perform a 3wire interface (CS, CLK, DI/DO).
Care must be taken with the leading dummy zero which is output after a READ command has been detected. Also, the controlling device must not drive the DI/DO bus during WRITE cycles.

## Organization (ORG)

This input selects the memory array organization. When the ORG pad is connected to +5 V the $64 \times 16$ organization is selected. When it is connected to ground, the 128 $x 8$ organization is selected. If the ORG pad is left unconnected, then an internal pullup device will select the 64 x 16 organization.

## Ready/Busy (RDY/BSY)

Pad 7 provides RDY/BSY status information. RDY/BSY is low if the device is performing a WRITE, ERAL, or WRAL operation. When it is HIGH, the internal selftimed WRITE, ERAL or WRAL operation has been completed and the device is ready to receive a new instruction.

## DATA PROTECTION

During power-up all modes of operation are inhibited until Vcc has reached a level of between 2.8 Vand 4.5 V. During power-down the source data protection circuitry acts to inhibit all modes when Vcc has fallen below the voltage range of 2.8 V to 4.5 V .
The EWEN and EWDS commands give additional protection against accidentally programming during normal operation.
After power-up the device is automatically in the EWDS mode. Therefore, EWEN instruction must be performed before any WRITE, ERAL or WRAL instruction can be executed.


## FUNCTIONAL DESCRIPTION

## START Condition

The START bit is detected by the device if CS and DI are both HIGH with respect to the positive edge of CLK for the first time.
Before a START condition is detected, CS, CLK and DI may change in any combination (except to that of a START condition) without resulting in any device operation (READ, WRITE, EWEN, EWDS, ERAL, and WRAL). As soon as CS is HIGH, the device is no longer in the standby mode.
An instruction following a START condition will only be executed if the required amount of opcode, address and data bits for any particular instruction is clocked in.

After execution of an instruction (i.e. clock in or out of the last required address or data bit) CLK and DI become "don't care" bits until a new start condition is detected.
Note:
CS must go LOW between consecutive instructions.

## DI/DO Pads

It is possible to connect the Data In and Data Out pads together. However, with this configuration it is possible for a "bus conflict" to occur during the "dummy zero" that precedes the READ operation, if AO is a logic HIGH level. Under such a condition the voltage level seen at Data Out is undefined and will depend upon the relative impedances of Data Out and the signal source driving $A 0$. The higher the current sourcing capability of $A 0$, the higher the voltage at the Data Out pad.

## READ Mode

The READ instruction outputs the serial data of the addressed memory location on the DO pad. A dummy bit (logical 0 ) precedes the $8 / 16$-bit output string. The output data changes during the HIGH state of the system clock (CLK). The dummy bit is output TPD after the positive edge of CLK, which was used to clock in the last address bit (AO). Therefore, care must be taken if DI and DO are connected together as a bus contention will occur for one clock cycle if AO is a one.

DO will go into HIGH-Z mode with the positive edge of the next CLK cycle. This follows tie output of the last data bit DO or the low going edge of CS, whichever occurs first. DO remains stable between CLK cycles for an unlimited time as long as CS stays HIGH.

The most significant data bit (D15 or D7) is always output first, followed by the lower significant bits (D14-D0 or D6 - DO).


## WRITE Mode

The WRITE instruction is followed by 8 or 16 bits of data which are written into the specified address. The most significant data bit (D15 or D7) has to be clocked in first followed by the lower significant data bits (D14 - D0 or D6 - D0). If a WRITE instruction is recognized by the device and all data bits have been clocked in, the device
performs an automatic erase cycle on the specified address before the data are written. The WRITE cycle is completely self timed and commences automatically after the last data bit (DO) has been clocked in.
The WRITE cycle takes 1 ms for 8 -bit mode and 2 ms for 16-bit mode max.


## ERASE/WRITE Enable/Disable (EWEN,EWDS)

The device is automatically in the ERASE/WRITE Disable mode (EWDS) after power-up. Therefore, EWEN
instruction has to be performed before any WRITE, ERAL, or WRAL instruction is executed by the device.

## ERASE/WRITE ENABLE

 AND DISABLE

## ERASE All (ERAL)

The entire chip will be erased to logical "1s" if this instruction is received by the device and it is in the EWEN mode.

The ERAL cycle is completely self-timed and commences after the last dummy address bit has been clocked in. ERAL takes 15 ms max in both 8-bit and 16bit modes.


## WRITE All (WRAL)

The entire chip will be written with the data specified in that command. The WRAL cycle is completely selftimed and commences after the last data bit (DO) has been clocked in. WRAL takes 15 ms max in both 8 -bit and 16-bit modes.

Note: The WRAL does not include an automatic erase cycle for the chip. Therefore, the WRAL instruction must be preceded by an ERAL instruction and the chip must be in the EWEN status in both cases.
The WRAL instruction is used for testing and/or device initialization.

## WRITE ALL



NOTES:

## 59C11 DICE FORM

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



Microchip

## 1K ( $128 \times 8$ ) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as one block of 128 bytes ( $128 \times 8$ )
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 2 bytes
- 1 ms write cycle time for single byte
- 100,000 erase/write cycles
- Data retention >10 years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
-Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## PIN CONFIGURATION

DIP Package


## DESCRIPTION

The Microchip Technology Inc. 85C72 is a 1 K bit Electrically Erasable PROM. The device is organized as 128 $x 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. Up to eight 85C72s may be connected to the two wire bus. The 85 C 72 is available in the standard 8 -pin DIP and a surface mount SOIC package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss ...............-0.3 V to +7 V Storage temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient temp. with power applied $\ldots . . .-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$ ESD protection on all pins $\qquad$ 4.0 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| A0, A1, A2 | Chip Address Inputs |
| VSS | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| NC | No Connect |
| VCC | +5 V Power Supply |



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


## AC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | THIGH | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | Tsu:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | Tsu:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | TSU:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Input filter time constant <br> (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | TwC |  | .7 N | N | ms | Byte or Page mode N $=$ \# <br> of bytes to be written |

Note 1: As transmitter, the device must provide this internal minimum delay time to bridge the undefined region ( min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 85C72 supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the start and STOP conditions, while the 85C72 works as slave.

Both, master and slave can operate as transmitter or receiver but the master device determines which mode is activated.
Up to eight 85 C 72 s can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Other devices can be connected to the bus, but require different device codes than the 85C72 (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus proiocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the dataline must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.
Accordingly, the following bus conditions have been defined (see Figure 1):


## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.

Each data transfer is initiated with a START condition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.

Note: The 85C72 does not generate any acknowledge bits if an internal programming cycle is in progress.

The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS


## SLAVE ADDRESS

The chip address inputs A0, A1 and A2 of each 85C72 must be externally connected to either Vcc or ground (Vss), assigning to each 85C72 a unique 3-bit address. Up to eight 85C72s may be connected to the bus. Chip selection is then accomplished through software by setting the bits A0, A1 and A2 of the slave address to the corresponding hardwired logic levels of the selected 85C72.
After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 85C72, followed by the chip address bits A0, A1 and A2.
The eighth bit of slave address determines if the master device wants to read or write to the 85C72. (See Figure 2.)

The 85C72 monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.


## BYTE PROGRAM MODE

In this mode, the master sends addresses and one data byte to the 85 C 72 .
Following the START condition, the device code (4-bit), the slave address ( 3 -bit), and the R $\bar{W}$ bit, which is logic LOW, are placed onto the bus by the master. This
indicates to the addressed 85C72 that a byte with a word address will follow after it has generated an acknowledge bit. Therefore the next byte transmitted by the master is the word address and will be written into the address pointer of the 85C72. The most significant bit of the word address is a "Do Not Care" value for the 85C72. After receiving the acknowledge of the 85 C 72 , the master device transmits the data word to be written into the addressed memory location. The 85C72 acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 85C72. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 85C72, the master sends addresses and data to the 85 C 72 which is the slave. (See Figure 3.) This is done by supplying a START condition followed by the 4-bit device code, the 3-bit slave address, and the $\mathrm{R} / \overline{\mathrm{W}}$ bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 85C72, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (One " Do Not Care" bit and seven address bits.) The 85C72 will generate an acknowledge after every 8 bits received and store them consecutively in a 2-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 2 bytes are transmitted by the master, the 85C72 will terminate the write cycle. This does not affect erase/write cycles of the EEPROM array.
If the master generates a STOP condition after transmitting the first data word (Point 'P' on Figure 3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to two) data bytes will be written in a serial manner.

The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( N max $=2$ ).


## READ MODE

This mode illustrates master device reading data from the 85C72.
As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode the address pointer must be written to.) During this period the 85C72 generates the necessary acknowledge bits as defined in the appropriate section.
The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the
slave generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pin, increments the address pointei and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.

In all modes, the address pointer will automatically increment from the end of the memory block ( 128 bytes) back to the first location in that block.

FIGURE 4 - READ MODE


## PIN DESCRIPTION

## A0, A1 and A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.

Up to eight 85C72s can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pin used to transfer addresses and data into and data out of the device. It is an open drain terminal.
For normal data transfer SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## NC No Connect

This pin can be left open or used as a tie point.

## Notes:

1) A "page" is defined as the maximum number of bytes that can be programmed in a single write cycle. The $85 C 72$ page is 2 bytes long.
2) A "block" is defined as a continuous area of memory with distinct boundaries. The address pointer can not cross the boundary from one block to another. It will however, wrap around from the end of a block to the first location in the same block. The 85C72 has only one block (128 bytes).

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 1K (128 x 8) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as one block of 128 bytes ( $128 \times 8$ )
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 2 bytes
- 1 ms write cycle time for single byte
- Available in wafer or wafflepack
- Temperature range:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$


## DIE CONFIGURATION

Die Size: $106 \times 76$ mils


1. A 0
2. Vcc
3. A 1
4. NF
5. A 2
6. SCL
7. Vss
8. SDA

## DESCRIPTION

The Microchip Technology Inc. 85C72 is a 1 K bit Electrically Erasable PROM. The device is organized as 128 $x 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. Up to eight 85C72s may be connected to the two wire bus. The 85 C 72 dice are available in wafer or wafflepack.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss -0.3 V to +7 V
Storage temperature ........................ $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$
ESD protection on all pins .................................... 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PAD FUNCTION TABLE |  |
| :---: | :--- |
| Name | Function |
| A0, A1, A2 | Chip Address Inputs |
| Vss | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| NF | No Function |
| VCC | +5 V Power Supply |


| DC CHARACTERISTICS | $V c c=+5 \mathrm{~V}( \pm 10 \%)$ <br> Commercial (C): Tamb $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH <br> VIL <br> Vol | $\begin{gathered} V C c \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V C C+1 \\ V C C \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | $\mathrm{lOL}=3.2 \mathrm{~mA}$ (SDA only) |
| A0, A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \text { Vcc }-0.5 \\ -0.3 \end{gathered}$ | $\begin{gathered} \mathrm{Vcc}+0.5 \\ 0.5 \end{gathered}$ | V |  |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CINT |  | 7.0 | pF | $\begin{aligned} & \text { Vin } / \text { Vout }=0 \mathrm{~V} \text { (Note } 1 \text { ) } \\ & \text { Tamb }=+25^{\circ} \mathrm{C}, f=1 \mathrm{MHz} \end{aligned}$ |
| Operating current <br> program cycle <br> read cycle | Icco <br> Iccw <br> ICCR |  | $\begin{aligned} & 3.5 \\ & 7.0 \\ & 750 \end{aligned}$ | mA <br> mA <br> $\mu \mathrm{A}$ | $\begin{aligned} & \text { FCLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VcC}=5 \mathrm{~V}, \\ & \mathrm{VCC}=5 \mathrm{~V} \\ & \mathrm{VCC}=5 \mathrm{~V} \end{aligned}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | $S D A=S C L=V C C=5 V$ (no PROGRAM active) |

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

## BUS TIMING START/STOP



## AC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | THIGH | 4000 |  |  | ns |  |
| Clock low time | TLOW | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | TSU:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TSU:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | TSU:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Noise suppression time constant <br> (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | TwC |  | .7 N | N | ms | Byte or Page mode N = \# <br> of bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 85C72 supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 85C72 works as slave. Both, master and slave can operate as transmit-
ter or receiver but the master device determines which mode is activated.

Up to eight 85C72s can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Other devices can be connected to the bus but require different device codes than the 85C72 (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.
Accordingly, the following bus conditions have been defined (see Figure 1):


## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a start condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.
Each data transfer is initiated with a STARTcondition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.

Note: The 85C72 does not generate any acknowledge bits if an internal programming cycle is in progress.

The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL


## SLAVE ADDRESS

The chip address inputs A0, A1 and A2 of each 85 C 72 must be externally connected to either Vcc or ground (Vss), assigning to each 85C72 a unique 3-bit address. Up to eight 85C72s may be connected to the bus. Chip selection is then accomplished through software by setting the bits A0, A1 and A2 of the slave address to the corresponding hardwired logic levels of the selected 85C72.
After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 85C72, followed by the chip address bits A0, A1 and A2.

The eighth bit of slave address determines if the master device wants to read or write to the 85C72. (See Figure 2.)

The 85C72 monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.


## BYTE PROGRAM MODE

In this mode, the master sends addresses and one data byte to the 85C72.
Following the START condition, the device code (4-bit),
the slave address (3-bit), and the $\mathrm{R} \overline{\mathrm{W}}$ bit, which is logic LOW, are placed onto the bus by the master. This indicates to the addressed 85C72 that a byte with a word address will follow after it has generated an acknowledge bit. Therefore, the next byte transmitted by the master is the word address and will be written into the address pointer of the 85C72. The most significant bit of the word address is a "Do Not Care" value for the 85C72. After receiving the acknowledge of the 85C72, the master device transmits the data word to be written into the addressed memory location. The 85C72 acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 85C72. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 85 C 72 , the master sends addresses and data to the 85C72 which is the slave (see Figure 3). This is done by supplying a start condition followed by the 4-bit device code, the 3-bit slave address, and the R/W bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 85C72, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (One do not care bit and seven address bits) The 85C72 will generate an acknowledge after every 8 bits received and store them consecutively in a 2-byte RAM until a stop condition is detected which initiates the internal programming cycle. If more than 2 bytes are transmitted by the master, the 85 C 72 will terminate the write cycle. This does not affect erase/ write cycles of the EEPROM array.
If the master generates a STOP condition after transmitting the first data word (Point ' $P$ ' on Figure 3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to 2 ) data bytes will be written in a serial manner.

## READ MODE

This mode illustrates master device reading data from the 85C72.

As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode the address pointer must be written to.) During this period the 85C72 generates the necessary acknowledge bits as defined in the appropriate section.

The master now generates another start condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave
generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pad, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a stop condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.

FIGURE 4 - READ MODE


## PAD DESCRIPTION

## A0, A1 and A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.

Up to eight 85C72s can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pad used to transfer addresses and data into and data out of the device. It is an open drain terminal.

For normal data transfer SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## NF No Function

This pad must be connected to Vss for normal operation.

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 2K ( $256 \times 8$ ) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as one block of 256 bytes ( $256 \times 8$ )
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 2 bytes
- 1 ms write cycle time for single byte
- 100,000 erase/write cycles
- Data retention >10 years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
-Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc. 85C82 is a 2 K bit Electrically Erasable PROM. The device is organized as 256 $x 8$ bit memory with a two wire serial interface. Advanced CMOStechnology allows a significant reduction in power over NMOS serial devices. The 85C82 also has a pagewrite capability for up to 2 bytes of data. Up to eight 85C82s may be connected to the two wire bus. The 85 C 82 is available in standard 8-pin DIP and surface mount SOIC package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss $\qquad$ -0.3 V to +7 V
Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$
ESD protection on all pins $\qquad$ .4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| AO A1, A2 | Chip Address Inputs |
| VSS | Ground |
| SDA | Serial Address/Data Input/Output |
| SCL | Serial Clock |
| NC | No Connect |
| VCC | +5 V Power Supply |


| DC CHARACTERISTICS |  |  |  |  | $\mathrm{VcC}=+5 \mathrm{~V}( \pm 10 \%)$ <br> Commercial (C): Tamb $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ <br> Industrial <br> (I): $\mathrm{Tamb}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Automotive <br> (E): Tamb $=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH <br> VIL <br> VoL | $\begin{gathered} \text { Vcc } \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V c c+1 \\ V C c \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | $\mathrm{IOL}=3.2 \mathrm{~mA}$ (SDA only) |
| A0, A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \text { Vcc-0.5 } \\ -0.3 \end{gathered}$ | $\begin{gathered} \mathrm{Vcc}+0.5 \\ 0.5 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CINT |  | 7.0 | pF | $\begin{aligned} & \text { Vin } / \text { Vout }=0 \mathrm{~V}(\text { Note } 1) \\ & \mathrm{Tamb}=+25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Operating current <br> program cycle <br> read cycle | Icco <br> ICCW <br> ICCR |  | $\begin{gathered} 3.5 \\ 4.25 \\ 7.0 \\ 8.5 \\ 750 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \text { FCLK }=100 \mathrm{kHz}, \text { program cycle time }=2 \mathrm{~ms}, \\ & \text { VCC }=5 \mathrm{~V}, \mathrm{Tamb}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \text { FCLK }=100 \mathrm{kHz}, \text { program cycle time }=2 \mathrm{~ms}, \\ & \mathrm{VCC}=5 \mathrm{~V}, \mathrm{Tamb}=(\mathrm{I}) \text { and }(\mathrm{E}) \\ & \mathrm{VCC}=5 \mathrm{~V}, \mathrm{Tamb}=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \mathrm{VCC}=5 \mathrm{~V}, \mathrm{Tamb}=(\mathrm{I}) \text { and (E) } \\ & \text { Vcc }=5 \mathrm{~V}, \text { Tamb }=(\mathrm{C}), \text { (I) and (E) } \end{aligned}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | SDA $=\mathrm{SCL}=\mathrm{VcC}=5 \mathrm{~V}$ (no PROGRAM active) |

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

## BUS TIMING START/STOP



## AC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | THIGH | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | Tsu:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TSU:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | TSU:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Input filter time constant <br> (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | TwC |  | .7 N | N | ms | Byte or Page mode N = \# <br> of bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 85C82 supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 85C82 works as
slave. Both, master and slave can operate as transmitter or receiver, but the master device determines which mode is activated.

Up to eight 85C82s can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Other devices can be connected to the bus, but require different device codes than the 85C82 (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.

Accordingly, the following bus conditions have been defined (see Figure 1):

## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a start condition, the data line is stable for the duration of the HIGH period of the clock signal.
The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.
Each data transfer is initiated with a START condition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.
Note: The 85C82 does not generate any acknowledge bits if an internal programming cycle is in progress.
The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS


## SLAVE ADDRESS

The chip address inputs A0, A1 and A2 of each 85 C 82 must be externally connected to either Vcc or ground (Vss), assigning to each 85C82 a unique 3-bit address. Up to eight 85C82s may be connected to the bus. Chip selection is then accomplished through software by setting the bits A0, A1 and A2 of the transmitted slave address to the corresponding hardwired logic levels of the selected 85 C 82 .

After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 85C82, followed by the chip address bits A0, A1 and A2.
The eighth bit of slave address determines if the master device wants to read or write to the 85C82. (See Figure 2.)

The 85C82 monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.


## BYTE PROGRAM MODE

In this mode the master sends addresses and one data byte to the 85C82.
Following the START condition, the device code (4-bit), the slave address (3-bit), and the $R / \bar{W}$ bit, which is logic

LOW, are placed onto the bus by the master. This indicates to the addressed 85C82 that a byte with a word address will follow after it has generated an acknowledge bit. Therefore, the next byte transmitted by the master is the word address and will be written into the address pointer of the 85C82. After receiving the acknowledge of the 85 C 82 , the master device transmits the data word to be written into the addressed memory location. The 85C82 acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 85 C 82 . (See Figure 3.)

## PAGE PROGRAM MODE

To program the 85 C 82 , the master sends addresses and data to the 85C82 which is the slave (see Figure 3). This is done by supplying a START condition followed by the 4-bit device code, the 3-bit slave address, and the R/W bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 85 C 82 , it places it in the lower 8 bits of the address pointer defining which memory location is to be written. The 85C82 will generate an acknowledge after every 8 bits received and store them consecutively in a 2-byte RAM until a stop condition is detected which initiates the internal programming cycle. If more than 2 bytes are transmitted by the master, the 85C82 will terminate the write cycle. This does not affect erase/write cycles of the EEPROM array.

If the master generates a STOP condition after transmitting the first data word (Point 'P' on Figure 3), byte programming mode is entered.

The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to two) data bytes will be written in a serial manner.

The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( $\mathrm{N} \max =2$ ).


## READ MODE

This mode illustrates master device reading data from the 85C82.
As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode, the address pointer must be written to.) During this period the 85C82 generates the necessary acknowledge bits as defined in the appropriate section.

The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the
data from the addressed location on to the SDA pin, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted $r$ 'hen the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.
Note: In all modes, the address pointer will automatically increment from the end of the memory block ( 256 byte) back to the first location in that block.

## FIGURE 4 - READ MODE



## PIN DESCRIPTION

## A0, A1 and A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.
Up to eight 85C82s can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pin used to transfer addresses and data into and data out of the device. It is an open drain terminal. For normal data transfer SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## NC No Connect

This pin can be left open or used as a tie point.

## Notes:

1) A "page" is defined as the maximum number of bytes that can be programmed in a single write cycle. The 85 C 82 page is 2 bytes long.
2) $A$ "block" is defined as a continuous area of memory with distinct boundaries. The address pointer can not cross the boundary from one block to another. It will however, wrap around from the end of a block to the first location in the same block. The 85C82 has only one block (256 bytes).

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 2K ( $256 \times 8$ ) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as one block of 256 bytes (256 x 8)
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 2 bytes
- 1 ms write cycle time for single byte
- Available in wafer or wafflepack
- Temperature range:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc. 85C82 is a 2 K bit Electrically Erasable PROM. The device is organized as 256 $\times 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. The 85C82 also has a pagewrite capability for up to 2 bytes of data. Up to eight 85C82s may be connected to the two wire bus. The 85 C 82 dice are available in wafer or wafflepack.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss . 0.3 V to +7 V
Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temp. with power applied....$-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$
ESD protection on all pins ..................................... 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PAD FUNCTION TABLE |  |
| :---: | :--- |
| Name | Function |
| A0,A1,A2 | Chip Address Inputs |
| Vss | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| NF | No Function |
| Vcc | +5 V Power Supply |



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


## AC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | THIGH | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | Tsu:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TSU:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | TsU:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Noise suppression time constant <br> (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | TwC |  | $.7 N$ | N | ms | Byte or Page mode N = \# <br> of bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 85C82 supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is, defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 85C82 works as slave. Both, master and slave can operate as transmit-
ter or receiver but the master device determines which mode is activated.
Up to eight 85C82s can be connected to the bus, selected by the A0, A1 and A2 chip address inputs. Other devices can be connected to the bus but require different device codes than the 85C82 (refer to section Slave Address).

## 85C82 DICE FORM

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.
Accordingly, the following bus conditions have been defined (see Figure 1):


## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.
The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.

Each data transfer is initiated with a START condition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.

Note: The 85C82 does not generate any acknowledge bits if an internal programming cycle is in progress.
The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS BUS


## SLAVE ADDRESS

The chip address inputs A0, A1 and A2 of each 85C82 must be externally connected to either Vcc or ground (Vss), assigning to each 85C82 a unique 3-bit address. Up to eight 85C82s may be connected to the bus. Chip selection is then accomplished through software by setting the bits A0, A1 and A2 of the transmitted slave address to the corresponding hardwired logic levels of the selected 85 C 82 .

After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 85C82, followed by the chip address bits A0, A1 and A2.
The eighth bit of slave address determines if the master device wants to read or write to the 85C82. (See Figure 2.)

The 85C82 monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.

FIGURE 2 - SLAVE ADDRESS ALLOCATION


## BYTE PROGRAM MODE

In this mode the master sends addresses and one data byte to the 85 C 82 .

Following the START condition, the device code (4-bit), the slave address (3-bit), and the $R, \bar{W}$ bit, which is logic LOW, are placed onto the bus by the master. This indicates to the addressed 85C82 that a byte with a word address will follow after it has generated an acknowledge bit. Therefore, the next byte transmitted by the master is the word address and will be written into the address pointer of the 85 C 82 . After receiving the acknowledge of the 85 C 82 , the master device transmits the data word to be written into the addressed memory location. The 85C82 acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 85C82. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 85 C 82 , the master sends addresses and data to the 85 C 82 which is the slave (see Figure 3). This is done by supplying a start condition followed by the 4-bit device code, the 3-bit slave address, and the R/W bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 85 C 82 , it places it in the lower 8 bits of the address pointer defining which memory location is to be written. The 85C82 will generate an acknowledge after every 8 bits received and store them consecutively in a 2-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 2 bytes are transmitted by the master, the 85 C 82 will terminate the write cycle. This does not affect erase/write cycles of the EEPROM array.
If the master generates a STOP condition after transmitting the first data word (Point ' $P$ ' on Figure 3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to 2 ) data bytes will be

## READ MODE

This mode illustrates master device reading data from the 85 C 82 .

As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: although this is a read mode the address pointer must be written to.) During this period the 85C82 generates the necessary acknowledge bits as defined in the appropriate section.
The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the data from the addressed location on to the SDA pad,
increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.
Note: In all modes, the address pointer will automatically increment from the end of the memory block (256 bytes) back to the first location in that block.

FIGURE 4 - READ MODE


## PAD DESCRIPTION

## A0, A1 and A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.
Up to eight 85C82s can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pad used to transfer addresses and data into and data out of the device. It is an open drain terminal.

For normal data transfer SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## NF No Function

This pad must be connected to Vss for normal operation.

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



Microchip

## 4K (512 x 8) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as two blocks of 256 bytes ( $2 \times 256 \times 8$ )
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 8 bytes
- 1 ms write cycle time for single byte
- 100,000 erase/write cycles
- Data retention >10 years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
—Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## PIN CONFIGURATION



## DESCRIPTION

The Microchip Technology Inc. 85C92 is a 4 K bit Electrically Erasable PROM. The device is organized as two blocks of $256 \times 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. The 85 C 92 also has a page-write capability for up to 8 bytes of data. Up to four 85C92s may be connected to the two wire bus. The 85 C 92 is available in the standard 8 -pin DIP and a surface mount SOIC package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss ...............-0.3 V to +7 V
Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$ ESD protection on all pins 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| A0 | No function. Must be connented to |
|  | Vcc or Vss |
| A1, A2 | Chip address Inputs |
| VSs | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| NC | No Connect |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS |  |  |  | $\mathrm{Vcc}=+5 \mathrm{~V}( \pm 10 \%)$ <br> Commercial <br> (C): $\mathrm{Tamb}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ <br> Industrial <br> (I): $\mathrm{Tamb}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Automotive <br> (E): Tamb $=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | VIH <br> VIL <br> Vol | $\begin{gathered} \text { Vcc } \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V c c+1 \\ V c c \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | $\mathrm{IOL}=3.2 \mathrm{~mA}$ (SDA only) |
| A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \mathrm{V} c \mathrm{C}-0.5 \\ -0.3 \end{gathered}$ | $\begin{gathered} \mathrm{Vcc}+0.5 \\ 0.5 \end{gathered}$ | V |  |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CINT |  | 7.0 | pF | $\begin{aligned} & \text { VIN } / \text { Vout }=0 \mathrm{~V} \text { (Note 1) } \\ & \text { TAMB }=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Operating current <br> program cycle <br> read cycle | Icco <br> Iccw <br> ICCR |  | $\begin{array}{r} 3.5 \\ \\ 4.25 \\ \\ 7.0 \\ 8.5 \\ 750 \end{array}$ | mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ | $\begin{aligned} & \text { FCLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VCC}=5 \mathrm{~V}, \\ & \text { Tamb }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \text { FcLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VCC}=5 \mathrm{~V}, \\ & \text { Tamb }=(\mathrm{I}) \text { and }(\mathrm{E}) \\ & \mathrm{VCC}=5 \mathrm{~V}, \text { Tamb }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \mathrm{VCC}=5 \mathrm{~V}, \mathrm{Tamb}=(\mathrm{I}) \text { and (E) } \\ & \mathrm{VcC}=5 \mathrm{~V}, \text { Tamb }=(\mathrm{C}), \text { (I) and (E) } \end{aligned}$ |
| Standby current | IcCs |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & S D A=S C L=V C C=5 \mathrm{~V} \\ & \text { (no PROGRAM active) } \end{aligned}$ |

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


## AC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | THIGH | 4000 |  |  | ns |  |
| Clock low time | TLOW | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | TsU:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | Tsu:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | TsU:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Input filter time constant <br> (SDA and SCL pins) | TI |  |  | 100 | ns |  |
| Program cycle time | TWC |  | .7 N | N | ms | Byte or Page mode N = \# <br> of bytes to be written |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 85C92 supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 85C92 works as slave. Both, master and slave can operate as transmit-
ter or receiver but the master device determines which mode is activated.

Up to four 85C92s can be connected to the bus, selected by the A1 and A2 chip address inputs. A0 must be tied to Vcc or Vss. Other devices can be connected to the bus but require different device codes than the 85C92 (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.

Accordingly, the following bus conditions have been defined (see Figure 1):

## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.

Each data transfer is initiated with a START condition and terminated with a STOP condition. The number of the data bytes transferred between the START and STOP conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.

Note: The 85C92 does not generate any acknowledge bits if an internal programming cycle is in progress.

The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case, the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS


## SLAVE ADDRESS

The chip address inputs A1 and A2 of each 85C92 must be externally connected to either Vcc or ground (Vss), assigning to each 85C92 a unique 2-bit address. Up to four 85C92s may be connected to the bus. Chip selection is then accomplished through software by setting the bits A1 and A2 of the slave address to the corresponding hardwired logic levels of the selected 85 C 92 . AO is not used and must be connected to either Vcc or Vss.

After generating a start condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 85C92, followed by the chip address bits A1 and A2. The seventh bit of that byte (BA) is used to select the upper block (addresses 100-1FF) or lower page (addresses 000-0FF) of the 85C92.

The eighth bit of slave address determines if the master device wants to read or write to the 85C92. (See Figure 2.)

The 85C92 monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.

## FIGURE 2 - SLAVE ADDRESS

 ALLOCATION

## BYTE PROGRAM MODE

In this mode the master sends addresses and one data byte to the 85 C 92 .

Following the START condition, the device code (4-bit), the slave address (3-bit), and the R/W bit, which is logic

LOW, are placed onto the bus by the master. This indicates to the addressed 85C92 that a byte with a word address will follow after it has generated an acknowledge bit. Therefore the next byte transmitted by the master is the word address and will be written into the address pointer of the 85C92. After receiving the acknowledge of the 85C92, the master device transmits the data word to be written into the addressed memory location. The 85C92 acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 85C92. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 85 C 92 , the master sends addresses and data to the 85C92 which is the slave (see Figure 3). This is done by supplying a START condition followed by the 4-bit device code, the 3-bit slave address, and the $R \bar{W}$ bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 85 C 92 , it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (The BA bit transmitted with the slave address is the ninth bit of the address pointer.) The 85C92 will generate an acknowledge after every 8 bits received and store them consecutively in an 8-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 8 bytes are transmitted by the master, the 85C92 will roll over and overwrite the data beginning with the first received byte. This does not affect erase/write cycles of the EEPROM array and is accomplished as a result of only allowing the address registers bottom 3 bits to increment while the upper 5 bits remain unchanged.

If the master generates a STOP condition after transmitting the first data word (Point ' $P$ ' on Figure 3), byte programming mode is entered.

The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to 8) data bytes will be written in a serial manner.

The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( $\mathrm{N} \max =8$ ).

## READ MODE

This mode illustrates master device reading data from the 85C92.

As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: Although this is a read mode, the address pointer must be written to.) During this period the 85C92 generates the necessary acknowledge bits as defined in the appropriate section.

The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the
data from the addressed location on to the SDA pin, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.

Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.

In all modes, the address pointer will not increment through ablock ( 256 byte) boundary but will wrap around to the first location in that block.

FIGURE 4 - READ MODE


## PIN DESCRIPTION

## AO

This pin must be connected to either Vcc or Vss.

## A1, A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.

Up to four 85C92s can be connected to the bus.
These inputs must be connected to either Vss or Vcc.

## SDA Serial Address/Data Input/Output

This is a bidirectional pin used to transfer addresses and data into and data out of the device. It is an open drain terminal.

For normal data transfer SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

## SCL Serial Clock

This input is used to synchronize the data transfer from and to the device.

## NC No Connect

This pin can be left open or used as a tie point.

## Notes:

1) A "page" is defined as the maximum number of bytes that can be programmed in a single write cycle. The 85C92 page is 8 bytes long.
2) A "block" is defined as a continuous area of memory with distinct boundaries. The address pointer can not cross the boundary from one block to another. It will however, wrap around from the end of a block to the first location in the same block. The 85C92 has two blocks, 256 bytes each.

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 4K (512 x 8) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- Organized as two blocks of 256 bytes ( $2 \times 256 \times 8$ )
- Two wire serial interface bus
- 5 volt only operation
- Self-timed write cycle (including auto-erase)
- Page-write buffer for up to 8 bytes
- 1 ms write cycle time for single byte
- Available in wafer or wafflepack
- Temperature range:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$


## DIE CONFIGURATION

Die Size: $113 \times 76$ mils


## DESCRIPTION

The Microchip Technology Inc. 85C92 is a 4 K bit Electrically Erasable PROM. The device is organized as two blocks of $256 \times 8$ bit memory with a two wire serial interface. Advanced CMOS technology allows a significant reduction in power over NMOS serial devices. The 85C92 also has a page-write capability for up to 8 bytes of data. Up to four 85C92s may be connected to the two wire bus. The 85C92 dice are available in wafer or wafflepack package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss -0.3 V to +7 V Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient temp. with power applied .....-65 ${ }^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering temperature of leads ( 10 seconds) .. $+300^{\circ} \mathrm{C}$ ESD protection on all pins ................................. 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PAD FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| A0, A1, A2 | Chip Address Inputs |
| Vss | Ground |
| SDA | Serial Address/Data I/O |
| SCL | Serial Clock |
| NF | No Function |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS | $\mathrm{Vcc}=+5 \mathrm{~V}( \pm 10 \%)$ <br> Commercial: $\mathrm{Tamb}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| SCL and SDA pins: High level input voltage Low level input voltage Low level output voltage | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \\ & \text { VL } \end{aligned}$ | $\begin{gathered} \operatorname{Vcc} \times 0.7 \\ -0.3 \end{gathered}$ | $\begin{gathered} V c c+1 \\ V c c \times 0.3 \\ 0.4 \end{gathered}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ | IOL $=3.2 \mathrm{~mA}$ (SDA only) |
| A0, A1 \& A2 pins: High level input voltage Low level input voltage | $\begin{aligned} & \mathrm{VIH}_{1} \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} \mathrm{Vcc}-0.5 \\ -0.3 \end{gathered}$ | $\begin{gathered} \mathrm{VCC}+0.5 \\ 0.5 \end{gathered}$ | $\stackrel{v}{v}$ |  |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Internal capacitance (all inputs/outputs) | CInt |  | 7.0 | pF | $\begin{aligned} & \text { Vin/VouT }=0 \mathrm{~V}(\text { Note } 1) \\ & \text { Tamb }=+25^{\circ} \mathrm{C}, f=1 \mathrm{MHz} \end{aligned}$ |
| Operating current <br> program cycle read cycle | Icco <br> Iccw <br> ICCR |  | $\begin{aligned} & 3.5 \\ & 7.0 \\ & 750 \end{aligned}$ | mA <br> mA $\mu \mathrm{A}$ | $\begin{aligned} & \text { FcLK }=100 \mathrm{kHz}, \text { program cycle } \\ & \text { time }=2 \mathrm{~ms}, \mathrm{VCC}=5 \mathrm{~V}, \\ & \mathrm{VCC}=5 \mathrm{~V} \\ & \mathrm{VCC}=5 \mathrm{~V} \end{aligned}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | $\mathrm{SDA}=\mathrm{SCL}=\mathrm{VCC}=5 \mathrm{~V}$ (no PROGRAM active) |

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


## AC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Units | Remarks |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Clock frequency | FCLK |  |  | 100 | kHz |  |
| Clock high time | THIGH | 4000 |  |  | ns |  |
| Clock low time | TLow | 4700 |  |  | ns |  |
| SDA and SCL rise time | TR |  |  | 1000 | ns |  |
| SDA and SCL fall time | TF |  |  | 300 | ns |  |
| START condition hold time | THD:STA | 4000 |  |  | ns | After this period the first <br> clock pulse is generated |
| START condition setup time | TsU:STA | 4700 |  |  | ns | Only relevant for repeated <br> START condition |
| Data input hold time | THD:DAT | 0 |  |  | ns |  |
| Data input setup time | TSU:DAT | 250 |  |  | ns |  |
| Data output delay time | TPD | 300 |  | 3500 | ns | See Note 1 |
| STOP condition setup time | TSU:STO | 4700 |  |  | ns |  |
| Bus free time | TBUF | 4700 |  |  | ns | Time the bus must be free <br> before a new transmission <br> can start |
| Noise suppression time constant | TI |  |  | 100 | ns |  |
| (SDA and SCL pins) |  |  | NN | ms | Byte or Page mode N = \# <br> of bytes to be written |  |
| Program cycle time | TwC |  |  |  |  |  |

Note 1: As transmitter the device must provide this internal minimum delay time to bridge the undefined region (min 300 ns ) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.


## FUNCTIONAL DESCRIPTION

The 85C92 supports a bidirectional two wire bus and data transmission protocol. A device that sends data onto the bus is defined as transmitter, and a device receiving data as receiver. The bus has to be controlled by a master device which generates the serial clock (SCL), controls the bus access, and generates the START and STOP conditions, while the 85C92 works as slave. Both, master and slave can operate as transmit-
ter or receiver but the master device determines which mode is activated.

Up to four 85C92s can be connected to the bus, selected by the A1 and A2 chip address inputs. A0 must be tied to Vcc or Vss. Other devices can be connected to the bus but require different device codes than the 85 C 92 (refer to section Slave Address).

## BUS CHARACTERISTICS

The following bus protocol has been defined:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is HIGH. Changes in the data line while the clock line is HIGH will be interpreted as a START or STOP condition.

Accordingly, the following bus conditions have been defined (see Figure 1):

## Bus not Busy (A)

Both data and clock lines remain HIGH.

## Start Data Transfer (B)

A HIGH to LOW transition of the SDA line while the clock (SCL) is HIGH determines a START condition. All commands must be preceded by a START condition.

## Stop Data Transfer (C)

A LOW to HIGH transition of the SDA line while the clock (SCL) is HIGH determines a STOP condition. All operations must be ended with a STOP condition.

## Data Valid (D)

The state of the data line represents valid data when, after a START condition, the data line is stable for the duration of the HIGH period of the clock signal.

The data on the line must be changed during the LOW period of the clock signal. There is one clock pulse per bit of data.

Each data transfer is initiated with a start condition and terminated with a stop condition. The number of the data bytes transferred between the start and stop conditions is determined by the master device and is theoretically unlimited.

## Acknowledge

Each receiving device, when addressed, is obliged to generate an acknowledge after the reception of each byte. The master device must generate an extra clock pulse which is associated with this acknowledge bit.

Note: The 85C92 does not generate any acknowledge bits if an internal programming cycle is in progress.

The device that acknowledges, has to pull down the SDA line during the acknowledge clock pulse in such a way that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse. Of course, setup and hold times must be taken into account. A master must signal an end of data to the slave by not generating an acknowledge bit on the last byte that has been clocked out of the slave. In this case the slave must leave the data line HIGH to enable the master to generate the STOP condition.

FIGURE 1 - DATA TRANSFER SEQUENCE ON THE SERIAL BUS


## SLAVE ADDRESS

The chip address inputs A1 and A2 of each 85 C92 must be externally connected to either Vcc or ground (Vss), assigning to each 85C92 a unique 2-bit address. Up to four 85C92s may be connected to the bus. Chip selection is then accomplished through software by setting the bits A1 and A2 of the slave address to the corresponding hardwired logic levels of the selected 85C92. AO is not used and must be connected to Vcc or Vss.
After generating a START condition, the bus master transmits the slave address consisting of a 4-bit device code (1010) for the 85C92, followed by the chip address bits A1 and A2. The seventh bit of that byte (PA) is used to select the upper page (addresses 100-1FF) or lower page (addresses 000-0FF) of the 85C92.
The eighth bit of slave address determines if the master device wants to read or write to the 85C92. (See Figure 2.)

The 85C92 monitors the bus for its corresponding slave address all the time. It generates an acknowledge bit if the slave address was true and it is not in a programming mode.


## BYTE PROGRAM MODE

In this mode the master sends addresses and one data byte to the 85C92.

Following the START condition, the device code (4-bit), the slave address (3-bit), and the R $\bar{W}$ bit, which is logic LOW, are placed onto the bus by the master. This
indicates to the addressed 85C92 that a byte with a word address will follow after it has generated an acknowledge bit. Therefore, the next byte transmitted by the master is the word address and will be written into the address pointer of the 85C92. After receiving the acknowledge of the 85C92, the master device transmits the data word to be written into the addressed memory location. The 85C92 acknowledges again and the master generates a STOP condition. This initiates the internal programming cycle of the 85C92. (See Figure 3.)

## PAGE PROGRAM MODE

To program the 85 C 92 , the master sends addresses and data to the 85C92 which is the slave (see Figure 3). This is done by supplying a start condition followed by the 4-bit device code, the 3-bit slave address, and the RAN bit which is defined as a logic LOW for a write. This indicates to the addressed slave that a word address will follow so the slave outputs the acknowledge pulse to the master during the ninth clock pulse. When the word address is received by the 85C92, it places it in the lower 8 bits of the address pointer defining which memory location is to be written. (The PA bit transmitted with the slave address is the ninth bit of the address pointer.) The 85C92 will generate an acknowledge after every 8 bits received and store them consecutively in an 8-byte RAM until a STOP condition is detected which initiates the internal programming cycle. If more than 8 bytes are transmitted by the master, the 85C92 will roll over and overwrite the data beginning with the first received byte. This does not affect erase/write cycles of the EEPROM array and is accomplished as a result of only allowing the address registers bottom 3 bits to increment while the upper 5 bits remain unchanged.
If the master generates a STOP condition after transmitting the first data word (Point ' $P$ ' on Figure 3), byte programming mode is entered.
The internal, completely self-timed PROGRAM cycle starts after the STOP condition has been generated by the master and all received (up to 8) data bytes will be written in a serial manner.

The PROGRAM cycle takes N milliseconds, whereby N is the number of received data bytes ( N max $=8$ ).


## READ MODE

This mode illustrates master device reading data from the 85 C 92 .

As can be seen from Figure 4, the master first sets up the slave and word addresses by doing a write. (Note: although this is a read mode the address pointer must be written to.) During this period the 85C92 generates the necessary acknowledge bits as defined in the appropriate section.
The master now generates another START condition and transmits the slave address again, except this time the read/write bit is set into the read mode. After the slave generates the acknowledge bit, it then outputs the
data from the addressed location on to the SDA pad, increments the address pointer and, if it receives an acknowledge from the master, will transmit the next consecutive byte. This autoincrement sequence is only aborted when the master sends a STOP condition instead of an acknowledge.
Note: If the master knows where the address pointer is, it can begin the read sequence at point ' $R$ ' indicated on Figure 4 and save time transmitting the slave and word addresses.
Note: In all modes, the address pointer will never automatically increment through a block (256 byte) boundary but will rotate back to the first location in that block.

FIGURE 4 - READ MODE


## PAD DESCRIPTION

## AO

This pad must be connected to either Vcc or Vss.

## A1, A2 Chip Address Inputs

The levels on these inputs are compared with the corresponding bits in the slave address. The chip is selected if the compare is true.
Up to four 85C92s can be connected to the bus.
These inputs must be connected to either Vcc or Vss.

## SDA Serial Address/Data Input/Output

This is a bidirectional pad used to transfer addresses and data into and data out of the device. It is an open drain terminal.
For normal data transfer SDA is allowed to change only during SCL LOW. Changes during SCL HIGH are reserved for indicating the START and STOP conditions.

NOTES:

## 85C92 DICE FORM

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 256 Bits (16 X 16) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- $16 \times 16$ bit memory organization
- Single 5 volt only operation
- Self-timed ERASE and WRITE cycles
- Automatic ERASE before WRITE
- Power on/off data protection circuitry
- 100,000 ERASE/WRITE cycles
- Data Retention > 10 Years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
- Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc. 93C06 is a 256 bit serial Electrically Erasable PROM. The device memory is configured as $16 \times 16$ bits. Advanced CMOS technology makes this device ideal for low power non-volatile memory applications. The 93C06 is available in the standard 8pin DIP and a surface mount SOIC package.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss............. -0.3 V to +7.0 V
Storage temperature ............................ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temperature with
power applied $\qquad$ $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering termperature of leads ( 10 seconds) $\ldots+300^{\circ} \mathrm{C}$
ESD protection on all pins $\qquad$ .4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| CS | Chip Select |
| CLK | Serial Clock |
| DI | Data In |
| DO | Data Out |
| Vss | Ground |
| NU | Not Utilized. No Connection |
| Vcc | +5 V Power Supply |


| DC CHARACTERISTICS |  |  |  | $\mathrm{VCC}=+$ Comme ndustria Automo | $\begin{aligned} & 10 \%) \\ & \text { Tamb }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| High level input voltage | VIH | 2.0 | Vcc + 1 | V |  |
| Low level input voltage | VIL | -0.3 | 0.8 | V |  |
| High level output voltage | VOH | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| Low level output voltage | Vol |  | 0.4 | V | $\mathrm{IOL}=3.2 \mathrm{~mA}$ |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc (Note 1) |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc (Note 1) |
| Internal capacitance (all inputs/outputs) | CINT |  | 7 | pF | $\begin{aligned} & \text { Vin } / \text { Vout }=0 \mathrm{~V}(\text { Note } 2) \\ & \text { Tamb }=+25^{\circ} \mathrm{C}, \mathrm{~F}=1 \mathrm{MHz} \end{aligned}$ |
| Operating current (all modes) | Icco |  | 4 | mA | FCLK $=1 \mathrm{MHz}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | $\mathrm{CS}=\mathrm{Vss}, \mathrm{Vcc}=5.5 \mathrm{~V}$ |

Note 1: Internal resistor pull-up at Pin 6.
Note 2: This parameter is periodically sampled and not $100 \%$ tested.


AC CHARACTERISTICS

| Parameter | Symbol | Min | Max | Units | Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Clock frequency | FCLK |  | 1 | MHz |  |
| Clock high time | TCKH | 500 |  | ns |  |
| Clock low time | TCKL | 500 |  | ns |  |
| Chip select setup time | TCSs | 50 |  | ns |  |
| Chip select hold time | TCSH | 0 |  | ns |  |
| Chip select low time | TCSL | 100 |  | ns |  |
| Data input setup time | TDIS | 100 |  | ns |  |
| Data input hold time | TDIH | 100 |  | ns |  |
| Data output delay time | TPD |  | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Data output disable time (from CS = Low) | TCZ | 0 | 100 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Data output disable time (from last clock) | TDDZ | 0 | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Status valid time | Tsv |  | 100 | ns | CL = 100 pF |
| Program cycle time (Auto Erase \& Write) | TwC |  | 2 | ms | for ERAL and WRAL |
| Erase cycle time | TEC |  | 1 | ms |  |

## PIN DESCRIPTION

## Chip Select (CS)

A HIGH level selects the device. A LOW level deselects the device and forces it into standby mode. However, a programming cycle which is already initiated and/or in progress will be completed, regardless of the CS input signal. If CS is brought LOW during a program cycle, the device will go into standby mode as soon as the programming cycle is completed.
CS must be LOW for 100 ns minimum (TCsL) between consecutive instructions. If CS is LOW, the internal control logic is held in a RESET status.

## Serial Clock (CLK)

The Serial Clock is used to synchronize the communication between a master device and the 93C06. Opcode, address, and data bits are clocked in on the positive edge of CLK. Data bits are also clocked out on the positive edge of CLK.
CLK can be stopped anywhere in the transmission sequence (at HIGH or LOW level) and can be continued anytime (with respect to clock HIGH time (TCKH) and clock LOW time (TCKL). This gives the controlling master freedom in preparing opcode, address and data.
CLK is a "Don't Care" if CS is LOW (device deselected). If CS is HIGH, but START condition has not been detected, any number of clock cycles can be received by the device without changing its status. (i.e., waiting for START condition).

CLK cycles are not required during the self-timed WRITE (i.e,. auto ERASE/WRITE) cycle.

After detection of a START condition, the specified number of clock cycles (respectively LOW to HIGH transitions of CLK) must be provided. These clock cycles are required to clock in all required opcode, address, and data bits before an instruction is executed (see instruction set truth table). CLK and DI then become "Don't Care" inputs waiting for a new start condition to be detected.
Note: CS must go LOW between consecutive instructions.

## Data In (DI)

Data In is used to clock in a Start bit, opcode, address, and data synchronously with the CLK input.

## Data Out (DO)

Data Out is used in the READ mode to output data synchronously with the CLK input (TPD after the positive edge of CLK).
This pin also provides READY/BUSY status information during ERASE and WRITE cycles. READY/BUSY status information is available on the DO pin if CS is brought high after being low for minimum chip select LOW time (TCSL) from the falling edge of the CLK which clocked in the last DI bit (DO for WRITE, A0 for ERASE) and an ERASE or WRITE operation has been initiated.

The status signal is not available on DO, if CS is held LOW or HIGH during the entire WRITE or ERASE cycle. In all other cases DO is in the HIGH-Z mode. If status is checked after the WRITE/ERASE cycle, a pull-up resistor on DO is required to read the READY signal.

DI and DO can be connected together to perform a 3wire interface (CS, CLK, DI/DO).

Care must be taken with the leading dummy zero which is outputted after a READ command has been detected. Also, the controlling device must not drive the DI/DO bus during ERASE and WRITE cycles if the READY/BUSY status information is output by the 93C06.


## FUNCTIONAL DESCRIPTION

## START Condition

The start bit is detected by the device if CS and DI are both HIGH with respect to the positive edge of CLK for the first time.

Before a START condition is detected, CS, CLK, and DI may change in any combination (except to that of a START condition), without resulting in any device operation (READ, WRITE, ERASE, EWEN, EWDS, ERAL, and WRAL). As soon as CS is High, the device is no longer in the standby mode.
An instruction following a START condition will only be executed if the required amount of opcode, address and data bits for any particular instruction is clocked in.
After execution of an instruction (i.e., clock in or out of the last required address or data bit) CLK and DI become don't care bits until a new START condition is detected.

## DIIDO

It is possible to connect the Data In and Data Out pins together. However, with this configuration it is possible for a "bus conflict" to occur during the "dummy zero" that precedes the READ operation, if AO is a logic HIGH level. Under such a condition the voltage level seen at Data Out is undefined and will depend upon the relative impedances of Data Out and the signal source driving $A 0$. The higher the current sourcing capability of $A O$, the higher the voltage at the Data Out pin.

## Data Protection and Noise Immunity

During power-up, all modes of operation are inhibited until Vcc has reached a level of between 2.8 Vand 4.5 V.

During power-down, the source data protection circuitry acts to inhibit all modes when Vcc has fallen below the range of 2.8 V to 4.5 V .
The EWEN and EWDS commands give additional protection against accidentally programming during normal operation.
After power-up, the device is automatically in the EWDS mode. Therefore, an EWEN instruction must be performed before any ERASE, or WRITE instruction can be executed.

## READ Mode

The READ instruction outputs the serial data of the addressed memory location on the DO pin. A dummy bit (logical 0) precedes the 16 -bit output string. The output data changes during the high state of the system clock (CLK). The dummy bit is output TPD after the positive edge of CLK, which was used to clock in the last address bit (AO). Therefore, care must be taken if DI and DO are connected together as a bus contention will occur for one clock cycle if A0 has been a "1".
DO will go into HIGH-Z mode with the positive edge of the next CLK cycle. This follows the output of the last databit DO or the negative edge of CS, whichever occurs first.
DO remains stable between CLK cycles for an unlimited time as long as CS stays HIGH.
The most significant data bit (D15) is always output first, followed by the lower significant bits (D14-D0).


## WRITE Mode

The WRITE instruction is followed by 16 bits of data which are written into the specified address. The most significant data bit (D15) has to be clocked in first, followed by the lower significant data bits (D14-D0). If a WRITE instruction is recognized by the device and all data bits have been clocked in, the device performs an
automatic ERASE cycle on the specified address before the data are written. The WRITE cycle is completely selftimed and commences automatically after the rising edge of the CLK signal for the last data bit (DO).
The WRITE cycle takes 2 ms max.


## ERASE Mode

The ERASE instruction forces all the data bits of the specified address to logical " 1 s ". The ERASE cycle is completely self-timed and commences automatically
after the last address bit has been clocked in.
The ERASE cycle takes 1 ms max.


## ERASE/WRITE Enable/Disable (EWEN, EWDS)

The device is automatically in the ERASE/WRITE Disable mode (EWDS) after power-up. Therefore, an EWEN
instruction has to be performed before any ERASE, WRITE, ERAL, WRAL instruction is executed by the device.


## ERASE All (ERAL)

The entire chip will be erased to logical " 1 s " if this instruction is received by the device and it is in the EWEN mode. The ERAL cycle is completely self-timed and com-
mences after the last dummy address bit has been clocked in.

ERAL takes 15 ms max.


## WRITE All (WRAL)

The entire chip will be written with the data specified in that command. The WRAL cycle is completely selftimed and commences after the last data bit (D0) has been clocked in. WRAL takes 15 ms max.
Note: The WRAL does not include an automatic erase
cycle for the chip. Therefore, the WRAL instruction must be preceded by an ERAL instruction and the chip must be in the EWEN status in both cases.

The WRAL instruction is used for testing and/or device initialization.


## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 256 Bits (16 X 16) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- $16 \times 16$ bit memory organization
- Single 5V only operation
- Self-timed ERASE and WRITE cycles
- Automatic ERASE before WRITE
- Power on/off data protection circuitry
- Available in wafer or waffle pack
- Temperature range:
- Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$



## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t Vss ............... -0.3 V to +7.0 V
Storage temperature . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temperature with
power applied
$-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering termperature of leads
(10 seconds) $+300^{\circ} \mathrm{C}$
ESD protection on all pins 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| DC CHARACTERISTICS |  |  | $V c c=+5 \mathrm{~V}$ ( $\pm 10 \%$ ) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Commercial: $\mathrm{Tamb}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |  |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| High level input voltage | VIH | 2.0 | Vcc + 1 | V |  |
| Low level input voltage | VIL | -0.3 | 0.8 | V |  |
| High level output voltage | VOH | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| Low level output voltage | VOL |  | 0.4 | V | $\mathrm{IOL}=3.2 \mathrm{~mA}$ |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc (Note 1) |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{A}$ | Vout = OV to Vcc (Note 1) |
| Internal capacitance (all inputs/outputs) | CINT |  | 7 | pF | VIN/Vout $=0 \mathrm{~V}$ (Note 2) <br> Tamb $=+25^{\circ} \mathrm{C}, F=1 \mathrm{MHz}$ |
| Operating current (all modes) | IcCo |  | 4 | mA | FCLK $=1 \mathrm{MHz}, \mathrm{VCC}=5.5 \mathrm{~V}$ |
| Standby current | Iccs |  | 100 | $\mu \mathrm{A}$ | $\mathrm{CS}=0 \mathrm{~V}, \mathrm{VCC}=5.5 \mathrm{~V}$ |

Note 1: Internal resistor pull-up at Pin 6.
Note 2: This parameter is periodically sampled and not $100 \%$ tested.

## SYNCHRONOUS DATA TIMING



| AC CHARACTERISTICS |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Conditions |
| Clock frequency | FCLK |  | 1 | MHz |  |
| Clock high time | TCKH | 500 |  | ns |  |
| Clock low time | Tckl | 500 |  | ns |  |
| Chip select setup time | Tcss | 50 |  | ns |  |
| Chip select hold time | Tcsh | 0 |  | ns |  |
| Chip select low time | Tcsl | 100 |  | ns |  |
| Data input setup time | ToIs | 100 |  | ns |  |
| Data input hold time | TIIH | 100 |  | ns |  |
| Data output delay time | TPD |  | 400 | ns | $C L=100 \mathrm{pF}$ |
| Data output disable time (from CS = Low) | Tcz | 0 | 100 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Data output disable time (from last clock) | Tddz | 0 | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Status valid time | Tsv |  | 100 | ns | $C L=100 \mathrm{pF}$ |
| Program cycle time (Auto Erase \& Write) | Twc |  | $\begin{array}{r} 2 \\ 15 \\ \hline \end{array}$ | ms ms | for ERAL and WRAL |
| Erase cycle time | Tec |  | 1 | ms |  |

## PIN DESCRIPTION

## Chip Select (CS)

A HIGH level selects the device. A LOW level deselects the device and forces it into standby mode. However, a programming cycle which is already initiated and/or in progress will be completed, regardless of the CS input signal. If CS is brought LOW during a program cycle, the device will go into standby mode as soon as the programming cycle is completed.
CS must be LOW for 100 ns minimum (TCSL) between consecutive instructions. If CS is LOW, the internal control logic is held in a RESET status.

## Serial Clock (CLK)

The Serial Clock is used to synchronize the communication between a master device and the 93C06. Opcode, address, and data bits are clocked in on the positive edge of CLK. Data bits are also clocked out on the positive edge of CLK.
CLK can be stopped anywhere in the transmission sequence (at HIGH or LOW level) and can be continued anytime (with respect to clock HIGH time (Tскн) and clock LOW time (TCKL). This gives the controlling master freedom in preparing opcode, address and data.
CLK is a "Don't Care" if CS is LOW (device deselected). If CS is HIGH, but START condition has been detected, any number of clock cycles can be received by the device without changing its status. (i.e., waiting for START condition).

CLK cycles are not required during the self-timed WRITE (i.e. auto ERASE/WRITE) cycle.

After detection of aSTART condition the specified number of clock cycles (respectively LOW to HIGH transitions of CLK) must be provided. These clock cycles are required to clock in all required opcode, address, and data bits before an instruction is executed (see instruction set truth table). CLK and DI then become don't care inputs waiting for a new start condition to be detected.
Note: CS must go LOW between consecutive instructions.

## Data In (DI)

Data In is used to clock in a START bit, opcode, address, and data synchronously with the CLK input.

## Data Out (DO)

Data Out is used in the READ mode to output data synchronously with the CLK input (TPD after the positive edge of CLK).
This pad also provides READY/BUSY status information during ERASE and WRITE cycles. READY/BUSY status information is available on the DO pad if CS is brought HIGH after being LOW for minimum chip select low time (TCSL) from the falling edge of the CLK which clocked in the last DI bit (D0 for WRITE, AO for ERASE) and an ERASE or WRITE operation has been initiated.

The status signal is not available on DO, if CS is heid LOW or HIGH during the entire WRITE or ERASE cycle. In all other cases, DO is in the HIGH-Z mode. If status is checked after the WRITE/ERASE cycle, a pull-up resistor on DO is required to read the READY signal.
DI and DO can be connected together to perform a 3wire interface (CS, CLK, DI/DO).

Care must be taken with the leading dummy zero which is outputted after a READ command has been detected. Also, the controlling device must not drive the DI/DO bus during ERASE and WRITE cycles if the READY/BUSY status information is output by the 93C06.


## FUNCTIONAL DESCRIPTION

## Start Condition

The START bit is detected by the device if CS and DI are both HIGH with respect to the positive edge of CLK for the first time.
Before a START condition is detected, CS, CLK, and DI may change in any combination (except to that of a START condition), without resulting in any device operation (READ, WRITE, ERASE, EWEN, EWDS, ERAL, and WRAL). As soon as CS is HIGH, the device is no longer in the standby mode.
An instruction following a START condition will only be executed if the required amount of opcode, address and data bits for any particular instruction is clocked in.
After execution of an instruction (i.e., clock in or out of the last required address or data bit) CLK and DI become don't care bits until a new START condition is detected.

## DIIDO

It is possible to connect the Data In and Data Out pads together. However, with this configuration it is possible for a "bus conflict" to occur during the "dummy zero" that precedes the READ operation, if AO is a logic HIGH level. Under such a condition the voltage level seen at Data Out is undefined and will depend upon the relative impedances of Data Out and the signal source driving $A 0$. The higher the current sourcing capability of $A 0$, the higher the voltage at the Data Out pad.

## Data Protection

During power-up, all modes of operation are inhibited
until Vcc has reached a level of between 2.8 V and 4.5 V. During power-down, the source data protection circuitry acts to inhibit all modes when Vcc has fallen below the range of 2.8 V to 4.5 V .
The EWEN and EWDS commands give additional protection against accidentally programming during normal operation.
After power-up, the device is automatically in the EWDS mode. Therefore, an EWEN instruction must be performed before any ERASE, or WRITE instruction can be executed.

## READ Mode

The READ instruction outputs the serial data of the addressed memory location on the DO pin. A dummy bit (logical 0) precedes the 16 -bit output string. The output data changes during the HIGH state of the system clock (CLK). The dummy bit is output TPD after the positive edge of CLK, which was used to clock in the last address bit (AO). Therefore, care must be taken if DI and DO are connected together as a bus contention will occur for one clock cycle if A0 has been a "1".
DO will go into HIGH-Z mode with the positive edge of the next CLK cycle. This follows the output of the last data bit DO or the low going edge of CS, which ever occurs first.
DO remains stable between CLK cycles for an unlimited time as long as CS stays HIGH.
The most significant data bit (D15) is always output first, followed by the lower significant bits (D14-D0).


## WRITE Mode

The WRITE instruction is followed by 16 bits of data which are written into the specified address. The most significant data bit (D15) has to be clocked in first followed by the lower significant data bits (D14-D0). If a WRITE instruction is recognized by the device and all data bits have been clocked in, the device performs an
automatic ERASE cycle on the specified address before the data are written. The WRITE cycle is completely selftimed and commences automatically after the last data bit (DO) has been clocked in.

The WRITE cycle takes 2 ms max.
WRITE MODE CLK

## ERASE Mode

The ERASE instruction forces the data bits of the specified address all to logical "1s". The ERASE cycle is completely self-timed and commences automatically
after the last address bit has been clocked in.
The ERASE cycle takes 1 ms max.


## ERASE/WRITE Enable/Disable (EWEN, EWDS)

The device is automatically in the ERASE/WWRITE Disable mode (EWDS) after power-up. Therefore, an EWEN instruction has to be performed before any ERASE,

WRITE, ERAL, WRAL instruction is executed by the device.


## ERASE All (ERAL)

The entire chip will erased to logical "1s" if this instruction is received by the device and it is in the EWEN mode. The ERAL cycle is completely self-timed and com-
mences after the last dummy address bit has been clocked in.

ERAL takes 15 ms max.


## WRITE All (WRAL)

The entire chip will be written with the data specified in that command. The WRAL cycle is completely selftimed and commences after the last data bit (DO) has been clocked in. WRAL takes 15 ms max.
Note: The WRAL does not include an automatic erase
cycle for the chip. Therefore, the WRAL instruction must be preceded by an ERAL instruction and the chip must be in the EWEN status in both cases.

The WRAL instruction is used for testing and/or device initialization.


NOTES:

## $93 C 06$ DICE FORM

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 1K (64 X 16) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- $64 \times 16$ bit memory organization
- Single 5 volt only operation
- Self-timed ERASE and WRITE cycles
- Automatic ERASE before WRITE
- Power on/off data protection circuitry
- 100,000 ERASE/WRITE cycles
- Data Retention > 10 years
- 8-pin DIP or SOIC package
- Available for extended temperature ranges:
- Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc. 93C46 is a 1 K bit serial Electrically Erasable PROM. The device memory is configured as $64 \times 16$ bits. Advanced CMOS technology makes this device ideal for low power non-volatile memory applications. The 93C46 is available in the standard 8pin DIP and a surface mount SOIC package. The 93C46X comes as SOIC only.


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t. Vss.............-0.3 V to +7.0 V
Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temperature with
power applied $\qquad$ $-65^{\circ} \mathrm{C}$ to +125 C
Soldering termperature of leads ( 10 seconds) $\ldots+300^{\circ} \mathrm{C}$
ESD protection on all pins 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| CS | Chip Select |
| CLK | Serial Clock |
| DI | Data In |
| DO | Data Out |
| Vss | Ground |
| NU | Not Utilized. No Connection |
| VCC | +5 V Power Supply |


|  | Vcc $=+5 \mathrm{~V}( \pm 10 \%)$ |
| :--- | :--- |
| DC CHARACTERISTICS |  |
|  | Commercial : |
|  | Tamb $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
|  | Industrial : |
|  | Tamb $=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
|  | Automotive: |
|  | Tamb $=-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |


| Parameter | Symbol | Min | Max | Units | Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Vcc detector threshold | VTH | 2.8 | 4.5 | V |  |
| High level input voltage | VIH | 2.0 | $\mathrm{VCC}+1$ | V |  |
| Low level input voltage | VIL | -0.3 | 0.8 | V |  |
| High level output voltage | VoH | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| Low level output voltage | VoL |  | 0.4 | V | $\mathrm{IOL}=3.2 \mathrm{~mA}$ |
| Input leakage current | ILI |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc (Note 1) |
| Output leakage current | ILO |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{VouT}=0 \mathrm{~V}$ to Vcc (Note 1) |
| Internal capacitance <br> (all inputs/outputs) | CINT |  | 7 | pF | VIN/VouT $=0 \mathrm{~V}(\mathrm{Note} 2)$ <br> Operating current <br> (all modes) <br> Standby current |
| ICCo |  | 4 | mA | $\mathrm{FCLK}=1 \mathrm{MHz}, \mathrm{VCC}=5.5 \mathrm{~V}$ |  |

Note 1: Internal resistor pull-up at Pin 6.
Note 2: This parameter is periodically sampled and not $100 \%$ tested.


| AC CHARACTERISTICS |  |  |  |  |  |  | Symbol | Min | Max | Units | Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | FCLK |  | 1 | MHz |  |  |  |  |  |  |  |
| Clock frequency | TCKH | 500 |  | ns |  |  |  |  |  |  |  |
| Clock high time | TCKL | 500 |  | ns |  |  |  |  |  |  |  |
| Clock low time | TCss | 50 |  | ns |  |  |  |  |  |  |  |
| Chip select setup time | TCSH | 0 |  | ns |  |  |  |  |  |  |  |
| Chip select hold time | TCsL | 100 |  | ns |  |  |  |  |  |  |  |
| Chip select low time | TDIs | 100 |  | ns |  |  |  |  |  |  |  |
| Data input setup time | TDIH | 100 |  | ns |  |  |  |  |  |  |  |
| Data input hold time | TPD |  | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |  |  |  |  |  |  |
| Data output delay time | TCz | 0 | 100 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |  |  |  |  |  |  |
| Data output disable time (from CS = low) | TDDZ | 0 | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |  |  |  |  |  |  |
| Data output disable time (from last clock) | TSV |  | 100 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |  |  |  |  |  |  |
| Status valid time | TsV |  | 2 | ms | for ERAL and WRAL |  |  |  |  |  |  |
| Program cycle time (Auto Erase \& Write) | TwC |  | 15 |  |  |  |  |  |  |  |  |
| ms |  |  |  |  |  |  |  |  |  |  |  |
| Erase cycle time | TEC |  | 1 | ms |  |  |  |  |  |  |  |

## PIN DESCRIPTION

## Chip Select (CS)

A HIGH level selects the device. A LOW level deselects the device and forces it into standby mode. However, a programming cycle which is already initiated and/or in progress will be completed, regardless of the CS input signal. If CS is brought LOW during a program cycle, the device will go into standby mode as soon as the programming cycle is completed.
CS must be LOW for 100 ns minimum (TCsL) between consecutive instructions. If CS is LOW, the internal control logic is held in a RESET status.

## Serial Clock (CLK)

The Serial Clock is used to synchronize the communication between a master device and the 93C46. Opcode, address, and data bits are clocked in on the positive edge of CLK. Data bits are also clocked out 0 , the positive edge of CLK.
CLK can be stopped anywhere in the transmission sequence (at HIGH or LOW level) and can be continued anytime (with respect to clock HIGH time (TCKH) and clock LOW time (TCKL). This gives the controlling master freedom in preparing opcode, address and data.
CLK is a "Don't Care" if CS is LOW (device deselected). If CS is HIGH, but STARTcondition has not been detected, any number of clock cycles can be received by the device without changing its status. (i.e., waiting for START condition).

CLK cycles are not required during the self-timed WRITE (i.e., autoERASE/WRITE) cycle.

After detection of a start condition, the specified number of clock cycles (respectively LOW to HIGH transitions of CLK) must be provided. These clock cycles are required to clock in all required opcode, address, and data bits before an instruction is executed (see instruction set truth table). CLK and DI then become "Don't Care" inputs waiting for a new start condition to be detected.
Note: CS must go LOW between consecutive instructions.

## Data In (DI)

Data In is used to clock in a START bit, opcode, address, and data synchronously with the CLK input.

## Data Out (DO)

Data Out is used in the READ mode to output data synchronously with the CLK input (TPD after the positive edge of CLK).
This pin also provides READY/BUSY status information during ERASE and WRITE cycles. READY/BUSY status information is available on the DO pin if CS is brought HIGH after being LOW for minimum chip select LOW time (TCSL) from the falling edge of the CLK which clocked in the last DI bit (DO for WRITE, AO for ERASE) and an ERASE or WRITE operation has been initiated.

The status signal is not available on DO, if CS is held LOW or HIGH during the entire WRITE or ERASE cycle. In all other cases DO is in the HIGH-Z mode. If status is checked after the WRITE/ERASE cycle, a pull-up resistor on DO is required to read the READY signal.

DI and DO can be connected together to perform a 3wire interface (CS, CLK, DI/DO).

Care must be taken with the leading dummy zero which is outputted after a READ command has been detected. Also, the controlling device must not drive the DI/DO bus during Erase and Write cycles if the READY/BUSY status information is outputted by the 93C46.

| INSTRUCTION SET |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Start BIT | Opcode OP1 OP2 | Address |  |  |  |  |  |  | Number of Data In | Data Out | Req. CLK Cycles |
| READ | 1 | 10 |  |  | A4 | A3 | A2 | A1 | A0 | - | D15-D0 | 25 |
| WRITE | 1. | 01 |  | A | A4 | A3 | A2 | A1 | A0 | D15-D0 | (RDY/BSY) | 25 |
| ERASE | 1 | 11 |  | A | A4 | A3 | A2 | A1 | A0 | - | (RDY/BSY) | 9 |
| EWEN | 1 | 00 |  |  | 1 | X | $X$ | $X$ | X | - | High-Z | 9 |
| EWDS | 1 | 00 |  |  | 0 | $x$ | $X$ | X | X | - | High-Z | 9 |
| ERAL | 1 | 00 |  |  | 0 | $x$ | $X$ | $X$ | X | - | (RDY/BSY) | 9 |
| WRAL | 1 | 00 |  |  | 1 | X | X | X | X | D15-D0 | (RDY/ $\overline{\mathrm{BSY}}$ ) | 25 |

## FUNCTIONAL DESCRIPTION

## START Condition

The START bit is detected by the device if CS and DI are both HIGH with respect to the positive edge of CLK for the first time.

Before a START condition is detected, CS, CLK, and DI may change in any combination (except to that of a START condition), without resulting in any device operation (READ, WRITE, ERASE, EWEN, EWDS, ERAL, and WRAL). As soon as CS is HIGH, the device is no longer in the standby mode.
An instruction following a START condition will only be executed if the required amount of opcode, address and data bits for any particular instruction is clocked in.
After execution of an instruction (i.e., clock in or out of the last required address or data bit) CLK and DI become don't care bits until a new start condition is detected.

## DI/DO

It is possible to connect the Data In and Data Out pins together. However, with this configuration it is possible for a "bus conflict" to occur during the "dummy zero" that precedes the READ operation, if AO is a logic HIGH level. Under such a condition the voltage level seen at Data Out is undefined and will depend upon the relative impedances of Data Out and the signal source driving $A 0$. The higher the current sourcing capability of $A 0$, the higher the voltage at the Data Out pin.

## Data Protection

During power-up, all modes of operation are inhibited until Vcc has reached a level of between 2.8 V and 4.5 V . During power-down, the source data protection circuitry
acts to inhibit all modes when Vcc has fallen below the range of 2.8 V to 4.5 V .
The EWEN and EWDS commands give additional protection against accidentally programming during normal operation.
After power-up, the device is automatically in the EWDS mode. Therefore, an EWEN instruction must be performed before any ERASE or WRITE instruction can be executed.

## READ Mode

The READ instruction outputs the serial data of the addressed memory location on the DO pin. A dummy bit (logical 0) precedes the 16 -bit output string. The output data changes during the HIGH state of the system clock (CLK). The dummy bit is output TPD after the positive edge of CLK, which was used to clock in the last address bit (AO). Therefore, care must be taken if DI and DO are connected together as a bus contention will occur for one clock cycle if $A 0$ has been a one.
DO will go into HIGH-Z mode with the positive edge of the next CLK cycle. This follows the output of the last data bit DO or the low going edge of CS, which ever occurs first.

DO remains stable between CLK cycles for an unlimited time as long as CS stays HIGH.

The most significant data bit (D15) is always output first, followed by the lower significant bits (D14-D0).

READ MODE


## WRITE Mode

The WRITE instruction is followed by 16 bits of data which are written into the specified address. The most significant data bit (D15) has to be clocked in first, followed by the lower significant data bits (D14-D0). If a WRITE instruction is recognized by the device and all data bits have been clocked in, the device performs an
automatic ERASE cycle on the specified address before the data are written. The WRITE cycle is completely selftimed and commences automatically after the rising edge of the CLK for the last data bit (D0).
The WRITE cycle takes 2 ms max.


## ERASE Mode

The ERASE instruction forces all the data bits of the specified address to logical "1s". The ERASE cycle is
completely self-timed and commences automatically after the last address bit has been clocked in.

The ERASE cycle takes 1 ms max.

## ERASE/WRITE Enable/Disable (EWEN, EWDS)

The device is automatically in the ERASE/WRITE Disable mode (EWDS) after power-up. Therefore, an

EWEN instruction has to be performed before any ERASE, WRITE, ERAL, WRAL instruction is executed by the device.


## ERASE All (ERAL)

The entire chip will be erased to logical "1s" if this instruction is received by the device and it is in the EWEN mode. The ERAL cycle is completely self-timed and com-
mences after the last dummy address bit has been clocked in.

ERAL takes 15 ms max.

ERASE ALL


## WRITE All (WRAL)

The entire chip will be written with the data specified in that command. The WRAL cycle is completely selftimed and commences after the rising edge of the CLK for the last data bit (DO). WRAL takes 15 ms max.

Note: The WRAL does not include an automatic ERASE
cycle for the chip. Therefore, the WRAL instruction must be preceded by an ERAL instruction and the chip must be in the EWEN status in both cases.

The WRAL instruction is used for testing and/or device initialization.


NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 1K ( $64 \times 16$ ) CMOS Serial Electrically Erasable PROM

## FEATURES

- Low power CMOS technology
- $64 \times 16$ bit memory organization
- Single 5 volt only operation
- Self-timed ERASE and WRITE cycles
- Automatic ERASE before WRITE
- Power on/off data protection circuitry
- Available in wafer or waffle pack
- Temperature range:
- Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc. 93C46 is a 1 K bit serial Electrically Erasable PROM. The device memory is configured as $64 \times 16$ bits. Advanced CMOS technology makes this device ideal for low power non-volatile memory applications. The 93C46 dice are available in wafer or wafflepack.


## $93 C 46$ DICE FORM

## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

All inputs and outputs w.r.t Vss ............... -0.3 V to +7.0 V
Storage temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient temperature with power applied
$-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Soldering termperature of leads
(10 seconds)
$+300^{\circ} \mathrm{C}$
ESD protection on all pins ...................................... 4 kV
*Notice: Stresses above those listed under "Maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| PAD FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| CS | Chip Select |
| CLK | Serial Clock |
| DI | Data In |
| DO | Data Out |
| Vss | Ground |
| NU | Not Utilized. No Connection |
| Vcc | +5 V Power Supply |



Note 1: Internal resistor pull-up at Pin 6.
Note 2: This parameter is periodically sampled and not $100 \%$ tested.


## AC CHARACTERISTICS

| Parameter | Symbol | Min | Max | Units | Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Clock frequency | FCLK |  | 1 | MHz |  |
| Clock high time | TCKH | 500 |  | ns |  |
| Clock low time | TCKL | 500 |  | ns |  |
| Chip select setup time | TCSs | 50 |  | ns |  |
| Chip select hold time | TCsH | 0 |  | ns |  |
| Chip select low time | TcSL | 100 |  | ns |  |
| Data input setup time | TDIS | 100 |  | ns |  |
| Data input hold time | TDIH | 100 |  | ns |  |
| Data output delay time | TPD |  | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Data output disable time (from CS = Low) | TCZ | 0 | 100 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Data output disable time (from last clock) | TDDZ | 0 | 400 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Status valid time | Tsv |  | 100 | ns | $\mathrm{CL}=100 \mathrm{pF}$ |
| Program cycle time (Auto Erase \& Write) | TwC |  | 2 | ms |  |
| Erase cycle time |  |  | 15 | ms | for ERAL and WRAL |

## PIN DESCRIPTION

## Chip Select (CS)

A HIGH level selects the device. A LOW level deselects the device and forces it into standby mode. However, a programming cycle which is already initiated and/or in progress will be completed, regardless of the CS input signal. If CS is brought LOW during a program cycle, the device will go into standby mode as soon as the programming cycle is completed.

CS must be LOW for 100 ns minimum (TCSL) between consecutive instructions. If CS is LOW, the internal control logic is held in a RESET status.

## Serial Clock (CLK)

The Serial Clock is used to synchronize the communication between a master device and the 93C46. Opcode, address, and data bits are clocked in on the positive edge of CLK. Data bits are also clocked out on the positive edge of CLK.

CLK can be stopped anywhere in the transmission sequence (at HIGH or LOW level) and can be continued anytime (with respect to clock high time (ТСкн) and Clock Low Time (TCKL). This gives the controlling master freedom in preparing opcode, address and data.
CLK is a "Don't Care" if CS is LOW (device deselected). If CS is HIGH, but STARTcondition has been detected, any number of clock cycles can be received by the device without changing its status. (i.e., waiting for START condition).

CLK cycles are not required during the self-timed WRITE (i.e., auto ERASE/WRITE) cycle.

After detection of a START condition the specified number of clock cycles (respectively LOW to HIGH transitions of CLK) must be provided. These clock cycles are required to clock in all required opcode, address, and data bits before an instruction is executed (see instruction set truth table). CLK and DI then become don't care inputs waiting for a new START condition to be detected.
Note: CS must go LOW between consecutive instructions.

## Data In (DI)

Data In is used to clock in a START bit, opcode, address, and data synchronously with the CLK input.

## Data Out (DO)

Data Out is used in the READ mode to output data synchronously with the CLK input (TPD after the positive edge of CLK).
This pad also provides READY/BUSY status information during ERASE and WRITE cycles. READY/BUSY status information is available on the DO pad if CS is brought high after being LOW for minimum chip select LOW time (TCSL) from the falling edge of the CLK which clocked in
the last DI bit (D0 for WRITE, A0 for ERASE) and an ERASE or WRITE operation has been initiated.

The status signal is not available on DO, if CS is held LOW or HIGH during the entire WRITE or ERASE cycle. In all other cases DO is in the HIGH-Z mode. If status is checked after the WRITE/ERASE cycle, a pull-up resistor on DO is required to read the READY signal.

DI and DO can be connected together to perform a 3wire interface (CS, CLK, DI/DO).

Care must be taken with the leading dummy zero which is outputted after a READ command has been detected. Also, the controlling device must not drive the DI/DObus during ERASE and WRITE cycles if the READY/BUSY status information is outputted by the 93C46.

| INSTRUCTION SET |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction | Start BIT | Opcode OP1 OP2 | Address |  |  |  |  |  | Number of Data In | Data Out | Req. CLK Cycles |
| READ | 1 | 10 | A | A4 | A3 | A2 | A1 | AO | - | D15-D0 | 25 |
| WRITE | 1 | 01 |  | A4 | A3 | A2 | A1 | A0 | D15-D0 | (RDY/BSY) | 25 |
| ERASE | 1 | 11 |  | A4 |  | A2 | A1 | AO | - | (RDY/BSY) | 9 |
| EWEN | 1 | 00 |  | 1 | X | X | X | $X$ | - | High-Z | 9 |
| EWDS | 1 | 00 | 0 | 0 | X | $X$ | X | X | - | High-Z | 9 |
| ERAL | 1 | 00 |  | 0 | X | X | X | X | - | (RDY/ $\overline{\text { BSY }}$ ) | 9 |
| WRAL | 1 | 00 |  | 1 |  | X | X | X | D15-D0 | (RDY/BSY) | 25 |

## FUNCTIONAL DESCRIPTION

## START Condition

The START bit is detected by the device if CS and DI are both HIGH with respect to the positive edge of CLK for the first time.
Before a START condition is detected, CS, CLK, and DI may change in any combination (except to that of a start condition), without resulting in any device operation (READ, WRITE, ERASE, EWEN, EWDS, ERAL, and WRAL). As soon as CS is HIGH, the device is no longer in the standby mode.
An instruction following a START condition will only be executed if the required amount of opcode, address and data bits for any particular instruction is clocked in.

After execution of an instruction (i.e. clock in or out of the last required address or data bit) CLK and DI become don't care bits until a new START condition is detected.

## DI/DO

It is possible to connect the Data In and Data Out pads together. However, with this configuration it is possible for a "bus conflict" to occur during the "dummy zero" that precedes the READ operation, if AO is a logic HIGH level.
Under such a condition the voltage level seen at Data Out is undefined and will depend upon the relative impedances of Data Out and the signal source driving $A 0$. The higher the current sourcing capability of $A 0$, the higher the voltage at the Data Out pad.

## Data Protection

During power-up, all modes of operation are inhibited
until Vcc has reached a level of between 2.8 V and 4.5 V. During power-down, the source data protection circuitry acts to inhibit all modes when Vcc has fallen below the voltage range of 2.8 V to 4.5 V .
The EWEN and EWDS commands give additional protection against accidentally programming during normal operation.
After power-up, the device is automatically in the EWDS mode. Therefore, an EWEN instruction must be performed before any ERASE or WRITE instruction can be executed.

## READ Mode

The READ instruction outputs the serial data of the addressed memory location on the DO pin. A dummy bit (logical 0 ) precedes the 16 -bit output string. The output data changes during the HIGH state of the system clock (CLK). The dummy bit is output TPD after the positive edge of CLK, which was used to clock in the last address bit (AO). Therefore, care must be taken if DI and DO are connected together as a bus contention will occur for one clock cycle if A 0 has been a " 1 ".
DO will go into HIGH-Z mode with the positive edge of the next CLK cycle. This follows the output of the last data bit DO or the low going edge of CS, which ever occurs first.
DO remains stable between CLK cycles for an unlimited time as long as CS stays HIGH.
The most significant data bit (D15) is always output first, followed by the lower significant bits (D14-D0).


## WRITE Mode

The WRITE instruction is followed by 16 bits of data which are written into the specified address. The most significant data bit (D15) has to be clocked in first followed by the lower significant data bits (D14-D0). If a WRITE instruction is recognized by the device and all data bits have been clocked in, the device performs an
automatic ERASE cycle on the specified address before the data are written. The WRITE cycle is completely selftimed and commences automatically after the last data bit (D0) has been clocked in.
The WRITE cycle takes 2 ms max.


## ERASE Mode

The ERASE instruction forces the data bits of the specified address all to logical "1s". The ERASE cycle is completely self-timed and commences automatically
after the last address bit has been clocked in.
The ERASE cycle takes 1 ms max.


## $93 C 46$ dICE FORM

## ERASE/WRITE Enable/Disable (EWEN, EWDS)

The device is automatically in the ERASE/WRITE Disable mode (EWDS) after power-up. Therefore, an EWEN
instruction has to be performed before any ERASE, WRITE, ERAL, WRAL instruction is executed by the device.


## ERASE All (ERAL)

The entire chip will erased to logical " 1 s " if this instruction is received by the device and it is in the EWEN mode. The ERAL cycle is completely self timed and commences after the last dummy address bit has been
clocked in.
ERAL takes 15 ms max.


## WRITE All (WRAL)

The entire chip will be written with the data specified in that command. The WRAL cycle is completely selftimed and commences after the last data bit (D0) has been clocked in. WRAL takes 15 ms max.

Note: The WRAL does not include an automatic erase
cycle for the chip. Therefore, the WRAL instruction must be preceded by an ERAL instruction and the chip must be in the EWEN status in both cases.

The WRAL instruction is used for testing and/or device initialization.


NOTES:

## $93 C 46$ dice form

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 24CXX / 85CXX TO MICROCONTROLLER COMMUNICATION Two Wire Bus Interface to PIC16C54

The Microchip Technology Inc.'s 24Cxx and 85Cxx serial EEPROMs feature a two wire serial interface bus. The bus protocol is I2C compatible. Interface to a serial port with I2C bus protocol in a microcontroller is trivial. This application note is intended for design engineers who want to develop their software programs to communicate a microcontroller with a two wire bus serial EEPROM through a general purpose I/O port.

Unlike other 3-wire bus serial E2PROMs, the 24Cxx/85Cxx communicate with any microcontroller only by a serial data I/O line (SDA) and a serial clock (SCL). Chip select is not required. Data transfer may be initiated only when the bus is not busy. During such transfer, the data line (SDA) must remain stable whenever the clock line (SCL) is high. Changes in the data line while the clock line is high are interpreted as a START or STOP condition. A typical transfer format is shown in Figure 1.


Fig. 1 Transfer Format

After the START condition, a slave address is sent. This address is 7 -bits long, the eighth bit is a data direction bit ( $\mathrm{R} / \overline{\mathrm{W}}$ ) - a logical ' 0 ' indicates a transmission WRITE, a logical ' 1 ' represents a request for data READ. A data transfer is always terminated by a STOP condition generated by the master controller. However, if a master still wishes to communicate on the bus, it can generate another START condition, and address another slave without first generating a STOP condition. Various combinations of read/write formats are then possible within such transfer.


Fig. 2 A Simple Hardware Connection
An example program has been provided in Appendix A containing all PIC16C54 routines needed to exercise a 24Cxx or 85 Cxx device. A simple hardware connection is illustrated in Figure 2. A maximum of 8 $24 \mathrm{C} 01 \mathrm{~A} / 24 \mathrm{C} 02 \mathrm{~A} / 85 \mathrm{C} 72 / 85 \mathrm{C} 82 \mathrm{~s}$ or $424 \mathrm{C} 04 \mathrm{~A} / 85 \mathrm{C} 92 \mathrm{~s}$ can be addressed by a microcontroller on the same two wire bus without additional interfaces. Each device is identified by its Chip Address and will only respond to a correct slave address of a serial communication. A detailed bus flow is shown in Figure 3.

Figure 3 as shown below describes how the bit stream is set up for READ and WRITE mode in the microcomputer programming software prior to sending it on the two wire serial bus.


Fig. 3A Setting The Internal Word Address Of The 24Cxx/85Cxx


Fig. 3B Byte Write Sequence


Fig. 3C Read Mode Sequence

The stop condition after write starts the internal self-timed write cycle which may last up to 6 milliseconds ( .7 ms per byte). Acknowledge signal should be monitored during this period.

## Appendix A:

PICALC CROSS ASSEMBLER 2.00 d: \seeprom\appnotes $\backslash i 2 c b u s . a s m$ Apr 11 15:36:02 1990 PAGE 1

TWO WIRE/I2C BUS INTERFACE WITH PIC16C5x







NOTES:

# ER59256/93C06 AND NMC9306/NMC93C06 COMPATIBILITY ISSUE 

Introduction
The ER59256 and 93C06 are 256 bits ( $16 \times 16$ ) serial EEPROM currently offered by Microchip. ER59256 is fabricated in N-channel SNOS technology and 93C06 in advanced CMOS. There are some uncertainties in the field regarding the compatibility between Microchip's 256 bits serial EEPROM and National. Namely NMC9306 and NMC93C06. This report highlights the differences.

Software Differences

|  | Microchip |  | ER59256 |  | Microchip 93C06 |  |  |  | National |  | NMC9306/NMC93C06 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INSTRUCTION | SB | OPCODE | ADDRESS | DATA | SB | OPCODE | ADDRESS | DATA | SB | OPCODE | ADDRESS | DATA |
| READ |  | 1000 | A3A2A1A0 | - | 1 | 1000 | A3A2A1A0 | - | 1 | $10 \times \mathrm{X}$ | A3A2A1A0 | - |
| WRITE |  | 0100 | A3A2A1A0 | D15-D0 | 1 | 0100 | A3A2A1A0 | D15-D0 | 1 | $01 \times x$ | A3A2A1A0 | D15 - D0 |
| ERASE | 1 | 1100 | A3A2A1A0 | - | 1 | 1100 | A3A2A1A0 | - | 1 | 11 XX | A3A2A1A0 | - |
| EWEN | 1 | 0011 | 0000 | $\cdot$ | 1 | 0011 | XXXX | - | 1 | 0011 | $\mathrm{X} \times \times \mathrm{X}$ | - |
| EWDS | 1 | 0000 | 0000 | - | 1 | 0000 | $\mathrm{x} \times \mathrm{x} \times$ | - | 1 | 0000 | x $\times$ x x | - |
| ERAL | 1 | 0010 | 0000 | * | 1 | 0010 | $\mathrm{x} \times \times \mathrm{x}$ | - |  | 0010 | $x \times \times \mathrm{x}$ | - |
| WRAL |  | NOT SPEC |  |  | 1 | 0001 | $\mathrm{x} \times \mathrm{x}$ | D15-D0 |  | 0001 | x $\times$ x x | D15-D0 |
| Note: | EWEN ..... Erase/Write Enable |  |  |  |  |  | ERAL ..... Erase All |  |  |  |  |  |

From the instruction sets shown, the address bits on EWEN, EWDS, ERAL and WRAL are "don't care" for 9306/93C06 and all logical 0's for ER59256. The WRAL instruction is not specified for ER59256. The two LSB of the opcode are "0 0" for Microchip's ER59256/93C06 and "don't care" for National's NMC9306/NMC93C06. In order to make software fully compatible to all parts, it is recommended to design program with all logical 0 's in place of the "don't care" bits.

Polling is available on the 93C06 and NMC93C06. The soft polling can be done by checking the status signal on the DO line (pin 4). A low busy signal $\overline{(\mathrm{BSY})}$ indicates the device is still in the programming mode and a high level (RDY) represents the device is ready to receive new instruction. ER59256 and NMC9306 however, do not provide this feature.

## Hardware Differences

|  | Microchip |  |  | National |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |
| PARAMETER | ER59256 | $93 C 06$ | NMC9306 | NMC93C06 |
| PIN 6 | NC | NC | NC | NC |
| PIN 7 | TEST | NC | NC | NC |
| CLOCK FREQ | 250 KHZ | 1 MHZ | 250 KHZ | 1 MHZ |
| CLK DUTY CYCLE | $25 \%-75 \%$ | not specified | not specified | not specified |
| CLK HIGH TIME min. | not specified | 500 ns | 1 us | 250 ns |
| CLK LOW TIME min. | not specified | 500 ns | 1 us | 250 ns |
| CS LOW TIME min. | not specified | 100 ns | 1 us | 250 ns |
| ENDURANCE | 10 K | 100 K | 40 K | 40 K |
| ESD RATING | 1.0 KV | 4.0 KV | 2.0 KV | 2.0 KV |
| ENW TIME | $10-30 \mathrm{~ms}$ | 2 ms | $10-30 \mathrm{~ms}$ | 10 ms |
| ACTIVE CURRENT | 10 mA | 4 mA | 10 mA | 3 mA |
| STANDBY CURRENT | 3 mA | 100 uA | 3 mA | 50 uA |

## Pin 6 and 7 configuration -

Microchip uses the pin 6 and 7 of ER59256 for factory internal test purposes. Pin 6 is used to monitor the on-chip charge pump which generates the required internal high programming voltage ( $>20$ volts) during the ERASE and WRITE cycles. Any circuitry connects to this pin will force to reduce the data retention of the device or even no programming will take place. Signal on pin 7 can force the device into its internal test modes resulting in overprogramming all memory locations. It is therefore recommended that pin 6 should be left open and pin 7 tied to Vss for normal operation.

Microchip's 93C06 and National's NMC9306/NMC93C06 have their pin 6 and 7 physically not utilized. To make ER59256 compatible, the TEST pin (pin 7) can be left floating but must be kept "clean" (noise-free).

## Clock high time, clock low time -

For a clock frequency of 250 kHz , both ER59256 and NMC9306 specify the same electrical parameters:

250 kHz equals 4 us clock cycle time
$25 \%$ of the clock period (4 us) $=1$ us (clock high time)
$75 \%$ of the clock period ( 4 us) $=3$ us (clock low time $=4-3$ us $=1$ us)
For slower clock frequencies, the ER59256 spec would restrict the user regarding clock low and high times:

| A clock frequency of $\quad 100 \mathrm{k} \mathrm{Hz}$ | $=10$ us cycle time |
| :--- | :--- |
| would result in clock low $=75 \%$ of 10 us | $=7.5 \mathrm{us}$ |
| and $\quad$ clock high $=25 \%$ of 10 us | $=2.5 \mathrm{us}$. |

In reality, Microchip's ER59256 can fulfill National's NMC9306 spec regarding SK low and SK high equal to 1 usec over all operating frequencies as 250 kHz is the maximium allowable frequency and is therefore the worst case.

## Chip select low time -

All parts require a chip select (CS) input goes low between any two instructions. Programming of the part (ER59256, NMC9306,NMC93C06) begins at the falling edge of the CS. Microchip's 93C06 however, starts self-programming at the rising edge of the last data clocked bit. CS goes low and high with a minimium of chip select low time (TcsI) during programming can be used for polling purpose as discribed in 2.

## NOTES:

## 24C01A COMPATIBILITY ISSUE AND ITS MOBILITY FOR MEMORY UPGRADE

The 24 C 01 is a $1 \mathrm{~K}(128 \times 8)$ serial EEPROM which is currently offered by Microchip and Xicor. There are several important differences between the two devices which are discussed in this report. This report refers to the Microchip part as the 24C01A and the Xicor part as the X24C01. It is intended to assist in designing a board which is compatible with either device.

There are three major differences between Microchip 24C01A and Xicor X24C01 as detailed in the following paragraphs.

### 2.1 PAGE MODE DIFFERENCES

The 24C01A was originally designed to work in the same socket as the PCD8572 which has a two-byte page mode. Its page is therefore two bytes deep. The X24C01 has a page mode of four bytes depth.

If more than two bytes are transmitted to the 24C01A during a page programming cycle, the $24 \mathrm{C01A}$ will terminate the write cycle.

In many applications where serial EEPROMs are used and speed is not a key issue, the byte write mode can be used without any loss of system performance. If only the byte write mode is used, there is no compatibility problem (other than the slave address software differences discussed in 2.2).

If the page write feature must be used, two different page mode algorithms can be transmitted by the master depending upon whose device is being used. The master will have to first do a polling routine to determine if it is interfacing with a 24C01A or X24C01. This polling technique is discussed in 2.2.

Interestingly, the 24C01A actually updates faster in the page mode even though it has one-half the page depth of the X24C01. This is due to the faster write cycle time of the 24C01A. The two devices are compared below:

|  | Microchip | Xicor |
| :--- | :--- | :--- |
|  |  |  |
| Max byte program time | 1 ms | 10 ms |
| Max page program time | $2 \mathrm{~ms}(2$ bytes $)$ | 10 ms (4 bytes) |
| Max time to program 4 bytes | 4 ms | 10 ms |
| Max time to rewrite device | 128 ms | 320 ms |

### 2.2 SOFTWARE DIFFERENCES

Microchip's 24C01A is designed to share a 2 -wire bus on which it resides with other devices. To support this, the first byte of each command sequence from the master to the 24C01A must be a slave address. The 24C01A monitors the 2 -wire bus for its slave address and "wakes-up" from standby mode if the address tre:ismitted matches its address as defined by the voltage level (Vss or Vcc) on pins 1, 2 and 3. X24C01 does not support a multiple device bus and will always "wake-up" if a start condition is detected.

A slave address must be transmitted to the 24C01A at certain points during reading and writing. This slave address is not required by the X24C01. Transmitting a slave address to X24C01 will result in erroneous operation. This problem can be solved by having the master transmit the the proper serial bit pattern to the slave, but first the master has to be ascertained which 24C01 it is communicating with.

The master can do a simple polling routine before beginning serial communication with 24C01A or X24C01 to determine which device it is working with. The proper serial protocol for both devices must be contained in the master controller's firmware. Once the master knows which 24C01 is on the bus, it can execute the proper serial commands.

The polling consists of the pattern like the one shown below:
SDA LINE: | start bit | 00000001 | acknowledge bit | data $7 \ldots 0$ |
If a X24C01 is used on the 2-wire bus, an acknowledge bit and eight data bits will be returned whereas 24C01A will issue no response and will ignore the command.

### 2.3 HARDWARE DIFFERENCES

As described earlier, the 24C01A is designed to share a 2 -wire bus with other devices while the X24C01 is not. Chip address bits are included in the slave address for the 24C01A, and are incorporated into pins 1, 2 and 3 of the device. They must be connected to Vcc or Vss for proper operation. Since pins 1, 2 and 3 of the Xicor part are NC (no connect) pins and they are not internally connected, they can be tied high or low.

Another hardware difference involves pin 7 which MUST be connected to Vss on X24C01. The 24C01A can have pin 7 connected to Vss or Vcc.

If only one device is planned for the 2 -wire bus, the board can be made compatible for either device by connecting pins 1, 2 and 3 to either Vss or Vcc and tieing pin 7 to Vss.

## Mobility For Memory Upgrade And Expansion

In system applications where the master device needs to address more than one serial EEPROM on a 2-wire bus, Microchip's 24C01A offers the flexibility. Up to eight 24C01As can be connected to the 2 -wire bus. More than one Xicor X24C01 connecting to the bus may result in bus contention.

If memory upgrade is required, Microchip's 24C01A can be upgraded to 24C02A (256 x 8) or 24C04A ( $512 \times 8$ ) on the same IC socket with NO change in hardware. Using Xicor X24C01 will have to reconfigure both software and hardware to accomodate the changes.

NOTES:

## SECTION 2 EEPROM PRODUCT SPECIFICATIONS

28C04A $4 \mathrm{~K}(512 \times 8)$ CMOS Electrically Erasable PROM ..... 2- 1
28C16A 16K (2K x 8) CMOS Electrically Erasable PROM ..... 2- 9
28C17A 16K (2K x 8) CMOS Electrically Erasable PROM ..... 2- 17
28C17A Dice 16K (2K x 8) CMOS Electrically Erasable PROM Die Form ..... 2- 25
28C64A 64K (8K x 8) CMOS Electrically Erasable PROM ..... 2- 33
28C64A Dice $64 \mathrm{~K}(8 \mathrm{~K} \times 8$ ) CMOS Electrically Erasable PROM Die Form ..... 2- 41

Microchip

## 28C04A

## 4K ( $512 \times 8$ ) CMOS Electrically Erasable PROM

## FEATURES

- Fast Read Access Time-150ns Maximum
- CMOS Technology for Low Power Dissipation
-30mA Active
$-100 \mu \mathrm{~A}$ Standby
- Fast Byte Write Time- $200 \mu \mathrm{~s}$ or 1 ms
- Data Retention >10 years
- High Endurance $10^{4}$ Erase/Write Cycles
- Automatic Write Operation
-Internal Control Timer
-Auto-Clear Before Write Operation
-On-Chip Address and Data Latches
- Data Polling
- Chip Clear Operation
- Enhanced Data Protection
-Vcc Detector
-Pulse Filter
-Write Inhibit
- 5-Volt-Only Operation
- Organized $512 \times 8$ JEDEC standard pinout
-24 Pin Dual-In-Line Package
-32 Pin Chip Carrier (Leadless or Plastic)
- Available for Extended Temperature Ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc 28C04A is a CMOS 4 K non-volatile electrically Erasable and Programmable Read Only Memory. The 28C04A is accessed like a static RAM for the read or write cycles without the need of external components. During a "byte write", the address and data are latched internally, freeing the microprocessor address and data bus for other operations. Following the initiation of write cycle, the device will go to a busy state and automatically clear and write the latched data using an internal control timer. To determine when a write cycle is complete, the 28C04A uses Data polling. Data polling allows the user to read the location last written to when the write operation is complete. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are required. A complete family of packages is offered to provide the utmost flexibility in applications.


| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{\mathrm{AO}}{\mathrm{C}}-\mathrm{AB}$ | Address Inputs |
| $\frac{\mathrm{CE}}{\mathrm{OE}}$ | Chip Enable |
| $\overline{\mathrm{WE}}$ | Output Enable |
| $\mathrm{I} / \mathrm{OO}-\mathrm{I} / \mathrm{O} 7$ | Write Enable |
| Vcc | Data Inputs/Outputs |
| Vss | +5V Power Supply |
| NC | Ground |
| NU | No Connect; No Internal |
|  | Connection |
|  | Not Used; No External |
|  | Connection is Allowed |

## ELECTRICAL CHARACTERISTICS MAXIMUM RATINGS*

Vcc and input voltages w.r.t. $V$ Ss........-0.6 V to +6.25 V
Voltage on $\overline{\mathrm{OE}}$ w.r.t. Vss -0.6 V to +13.5 V
Output Voltage w.r.t. Vss ................... -0.6 V to $\mathrm{Vcc}+0.6 \mathrm{~V}$
Storage temperature .......................... $65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Ambient temp. with power applied ........ $-50^{\circ} \mathrm{C}$ to $95^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ / WRITE OPERATION DC Characteristics |  |  |  | $V c c=+5 \mathrm{~V} \pm 10 \%$ <br> Commercial (C): Tamb $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> Industrial <br> (I): $\mathrm{Tamb}=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{gathered} \text { Vcc+1 } \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-0.1 \mathrm{~V}$ to $\mathrm{Vcc}+1$ |
| Input Capacitance |  | CIN |  | 10 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Voltages | Logic "1" <br> Logic "0" | VOH <br> Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{lOH}=-400 \mu \mathrm{~A} \\ & \mathrm{lOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | - Vout $=-0.1 \mathrm{~V}$ to $\mathrm{Vcc}+0.1 \mathrm{~V}$ |
| Output Capacitance |  | COUT |  | 12 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | TTL input | ICC |  | 30 | mA | $\begin{aligned} & f=5 \mathrm{MHz} \text { (Note 1) } \\ & \mathrm{Vcc}=5.5 \mathrm{~V} ; \end{aligned}$ |
| Power Supply Current, Standby | TTL input TTL input CMOS input | ICC(S)TTL ICC(S)TTL ICC(S)CMOS |  | $\begin{gathered} 2 \\ 3 \\ 100 \end{gathered}$ | mA mA $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\overline{C E}}=V I H\left(0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}\right) \\ & \overline{\mathrm{CE}}=\mathrm{VIH}\left(-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}\right) \\ & \overline{\mathrm{CE}}=\mathrm{VCC}-0.3 \text { to } \mathrm{VCC}+1 \end{aligned}$ |

Note: (1) AC power supply current above $5 \mathrm{MHz}: 1 \mathrm{~mA} / \mathrm{MHz}$

| READ OPERATION <br> AC Characteristics | AC Testing Waveform: $\quad \mathrm{VIH}=2.4 \mathrm{~V} ; \mathrm{VIL}=0.45 \mathrm{~V} ; \mathrm{VOH}=2.0 \mathrm{~V}$; $\mathrm{VOL}=0.8 \mathrm{~V}$ <br> Output Load: $\quad 1$ TTL Load +100 pF <br> Input Rise and Fall Times: 20 nsec <br> Ambient Temperature: <br> Commercial (C): $\mathrm{Tamb}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> Industrial (I): Tamb $=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 28C04A-15 |  | 28C04A-20 |  | 28C04A-25 |  | Units | Conditions |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | tacc |  | 150 |  | 200 |  | 250 | ns | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tCE |  | 150 |  | 200 |  | 250 | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | toe |  | 70 |  | 80 |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ High to Output Float | tofF | 0 | 50 | 0 | 55 | 0 | 70 | ns |  |
| Output Hold from Address, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever occurs first. | tor | 0 |  | 0 |  | 0 |  | ns |  |

## READ WAVEFORMS



Notes: (1) tOFF is specified for $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first
(2) $\overline{\mathrm{OE}}$ may be delayed up to tCE - tOE after the falling edge of $\overline{\mathrm{CE}}$ without impact on TCE
(3) This parameter is sampled and is not $100 \%$ tested

| BYTE WRITE <br> AC Characteristics | AC Testing Waveform: Output Load: Input Rise/Fall Times: Ambient Temperature: | $=2.4 \mathrm{~V}$ <br> L Loa sec merc strial | $\begin{aligned} & \text { VIL }=0 \\ & +100 \end{aligned}$ <br> (C): T <br> (I): T | $\begin{aligned} & 45 \mathrm{~V} ; \mathrm{Vo} \\ & \mathrm{~F} \\ & \mathrm{mb}= \\ & \mathrm{mb}=-4 \end{aligned}$ | $\mathrm{H}=2.0 \mathrm{~V} ; \mathrm{VOL}=0.8 \mathrm{~V}$ <br> C to $70^{\circ} \mathrm{C}$ $0^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tas | 10 |  | ns |  |
| Address Hold Time | taH | 50 |  | ns |  |
| Data Set-Up Time | tDS | 50 |  | ns |  |
| Data Hold Time | tDH | 10 |  | ns |  |
| Write Pulse Width | tWPL | 100 |  | ns | Note 1 |
| Write Pulse High Time | tWPH | 50 |  | ns | * |
| $\overline{\text { OE Hold Time }}$ | tOEH | 10 |  | ns |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 10 |  | ns |  |
| Data Valid Time | tDV |  | 1000 | ns | Note 2 |
| Write Cycle Time (28C04A) <br> Write Cycle Time (28C04AF) | twc twC |  | $\begin{gathered} 1 \\ 200 \end{gathered}$ | ms $\mu \mathrm{s}$ | 0.5 ms typical $100 \mu$ s typical |
| Note: (1) A write cycle can be initiated $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$ going low, whichever occurs last. The data is latched on the positive edge of $\overline{C E}$ or $\overline{W E}$, whichever occurs first. <br> (2) Data must be valid within 1000 ns max. after a write cycle is initiated and must be stable at least until tDH after the positive edge of $\overline{W E}$ or $\overline{\mathrm{CE}}$, whichever occurs first. |  |  |  |  |  |



## DATA POLLING

 Waveforms

## CHIP CLEAR

Waveforms


## DEVICE OPERATION

The Microchip Technology Inc 28C04A has four basic modes of operation-read, standby, write inhibit, and byte write-as outlined in the following table.

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { WE }}$ | I/O |
| :--- | :---: | :---: | :---: | :--- |
| Read | L | L | H | Dout |
| Standby | H | X | X | High Z |
| Write Inhibit | H | X | X | High Z |
| Write Inhibit | X | L | X | High Z |
| Write Inhibit | X | X | H | High Z |
| Byte Write | L | H | L | Din |
|  |  |  |  |  |
| Byte Clear | Automatic Before Each "Write" |  |  |  |

X = Any TTL level.

## Read Mode

The 28C04A has two control functions, both of which must be logically satisfied 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 is used to gate data to the output pins independent of device selection. Assuming that addresses are stable, address access time (tACC) is equal to the delay from $\overline{C E}$ to output (tCE). Data is available at the output 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 tacc-toe.

## Standby Mode

The 28C04A is placed in the standby mode by applying a high signal to the $\overline{C E}$ input. When in the standby mode, the outputs are in a high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## Data Protection

In order to ensure data integrity, especially during critical power-up and power-down transitions, the following enhanced data protection circuits are incorporated:

First, an internal Vcc detect ( 3.3 volts typical) will inhibit the initiation of non-volatile programming operation when Vcc is less than the Vcc detect circuit trip.

Second, there is a $\overline{W E}$ filtering circuit that prevents $\overline{W E}$ pulses of less than 10 ns duration from initiating a write cycle.

Third, holding $\overline{W E}$ or $\overline{C E}$ high or $\overline{O E}$ low, inhibits a write cycle during power-on and power-off (Vcc).

## Write Mode

The 28C04A has a write cycle similar to that of a Static RAM. The write cycle is completely self-timed and initiated by a low going pulse on the WE pin. On the falling edge of WE, the address information is latched. On rising edge, the data and the control pins ( $\overline{C E}$ and $\overline{\mathrm{OE}})$ are latched.

## Data Polling

The 28C04A features Data polling to signal the completion of a byte write cycle. During a write cycle, an attempted read of the last byte written results in the data complement of I/O7 (I/O0 to I/O6 are indeterminable). After completion of the write cycle, true data is available. Data polling allows a simple read/compare operation to determine the status of the chip eliminating the need for external hardware.

## Optional Chip Clear

All data may be cleared to 1 's in a chip clear cycle by raising $\overline{\mathrm{OE}}$ to 12 volts and bringing the $\overline{\mathrm{WE}}$ and $\overline{\mathrm{CE}}$ low. This procedure clears all data.

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

| PART NUMBERS |  |  |
| :---: | :---: | :---: |

# 16K (2K x 8) CMOS Electrically Erasable PROM 

## FEATURES

- Fast Read Access Time-150ns Maximum
- CMOS Technology for Low Power Dissipation
-30mA Active
- $100 \mu \mathrm{~A}$ Standby
- Fast Byte Write Time- $200 \mu \mathrm{~s}$ or 1 ms
- Data Retention >10 years
- High Endurance $10^{4}$ Erase/Write Cycles
- Automatic Write Operation
-Internal Control Timer
-Auto-Clear Before Write Operation
-On-Chip Address and Data Latches
- Data polling
- Chip Clear Operation
- Enhanced Data Protection
—Vcc Detector
-Pulse Filter
-Write Inhibit
- Electronic Signature for Device Identification
- 5-Volt-Only Operation
- Organized 2Kx8 JEDEC Standard Pinout
-24 Pin Dual-In-Line Package
-32-Pin Chip Carrier (Leadless or Plastic)
- Available for Extended Temperature Ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
—Military ${ }^{*}$ : $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc 28C16A is a CMOS 16K non-volatile electrically Erasable and Programmable Read Only Memory. The 28C16A is accessed like a static RAM for the read or write cycles without the need of external components. During a "byte write", the address and data are latched internally, freeing the microprocessor address and data bus for other operations. Following the initiation of write cycle, the device will go to a busy state and automatically clear and write the latched data using an internal control timer. To determine when a write cycle is complete, the 28C16A uses $\overline{\text { Data }}$ polling. $\overline{\text { Data }}$ polling allows the user to read the location last written to when the write operation is complete. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are required. A complete family of packages is offered to provide the utmost flexibility in applications.

* See military data sheet DS60036.


| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{\mathrm{AO}}{\mathrm{CE}}-\mathrm{A} 10$ | Address Inputs |
| $\frac{\mathrm{OE}}{\mathrm{WE}}$ | Chip Enable |
| $\mathrm{O} / \mathrm{OO}-\mathrm{I} / \mathrm{O} 7$ | Write Enable |
| Vcc | Data Inputs/Outputs |
| Vss | +5V Power Supply |
| NC | Ground |
|  | No Connect; No Internal |
| NU | Connection |
|  | Not Used; No External |
|  | Connection is Allowed |

## ELECTRICAL CHARACTERISTICS MAXIMUM RATINGS*

Vcc and input voltages w.r.t. Vss $\ldots . . . . . .-0.6 \mathrm{~V}$ to +6.25 V
Voltage on $\overline{\mathrm{OE}}$ w.r.t. Vss .......................... -0.6 V to +13.5 V
Voltage on A9 w.r.t. Vss ........................... -0.6 V to +13.5 V
Output Voltage w.r.t. Vss ................... -0.6 V to $\mathrm{Vcc}+0.6 \mathrm{~V}$
Storage temperature ..........................-65 C to $125^{\circ} \mathrm{C}$
Ambient temp. with power applied ........ $50^{\circ} \mathrm{C}$ to $95^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ / WRITE OPERATION DC Characteristics |  |  |  | $\begin{aligned} & \text { VcC }=+5 \mathrm{~V} \pm 10 \% \\ & \begin{array}{ll} \text { Commercial (C): } \mathrm{Tamb}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \text { Industrial } & \text { (I): } \mathrm{Tamb}=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{array} \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{gathered} \text { VCC+1 } \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-0.1 \mathrm{~V}$ to $\mathrm{Vc}+1$ |
| Input Capacitance |  | CIN |  | 10 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Voltages | Logic "1" <br> Logic "0" | VOH <br> VoL | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{lOH}=-400 \mu \mathrm{~A} \\ & \mathrm{lOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | VOUT $=-0.1 \mathrm{~V}$ to $\mathrm{Vcc}+0.1 \mathrm{~V}$ |
| Output Capacitance |  | Cout |  | 12 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | TTL input | ICC |  | 30 | mA | $\begin{aligned} & f=5 \mathrm{MHz} \text { (Note 1) } \\ & \mathrm{Vcc}=5.5 \mathrm{~V} ; \end{aligned}$ |
| Power Supply Current, Standby | TTL input TTL input CMOS input | ICC(S)TTL ICC(S)TTL ICC(S)CMOS |  | $\begin{gathered} 2 \\ 3 \\ 100 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \overline{\overline{C E}}=V_{H}\left(0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}\right) \\ & \overline{\mathrm{CE}}=\mathrm{VIH}^{\left(-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}\right)} \\ & \overline{\mathrm{CE}}=\mathrm{Vcc}-0.3 \text { to } \mathrm{VcC}+1 \end{aligned}$ |

Note: (1) AC power supply current above $5 \mathrm{MHz}: 1 \mathrm{~mA} / \mathrm{MHz}$

| READ OPERATION AC Characteristics | $\begin{array}{ll}\text { AC Testing Waveform: } & \mathrm{VIH}=2.4 \mathrm{~V} ; \mathrm{VIL}=0.45 \mathrm{~V} ; \mathrm{VOH}=2.0 \mathrm{~V} ; \mathrm{VOL}=0.8 \mathrm{~V} \\ \text { Output Load: } & 1 \mathrm{TTL} \text { Load }+100 \mathrm{pF} \\ \text { Input Rise and Fall Times: } 20 \mathrm{nsec} \\ \text { Ambient Temperature: } & \begin{array}{l}\text { Commercial (C): } \mathrm{Tamb}=00^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \text { Industrial } \\ \\ \end{array} \begin{array}{ll}\text { (I): Tamb }=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}\end{array}\end{array}$ |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 28C16A-15 |  | 28C16A-20 |  | 28C16A-25 |  | Units | Conditions |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | tacc |  | 150 |  | 200 |  | 250 | ns | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tce |  | 150 |  | 200 |  | 250 | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{O E}$ to Output Delay | toe |  | 70 |  | 80 |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ High to Output Float | toff | 0 | 50 | 0 | 55 | 0 | 70 | ns |  |
| Output Hold from Address, $\overline{\mathrm{CE}}$ or $\overline{O E}$, whichever occurs first. | toh | 0 |  | 0 |  | 0 |  | ns |  |

## READ WAVEFORMS

Address


Notes: (1) toff is specified for $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first
(2) $\overline{O E}$ may be delayed up to $1 C E$ - toE after the falling edge of $\overline{C E}$ without impact on $\mathbf{C E}$
(3) This parameter is sampled and is not $100 \%$ tested

| BYTE WRITE AC Characteristics | AC Testing Waveform: $\mathrm{VIH}=2.4 \mathrm{~V} ; \mathrm{VIL}=0.45 \mathrm{~V} ; \mathrm{VOH}=2.0 \mathrm{~V} ; \mathrm{VOL}=0.8 \mathrm{~V}$ <br> Output Load: $\quad 1$ TTL Load +100 pF <br> Input Rise/Fall Times: 20 nsec <br> Ambient Temperature: <br> Commercial (C): Tamb $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> Industrial (I): Tamb $=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tas | 10 |  | ns |  |
| Address Hold Time | tah | 50 |  | ns |  |
| Data Set-Up Time | tos | 50 |  | ns |  |
| Data Hold Time | tDH | 10 |  | ns |  |
| Write Pulse Width | tWPL | 100 |  | ns | Note 1 |
| Write Pulse High Time | tWPH | 50 |  | ns |  |
| $\overline{\text { OE Hold Time }}$ | toen | 10 |  | ns |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 10 |  | ns |  |
| Data Valid Time | tDV |  | 1000 | ns | Note 2 |
| Write Cycle Time (28C16A) <br> Write Cycle Time (28C16AF) | tw twc |  | $\begin{gathered} 1 \\ 200 \end{gathered}$ | ms $\mu \mathrm{s}$ | 0.5 ms typical $100 \mu$ typical |

Note: (1) A write cycle can be initiated $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$ going low, whichever occurs last. The data is latched on the positive edge of $\overline{C E}$ or $\overline{W E}$, whichever occurs first.
(2) Data must be valid within 1000 ns max. after a write cycle is initiated and must be stable at least until tDH after the positive edge of $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first.


## DATA POLLING

## Waveforms



## CHIP CLEAR

## Waveforms



## SUPPLEMENTARY CONTROL



## DEVICE OPERATION

The Microchip Technology Inc 28C16A has four basic modes of operation-read, standby, write inhibit, and byte write-as outlined in the following table.

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { WE }}$ | 1/O |
| :---: | :---: | :---: | :---: | :---: |
| Read | L | L | H | DOUT |
| Standby | H | X | X | High Z |
| Write Inhibit | H | X | X | High Z |
| Write Inhibit | X | L | X | High Z |
| Write Inhibit | X | X | H | High Z |
| Byte Write | L | H | L | Din |
| Byte Clear | Automatic Before Each "Write" |  |  |  |

X = Any TTL level.

## Read Mode

The 28C16A has two control functions, both of which must be logically satisfied 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 is used to gate data to the output pins independent of device selection. Assuming that addresses are stable, address access time (tACC) is equal to the delay from $\overline{\mathrm{CE}}$ to output (tCE). Data is available at the output toE after the falling edge of $\overline{\mathrm{OE}}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least tacc-toe.

## Standby Mode

The 28C16A is placed in the standby mode by applying a high signal to the $\overline{C E}$ input. When in the standby mode, the outputs are in a high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## Data Protection

In order to ensure data integrity, especially during critical power-up and power-down transitions, the following enhanced data protection circuits are incorporated:

First, an internal Vcc detect ( 3.3 volts typical) will inhibit the initiation of non-volatile programming operation when Vcc is less than the Vcc detect circuit trip.

Second, there is a $\overline{W E}$ filtering circuit that prevents $\overline{W E}$ pulses of less than 10 ns duration from initiating a write cycle.

Third, holding $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$ high or $\overline{\mathrm{OE}}$ low, inhibits a write cycle during power-on and power-off (Vcc).

## Write Mode

The 28C16A has a write cycle similar to that of a Static RAM. The write cycle is completely self-timed and initiated by a low going pulse on the WE pin. On the falling edge of $\overline{W E}$, the address information is latched. On rising edge, the data and the control pins ( $\overline{C E}$ and $\overline{\mathrm{OE}})$ are latched.

## Data Polling

The 28C16A features Data polling to signal the completion of a byte write cycle. During a write cycle, an attempted read of the last byte written results in the data complement of I/O7 (I/O0 to I/O6 are indeterminable). After completion of the write cycle, true data is available. Data polling allows a simple read/compare operation to determine the status of the chip eliminating the need for external hardware.

## Electronic Signature for Device Identification

An extra row of 32 bytes of EEPROM memory is available to the user for device identification. By raising A9 to $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ and using address locations 7 EO to 7 FF , the additional bytes can be written to or read from in the same manner as the regular memory array.

## Optional Chip Clear

All data may be cleared to 1 's in a chip clear cycle by raising $\overline{\mathrm{OE}}$ to 12 volts and bringing the $\overline{\mathrm{WE}}$ and $\overline{\mathrm{CE}}$ low. This procedure clears all data, except for the extra row.

## NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.


## 16K (2K x 8) CMOS Electrically Erasable PROM

## FEATURES

- Fast Read Access Time-150ns Maximum
- CMOS Technology for Low Power Dissipation
-30mA Active
$-100 \mu \mathrm{~A}$ Standby
- Fast Byte Write Time- $200 \mu \mathrm{~s}$ or 1 ms
- Data Retention >10 years
- High Endurance $10^{4}$ Erase/Write Cycles
- Automatic Write Operation
-Internal Control Timer
-Auto-Clear Before Write Operation
-On-Chip Address and Data Latches
- Data Polling
- Ready/Busy
- Chip Clear Operation
- Enhanced Data Protection
-Vcc Detector
-Pulse Filter
-Write Inhibit
- Electronic Signature for Device Identification
- 5-Volt-Only Operation
- Organized 2Kx8 JEDEC Standard Pinout
-28 Pin Dual-In-Line Package
-32-Pin Chip Carrier (Leadless or Plastic)
- Available for Extended Temperature Ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
—Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
—Military ${ }^{*}$ : $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc 28C17A is a CMOS 16K non-volatile electrically Erasable and Programmable Read Only Memory. The 28C17A is accessed like a static RAM for the read or write cycles without the need of external components. During a "byte write", the address and data are latched internally, freeing the microprocessor address and data bus for other operations. Following the initiation of write cycle, the device will go to a busy state and automatically clear and write the latched data using an internal control timer. To determine when the write cycle is complete, the user has a choice of monitoring the Ready/Busy output or using Data polling. The Ready/Busy pin is an open drain output, which allows easy configuration in wired-or systems. Alternatively, Data polling allows the user to read the location last written to when the write operation is complete. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are required. A complete family of packages is offered to provide the utmost flexibility in applications.

* See military data sheet DS60036.

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{\text { AO }- \text { A10 }}{\overline{\mathrm{CE}}}$ | Address Inputs |
| $\overline{\mathrm{OE}}$ | Chip Enable |
| $\overline{\mathrm{WE}}$ | Output Enable |
| I/OO $-\mathrm{I} / \mathrm{O7}$ | Write Enable |
| RDY/Busy | Data Inputs/Outputs |
| Vcc | Ready/Busy |
| Vss | +5V Power Supply |
| NC | Ground |
|  | No Connect; No Internal |
| NU | Connection |
|  | Not Used; No External |
|  | Connection is Allowed |

## ELECTRICAL CHARACTERISTICS MAXIMUM RATINGS*

Vcc and input voltages w.r.t. Vss ........ -0.6 V to +6.25 V
Voltage on $\overline{\mathrm{OE}}$ w.r.t. Vss ......................... -0.6 V to +13.5 V
Voltage on A9 w.r.t. Vss .......................... -0.6 V to +13.5 V
Output Voltage w.r.t. Vss ...................-0.6V to Vcc +0.6 V
Storage temperature .......................... $65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Ambient temp. with power applied ........ $-50^{\circ} \mathrm{C}$ to $95^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ / WRITE OPERATION DC Characteristics |  |  |  | $\begin{aligned} & \text { Vcc }=+5 \mathrm{~V} \pm 10 \% \\ & \text { Commercial (C): } \mathrm{Tamb}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \text { Industrial } \\ & \text { (I): } \mathrm{Tamb}=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{array}{\|c} \hline \text { Vcc+1 } \\ 0.8 \end{array}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-0.1 \mathrm{~V}$ to $\mathrm{VcC}+1$ |
| Input Capacitance |  | CIN |  | 10 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Voltages | $\begin{aligned} & \text { Logic "1" } \\ & \text { Logic "0" } \end{aligned}$ | VOH <br> Vol | 2.4 | 0.45 | $\begin{aligned} & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{IOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | Vout $=-0.1 \mathrm{~V}$ to $\mathrm{Vcc}+0.1 \mathrm{~V}$ |
| Output Capacitance |  | Cout |  | 12 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} \text {; } \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | TTL input | ICC |  | 30 | mA | $\begin{aligned} & f=5 \mathrm{MHz} \text { (Note 1) } \\ & \mathrm{Vcc}=5.5 \mathrm{~V} ; \end{aligned}$ |
| Power Supply Current, Standby | TTL input TTL input CMOS input | $\begin{gathered} \text { ICC(S)TTL } \\ \text { ICC(S)TTL } \\ \operatorname{ICC(S)CMOS} \end{gathered}$ |  | $\begin{gathered} 2 \\ 3 \\ 100 \end{gathered}$ | mA mA $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{VIH}\left(0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}\right) \\ & \overline{\mathrm{CE}}=\mathrm{VIH}\left(-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}\right) \\ & \overline{\mathrm{CE}}=\mathrm{Vcc}-0.3 \text { to } \mathrm{Vcc}+1 \end{aligned}$ |

Note: (1) AC power supply current above $5 \mathrm{MHz}: 1 \mathrm{~mA} / \mathrm{MHz}$

| READ OPERATION AC Characteristics | AC Testing Waveform: $\quad \mathrm{VIH}=2.4 \mathrm{~V} ; \mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V}$; $\mathrm{VOL}=0.8 \mathrm{~V}$ Output Load: $\quad 1$ TTL Load +100 pF <br> Input Rise and Fall Times: 20 nsec <br>  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 28C17A-15 |  | 28C17A-20 |  | 28C17A-25 |  | Units | Conditions |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | tacc |  | 150 |  | 200 |  | 250 | ns | $\overline{O E}=\overline{C E}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tce |  | 150 |  | 200 |  | 250 | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | toe |  | 70 |  | 80 |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ High to Output Float | tOFF | 0 | 50 | 0 | 55 | 0 | 70 | ns |  |
| Output Hold from Address, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever occurs first. | tor | 0 |  | 0 |  | 0 |  | ns |  |

## READ WAVEFORMS



Notes: (1) toff is specified for $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first
(2) $\overline{\mathrm{OE}}$ may be delayed up to tCE - tOE after the falling edge of $\overline{\mathrm{CE}}$ without impact on tCE
(3) This parameter is sampled and is not $100 \%$ tested

| BYTE WRITE <br> AC Characteristics | AC Testing Waveform: Output Load: Input Rise/Fall Times: Ambient Temperature: | $=2.4 \mathrm{~V}$ <br> L Loa <br> sec <br> merc <br> strial | $\begin{aligned} & \text { IL }=0 \\ & +100 \\ & \text { (C): } \mathrm{T} \\ & \text { (I) } \mathrm{T} \end{aligned}$ | $\begin{aligned} & 5 \mathrm{~V} ; \mathrm{Vo} \\ & \mathrm{~F} \\ & \mathrm{mb}= \\ & \mathrm{mb}=-4 \end{aligned}$ | $\mathrm{H}=2.0 \mathrm{~V} ; \mathrm{VOL}=0.8 \mathrm{~V}$ <br> C to $70^{\circ} \mathrm{C}$ <br> C to $85^{\circ} \mathrm{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tAS | 10 |  | ns |  |
| Address Hold Time | tah | 50 |  | ns |  |
| Data Set-Up Time | tDs | 50 |  | ns |  |
| Data Hold Time | tDH | 10 |  | ns |  |
| Write Pulse Width | tWPL | 100 |  | ns | Note 1 |
| Write Pulse High Time | WPPH | 50 |  | ns |  |
| $\overline{\text { OE Hold Time }}$ | toen | 10 |  | ns |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 10 |  | ns |  |
| Data Valid Time | tov |  | 1000 | ns | Note 2 |
| Time to Device Busy | tDB |  | 50 | ns |  |
| Write Cycle Time (28C17A) <br> Write Cycle Time (28C17AF) | twc <br> twc |  | $\begin{gathered} 1 \\ 200 \\ \hline \end{gathered}$ | ms <br> $\mu \mathrm{s}$ | 0.5 ms typical <br> $100 \mu$ s typical |
| Note: (1) A write cycle can be initiated $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$ going low, whichever occurs last. The data is latched on the positive edge of $\overline{C E}$ or $\overline{W E}$, whichever occurs first. <br> (2) Data must be valid within 1000 ns max. after a write cycle is initiated and must be stable at least until tDH after the positive edge of $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first. |  |  |  |  |  |



## DATA POLLING

## Waveforms




## SUPPLEMENTARY CONTROL

| Mode | $\overline{C E}$ | $\overline{\mathrm{OE}}$ | WE | A9 | Vcc | 1/OI |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Chip Clear | VIL | VH | VIL | X | Vcc |  |
| Extra Row Read | VIL | VIL | VIH | $\mathrm{A} 9=\mathrm{VH}$ | Vcc | Data Out |
| Extra Row Write | * | VIH | * | $\mathrm{A} 9=\mathrm{VH}$ | Vcc | Data In |
| Note: $\mathrm{VH}=12.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$ * Pulsed per programming waveforms. |  |  |  |  |  |  |

## DEVICE OPERATION

The Microchip Technology Inc 28C17A has four basic modes of operation-read, standby, write inhibit, and byte write-as outlined in the following table.

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}$ | $\overline{W E}$ | I/O | Rdy/Eusy ${ }^{\text {(1) }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | L | L | H | Dout | H |
| Standby | H | X | X | High Z | H |
| Write Inhibit | H | X | X | High Z | H |
| Write Inhibit | X | L | X | High Z | H |
| Write Inhibit | X | X | H | High Z | H |
| Byte Write | L | H | L | Din | L |
| Byte Clear | Automatic Before Each "Write" |  |  |  |  |

Note: (1) Open drain output.
(2) $X=$ Any TTL level.

## Read Mode

The 28C17A has two control functions, both of which must be logically satisfied 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 is used to gate data to the output pins independent of device selection. Assuming that addresses are stable, address access time (tACC) equal to the delay from $\overline{\mathrm{CE}}$ to output (tCE). Data is available at the output 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 tacc-toe.

## Standby Mode

The 28C17A is placed in the standby mode by applying a high signal to the $\overline{C E}$ input. When in the standby mode, the outputs are in a high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## Data Protection

In order to ensure data integrity, especially during critical power-up and power-down transitions, the following enhanced data protection circuits are incorporated:

First, an internal Vcc detect ( 3.3 volts typical) will inhibit the initiation of non-volatile programming operation when Vcc is less than the Vcc detect circuit trip.

Second, there is a $\overline{W E}$ filtering circuit that prevents $\overline{W E}$ pulses of less than 10 ns duration from initiating a write cycle.

Third, holding $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$ high or $\overline{\mathrm{OE}}$ low, inhibits a write cycle during power-on and power-off (VCC).

## Write Mode

The 28C17A has a write cycle similar to that of a Static RAM. The write cycle is completely self-timed and initiated by a low going pulse on the WE pin. On the falling edge of $\overline{W E}$, the address information is latched. On rising edge, the data and the control pins ( $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ ) are latched. The Ready/Busy pin goes to a logic low level indicating that the 28C17A is in a write cycle which signals the microprocessor host that the system bus is free for other activity. When Ready/ $\overline{\text { Busy }}$ goes back to a high, the 28C17A has completed writing and is ready to accept another cycle.

## Data Polling

The 28C17A features Data polling to signal the completion of a byte write cycle. During a write cycle, an attempted read of the last byte written results in the data complement of I/O7 (I/O0 to I/O6 are indeterminable). After completion of the write cycle, true data is available. Data polling allows a simple read/compare operation to determine the status of the chip eliminating the need for external hardware.

## Electronic Signature for Device Identification

An extra row of 32 bytes of EEPROM memory is available to the user for device identification. By raising A9 to $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ and using address locations 7 EO to 7 FF , the additional bytes can be written to or read from in the same manner as the regular memory array.

## Optional Chip Clear

All data may be cleared to 1 's in a chip clear cycle by raising $\overline{\mathrm{OE}}$ to 12 volts and bringing the $\overline{\mathrm{WE}}$ and $\overline{\mathrm{CE}}$ low. This procedure clears all data, except for the extra row.

NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.


## 16K (2K x 8) CMOS Electrically Erasable PROM

## FEATURES

- 250ns Access Time
- CMOS Technology for Low Power Dissipation
-30mA Active
-100 A A Standby
- Fast Byte Write Time-1ms
- Automatic Write Operation
-Internal Control Timer
-Auto-Clear Before Write Operation
-On-Chip Address and Data Latches
- Data Polling
- Ready/Busy
- Chip Clear Operation
- Enhanced Data Protection
-Vcc Detector
-Pulse Filter
—Write Inhibit
- Electronic Signature for Device Identification
- 5-Volt-Only Operation
- Commercial Temperature Range:
$-0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
- Available in Wafer Form or Waffle Pack



## DESCRIPTION

The Microchip Technology Inc 28C17A is a CMOS 16K non-volatile electrically Erasable and Programmable Read Only Memory. The 28C17A is accessed like a static RAM for the read or write cycles without the need of external components. During a "byte write", the address and data are latched internally, freeing the microprocessor address and data bus for other operations. Following the initiation of write cycle, the device will go to a busy state and automatically clear and write the latched data using an internal control timer. To determine when the write cycle is complete, the user has a choice of monitoring the Ready/Busy output or using $\overline{\text { Data polling. The Ready/Busy pin is an open drain }}$ output, which allows easy configuration in wired-or systems. Alternatively, $\overline{\text { Data }}$ polling allows the user to read the location last written to when the write operation is complete. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are required.


| PIN FUNCTION TABLE |  |
| :---: | :---: |
| Name | Function |
| A0-A10 | Address Inputs |
| CE | Chip Enable |
| OE | Output Enable |
| WE | Write Enable |
| 1/00-1/07 | Data Inputs/Outputs |
| RDY/Busy | Ready/Busy |
| Vcc | +5V Power Supply |
| Vss | Ground |
| NC | No Connect; No Internal Connection |

## ELECTRICAL CHARACTERISTICS Maximum Ratings*

Vcc and input voltages w.r.t. Vss ........ -0.6 V to +6.25 V
Voltage on OE w.r.t. Vss -0.6 V to +13.5 V
Voltage on A9 w.r.t. Vss -0.6 V to +13.5 V
Output Voltage w.r.t. Vss ................... -0.6 V to $\mathrm{Vcc}+0.6 \mathrm{~V}$
Storage temperature $-65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Ambient temp. with power applied........ $50^{\circ} \mathrm{C}$ to $95^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ / WRITE OPERATION DC Characteristics |  |  |  | $\mathrm{VcC}=+5 \mathrm{~V} \pm 10 \%$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Comm | ercial: | Tamb $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{VIL}^{2} \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{gathered} \mathrm{Vcc}+1 \\ 0.8 \end{gathered}$ | v |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-0.1 \mathrm{~V}$ to $\mathrm{VCC}+1$ |
| Input Capacitance |  | Cin |  | 10 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \mathrm{Tamb}=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Voltages | $\begin{aligned} & \text { Logic "1" } \\ & \text { Logic "0" } \end{aligned}$ | $\begin{aligned} & \text { VoH } \\ & \text { Vol } \end{aligned}$ | 2.4 | 0.45 | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{lOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | Vout $=-0.1 \mathrm{~V}$ to $\mathrm{Vcc}+0.1 \mathrm{~V}$ |
| Output Capacitance |  | Cout |  | 12 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \operatorname{Tamb}=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | TTL input | Icc |  | 30 | mA | $\begin{aligned} & f=5 \mathrm{MHz}(\text { Note } 1) \\ & \mathrm{VcC}=5.5 \mathrm{~V} \end{aligned}$ |
| Power Supply Current, Standby | TTL input CMOS input | ICC(S)TTL Icc(s)cmos |  | $\begin{gathered} 2 \\ 100 \end{gathered}$ | ${ }_{\mu \mathrm{A}}^{\mathrm{mA}}$ | $\begin{aligned} & \overline{\overline{C E}}=\mathrm{V} \mathbf{H} \\ & \mathrm{CE}=\mathrm{Vcc}-0.3 \text { to } \mathrm{VcC}+1 \end{aligned}$ |

Note: (1) AC power supply current above $5 \mathrm{MHz}: 1 \mathrm{~mA} / \mathrm{MHz}$

## 28C17A DICE FORM

| READ OPERATION <br> AC Characteristics | AC Testing Waveform: Output Load: Input Rise and Fall Times: Ambient Temperature: | ```VIH=2.4V; VIL=0.45V; VOH=2.0V; VOL = 0.8V 1 TTL Load + 100 pF 20 nsec Commercial: Tamb = 0 }\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to 70``` |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 28 C |  | Units | Conditions |
|  |  | Min | Max |  |  |
| Address to Output Delay | tacc |  | 250 | ns | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tCE |  | 250 | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | toe |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ High to Output Float | toff | 0 | 70 | ns |  |
| Output Hold from Address, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever occurs first. | toh | 0 |  | ns |  |

## READ WAVEFORMS



Notes: (1) toff is specified for $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first
(2) $\overline{O E}$ may be delayed up to tCE - toE after the falling edge of $\overline{C E}$ without impact on ICE
(3) This parameter is sampled and is not $100 \%$ tested

## 28C17A DICE FORM




## DATA POLLING

## Waveforms




## SUPPLEMENTARY CONTROL

| Mode | $\overline{\text { CE }}$ | $\overline{\mathrm{OE}}$ | WE | A9 | Vcc | 1/01 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Chip Clear | VIL | VH | VIL | X | Vcc |  |
| Extra Row Read | VIL | VIL | $\mathrm{V}_{1}$ | $\mathrm{A} 9=\mathrm{VH}$ | Vcc | Data Out |
| Extra Row Write | * | $\mathrm{V}_{1}$ | * | $\mathrm{A} 9=\mathrm{VH}$ | Vcc | Data In |
|  |  |  |  |  |  |  |

## DEVICE OPERATION

The Microchip Technology Inc 28C17A has four basic modes of operation-read, standby, write inhibit, and byte write-as outlined in the following table.

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}$ | $\overline{W E}$ | I/O | Rdy/Eusy ${ }^{\text {(1) }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | L | L | H | Dout | H |
| Standby | H | X | X | High Z | H |
| Write Inhibit | H | X | X | High Z | H |
| Write Inhibit | X | L | X | High Z | H |
| Write Inhibit | X | X | H | High Z | H |
| Byte Write | L | H | L | Din | L |
| Byte Clear | matic Before Each "Write" |  |  |  |  |

Note: (1) Open drain output.
(2) $X=$ Any TTL level.

## Read Mode

The 28C17A has two control functions, both of which must be logically satisfied 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 is used to gate data to the output pins independent of device selection. Assuming that addresses are stable, address access time (tACC) equal to the delay from $\overline{C E}$ to output (tCE). Data is available at the output toE after the falling edge of $\overline{\mathrm{OE}}$, assuming that $\overline{\mathrm{CE}}$ has been low and addresses have been stable for at least tacc-toe.

## Standby Mode

The 28C17A is placed in the standby mode by applying a high signal to the $\overline{C E}$ input. When in the standby mode, the outputs are in a high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## Data Protection

In order to ensure data integrity, especially during critical power-up and power-down transitions, the following enhanced data protection circuits are incorporated:

First, an internal Vcc detect ( 3.3 volts typical) will inhibit the initiation of non-volatile programming operation when Vcc is less than the Vcc detect circuit trip.

Second, there is a $\overline{W E}$ filtering circuit that prevents $\overline{W E}$ pulses of less than 10ns duration from initiating a write cycle.

Third, holding $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$ high or $\overline{\mathrm{OE}}$ low, inhibits a write cycle during power-on and power-off (VCC).

## Write Mode

The 28C17A has a write cycle similar to that of a Static RAM. The write cycle is completely self-timed and initiated by a low going pulse on the $\overline{W E}$ pin. On the falling edge of $\overline{W E}$, the address information is latched. On rising edge, the data and the control pins ( $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ ) are latched. The Ready/Busy pingoes to a logic low level indicating that the 28C17A is in a write cycle which signals the microprocessor host that the system bus is free for other activity. When Ready/Busy goes back to a high, the 28C17A has completed writing and is ready to accept another cycle.

## Data Polling

The 28C17A features $\overline{\text { Data }}$ polling to signal the completion of a byte write cycle. During a write cycle, an attempted read of the last byte written results in the data complement of I/O7 (I/O0 to I/O6 are indeterminable). After completion of the write cycle, true data is available. Data polling allows a simple read/compare operation to determine the status of the chip eliminating the need for external hardware.

## Electronic Signature for Device Identification

An extra row of 32 bytes of EEPROM memory is available to the user for device identification. By raising A9 to $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ and using address locations 7 EO to 7 FF , the additional bytes can be written to or read from in the same manner as the regular memory array.

## Optional Chip Clear

All data may be cleared to 1 's in a chip clear cycle by raising $\overline{\mathrm{OE}}$ to 12 volts and bringing the $\overline{\mathrm{WE}}$ and $\overline{\mathrm{CE}}$ low. This procedure clears all data, except for the extra row.

## NOTES:

## 28C17A DICE FORM

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



# 64K (8K x 8) CMOS Electrically Erasable PROM 

## FEATURES

- Fast Read Access Time-150ns Maximum
- CMOS Technology for Low Power Dissipation
- 30mA Active
-100 AA Standby
- Fast Byte Write Time- $200 \mu \mathrm{~s}$ or 1 ms
- Data Retention >10 years
- High Endurance $10^{4}$ Erase/Write Cycles
- Automatic Write Operation
-Internal Control Timer
-Auto-Clear Before Write Operation
-On-Chip Address and Data Latches
- Data Polling
- Ready/Busy
- Chip Clear Operation
- Enhanced Data Protection
—Vcc Detector
-Pulse Filter
-Write Inhibit
- Electronic Signature for Device Identification
- 5-Volt-Only Operation
- Organized 8 Kx 8 JEDEC Standard Pinout
-28 Pin Dual-In-Line Package
-32-Pin Chip Carrier (Leadless or Plastic)
- Available for Extended Temperature Ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
—Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
—Military**: $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc 28C64A is a CMOS 64K non-volatile electrically Erasable and Programmable Read Only Memory. The 28C64A is accessed like a static RAM for the read or write cycles without the need of external components. During a "byte write", the address and data are latched internally, freeing the microprocessor address and data bus for other operations. Following the initiation of write cycle, the device will go to a busy state and automatically clear and write the latched data using an internal control timer. To determine when the write cycle is complete, the user has a choice of monitoring the Ready/ $\overline{\text { Busy output or using }}$ $\overline{\text { Data polling. The Ready/Busy pin is an open drain }}$ output, which allows easy configuration in wired-or systems. Alternatively, $\overline{\text { Data }}$ polling allows the user to read the location last written to when the write operation is complete. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are required. A complete family of packages is offered to provide the utmost flexibility in applications.
** See Military Data Sheet DS60003


| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{\mathrm{AO}-\mathrm{A} 12}{\underline{\mathrm{CE}}}$ | Address Inputs |
| $\underline{\mathrm{OE}}$ | Chip Enable |
| $\overline{\mathrm{WE}}$ | Output Enable |
| $\mathrm{I} / \mathrm{OO}-\mathrm{l} / \mathrm{O7}$ | Write Enable |
| RDY/Busy | Data Inputs/Outputs |
| Vcc | Ready/Busy |
| Vss | +5V Power Supply |
| NC | Ground |
|  | No Connect; No Internal |
| NU | Connection |
|  | Not Used; No External |
|  | Connection is Allowed |

## ELECTRICAL CHARACTERISTICS MAXIMUM RATINGS*

Vcc and input voltages w.r.t. Vss.......-0.6 V to +6.25 V
Voltage on $\overline{\mathrm{OE}}$ w.r.t. Vss ......................... -0.6 V to +13.5 V
Voltage on A 9 w.r.t. Vss .......................... -0.6 V to +13.5 V
Output Voltage w.r.t. Vss ................... -0.6 V to $\mathrm{Vcc}+0.6 \mathrm{~V}$
Storage temperature $-65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Ambient temp. with power applied ........ $50^{\circ} \mathrm{C}$ to $95^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ / WRITE OPERATION DC Characteristics |  |  |  | $\begin{aligned} & \text { VcC }=+5 \mathrm{~V} \pm 10 \% \\ & \text { Commercial (C): } \mathrm{Tamb}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \text { Industrial } \\ & \text { (I): } \mathrm{Tamb}=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | $\begin{aligned} & \text { Logic "1" } \\ & \text { Logic "0" } \end{aligned}$ | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{array}{\|c} \hline \text { Vcc+1 } \\ 0.8 \end{array}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-0.1 \mathrm{~V}$ to $\mathrm{Vc}++1$ |
| Input Capacitance |  | Cin |  | 10 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Output Voltages | Logic "1" <br> Logic "0" | VOH Vol | 2.4 | 0.45 | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ | $\begin{aligned} & \mathrm{lOH}=-400 \mu \mathrm{~A} \\ & \mathrm{lOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VOUT}=-0.1 \mathrm{~V}$ to $\mathrm{Vcc}+0.1 \mathrm{~V}$ |
| Output Capacitance |  | Cout |  | 12 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | TTL input | Icc |  | 30 | mA | $\begin{aligned} & \mathrm{f}=5 \mathrm{MHz} \text { (Note 1) } \\ & \mathrm{Vcc}=5.5 \mathrm{~V} ; \end{aligned}$ |
| Power Supply Current, Standby | TTL input TTL input CMOS input | ICC(S)TTL ICC(S)TTL Icc(S)CMOS |  | $\begin{gathered} 2 \\ 3 \\ 100 \end{gathered}$ | mA <br> mA <br> $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{VIH}\left(0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}\right) \\ & \overline{\mathrm{CE}}=\mathrm{VIH}\left(-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}\right) \\ & \overline{\mathrm{CE}}=\mathrm{Vcc}-0.3 \text { to } \mathrm{Vcc}+1 \end{aligned}$ |

Note: (1) AC power supply current above $5 \mathrm{MHz}: 2 \mathrm{~mA} / \mathrm{MHz}$

| READ OPERATION AC Characteristics | AC Testing Waveform: Output Load: Input Rise and Fall Times: Ambient Temperature: |  |  |  | $\begin{aligned} & \mathrm{VIH}=2.4 \mathrm{~V} ; \mathrm{VIL}=0.45 \mathrm{~V} ; \mathrm{VOH}=2.0 \mathrm{~V} ; \mathrm{VOL}=0.8 \mathrm{~V} \\ & 1 \mathrm{TTL} \text { Load }+100 \mathrm{pF} \\ & 20 \text { nsec } \\ & \text { Commercial (C):Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \text { Industrial } \\ & \text { (I): } \mathrm{Tamb}=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 28C64A-15 |  | 28C64A-20 |  | 28C64A-25 |  | Units | Conditions |
|  |  | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | tACC |  | 150 |  | 200 |  | 250 | ns | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tCe |  | 150 |  | 200 |  | 250 | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | toe |  | 70 |  | 80 |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ High to Output Float | toff | 0 | 50 | 0 | 55 | 0 | 70 | ns |  |
| Output Hold from Address, $\overline{\mathrm{CE}}$ or $\overline{O E}$, whichever occurs first. | tor | 0 |  | 0 |  | 0 |  | ns |  |

## READ WAVEFORMS



Notes: (1) toff is specified for $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first
(2) $\overline{O E}$ may be delayed up to tCE - toE after the falling edge of $\overline{\mathrm{CE}}$ without impact on XCE
(3) This parameter is sampled and is not $100 \%$ tested

| BYTE WRITE <br> AC Characteristics | AC Testing Waveform: Output Load: Input Rise/Fall Times: Ambient Temperature: | $=2.4 \mathrm{~V}$ <br> L Load <br> sec <br> merc <br> strial | $\begin{aligned} & / \mathrm{IL}=0 \\ & +100 \end{aligned}$ <br> (C): T $\text { (I): } \mathrm{T}$ | $\begin{aligned} & \mathrm{nb}= \\ & \mathrm{nb}=- \end{aligned}$ | $\begin{aligned} & \mathrm{H}=2.0 \mathrm{~V} ; \mathrm{VOL}=0.8 \mathrm{~V} \\ & \mathrm{O}^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & 0^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tAS | 10 |  | ns |  |
| Address Hold Time | taH | 50 |  | ns |  |
| Data Set-Up Time | tDs | 50 |  | ns |  |
| Data Hold Time | tDH | 10 |  | ns |  |
| Write Pulse Width | twPL | 100 |  | ns | Note 1 |
| Write Pulse High Time | tWPH | 50 |  | ns |  |
| $\overline{\mathrm{OE}}$ Hold Time | TOEH | 10 |  | ns |  |
| OE Set-Up Time | toes | 10 |  | ns |  |
| Data Valid Time | tov |  | 1000 | ns | Note 2 |
| Time to Device Busy | tDB |  | 50 | ns |  |
| Write Cycle Time (28C64A) <br> Write Cycle Time (28C64AF) | twc <br> twc |  | $\begin{gathered} 1 \\ 200 \end{gathered}$ | $\mathrm{ms}$ $\mu \mathrm{s}$ | 0.5 ms typical $100 \mu$ s typical |
| Note: (1) A write cycle can be initiated $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$ going low, whichever occurs last. The data is latched on the positive edge of $\overline{C E}$ or $\overline{W E}$, whichever occurs first. <br> (2) Data must be valid within 1000 ns max. after a write cycle is initiated and must be stable at least until tDH after the positive edge of $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first. |  |  |  |  |  |



## DATA POLLING

## Waveforms



## CHIP CLEAR

Waveforms


## SUPPLEMENTARY CONTROL

| Mode | $\overline{C E}$ | $\overline{O E}$ | WE | A9 | Vcc | I/OI |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Chip Clear | VIL | VH | VIL | X | Vcc |  |
| Extra Row Read | VIL | VIL | $\mathrm{V}_{1}$ | $\mathrm{A} 9=\mathrm{VH}$ | Vcc | Data Out |
| Extra Row Write | * | VIH | * | $\mathrm{A} 9=\mathrm{VH}$ | Vcc | Data In |

## DEVICE OPERATION

The Microchip Technology Inc 28C64A has four basic modes of operation-read, standby, write inhibit, and byte write-as outlined in the following table.

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}$ | $\overline{W E}$ | I/O | Rdy/Eusy ${ }^{\text {(1) }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | L | L | H | Dout | H |
| Standby | H | X | X | High Z | H |
| Write Inhibit | H | X | X | High Z | H |
| Write Inhibit | X | L | X | High Z | H |
| Write Inhibit | X | X | H | High Z | H |
| Byte Write | L | H | 1 | Din | L |
| Byte Clear | Automatic Before Each "Write" |  |  |  |  |

Note: (1) Open drain output.
(2) $X=$ Any TTL level.

## Read Mode

The 28C64A has two control functions, both of which must be logically satisfied 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 (OE) is the output control and is used to gate data to the output pins independent of device selection. Assuming that addresses are stable, address access time (tACC) is equal to the delay from $\overline{C E}$ to output (tCE). Data is available at the output toE after the falling edge of $\overline{\mathrm{OE}}$, assuming that $\overline{\mathrm{CE}}$ has been low and addresses have been stable for at least tacc-toe.

## Standby Mode

The 28C64A is placed in the standby mode by applying a high signal to the $\overline{\mathrm{CE}}$ input. When in the standby mode, the outputs are in a high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## Data Protection

In order to ensure data integrity, especially during critical power-up and power-down transitions, the following enhanced data protection circuits are incorporated:

First, an internal Vcc detect ( 3.3 volts typical) will inhibit the initiation of non-volatile programming operation when Vcc is less than the Vcc detect circuit trip.

Second, there is a $\overline{W E}$ filtering circuit that prevents $\overline{W E}$ pulses of less than 10ns duration from initiating a write cycle.

Third, holding $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$ high or $\overline{\mathrm{OE}}$ low, inhibits a write cycle during power-on and power-off (Vcc).

## Write Mode

The 28C64A has a write cycle similar to that of a Static RAM. The write cycle is completely self-timed and initiated by a low going pulse on the WE pin. On the falling edge of $\overline{W E}$, the address information is latched. On rising edge, the data and the control pins ( $\overline{C E}$ and $\overline{\mathrm{OE}}$ ) are latched. The Ready/ $\overline{\mathrm{Busy}}$ pin goes to a logic low level indicating that the 28C64A is in a write cycle which signals the microprocessor host that the system bus is free for other activity. When Ready/Busy goes back to a high, the 28C64A has completed writing and is ready to accept another cycle.

## Data Polling

The 28C64A features Data polling to signal the completion of a byte write cycle. During a write cycle, an attempted read of the last byte written results in the data complement of I/O7 (I/O0 to I/O6 are indeterminable). After completion of the write cycle, true data is available. $\overline{\text { Data }}$ polling allows a simple read/compare operation to determine the status of the chip eliminating the need for external hardware.

## Electronic Signature for Device Identification

An extra row of 32 bytes of EEPROM memory is available to the user for device identification. By raising A9 to $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ and using address locations 1 FEO to 1FFF, the additional bytes can be written to or read from in the same manner as the regular memory array.

## Optional Chip Clear

All data may be cleared to 1 's in a chip clear cycle by raising $\overline{O E}$ to 12 volts and bringing the $\overline{W E}$ and $\overline{C E}$ low. This procedure clears all data, except for the extra row.

NOTES:

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.


## 64K (8K x 8) CMOS Electrically Erasable PROM

## FEATURES

- 250ns Access Time
- CMOS Technology for Low Power Dissipation
-30mA Active
-100 $\mu \mathrm{A}$ Standby
- Fast Byte Write Time-1ms
- Automatic Write Operation
-Internal Control Timer
-Auto-Clear Before Write Operation
-On-Chip Address and Data Latches
- Data Polling
- Ready/Busy
- Chip Clear Operation
- Enhanced Data Protection
-Vcc Detector
—Pulse Filter
—Write Inhibit
- Electronic Signature for Device Identification
- 5-Volt-Only Operation
- Commercial Temperature Range:
$-0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
- Available in Wafer Form or Waffle Pack


## DESCRIPTION

The Microchip Technology Inc 28C64A is a CMOS 64K non-volatile electrically Erasable and Programmable Read Only Memory. The 28C64A is accessed like a static RAM for the read or write cycles without the need of external components. During a "byte write", the address and data are latched internally, freeing the microprocessor address and data bus for other operations. Following the initiation of write cycle, the device will go to a busy state and automatically clear and write the latched data using an internal control timer. To determine when the write cycle is complete, the user has a choice of monitoring the Ready/Busy output or using Data polling. The Ready/Busy pin is an open drain output, which allows easy configuration in wired-or systems. Alternatively, $\overline{\text { Data }}$ polling allows the user to read the location last written to when the write operation is complete. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are required.


| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{\mathrm{AO}}{\mathrm{CE}}-\mathrm{A} 12$ | Address Inputs |
| $\overline{\mathrm{OE}}$ | Chip Enable |
| $\overline{\mathrm{WE}}$ | Output Enable |
| $\mathrm{I} / \mathrm{OO}-\mathrm{I} / \mathrm{O} 7$ | Write Enable |
| $\mathrm{RDY/Busy}$ | Data Inputs/Outputs |
| Vcc | Ready/Busy |
| Vss | +5V Power Supply |
| NU | Ground |
|  | Not Used; No External |
|  | Connection is Allowed |

## ELECTRICAL CHARACTERISTICS MAXIMUM RATINGS*

Vcc and input voltages w.r.t. Vss $\ldots . . . . .-0.6 \mathrm{~V}$ to +6.25 V
Voltage on $\overline{\mathrm{OE}}$ w.r.t. Vss -0.6 V to +13.5 V
Voltage on A9 w.r.t. Vss -0.6 V to +13.5 V
Output Voltage w.r.t. Vss -0.6 V to $\mathrm{Vcc}+0.6 \mathrm{~V}$
Storage temperature $-65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Ambient temp. with power applied ........ $50^{\circ} \mathrm{C}$ to $95^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ / WRITE OPERATION DC Characteristics |  |  |  | $\begin{aligned} & \text { Vcc }=+5 \mathrm{~V} \pm 10 \% \\ & \text { Commercial: Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{gathered} \text { Vcc+1 } \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-0.1 \mathrm{~V}$ to $\mathrm{VcC}+1$ |
| Input Capacitance |  | CIN |  | 10 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Voltages | Logic "1" <br> Logic "0" | VOH Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{IOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | Vout $=-0.1 \mathrm{~V}$ to $\mathrm{Vcc}+0.1 \mathrm{~V}$ |
| Output Capacitance |  | Cout |  | 12 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | TTL input | ICC |  | 30 | mA | $\begin{aligned} & \mathrm{f}=5 \mathrm{MHz} \text { (Note } 1 \text { ) } \\ & \mathrm{VcC}=5.5 \mathrm{~V} ; \end{aligned}$ |
| Power Supply Current, Standby | TTL input CMOS input | ICC(S)TTL ICC(S)CMOS | $\cdot$ | $\begin{gathered} 2 \\ 100 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{VIH} \\ & \overline{\mathrm{CE}}=\mathrm{Vcc}-0.3 \text { to } \mathrm{Vcc}+1 \end{aligned}$ |

Note: (1) AC power supply current above 5 MHz : $2 \mathrm{~mA} / \mathrm{MHz}$

## 28C64A DICE FORM

| READ OPERATION AC Characteristics | AC Testing Waveform: Output Load: Input Rise and Fall Times: Ambient Temperature: |  | ```VIH=2.4V; VIL =0.45V; VOH=2.0V; VOL = 0.8V 1 TTL Load + 100 pF 20 nsec Commercial: Tamb = 0 C to 70 C``` |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 28C64A-25 |  | Units | Conditions |
|  |  | Min | Max |  |  |
| Address to Output Delay | tACC |  | 250 | ns | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tCE |  | 250 | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | toe |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ High to Output Float | toFF | 0 | 70 | ns |  |
| Output Hold from Address, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever occurs first. | tor | 0 |  | ns |  |

## READ WAVEFORMS



Notes: (1) toff is specified for $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first
(2) $\overline{\mathrm{OE}}$ may be delayed up to tCE - tOE after the falling edge of $\overline{\mathrm{CE}}$ without impact on tCE
(3) This parameter is sampled and is not $100 \%$ tested

## 28C64A DICE FORM

| BYTE WRITE <br> AC Characteristics | AC Testing Waveform: Output Load: Input Rise/Fall Times: Ambient Temperature: |  | ```VIH =2.4V; VIL =0.45V; VOH =2.0V; VoL = 0.8V 1 TTL Load + 100 pF 20 nsec Commercial: Tamb = 0 C to 70 C``` |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-up Time | tAS | 50 |  | ns |  |
| Address Hold Time | taH | 100 |  | ns |  |
| Data Set-Up Time | tDS | 100 |  | ns |  |
| Data Hold Time | tDH | 50 |  | ns |  |
| Write Pulse Width | twPL | 100 |  | ns | Note 1 |
| Write Pulse High Time | tWPH | 50 |  | ns |  |
| $\overline{\text { OE Hold Time }}$ | tOEH | 10 |  | ns |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 10 |  | ns |  |
| Data Valid Time | tov | - | 1000 | ns | Note 2 |
| Time to Device Busy | tDB | - | 50 | ns |  |
| Write Cycle Time (28C64A) | twc | - | 1 | ms | 0.5 ms typical |
| Note: (1) A write cycle can be initiated $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$ going low, whichever occurs last. The data is latched on the positive edge of CE or WE, whichever occurs first. <br> (2) Data must be valid within 1000 ns max. after a write cycle is initiated and must be stable at least until tDH after the positive edge of WE or CE, whichever occurs first. |  |  |  |  |  |




CHIP CLEAR
Waveforms


SUPPLEMENTARY CONTROL

| Mode | $\overline{C E}$ | $\overline{\text { OE }}$ | WE | A9 | Vcc | I/OI |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Chip Clear | VIL | VH | VIL | X | Vcc |  |
| Extra Row Read | VIL | VIL | VIH | $\mathrm{A} 9=\mathrm{VH}$ | Vcc | Data Out |
| Extra Row Write | * | VIH | * | $\mathrm{A} 9=\mathrm{VH}$ | Vcc | Data In |
| Note: $\mathrm{VH}_{\mathrm{H}}=12.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$ * Pulsed per programming waveforms. |  |  |  |  |  |  |

## DEVICE OPERATION

The Microchip Technology Inc 28C64A has four basic modes of operation-read, standby, write inhibit, and byte write-as outlined in the following table.

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { WE }}$ | I/O | Rdy/Busy(1) |  |
| :--- | :---: | :---: | :--- | :--- | :--- | :---: |
| Read | L | L | H | Dout | H |  |
| Standby | H | X | X | High Z | H |  |
| Write Inhibit | H | X | X | High Z | H |  |
| Write Inhibit | X | L | X | High Z | H |  |
| Write Inhibit | X | X | H | High Z | H |  |
| Byte Write | L | H | L | Din | L |  |
|  |  |  |  |  |  |  |
| Byte Clear | Automatic Before Each "Write" |  |  |  |  |  |

Note: (1) Open drain output.
(2) $X=$ Any TTL level.

## Read Mode

The 28C64A has two control functions, both of which must be logically satisfied 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 (OE) is the output control and is used to gate data to the output pins independent of device selection. Assuming that addresses are stable, address access time (tACC) is equal to the delay from $\overline{C E}$ to output ( $\mathrm{t} C E$ ). Data is available at the output 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 tacc-toe.

## Standby Mode

The 28C64A is placed in the standby mode by applying a high signal to the $\overline{C E}$ input. When in the standby mode, the outputs are in a high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## Data Protection

In order to ensure data integrity, especially during critical power-up and power-down transitions, the following enhanced data protection circuits are incorporated:

First, an internal Vcc detect (3.3 volts typical) will inhibit the initiation of non-volatile programming operation when Vcc is less than the Vcc detect circuit trip.

Second, there is a $\overline{W E}$ filtering circuit that prevents $\overline{W E}$ pulses of less than 10ns duration from initiating a write cycle.

Third, holding $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CE}}$ high or $\overline{\mathrm{OE}}$ low, inhibits a write cycle during power-on and power-off (Vcc).

## Write Mode

The 28C64A has a write cycle similar to that of a Static RAM. The write cycle is completely self-timed and initiated by a low going pulse on the WE pin. On the falling edge of $\overline{W E}$, the address information is latched. On rising edge, the data and the control pins ( $\overline{C E}$ and $\overline{\mathrm{OE}}$ ) are latched. The Ready/Busy pin goes to a logic low level indicating that the 28C64A is in a write cycle which signals the microprocessor host that the system bus is free for other activity. When Ready/Busy goes back to a high, the 28C64A has completed writing and is ready to accept another cycle.

## Data Polling

The 28C64A features Data polling to signal the completion of a byte write cycle. During a write cycle, an attempted read of the last byte written results in the data complement of I/O7 (I/O0 to I/O6 are indeterminable). After completion of the write cycle, true data is available. $\overline{\text { Data }}$ polling allows a simple read/compare operation to determine the status of the chip eliminating the need for external hardware.

## Electronic Signature for Device Identification

An extra row of 32 bytes of EEPROM memory is available to the user for device identification. By raising A9 to $12 \mathrm{~V} \pm 0.5 \mathrm{~V}$ and using address locations 1 FEO to 1FFF, the additional bytes can be written to or read from in the same manner as the regular memory array.

## Optional Chip Clear

All data may be cleared to 1's in a chip clear cycle by raising $\overline{\mathrm{OE}}$ to 12 volts and bringing the $\overline{\mathrm{WE}}$ and $\overline{\mathrm{CE}}$ low. This procedure clears all data, except for the extra row.

NOTES:

## 28C64A dICE FORM

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## SECTION 3 EPROM PRODUCT SPECIFICATIONS

27C6464K (8K x 8) CMOS UV Erasable PROM3- 127C128 128K (16K x 8) CMOS UV Erasable PROM ..... 3- 9
27 C 256 256K (32K x 8) CMOS UV Erasable PROM ..... 3-17
27 C 512 512K ( $64 \mathrm{~K} \times 8$ ) CMOS UV Erasable PROM ..... 3- 25
27HC64 $64 \mathrm{~K}(8 \mathrm{~K} \times 8$ ) High Speed CMOS UV Erasable PROM ..... 3- 33
27HC256 256K (32K x 8) High Speed CMOS UV Erasable PROM ..... 3-41
27HC1616 256K (16K x 16) High Speed CMOS UV Erasable PROM ..... 3- 49
27HC641 64K (8K x 8) High Speed CMOS UV Erasable PROM ..... 3- 57
27Cxxx 27Cxxx EPROM Family Programming Algorithm ..... 3- 65

Microchip

## 64K (8K x 8) CMOS EPROM

## FEATURES

- High speed performance
-120ns maximum access time
- CMOS Technology for low power consumption
-20mA Active current
$-100 \mu \mathrm{~A}$ Standby current
- Factory programming available
- Auto-insertion-compatible plastic packages
- Auto $I \mathrm{D}^{\mathrm{TM}}$ aids automated programming
- Separate chip enable and output enable controls
- High speed "express" programming algorithm
- Organized $8 \mathrm{~K} \times 8$ : JEDEC standard pinouts
-28-pin Dual-in-line package
-32-pin Chip carrier (leadless or plastic)
-28-pin SOIC package
-Tape and reel
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
—Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
—Automotive: $-40^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
—Military** (B): $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc 27C64 is a CMOS 64K bit (electrically) Programmable Read Only Memory. The device is organized as 8 K words by 8 bits ( 8 K bytes). Accessing individual bytes from an address transition or from power-up (chip enable pin going low) is accomplished in less than 120 ns . This very high speed device allows the most sophisticated microprocessors to run at full speed without the need for WAIT states. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are requirements.

A complete family of packages is offered to provide the most flexibility in applications. For surface mount applications, PLCC or SOIC packaging is available. Tape and reel packaging is also available for PLCC or SOIC packages. U.V. erasable versions are also available.


[^1]
## PIN FUNCTION TABLE

| Name | Function |
| :--- | :--- |
| $\frac{\mathrm{AO}}{\mathrm{CE}}-\mathrm{A} 12$ | Address Inputs |
| $\frac{\mathrm{OE}}{\mathrm{OE}}$ | Chip Enable |
| VGM | Output Enable |
| OPP - O7 | Program Enable |
| Vcc | Data Output Voltage |
| Vss | +5V Power Supply |
| NC | Ground |
|  | No Connection; No Internal |
| NU | Connections |
|  | Not Used; No External |
|  | Connection Is Allowed |

## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Vcc and input voltages w.r.t. Vss .......... -0.6 V to +7.25 V
VPP voltage w.r.t. Vss during
programming $\qquad$ -0.6 V to +14 V
Voltage on A9 w.r.t. Vss . $\qquad$ .0 .6 V to +13.5 V
Output voltage w.r.t. Vss $\qquad$ -0.6 V to $\mathrm{Vcc}+1.0 \mathrm{~V}$
Storage temperature $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Ambient temp. with power applied $-65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
"Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ OPERATION DC Characteristics |  |  |  |  | Vcc $=$ Comm Indus Autor | $+5 \mathrm{~V} \pm$ <br> ercial: <br> rial: <br> otive: | ```0% Tamb= 00}\textrm{C}\mathrm{ to 70 Tamb= -40 C to 85 C Tamb= -40 C to 125 C``` |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | all | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.5 \\ \hline \end{array}$ | $\begin{gathered} \text { VCC }+1 \\ 0.8 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage | all |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | VIN $=0$ to Vcc |
| Output Voltages | all | Logic "1" Logic "0" | VOH <br> Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{lOH}=-400 \mu \mathrm{~A} \\ & \mathrm{lOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage | all |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | VOUT $=0 \mathrm{~V}$ to Vcc |
| Input Capacitance | all |  | CIN |  | 6 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | all |  | COUT |  | 12 | pF | $\begin{aligned} & \text { VoUT }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | $\begin{aligned} & \mathrm{S} \\ & \mathrm{X} \end{aligned}$ | TTL input TTL input | $\begin{aligned} & \hline \text { ICC1 } \\ & \text { ICC2 } \end{aligned}$ |  | $\begin{aligned} & 20 \\ & 25 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} ; \mathrm{VPP}=\mathrm{VCC} ; \\ & \mathrm{f}=1 \mathrm{MHz} ; \\ & \mathrm{OE}=\mathrm{CE}=\mathrm{VIL} ; \\ & \text { lout }=0 \mathrm{~mA} ; \\ & \mathrm{VIL}=-0.1 \text { to } 0.8 \mathrm{~V} ; \\ & \mathrm{VIH}=2.0 \text { to } \mathrm{VCC} ; \\ & \text { Note } 1 \\ & \hline \end{aligned}$ |
| Power Supply Current, Standby | S X all | TTL input. TTL input CMOS input | ICC(S) |  | $\begin{gathered} 2 \\ 3 \\ 100 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \end{aligned}$ | $\overline{\mathrm{CE}}=\mathrm{Vcc} \pm 0.2 \mathrm{~V}$ |
| IPP Read Current Vpp Read Voltage | all all | Read Mode Read Mode | $\begin{aligned} & \text { IPP } \\ & \text { VPP } \end{aligned}$ | Vcc-0.7 | $\begin{aligned} & 100 \\ & \mathrm{Vcc} \\ & \hline \end{aligned}$ | $\begin{gathered} \mu \mathrm{A} \\ \mathrm{~V} \\ \hline \end{gathered}$ | $\begin{aligned} & \hline \mathrm{VPP}=5.5 \mathrm{~V} \\ & \text { Note } 2 \end{aligned}$ |
| * Parts: $\quad S=$ Standard Power; $X=$ Extended Temp. Range; <br> Notes: (1) AC Power component above 1 MHz : 8 mA up to maximum frequency. <br> (2) Vcc must be applied before VPP, and be removed simultaneously or after VPP. |  |  |  |  |  |  |  |

## 27C64

| READ OPERATION AC Characteristics |  |  | AC Testing Waveform: Output Load: Input Rise and Fall Times: Ambient Temperature: |  |  |  |  | $\mathrm{VIH}=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V} \mathrm{VoL}=0.8 \mathrm{~V}$ <br> 1 TTL Load + 100 pF <br> 10nsec <br> Commercial: $\mathrm{Tamb}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> Industrial: $\quad$ Tamb $=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ <br> Automotive: $\mathrm{Tamb}=-40^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 27C64-12 |  | 27C64-15 |  | 27C64-17 |  |  | 27C64-20 |  |  | 27C64-25 |  | Units | Conditions |
|  |  | Min | Max | Min | Max | Min |  |  | Min |  |  | Min | Max |  |  |
| Address to Output Delay | tacc |  | 120 |  | 150 |  |  |  |  |  |  |  | 250 | ns | $\overline{C E}=\overline{O E}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tCE |  | 120 |  | 150 |  |  |  |  |  |  |  | 250 | ns | $\overline{O E}=\mathrm{VIL}$ |
| $\overline{\text { OE to Output Delay }}$ | toe |  | 65 |  | 70 |  |  |  |  |  |  |  | 100 | ns | $\overline{C E}=\mathrm{VIL}$ |
| $\overline{C E}$ or $\overline{O E}$ to O/P High Impedance | toff | 0 | 50 | 0 | 50 | 0 |  |  | 0 |  |  | 0 | 60 | ns |  |
| Output Hold from Address $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever occurs first | toh | 0 |  | 0 |  | 0 |  |  | 0 |  |  | 0 |  | ns |  |

## READ WAVEFORMS



Notes: (1) toff is specified for $\overline{O E}$ or $\overline{C E}$, whichever occurs first
(2) $\overline{O E}$ may be delayed up to $\operatorname{tCE}-$ - $O E$ after the falling edge of $\overline{C E}$ without impact on $\operatorname{CCE}$
(3) This parameter is sampled and is not $100 \%$ tested.

| PROGRAMMING <br> DC Characteristics | Ambient Temperature: $\operatorname{Tamb}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} 2.0 \\ -0.1 \end{gathered}$ | $\begin{gathered} \text { VCC }+1 \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output Voltages | Logic "1" <br> Logic "0" | VoH <br> Vol | 2.4 | 0.45 | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{IOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Vcc Current, program \& verify |  | ICC2 |  | 20 | mA | Note 1 |
| VPP Current, program |  | IPP2 |  | 25 | mA | Note 1 |
| A9 Product Identification |  | VH | 11.5 | 12.5 | $\checkmark$ |  |

Note: (1) Vcc must be applied simultaneously or before VPP and removed simultaneously or after VPP

| PROGRAMMING AC Characteristics for Program, Program Verify and Program Inhibit Modes | AC Testing Waveform: $\mathrm{VIH}=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V}$; $\mathrm{VOL}=0.8 \mathrm{~V}$ <br> Output Load: $\quad 1$ TTL Load +100 pF <br> Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ <br> $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tAS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Set-Up Time | tDS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Hold Time | tDH | 2 |  | $\mu \mathrm{s}$ |  |
| Address Hold Time | taH | 0 |  | $\mu \mathrm{s}$ |  |
| Float Delay (2) | tDF | 0 | 130 | ns |  |
| Vcc Set-Up Time | tvCs | 2 |  | $\mu \mathrm{s}$ |  |
| Program Pulse Width (1) | tPW | 95 | 105 | $\mu \mathrm{s}$ | 100 $\mu$ s typical |
| CE Set-Up Time | tCES | 2 |  | $\mu \mathrm{s}$ |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 2 |  | $\mu \mathrm{S}$ |  |
| VPP Set-Up Time | tVPS | 2 |  | $\mu \mathrm{S}$ |  |
| Data Valid from OE | toe |  | 100 | ns |  |
| Notes: (1) For express algorithm, initial programming width tolerance is $100 \mu \mathrm{sec} \pm 5 \%$. <br> (2) This parameter is only sampled and not $100 \%$ tested. Output float is defined as the point where data is no longer driven (see timing diagram). |  |  |  |  |  |

## PROGRAMMING

## Waveforms



Notes: (1) tDF and toe are characteristics of the device but must be accommodated by the programmer
(2) $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ for express algorithm

## MODES

| Operation Mode | $\overline{C E}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { PGM }}$ | Vpp | A9 | O0-07 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | VIL | VIL | VIH | Vcc | X | Dout |
| Program | VIL | VIH | VIL | VH | X | Din |
| Program Verify | VIL | VIL | VIH | VH | X | Dout |
| Program Inhibit | VIH | X | X | VH | X | High Z |
| Standby | VIH | X | X | Vcc | X | High Z |
| Output Disable | VIL | VIH | VIH | Vcc | X | High Z |
| Identity | VIL | VIL | VIH | Vcc | VH | Identity Code |

$X=$ Don't Care

Read Mode
(See Timing Diagrams and AC Characteristics)
Read Mode is accessed when
a) the $\overline{\mathrm{CE}}$ pin is low to power up (enable) the chip
b) the $\overline{\mathrm{OE}}$ pin is low to gate the data to the output pins.

For Read operations, if the addresses are stable, the address access time ( tACC ) is equal to the delay from $\overline{\mathrm{CE}}$ to output (tCE). Data is transferred to the output after a delay from the falling edge of $\overline{\mathrm{OE}}$ (tOE).

## Standby Mode

The standby mode is defined when the $\overline{\mathrm{CE}}$ pin is high (VIH) and a program mode is not defined.

When these condition are met, the supply current will drop from 20 mA to $100 \mu \mathrm{~A}$.

## Output Enable

This feature eliminates bus contention in multiple bus microprocessor systems and the outputs go to a high impedance when the following condition is true:

- The $\overline{\mathrm{OE}}$ pin is high and a program is not defined.


## Erase Mode (U.V. Windowed Versions)

Windowed products offer the ability to erase the memory array. The memory matrix is erased to the all 1's state as a result of being exposed to ultraviolet light. To ensure complete erasure, a dose of 15 watt-second $/ \mathrm{cm}^{2}$ is required. This means that the device window must be placed within one inch and directly underneath an ultraviolet lamp with a wavelength of 2537 Angstroms, intensity of $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ for approximately 20 minutes.

## Programming Mode

The express algorithm has been developed to improve on the programming throughput times in a production environment. Up to 10 100-microsecond pulses are applied until the byte is verified. No overprogramming is required. A flowchart of the express algorithm is shown in Figure 1.

Programming takes place when:
a) Vcc is brought to proper voltage,
b) VPP is brought to proper VH level,
c) the $\overline{\mathrm{CE}}$ pin is low,
d) the $\overline{O E}$ pin is high, and
e) the $\overline{\mathrm{PGM}}$ pin is low.

Since the erased state is " 1 " in the array, programming of " 0 " is required. The address to be programmed is set via pins A0-A12 and the data to be programmed is presented to pins O0-07. When data and address are stable, $\overline{\mathrm{OE}}$ is high, $\overline{\mathrm{CE}}$ is low and a low-going pulse on the $\overline{\mathrm{PGM}}$ line programs that location.

## Verify

After the array has been programmed it must be verified to ensure all the bits have been correctly programmed. This mode is entered when all the following conditions are met:
a) Vcc is at the proper level,
b) VPP is at the proper VH level,
c) the $\overline{\mathrm{CE}}$ line is low,
d) the PGM line is high, and
e) the $\overline{\mathrm{OE}}$ line is low.

## Inhibit

When programming multiple devices in parallel with different data, only $\overline{\mathrm{CE}}$ or $\overline{\mathrm{PGM}}$ need be under separate control to each device. By pulsing the $\overline{C E}$ or $\overline{P G M}$ line low on a particular device in conjunction with the $\overline{\mathrm{PGM}}$ or $\overline{\mathrm{CE}}$ line low, that device will be programmed; all other devices with $\overline{C E}$ or $\overline{P G M}$ held high will not be programmed with the data, although address and data will be available on their input pins (i.e., when a high level is present on $\overline{\mathrm{CE}}$ or $\overline{\mathrm{PGM}}$ ); and the device is inhibited from programming.

## Identity Mode

In this mode specific data is outputted which identifies the manufacturer as Microchip Technology Inc and device type. This mode is entered when Pin A9 is taken to VH ( 11.5 V to 12.5 V ). The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ lines must be at VIL. AO is used to access any of the two non-erasable bytes whose data appears on O0 through O 7.

| Pin $\longrightarrow$ | Input | Output |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Identity $\downarrow$ | AO | $\begin{aligned} & 0 \\ & 7 \end{aligned}$ | $\begin{aligned} & 0 \\ & 6 \end{aligned}$ | $\begin{aligned} & 0 \\ & 5 \end{aligned}$ | $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | $\begin{aligned} & 0 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 2 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | 0 | $H$ $e$ x |
| Manufacturer | VIL | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 |
| Device Type* | VIH | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 02 |

[^2]
## PROGRAMMING - FIGURE 1

## EXPRESS ALGORITHM

Conditions:
Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$
$\mathrm{VcC}=6.5 \pm 0.25 \mathrm{~V}$
$\mathrm{VPP}=13.0 \pm 0.25 \mathrm{~V}$


## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 128K (16K x 8) CMOS EPROM

## FEATURES

- High speed performance
-120ns Maximum access time
- CMOS Technology for low power consumption
-20mA Active current
- $100 \mu \mathrm{~A}$ Standby current
- Factory programming available
- Auto-insertion-compatible plastic packages
- Auto $I^{\text {TM }}$ aids automated programming
- Separate chip enable and output enable controls
- High speed "express" programming algorithm
- Organized 16K x 8: JEDEC standard pinouts
-28-pin Dual-in-line package
-32-pin Chip carrier (leadless or plastic)
-28-pin SOIC package
-Tape and reel
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
—Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
—Automotive: $-40^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
—Military** $(\mathrm{B}):-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc 27C128 is a CMOS 128K bit (electrically) Programmable Read Only Memory. The device is organized as 16 K words by 8 bits (16K bytes). Accessing individual bytes from an address transition or from power-up (chip enable pin going low) is accomplished in less than 120 ns . This very high speed device allows the most sophisticated microprocessors to run at full speed without the need for WAIT states. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are requirements.

A complete family of packages is offered to provide the most flexibility in applications. For surface mount applications, PLCC or SOIC packaging is available. Tape and reel packaging is also available for PLCC or SOIC packages. UV erasable versions are also available.

[^3]| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\mathrm{AO}-\mathrm{A} 13$ |  |
| CE | Address Inputs |
| OE | Chip Enable |
| PGM | Output Enable |
| VPP | Program Enable |
| $\mathrm{OO}-\mathrm{O7}$ | Programming Voltage |
| Vcc | Data Output |
| Vss | +5V Power Supply |
| NC | Ground |
| NU | No Connection; No |
|  | Internal Connections |
|  | Not Used; No External |
|  | Connection Is Allowed |

## ELECTRICAL CHARACTERISTICS Maximum Ratings*

Vcc and input voltages w.r.t. Vss .......... -0.6 V to +7.25 V
VPP voltage w.r.t. Vss during programming $\qquad$ -0.6 V to +14 V
Voltage on A9 w.r.t. Vss .......................... -0.6 V to +13.5 V
Output voltage w.r.t. Vss ..................... -0.6 V to $\mathrm{Vcc}+1 \mathrm{~V}$
Storage temperature $.65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ OPERATION DC Characteristics |  |  |  | $\begin{array}{ll} \text { VCC }=+5 \mathrm{~V} \pm 10 \% \\ \text { Commercial: } & \mathrm{Tamb}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \text { Industrial: } & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \\ \text { Automotive: } & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C} \end{array}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | all | Logic "1" <br> Logic "0" | $\mathrm{V}_{\mathrm{IH}}$ VIL | $\begin{array}{r} 2.0 \\ -0.5 \end{array}$ | $\begin{gathered} \text { VCc+1 } \\ 0.8 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage | all |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0$ to Vcc |
| Output Voltages | all | Logic "1" <br> Logic "0" | VoH Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{IOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage | all |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Input Capacitance | all |  | Cin |  | 6 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | all |  | COUT |  | 12 | pF | $\begin{aligned} & \text { VOUT }=0 \mathrm{~V} ; \mathrm{Tamb}=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | $\begin{aligned} & \mathrm{S} \\ & \mathrm{X} \end{aligned}$ | TTL input TTL input | $\begin{aligned} & \text { ICC1 } \\ & \text { ICC2 } \end{aligned}$ |  | $\begin{aligned} & 20 \\ & 25 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} ; \mathrm{VPP}=\mathrm{VCC} ; \\ & \mathrm{f}=1 \mathrm{MHZ} ; \\ & \mathrm{OE}=\overline{\mathrm{CE}}=\mathrm{VIL} ; \\ & \text { lout }=0 \mathrm{~mA} ; \\ & \mathrm{VIL}=-0.1 \text { to } 0.8 \mathrm{~V} ; \\ & \mathrm{VIH}=2.0 \text { to } \mathrm{VCC} ; \\ & \text { Note } 1 \\ & \hline \end{aligned}$ |
| Power Supply Current, Standby | $\mathrm{S}$ | TTL input TTL input CMOS input | ICC(S) |  | $\begin{gathered} 2 \\ 3 \\ 100 \end{gathered}$ | mA <br> mA <br> $\mu \mathrm{A}$ | $\overline{\mathrm{CE}}=\mathrm{Vcc} \pm 0.2 \mathrm{~V}$ |
| IPP Read Current Vpp Read Voltage | all | Read Mode Read Mode | $\begin{aligned} & \text { IPP } \\ & \text { VPP } \\ & \hline \end{aligned}$ | Vcc-0.7 | $\begin{aligned} & 100 \\ & \mathrm{Vcc} \end{aligned}$ | $\begin{gathered} \mu \mathrm{A} \\ \mathrm{~V} \end{gathered}$ | $\begin{aligned} & \hline \mathrm{VPP}=5.5 \mathrm{~V} \\ & \text { Note } 2 \end{aligned}$ |
| * Parts: $\quad S=$ Standard Power; $X=$ Extended Temp. Range; <br> Notes: (1) AC Power component above 1 MHz : 8 mA up to maximum frequency. <br> (2) Vcc must be applied before VPP, and be removed simultaneously or after VPP. |  |  |  |  |  |  |  |


| READ OPERATION AC Characteristics |  |  | AC Testing Waveform: <br> Output Load: Input Rise and Fall Times: Ambient Temperature: |  |  |  |  | ```VIH=2.4V and VIL = 0.45V; VOH=2.0V VOL =0.8V 1 TTL Load + 100pF 10nsec Commercial: Tamb = 00 C to 70 C Industrial: }\quad\mathrm{ Tamb =-40 C to 85 C Automotive: Tamb = 40 C to 125 C``` |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 27C128-12 |  | 27C128-15 |  | 27C128-17 |  | 27C128-20 |  | 27C128-25 |  | Units | Conditions |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | tacc |  | 120 |  | 150 |  | 170 |  | 200 |  | 250 | ns | $\overline{C E}=\overline{O E}=V_{I L}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tce |  | 120 |  | 150 |  | 170 |  | 200 |  | 250 | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | toe |  | 65 |  | 70 |  | 70 |  | 75 |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ to O/P High Impedance | tOFF | 0 | 50 | 0 | 50 | 0 | 50 | 0 | 55 | 0 | 60 | ns |  |
| Output Hold from Address $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever occurs first | tor | 0 |  | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |



| PROGRAMMING <br> DC Characteristics | Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $\mathrm{Vcc}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | VIH VIL | $\begin{gathered} 2.0 \\ -0.1 \end{gathered}$ | $\begin{gathered} \text { Vcc+1 } \\ 0.8 \end{gathered}$ | $\begin{aligned} & V \\ & V \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output Voltages | Logic "1" <br> Logic "0" | VOH VoL | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{IOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Vcc Current, program \& verify |  | IcC2 |  | 20 | mA | Note 1 |
| VPP Current, program |  | IPP2 |  | 25 | mA | Note 1 |
| A9 Product Identification |  | VH | 11.5 | 12.5 | V |  |

Note: (1) Vcc must be applied simultaneously or before VPP and removed simultaneously or after VPP

| PROGRAMMING AC Characteristics for Program, Program Verify and Program Inhibit Modes | AC Testing Waveform: $\mathrm{VIH}=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V}$; $\mathrm{VoL}=0.8 \mathrm{~V}$ <br> Output Load: $\quad 1$ TTL Load +100 pF <br> Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $\mathrm{VcC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tas | 2 |  | $\mu \mathrm{s}$ |  |
| Data Set-Up Time | tDS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Hold Time | tDH | 2 |  | $\mu \mathrm{s}$ |  |
| Address Hold Time | taH | 0 |  | $\mu \mathrm{s}$ |  |
| Float Delay (2) | tDF | 0 | 130 | ns |  |
| Vcc Set-Up Time | tvCs | 2 |  | $\mu \mathrm{s}$ |  |
| Program Pulse Width (1) | tPW | 95 | 105 | $\mu \mathrm{s}$ | $100 \mu$ s typical |
| $\overline{\mathrm{CE}}$ Set-Up Time | tCES | 2 |  | $\mu \mathrm{s}$ |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 2 |  | $\mu \mathrm{s}$ |  |
| Vpp Set-Up Time | tVPS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Valid from $\overline{\mathrm{OE}}$ | toe |  | 100 | ns |  |
| Notes: (1) For express algorithm, initial programming width tolerance is $100 \mu \mathrm{sec} \pm 5 \%$. <br> (2) This parameter is only sampled and not $100 \%$ tested. Output float is defined as the point where data is no longer driven (see timing diagram). |  |  |  |  |  |

## PROGRAMMING

## Waveforms



Notes: (1) tDF and toE are characteristics of the device but must be accommodated by the programmer (2) $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ for express algorithm

## MODES

| Operation Mode | $\overline{C E}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { PGM }}$ | VPP | A9 | O0-07 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | VIL | VIL | VIH | Vcc | X | Dout |
| Program | VIL | VIH | VIL | VH | X | Din |
| Program Verity | VIL | VIL | VIH | VH | X | Dout |
| Program Inhibit | VIH | X | X | VH | X | High Z |
| Standby | VIH | X | X | Vcc | X | High Z |
| Output Disable | VIL | VIH | VIH | Vcc | X | High Z |
| Identity | VIL | VIL | VIH | Vcc | VH | Identity Code |

X = Don't Care

## Read Mode

(See Timing Diagrams and AC Characteristics)
Read Mode is accessed when
a) the $\overline{\mathrm{CE}}$ pin is low to power up (enable) the chip
b) the $\overline{\mathrm{OE}}$ pin is low to gate the data to the output pins.

For Read operations, if the addresses are stable, the address access time ( tACC ) is equal to the delay from $\overline{\mathrm{CE}}$ to output (tCE). Data is transferred to the output after a delay from the falling edge of $\overline{O E}$ (toE).

## Standby Mode

The standby mode is defined when the $\overline{\mathrm{CE}}$ pin is high (VIH) and a program mode is not defined.

When these condition are met, the supply current will drop from 20 mA to $100 \mu \mathrm{~A}$.

## Output Enable

This feature eliminates bus contention in multiple bus microprocessor systems and the outputs go to a high impedance when the following condition is true:

- The $\overline{\mathrm{OE}}$ pin is high and a program is not defined.


## Erase Mode (U.V. Windowed Versions)

Windowed products offer the ability to erase the memory array. The memory matrix is erased to the all 1's state as a result of being exposed to ultraviolet light. To ensure complete erasure, a dose of 15 watt-second $/ \mathrm{cm}^{2}$ is required. This means that the device window must be placed within one inch and directly underneath an ultraviolet lamp with a wavelength of 2537 Angstroms, intensity of $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ for approximately 20 minutes.

## Programming Mode

The express algorithm has been developed to improve on the programming throughput times in a production environment. Up to 10100 -microsecond pulses are applied until the byte is verified. No overprogramming is required. A flowchart of the express algorithm is shown in Figure1.

Programming takes place when:
a) Vcc is brought to proper voltages,
b) VPP is brought to proper VH level,
c) the $\overline{C E}$ pin is low,
d) the $\overline{O E}$ pin is high, and
e) the $\overline{\mathrm{PGM}}$ pin is low.

Since the erased state is " 1 " in the array, programming of " 0 " is required. The address to be programmed is set via pins A0-A13 and the data to be programmed is presented to pins O0-O7. When data and address are stable, $\overline{\mathrm{CE}}$ is low and a low-going pulse on the $\overline{\mathrm{PGM}}$ line programs that location.

## Verify

After the array has been programmed it must be verified to ensure all the bits have been correctly programmed. This mode is entered when all the following conditions are met:
a) VCC is at the proper level,
b) VPP is at the proper VH fevel,
c) the $\overline{\mathrm{CE}}$ line is low,
d) the $\overline{\mathrm{PGM}}$ line is high, and
e) the $\overline{\mathrm{OE}}$ line is low.

## Inhibit

When programming multiple devices in parallel with different data, only $\overline{C E}$ or $\overline{P G M}$ need be under separate control to each device. By pulsing the $\overline{\mathrm{CE}}$ or $\overline{\mathrm{PGM}}$ line low on a particular device in conjunction with the $\overline{\mathrm{PGM}}$ or $\overline{\mathrm{CE}}$ line low, that device will be programmed; all other devices with $\overline{C E}$ or $\overline{P G M}$ held high will not be programmed with the data, although address and data will be available on their input pins (i.e., when a high level is present on $\overline{\mathrm{CE}}$ or $\overline{\mathrm{PGM}}$ ); and the device is inhibited from programming.

## Identity Mode

In this mode specific data is outputted which identifies the manufacturer as Microchip Technology Inc and device type. This mode is entered when Pin A9 is taken to $\mathrm{VH}(11.5 \mathrm{~V}$ to 12.5 V$)$. The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ lines must be at VIL. AO is used to access any of the two non-erasable bytes whose data appears on O 0 through O 7 .

| Pin $\longrightarrow$ | Input | Output |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Identity $\dagger$ | AO | $\begin{aligned} & 0 \\ & 7 \end{aligned}$ | $\begin{aligned} & 0 \\ & 6 \end{aligned}$ | $\begin{aligned} & 0 \\ & 5 \end{aligned}$ | $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | $\begin{aligned} & 0 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 2 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $H$ $e$ x |
| Manufacturer | VIL | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 |
| Device Type* | VIH | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 83 |

[^4]
## PROGRAMMING - FIGURE 1 EXPRESS ALGORITHM

Conditions:
Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$
$\mathrm{Vcc}=6.5 \pm 0.25 \mathrm{~V}$
$V P P=13.0 \pm 0.25 \mathrm{~V}$


## 27 C 128

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



Microchip

## 27C256

## 256K (32K x 8) CMOS EPROM

## FEATURES

- High speed performance
-120ns maximum access time
- CMOS Technology for low power consumption
-20mA Active current
- $100 \mu \mathrm{~A}$ Standby current
- Factory programming available
- Auto-insertion-compatible plastic packages
- Auto ID ${ }^{\text {TM }}$ aids automated programming
- Separate chip enable and output enable controls
- High speed "express" programming algorithm
- Organized $32 \mathrm{~K} \times 8$ : JEDEC standard pinouts
-28-pin Dual-in-line package
-32-pin Chip carrier (leadless or plastic)
-28-pin SOIC package
-Tape and reel
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
-Automotive: $-40^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
—Military** (B): $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc 27C256 is a CMOS 256K bit (electrically) Programmable Read Only Memory. The device is organized as 32 K words by 8 bits ( 32 K bytes). Accessing individual bytes from an address transition or from power-up (chip enable pin going low) is accomplished in less than 120 ns . This very high speed device allows the most sophisticated microprocessors to run at full speed without the need for WAIT states. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are requirements.

A complete family of packages is offered to provide the most flexibility in applications. For surface mount applications, PLCC or SOIC packaging is available. Tape and reel packaging is also available for PLCC or SOIC packages. UV erasable versions are also available.

[^5]| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{\text { AO }}{\mathrm{CE}}-\mathrm{A} 14$ | Address Inputs |
| $\underline{\mathrm{OE}}$ | Chip Enable |
| VPP | Output Enable |
| O0 - O7 | Programming Voltage |
| Vcc | Data Output |
| Vss | +5V Power Supply |
| NC | Ground |
|  | No Connection; |
| NU | No Internal Connection |
|  | Not Used; No External |
|  | Connection is Allowed |

## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Vcc and input voltages w.r.t. Vss.......... -0.6 V to +7.25 V
VPP voltage w.r.t. Vss during
programming
. V to +14.0 V
Voltage on A9 w.r.t. Vss .......................... -0.6 V to +13.5 V
Output voltage w.r.t. Vss .................-0.6V to Vcc +1.0 V
Storage temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ OPERATION DC Characteristics |  |  |  |  | $\begin{array}{ll} \text { Vcc }=+5 \mathrm{~V} \pm 10 \% \\ \text { Commercial: } & \text { Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \text { Industrial: } & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \\ \text { Automotive: } & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C} \end{array}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | all | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.5 \end{array}$ | $\begin{gathered} \text { Vcc+1 } \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage | all |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | VIN $=0$ to VCC |
| Output Voltages | all | Logic "1" Logic "0" | VOH <br> Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{lOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage | all |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | VOUT $=0 \mathrm{~V}$ to Vcc |
| Input Capacitance | all |  | CIN |  | 6 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | all |  | COUT |  | 12 | pF | $\begin{aligned} & \text { VOUT }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | $\begin{aligned} & \hline \mathrm{S} \\ & \mathrm{X} \end{aligned}$ | TTL input TTL input | $\begin{aligned} & \text { ICC1 } \\ & \text { ICC2 } \end{aligned}$ |  | $\begin{aligned} & 20 \\ & 25 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} ; \mathrm{VPP}=\mathrm{VCC} ; \\ & \mathrm{f}=1 \mathrm{MHz} ; \\ & \mathrm{OE}=\mathrm{CE}=\mathrm{VIL} ; \\ & \text { lout }=0 \mathrm{~mA} ; \\ & \mathrm{VIL}=-0.1 \text { to } 0.8 \mathrm{~V} ; \\ & \mathrm{VIH}=2.0 \text { to } \mathrm{VCC} ; \\ & \text { Note } 1 \\ & \hline \end{aligned}$ |
| Power Supply Current, Standby | S X all | TTL input TTL input • CMOS input | ICC(S) |  | $\begin{gathered} 2 \\ 3 \\ 100 \\ \hline \end{gathered}$ | mA <br> mA <br> $\mu \mathrm{A}$ | $\overline{\mathrm{CE}}=\mathrm{VCC} \pm 0.2 \mathrm{~V}$ |
| IPP Read Current Vpp Read Voltage | $\begin{aligned} & \text { all } \\ & \text { all } \end{aligned}$ | Read Mode Read Mode | $\begin{aligned} & \text { IPP } \\ & \text { VPP } \\ & \hline \end{aligned}$ | Vcc-0.7 | $\begin{aligned} & 100 \\ & \mathrm{Vcc} \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VPP }=5.5 \mathrm{~V} \\ & \text { Note } 2 \end{aligned}$ |
| * Parts: $\quad S=$ Standard Power; $X=$ Extended Temp. Range; <br> Notes: (1) AC Power component above 1 MHz : 5 mA up to maximum frequency. <br> (2) Vcc must be applied before VPP, and be removed simultaneously or after VPP. |  |  |  |  |  |  |  |


| READ OPERATION AC Characteristics |  |  | AC Testing Waveform: Output Load: Input Rise and Fall Times: Ambient Temperature: |  |  |  |  | $\mathrm{V} H=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V} \mathrm{VOL}=0.8 \mathrm{~V}$ <br> 1 TTL Load + 100pF <br> 10nsec <br> Commercial: Tamb $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> Industrial: $\quad$ Tamb $=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ <br> Automotive: $\mathrm{Tamb}=-40^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 27C2 | 56-12 | 27C2 | 6-15 | 27C2 | 56-17 | 27C2 | 56-20 | 27C2 | 56-25 | Units | Conditions |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | tacc |  | 120 |  | 150 |  | 170 |  | 200 |  | 250 | ns | $\overline{C E}=\overline{O E}=V_{L L}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | tCE |  | 120 |  | 150 |  | 170 |  | 200 |  | 250 | ns | $\overline{O E}=V_{\text {IL }}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | toe |  | 50 |  | 60 |  | 70 |  | 75 |  | 100 | ns | $\overline{C E}=V_{L L}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ to O/P High Impedance | toff | 0 | 35 | 0 | 50 | 0 | 50 | 0 | 55 | 0 | 60 | ns |  |
| Output Hold from Address $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever goes first | tor | 0 |  | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |

## READ WAVEFORMS



Notes: (1) toff is specified for $\overline{O E}$ or $\overline{C E}$, whichever occurs first
(2) $\overline{O E}$ may be delayed up to $C C E-$ TOE after the falling edge of $\overline{C E}$ without impact on tCE
(3) This parameter is sampled and is not $100 \%$ tested.

| PROGRAMMING DC Characteristics | Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $\mathrm{VcC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} 2.0 \\ -0.1 \end{gathered}$ | $\begin{gathered} \text { VCC }+1 \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to Vcc |
| Output Voltages | Logic "1" <br> Logic "0" | VOH Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{IOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Vcc Current, program \& verify |  | ICC2 |  | 20 | mA | Note 1 |
| VPP Current, program |  | IPP2 |  | 25 | mA | Note 1 |
| A9 Product Identification |  | VH | 11.5 | 12.5 | V |  |

Note: (1) VCC must be applied simultaneously or before VPP and removed simultaneously or after VPP

| PROGRAMMING AC Characteristics for Program, Program Verify and Program Inhibit Modes | AC Testing Waveform: VIH $=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V}$; VOL $=0.8 \mathrm{~V}$ <br> Output Load: $\quad 1$ TTL Load +100 pF <br> Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $\mathrm{VcC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tAS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Set-Up Time | tDS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Hold Time | tDH | 2 |  | $\mu \mathrm{s}$ |  |
| Address Hold Time | tAH | 0 |  | $\mu \mathrm{s}$ |  |
| Float Delay (2) | tDF | 0 | 130 | ns |  |
| Vcc Set-Up Time | tvCs | 2 |  | $\mu \mathrm{s}$ |  |
| Program Pulse Width (1) | tPW | 95 | 105 | $\mu \mathrm{s}$ | 100 $\mu$ s typical |
| $\overline{\text { CE Set-Up Time }}$ | tces | 2 |  | $\mu \mathrm{s}$ |  |
| $\overline{\mathrm{OE}}$ Set-Up Time | toes | 2 |  | $\mu \mathrm{s}$ |  |
| VPP Set-Up Time | tVPS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Valid from $\overline{\mathrm{OE}}$ | toe |  | 100 | ns |  |
| Notes: (1) For express algorithm, initial programming width tolerance is $100 \mu \mathrm{sec} \pm 5 \%$. <br> (2) This parameter is only sampled and not $100 \%$ tested. Output float is defined as the point where data is no longer driven (see timing diagram). |  |  |  |  |  |

## PROGRAMMING

## Waveforms



Notes: (1) tDF and toe are characteristics of the device but must be accommodated by the programmer
(2) $\mathrm{Vcc}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ for express algorithm

MODES

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}$ | VPP | A9 | O0 - O7 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Read | VIL | VIL | Vcc | X | Dout |
| Program | VIL | VIH | VH | X | DIN |
| Program Verify | VIH | VIL | VH | X | Dout |
| Program Inhibit | VIH | VIH | VH | X | High Z |
| Standby | VIH | X | VcC | X | High Z |
| Output Disable | VIL | VIH | Vcc | X | High Z |
| Identity | VIL | VIL | VCC | VH | Identity Code |

X = Don't Care

## Read Mode

(See Timing Diagrams and AC Characteristics)
Read Mode is accessed when
a) the $\overline{\mathrm{CE}}$ pin is low to power up (enable) the chip
b) the $\overline{\mathrm{OE}}$ pin is low to gate the data to the output pins.

For Read operations, if the addresses are stable, the address access time ( $\mathrm{t} A C C$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output (tCE). Data is transferred to the output after a delay from the falling edge of $\overline{\mathrm{OE}}$ (tOE).

## Standby Mode

The standby mode is defined when the $\overline{\mathrm{CE}}$ pin is high (VIH) and a program mode is not defined.

When these condition are met, the supply current will drop from 20 mA to $100 \mu \mathrm{~A}$.

## Output Enable

This feature eliminates bus contention in multiple bus microprocessor systems and the outputs go to a high impedance when the following condition is true:

- The $\overline{\mathrm{OE}}$ pin is high and a program is not defined.


## Erase Mode (U.V. Windowed Versions)

Windowed products offer the ability to erase the memory array. The memory matrix is erased to the all 1 's state as a result of being exposed to ultraviolet light. To ensure complete erasure, a dose of 15 watt-second $/ \mathrm{cm}^{2}$ is required. This means that the device window must be placed within one inch and directly underneath an ultraviolet lamp with a wavelength of 2537 Angstroms, intensity of $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ for approximately 20 minutes.

## Programming Mode

The express algorithm has been developed to improve on the programming throughput times in a production environment. Up to 10100 -microsecond pulses are applied until the byte is verified. No overprogramming is required. A flowchart of the express algorithm is shown in Figure 1.

Programming takes place when:
a) VCC is brought to proper voltage,
b) Vpp is brought to proper $\mathrm{VH}_{\mathrm{H}}$ level,
c) The $\overline{\mathrm{OE}}$ pin is high and
d) the $\overline{C E}$ pin is low.

Since the erased state is " 1 " in the array, programming of " 0 " is required. The address to be programmed is set via pins AO-A14 and the data to be programmed is presented to pins O0-07. When data and address are stable, a low-going pulse on the $\overline{\mathrm{CE}}$ line programs that location.

## Verify

After the array has been programmed it must be verified to ensure all the bits have been correctly programmed. This mode is entered when all the following conditions are met:
a) VCC is at the proper level,
b) VPP is at the proper VH level,
c) The $\overline{C E}$ pin is high and
d) the $\overline{\mathrm{OE}}$ line is low.

## Inhibit

When programming multiple devices in parallel with different data, only $\overline{\mathrm{CE}}$ need be under separate control to each device. By pulsing the $\overline{\mathrm{CE}}$ line low on a particular device, that device will be programmed; all other devices with $\overline{\mathrm{CE}}$ held high will not be programmed with the data, although address and data will be available on their input pins.

## Identity Mode

In this mode specific data is outputted which identifies the manufacturer as Microchip Technology Inc and device type. This mode is entered when Pin A9 is taken to $\mathrm{VH}(11.5 \mathrm{~V}$ to 12.5 V$)$. The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ lines must be at VIL. AO is used to access any of the two non-erasable bytes whose data appears on O 0 through O 7.

| Pin $\longrightarrow$ | Input | Output |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Identity $\square$ | A0 | $\begin{aligned} & 0 \\ & 7 \end{aligned}$ | $0$ | $\begin{aligned} & 0 \\ & 5 \end{aligned}$ | $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | $\begin{aligned} & 0 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 2 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $H$ $e$ X |
| Manufacturer | VIL | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 |
| Device Type* | VIH | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 8C |

[^6]
## PROGRAMMING - FIGURE 1 EXPRESS ALGORITHM

Conditions:
Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$
$V c c=6.5 \pm 0.25 \mathrm{~V}$
$\mathrm{VPP}=13.0 \pm 0.25 \mathrm{~V}$


## 27 C 256

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS

```
27C256-25 I/P
```



## 512K (64K x 8) CMOS EPROM

## FEATURES

- High speed performance -120ns access time available
- CMOS Technology for low power consumption
-35mA Active current
$-100 \mu \mathrm{~A}$ Standby current
- Factory programming available
- Auto-insertion-compatible plastic packages
- Auto $I D^{\mathrm{TM}}$ aids automated programming
- High speed "express" programming algorithm
- Organized 64K x 8: JEDEC standard pinouts -28-pin Dual-in-line package
-32-pin Chip carrier (leadless or plastic)
-28-pin SOIC package
-Tape and reel
- Available for extended temperature ranges:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
—Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
—Automotive: $-40^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
—Military** (B): $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc 27C512 is a CMOS 512 K bit (electrically) Programmable Read Only Memory. The device is organized into 64 K words by 8 bits ( 64 K bytes). Accessing individual bytes from an address transition or from power-up (chip enable pin going low) is accomplished in less than 120 ns. This very high speed device allows the most sophisticated microprocessors to run at full speed without the need for WAIT states. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are requirements.

A complete family of packages is offered to provide the most flexability in applications. For surface mount applications, PLCC or SOIC packaging is available. Tape or reel packaging is also available for PLCC or SOIC packages. U.V. erasable versions are also available.


[^7]
## PIN FUNCTION TABLE

| Name | Function |
| :--- | :--- |
| $\frac{\mathrm{AO}}{\mathrm{CE}}-\mathrm{A} 15$ | Address Inputs <br> Chip Enable <br> $\mathrm{OE} /$ VPP |
|  | Output Enable/ <br> Programming Voltage <br> Vcc O7 |
| Data Output |  |
| Vss | +5V Power Supply |
| NC | Ground |
| NU | No Connection; No Internal |
|  | Connection |
|  | Not Used; No External |
|  | Connection Is Allowed |

## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Vcc and input voltages w.r.t. Vss $\qquad$ 0.6 V to +7.25 V

VPP voltage w.r.t. Vss during programming $\qquad$ -0.6 V to +14.0 V
Voltage on A 9 w.r.t. Vss .......................... -0.6 V to +13.5 V
Output voltage w.r.t. Vss ................. -0.6 V to $\mathrm{Vcc}+1.0 \mathrm{~V}$
Storage temperature $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Ambient temp. with power applied ..... $-65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ OPERATION DC Characteristics |  |  |  |  | $\begin{array}{ll} \text { Vcc }=+5 \mathrm{~V} \pm 10 \% \\ \text { Commercial: } & \text { Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \text { Industrial: } & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \\ \text { Automotive: } & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C} \end{array}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | all | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.5 \\ \hline \end{array}$ | $\begin{gathered} V c c+1 \\ 0.8 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage | all |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0$ to Vcc |
| Output Voltages | all | Logic "1" <br> Logic "0" | VOH Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{lOH}=-400 \mu \mathrm{~A} \\ & \mathrm{lOL}=2.1 \mathrm{~mA} \end{aligned}$ |
| Output Leakage | all |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Input Capacitance | all |  | CIn |  | 6 | pF | $\begin{aligned} & \text { VIN }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | all |  | COUT |  | 12 | pF | $\begin{aligned} & \text { Vout }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | $\begin{aligned} & \mathrm{S} \\ & \mathrm{X} \end{aligned}$ | TTL input TTL input | $\begin{aligned} & \text { ICC } \\ & \text { ICC } \end{aligned}$ |  | $\begin{aligned} & 35 \\ & 45 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} ; \overline{\mathrm{OE} / \mathrm{VPP}=\overline{\mathrm{CE}}=\mathrm{VIL} ;} \\ & \text { lout }=0 \mathrm{~mA} ; \\ & \mathrm{VIL}=-0.1 \text { to } 0.8 \mathrm{~V} ; \\ & \mathrm{VIH}=2.0 \text { to } \mathrm{VCC} ; \end{aligned}$ |
| Power Supply Current, Standby | $\begin{aligned} & \mathrm{S} \\ & \mathrm{X} \\ & \mathrm{~S} \end{aligned}$ | TTL input TTL input CMOS input | $\operatorname{ICC}(\mathrm{S}) \mathrm{TtL}$ ICC(S)TTL IcC(S)cmos |  | $\begin{gathered} 2 \\ 3 \\ 100 \end{gathered}$ | mA <br> mA <br> $\mu \mathrm{A}$ | $\overline{\mathrm{CE}}=\mathrm{Vcc} \pm 0.2 \mathrm{~V}$ |
| * Parts: $\quad S=$ Standard Power; $X=$ Extended Temp. Range; <br> Notes: (1) AC Power component above 1 MHz : $2 \mathrm{~mA} / \mathrm{MHz}$. |  |  |  |  |  |  |  |


| READ OPERATION AC Characteristics |  |  | AC Testing Waveform: Output Load: Input Rise and Fall Times: Ambient Temperature: |  |  |  |  | ```VIH=2.4V and VIL=0.45V; VOH=2.0 V and VOL = 0.8V 1 TTL Load + 100pF 10nsec Commercial: Tamb = 0 C to 70 C Industrial: Tamb =-40 C to 85' C Automotive: Tamb = -40 C to 125 C``` |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Sym | 27C512-12* |  | 27C512-15 |  | 27C512-17 |  | 27C512-20 |  | 27C512-25 |  | Units | Conditions |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | tacc |  | 120 |  | 150 |  | 170 |  | 200 |  | 250 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}} / \mathrm{VPP}=\mathrm{VIL}$ |
| $\overline{\text { CEto Output Delay }}$ | tCE |  | 120 |  | 150 |  | 170 |  | 200 |  | 250 | ns | $\overline{O E} / \mathrm{VPP}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | toe |  | 65 |  | 70 |  | 70 |  | 75 |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output High Impedance | toFF | 0 | 50 | 0 | 50 | 0 | 50 | 0 | 55 | 0 | 60 | ns |  |
| Output Hold from Address, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}} / \mathrm{VPP}$, whichever occured first | toh | 0 |  | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |

READ WAVEFORMS


Notes: (1) tOFF is specified for $\overline{\mathrm{OE}} / \mathrm{VPP}$ or $\overline{\mathrm{CE}}$, whichever occurs first
(2) $\overline{\mathrm{OE}}$ may be delayed up to tCE - TOE after the falling edge of $\overline{\mathrm{CE}}$ without impact on tCE
(3) This parameter is sampled and is not $100 \%$ tested.

| PROGRAMMING <br> DC Characteristics | Status | Symbol | Min | Max | Units | Conditions (See Note 1) |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Logic "1" <br> Logic "0" | VIH <br> VIL | 2.0 <br> -0.1 | VCC +1 <br> 0.8 | V | V |

## PROGRAMMING AC Characteristics

for Program, Program Verify and Program Inhibit Modes

AC Testing Waveform: $\mathrm{VIH}=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V}$; $\mathrm{VOL}=0.8 \mathrm{~V}$ Output Load: $\quad 1$ TTL Load +100 pF
Ambient Temperature: $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$
$\mathrm{VcC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \overline{\mathrm{OE}} / \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$

| Parameter | Symbol | Min | Max | Units | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Address Set-Up Time | tAS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Set-Up Time | tDS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Hold Time | tDH | 2 |  | $\mu \mathrm{s}$ |  |
| Address Hold Time | tAH | 0 |  | $\mu \mathrm{s}$ |  |
| Float Delay (2) | tDF | 0 | 130 | ns |  |
| Vcc Set-Up Time | tvCs | 2 |  | $\mu \mathrm{s}$ |  |
| Program Pulse Width (1) | tPW | 95 | 105 | $\mu \mathrm{s}$ | 100 $\mu$ s typical |
| $\overline{\text { CE Set-Up Time }}$ | tces | 2 |  | $\mu \mathrm{s}$ |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 2 |  | $\mu \mathrm{s}$ |  |
| OE Hold Time | toen | 2 |  | $\mu \mathrm{s}$ |  |
| $\overline{\text { OE Recovery Time }}$ | tor | 2 |  | $\mu \mathrm{S}$ |  |
| $\overline{\text { OE/VPP Rise Time During Programming }}$ | tPRT | 50 |  | ns |  |

Notes: (1) For express algorithm, initial programming width tolerance is $100 \mu \mathrm{sec} \pm 5 \%$.
(2) This parameter is only sampled and not $100 \%$ tested. Output float is defined as the point where data is no longer driven (see timing diagram).

## PROGRAMMING

## Waveforms



Notes: (1) tDF and IOE are characteristics of the device but must be accommodated by the programmer
(2) $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ for express algorithm

## MODES

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE} / \mathrm{VPP}}$ | A9 | O0 - O7 |
| :--- | :--- | :--- | :--- | :--- |
| Read | VIL | VIL | X | DouT |
| Program | VIL | VH | X | DIN |
| Program Verify | VIL | VIL | X | DouT |
| Program Inhibit | VIH | VH | X | High Z |
| Standby | VIH | X | X | High Z |
| Output Disable | VIL | VIH | X | High Z |
| Identity | VIL | VIL | VH | Identity Code |

X = Don't Care

## Read Mode

(See Timing Diagrams and AC Characteristics)
Read Mode is accessed when
a) the $\overline{C E}$ pin is low to power up (enable) the chip
b) the $\overline{\mathrm{OE}}$ /VPP pin is low to gate the data to the output pins.

For Read operations, if the addresses are stable, the address access time ( $\mathrm{A} A C \mathrm{C}$ ) is equal to the delay from CE to output (tCE). Data is transferred to the output after a delay (toE) from the falling edge of $\overline{\mathrm{OE}} / \mathrm{VPP}$.

## Standby Mode

The standby mode is defined when the $\overline{\mathrm{CE}}$ pin is high and a program mode is not identified.

When this condition is met, the supply current will drop from 35 mA to $100 \mu \mathrm{~A}$.

## Output Enable $\overline{\mathbf{O E}} / \mathrm{VPP}$

This multifunction pin eliminates bus connection in multiple bus microprcessor systems and the outputs go to high impedance when:

$$
\text { - the } \overline{\mathrm{OE}} / \mathrm{VPP} \text { pin is high }(\mathrm{VIH}) \text {. }
$$

When a VH input is applied to this pin, it supplies the programming voltage (VPP) to the device.

## Erase Mode (U.V. Windowed Versions)

Windowed products offer the ability to erase the memory array. The memory matrix is erased to the all " 1 "'s state as a result of being exposed to ultraviolet light. To ensure complete erasure, a dose of 15 watt-second $/ \mathrm{cm}^{2}$ is required. This means that the device window must be placed within one inch and directly underneath an ultraviolet lamp with a wavelength of 2537 Angstroms, intensity of $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ for approximately 20 minutes.

## Programming Mode

The express algorithm has been developed to improve on the programming throughput times in a production environment. Up to 10 100-microsecond pulses are applied until the byte is verified. No overprogramming is required. A flowchart of the express algorithm is shown in Figure 1.

Programming takes place when:
a) Vcc is brought to the proper voltage,
b) $\overline{\mathrm{EE}} / \mathrm{VPP}$ is brought to the proper VH level, and
c) $\overline{\mathrm{CE}}$ line is low.

Since the erased state is " 1 " in the array, programming of " 0 " is required. The address to be programmed is set via pins A0 - A15 and the data to be programmed is presented to pins O0-O7. When data and address are stable, a low going pulse on the $\overline{\mathrm{CE}}$ line programs that location.

## Verify

After the array has been programmed it must be verified to ensure all the bits have been correctly programmed. This mode is entered when all the following conditions are met:
a) Vcc is at the proper level,
b) the OE/VPP pin is low, and
c) the $\overline{C E}$ line is low.

## Inhibit

When programming multiple devices in parallel with different data, only $\overline{\mathrm{CE}}$ needs to be under separate control to each device. By pulsing the $\overline{\mathrm{CE}}$ line low on a particular device, that device will be programmed; all other devices with $\overline{\mathrm{CE}}$ held high will not be programmed with the data (although address and data will be available on their input pins).

## Identity Mode

In this mode specific data is output which identifies the manufacturer as Microchip Technology Inc and the device type. This mode is entered when Pin A9 is taken to $\mathrm{VH}(11.5 \mathrm{~V}$ to 12.5 V$)$. The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}} / \mathrm{VPP}$ lines must be at VIL. AO is used to access any of the two nonerasable bytes whose data appears on O 0 through O 7.

| Pin $\longrightarrow$ | Input | Output |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Identity | A0 | $\begin{aligned} & 0 \\ & 7 \end{aligned}$ | $\begin{aligned} & 0 \\ & 6 \end{aligned}$ | $\begin{aligned} & 0 \\ & 5 \end{aligned}$ | $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | $\begin{aligned} & 0 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 2 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $H$ $e$ x |
| Manufacturer | VIL | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 |
| Device Type* | VIH | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0D |

* Code subject to change.


## PROGRAMMING - FIGURE 1 EXPRESS ALGORITHM

Conditions:
Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $\mathrm{Vcc}=6.5 \pm 0.25 \mathrm{~V}$
$\overline{\mathrm{OE}} / \mathrm{VPP}=13.0 \pm 0.25 \mathrm{~V}$


## $27 C 512$

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS

| 27C512 |
| :---: | :---: | :---: | :--- |

# 64K (8K x 8) High Speed CMOS UV Erasable PROM 

## FEATURES

- Bipolar Performance
- 40ns Maximum Access Time
- CMOS Technology For Low Power Consumption
- 80mA Active Current
- 100 A A Standby Current (Low Power Option)
- OTP (One Time Programming) Available
- Auto-Insertion-Compatible Plastic Packages
- Auto ID ${ }^{\text {тм }}$ Aids Automated Programming
- Separate Chip Enable and Output Enable Controls
- Two Programming Algorithms Allow Improved Programming Times
— Fast Programming
- Express
- Organized 8K x 8: JEDEC Standard Pinouts
- 28 Pin Dual in Line Package
- 32 Pin Chip Carrier (Leadless or Plastic)
- Available for Extended Temperature Ranges:
- Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
- Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
—Military**: $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc 27HC64 is a CMOS 64K bit ultraviolet light Erasable (electrically) Programmable Read Only Memory. The device is organized as 8 K words by 8 bits ( 8 K bytes). An advanced CMOS design allows bipolar speed with a significant reduction in power over bipolar PROMs. A low power option (L) allows further standby power reduction to $100 \mu \mathrm{~A}$. The 27HC64 is configured in a standard 64 K EPROM pinout, which allows an easy upgrade for 27C64 sockets. This very high speed device allows digital signal processors (DSP) or other sophisticated microprocessors to run at full speed without the need for WAIT states. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are requirements.

A complete family of packages is offered to provide the most flexibility in applications. One Time Programming (OTP) is available for low cost (plastic) applications.


[^8]| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{\mathrm{AO}-\mathrm{A} 12}{\mathrm{CE}}$ | Address Inputs |
| $\overline{\mathrm{OE}}$ | Chip Enable |
| PGM | Output Enable |
| VPP | Program Enable |
| $\mathrm{OO}-\mathrm{O} 7$ | Programming Voltage |
| VCC | Data Output |
| Vss | +5V Power Supply |
| NC | Ground |
|  | No Connection; No |
| NU | Internal Connection |
|  | Not Used; No External |
|  | Connection Is |
|  | Allowed |

## ELECTRICAL CHARACTERISTICS Maximum Ratings*

Vcc and input voltages w.r.t. Vss...- -0.6 V to +7.25 V
Vpp voltage w.r.t. Vss during programming ............................. -0.6 V to +14 V
Voltage on A 9 w.r.t. Vss ................. -0.6 V to +13.5 V
Output voltage w.r.t. Vss................ -0.6 V to $\mathrm{Vcc}+1.0 \mathrm{~V}$
Storage temperature .................... $65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Ambient temp. with power applied $-65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ ESD protection on all pins .............2KV
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ OPERATION DC Characteristics |  |  |  |  | Vcc | $=+5 \mathrm{~V} \pm$ <br> mercial strial: | $10 \%$ <br> Tamb $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> Tamb $=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | all | Logic "1" <br> Logic "0" | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{VIL}^{2} \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{Vcc+1} \\ & 0.8 \end{aligned}$ | $\begin{array}{\|l\|} \hline \mathrm{V} \\ \mathrm{~V} \end{array}$ |  |
| Input Leakage | all |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0$ to VCC |
| Output Voltages | all | Logic "1" <br> Logic "0" | Voh Vol | 2.4 | 0.45 | $\begin{array}{\|l\|} \mathrm{V} \\ \mathrm{v} \end{array}$ | $\begin{aligned} \mathrm{IOH} & =-4 \mathrm{~mA} \\ \mathrm{CL} & =16 \mathrm{~mA} \end{aligned}$ |
| Leakage | all |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | VOUT $=0 \mathrm{~V}$ to Vcc |
| Input Capacitance | all |  | Cln |  | 6 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | all |  | Cout |  | 12 | pF | $\begin{aligned} & \text { VOUT }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | $\begin{aligned} & \mathrm{S}, \mathrm{~L} \\ & \text { SX,LX } \end{aligned}$ | TTL input TTL input | $\begin{aligned} & \text { ICC1 } \\ & \text { lca } \end{aligned}$ |  | $\begin{aligned} & 80 \\ & 90 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{array}{\|l} \hline \mathrm{VCC}=5.5 \mathrm{~V} ; \mathrm{VPP}=\mathrm{VCC} \\ \mathrm{f}=2 \mathrm{MHz} ; \\ \mathrm{OE}=\overline{\mathrm{CE}}=\mathrm{VIL} ; \\ \text { lout }=0 \mathrm{~mA} ; \\ \mathrm{VIL}=-0.1 \text { to } 0.8 \mathrm{~V} ; \\ \mathrm{VIH}=2.0 \text { to VCC; } \\ \text { Note } 1 \\ \hline \end{array}$ |
| Power Supply Current, Standby | $\begin{aligned} & \hline S \\ & S X \end{aligned}$ |  | $\operatorname{ICC}(\mathrm{s}) 1$ |  | $\begin{aligned} & 40 \\ & 50 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| Power Supply Current, Standby | $\begin{aligned} & \hline L X \\ & L, L X \\ & \hline \end{aligned}$ | TTL input TTL input CMOS input | $\operatorname{lcc(s)2}$ |  | $\begin{aligned} & \hline 2 \\ & 3 \\ & 100 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \end{aligned}$ | $\overline{\mathrm{CE}}=\mathrm{Vcc} \pm 0.2 \mathrm{~V}$ |
| IPP Read Current Vpp Read Voltage | $\begin{array}{\|l\|l} \hline \text { all } \\ \text { all } \end{array}$ | Read Mode Read Mode | $\begin{aligned} & \text { IPP } \\ & \text { VPP } \end{aligned}$ | $\begin{aligned} & \text { Vcc- } \\ & 0.7 \\ & \hline \end{aligned}$ | $\begin{aligned} & 100 \\ & \mathrm{Vcc} \end{aligned}$ | $\begin{array}{\|c\|} \mu \mathrm{V} \\ \hline \end{array}$ | $\mathrm{VPP}=5.5 \mathrm{~V}$ <br> Note 2 |
| * Parts: $\quad S=$ Standard Power; L = Low Power; $X=$ Industrial Temp Range; <br> Notes: (1) AC Power component above $2 \mathrm{MHz}: 3 \mathrm{~mA} / \mathrm{MHz}$ for standard part; 5 mAMHz for industrial temperature range part. <br> (2) Vcc must be applied before (or simultaneously with VPP), and be removed after (or simultaneously with) VPP. |  |  |  |  |  |  |  |


| READ OPERATION <br> AC Characteristics |  | AC Testing Waveform: Output Load: Input Rise and Fall Times: Ambient Temperature: |  |  |  |  | $\begin{aligned} & \mathrm{VIH}=3.0 \mathrm{~V} \text { and } \mathrm{VIL}=0.0 \mathrm{~V} ; \mathrm{VOH}=\mathrm{VOL}=1.5 \mathrm{~V} \\ & 1 \mathrm{TTL} \text { Load }+30 \mathrm{pF} \\ & 5 \mathrm{nsec} \\ & \text { Commercial: Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \text { Industrial: Tamb }=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Sym | 27HC64-40 |  | 27HC64-45 |  | 27HC64-55 |  | 27HC64-70 |  | Units | Conditions |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | all | tacc |  | 40 |  | 45 |  | 55 |  | 70 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | $\begin{aligned} & L \\ & S \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline \text { tCE1 } \\ \text { tCE2 } \\ \hline \end{array}$ |  | $\begin{aligned} & 40 \\ & 30 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 45 \\ & 30 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 55 \\ & 35 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 70 \\ & 45 \\ & \hline \end{aligned}$ | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | all | toe |  | 25 |  | 25 |  | 25 |  | 25 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{C E}$ or $\overline{O E}$ to O/P High Impedance | all | tofF | 0 | 20 | 0 | 20 | 0 | 20 | 0 | 25 | ns |  |
| Output Hold from Address $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, whichever goes first | all | tor | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |
| * Parts: S = Standard Power; L = Low Power <br> ** 27HC64-40 is only available in commercial temperature range |  |  |  |  |  |  |  |  |  |  |  |  |

## READ WAVEFORMS



Notes: (1) toff is specified for $\overline{O E}$ or $\overline{C E}$, whichever occurs first
(2) $\overline{\mathrm{OE}}$ may be delayed up to CCE - toE after the falling edge of $\overline{\mathrm{CE}}$ without impact on TCE
(3) This parameter is sampled and is not $100 \%$ tested.

| PROGRAMMING <br> DC Characteristics | Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ For VPP and Vcc Voltages refer to Programming Algorithms |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | VIH VIL. | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{gathered} \text { Vcc+1 } \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=\mathrm{OV}$ to Vcc |
| Output Voltages | Logic "1" <br> Logic "0" | VOH Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-4 \mathrm{~mA} \\ & \mathrm{IOL}=16 \mathrm{~mA} \end{aligned}$ |
| Vcc Current, program \& verify |  | ICC |  | 80 | mA | Note 1 |
| VPP Current, program |  | IPP |  | 40 | mA | Note 1 |
| A9 Product Identification |  | VH | 11.5 | 12.5 | V |  |

Note: (1) VcC must be applied simultaneously or before VPP and removed simultaneously or after VPP

| PROGRAMMING AC Characteristics for Program, Program Verify and Program Inhibit Modes | AC Testing Waveform: $\mathrm{VIH}=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V}$; $\mathrm{VOL}=0.8 \mathrm{~V}$ <br> Output Load: $\quad 1$ TTL Load +100 pF <br> Ambient Temperature: $\mathrm{Tamb}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ <br> For VPP and Vcc Voltages, refer to Programming Algorithms |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tAS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Set-Up Time | tos | 2 |  | $\mu \mathrm{s}$ |  |
| Data Hold Time | to H | 2 |  | $\mu \mathrm{s}$ |  |
| Address Hold Time | taH | 0 |  | $\mu \mathrm{s}$ |  |
| Float Delay (3) | tof | 0 | 130 | ns |  |
| Vcc Set-Up Time | tvcs | 2 |  | $\mu \mathrm{s}$ |  |
| Program Pulse Width (1) | tPW | 0.95 | 1.05 | ms | 1 ms typical |
| Program Pulse Width (1) | tpw | 95 | 105 | $\mu \mathrm{s}$ | $100 \mu$ stypical |
| $\overline{\text { CE Set-Up Time }}$ | tces | 2 |  | $\mu \mathrm{s}$ |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 2 |  | $\mu \mathrm{s}$ |  |
| Vpp Set-Up Time | tvPs | 2 |  | $\mu \mathrm{s}$ |  |
| Overprogram Pulse Width (2) | topw | 2.85 | 78.75 | ms |  |
| Data Valid from $\overline{\mathrm{OE}}$ | toe |  | 100 | ns |  |
| Notes: (1) For Express algorithm, initial programming width tolerance is $100 \mu \mathrm{sec} \pm 5 \%$. For fast programming algorithm, initial program pulse width tolerance is $1 \mathrm{msec} \pm 5 \%$. <br> (2) For fast programming algorithm, the length of the overprogram pulse may vary from 2.85 to 78.75 msec as a function of the iteration counter value. <br> (3) This parameter is only sampled and not $100 \%$ tested. Output float is defined as the point where data is no longer driven (see timing diagram). |  |  |  |  |  |



## MODES

| Operation Mode | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{OE}}$ | $\overline{\text { PGM }}$ | VPP | A9 | O0-07 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | VIL | VIL | VIH | Vcc | X | Dout |
| Program | VIL | VIH | VIL | Vh | X | Din |
| Program Verify | VIL | VIL | VIH | VH | X | Dout |
| Program Inhibit | VIH | X | X | VH | X | High Z |
| Standby | VIH | X | X | Vcc | X | High Z |
| Output Disable | VIL | VIH | VIH | Vcc | X | High Z |
| Identity | VIL | VIL | VIH | Vcc | VH | Identity Code |

X = Don't Care

Read Mode
(See Timing Diagrams and AC Characteristics)
Read Mode is accessed when
a) the $\overline{\mathrm{CE}}$ pin is low to power up (enable) the chip
b) the $\overline{\mathrm{OE}}$ pin is low to gate the data to the output pins.

For Read operations on the low powered version, if the addresses are stable, the address access time ( $\mathrm{t} A \mathrm{CC}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output (tCE). A faster $\overline{\mathrm{CE}}$ access time (tCE) is available on the standard part to provide the additional time for decoding of the $\overline{\mathrm{CE}}$ signal. Data is transferred to the output after a delay from the falling edge of $\overline{\mathrm{OE}}$ (tOE).

## 27HC64

## Standby Mode

The standby mode is defined when the $\overline{\mathrm{CE}}$ pin is high (VIH).

When this condition is met, the supply current will drop from 80 mA to $100 \mu \mathrm{~A}$ on the low power part and to 40 mA on the standard part.

## Output Enable

This feature eliminates bus contention in multipie bus microprocessor systems and the outputs go to a high impedance when

- The $\overline{\mathrm{OE}}$ pin is high and a program is not defined.


## Erase Mode

Windowed products offer the ability to erase the memory array. The memory matrix is erased to the all 1 's state as a result of being exposed to ultraviolet light. To ensure complete erasure, a dose of 15 watt-second $/ \mathrm{cm}^{2}$ is required. This means that the device window must be placed within one inch and directly underneath an ultraviolet lamp with a wavelength of 2537 Angstroms, intensity of $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ for 20 minutes.

## Programming Mode

Two programming algorithms are available. The fast programming algorithm is the industry-standard programming mode that requires both initial programming pulses and overprogramming pulses. A flowchart of the fast programming algorithm is shown in Figure 1.

The Express algorithm has been developed to improve on the programming throughput times in a production environment. Up to 10100 -microsecond pulses are applied until the byte is verified. No overprogramming is required. A flowchart of the Express algorithm is shown in Figure 2.

Programming takes place when:
a) VCC is brought to proper voltage,
b) Vpp is brought to proper VH level,
c) the $\overline{\mathrm{CE}}$ pin is low,
d) the $\overline{O E}$ pin is high, and
e) the $\overline{\text { PGM }}$ pin is low.

Since the erased state is " 1 " in the array, programming of " 0 " is required. The address to be programmed is set via pins A0-A12 and the data to be programmed is presented to pins O0-O7. When data and address are stable, $\overline{\mathrm{OE}}$ is high, $\overline{\mathrm{CE}}$ is low and a low-going pulse on the $\overline{\mathrm{PGM}}$ line programs that location.

## Verify

After the array has been programmed it must be verified to ensure all the bits have been correctly programmed. This mode is entered when all the following conditions are met:
a) VCC is at the proper level,
b) VPP is at the proper VH level,
c) the $\overline{\mathrm{CE}}$ line is low,
d) the $\overline{\mathrm{PGM}}$ line is high, and
e) the $\overline{\mathrm{OE}}$ line is low.

Inhibit

When programming multiple devices in paraliei wititi different data, only $\overline{\mathrm{CE}}$ need be under separate control to each device. By pulsing the $\overline{C E}$ line low on a particular device in conjunction with the $\overline{\text { PGM }}$ line low, that device will be programmed; all other devices with $\overline{\mathrm{CE}}$ held high will not be programmed with the data, although address and data will be available on their input pins (i.e., when a high level is present on $\overline{\mathrm{CE}}$ or $\overline{\mathrm{PGM}}$ ); and the device is inhibited from programming.

## Identity Mode

In this mode specific data is outputted which identifies the manufacturer as Microchip Technology Inc., and device type. This mode is entered when Pin A9 is taken to $\mathrm{VH}(11.5 \mathrm{~V}$ to 12.5 V$)$. The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ lines must be at VIL. AO is used to access any of the two non-erasable bytes whose data appears on O 0 through O 7.

| Pin $\longrightarrow$ | Input | Output |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Identity | AO | $\begin{aligned} & 0 \\ & 7 \end{aligned}$ | $\begin{aligned} & 0 \\ & 6 \end{aligned}$ | $\begin{aligned} & 0 \\ & 5 \end{aligned}$ | $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | $\begin{aligned} & 0 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 2 \end{aligned}$ | $0$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $H$ $e$ X |
| Manufacturer | VIL | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 |
| Device Type* | VIH | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 91 |

* Code subject to change.


## PROGRAMMING - FIGURE 1

## EXPRESS ALGORITHM

Conditions:
Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $\mathrm{VcC}=6.5 \pm 0.25 \mathrm{~V}$ $V P P=13.0 \pm 0.25 \mathrm{~V}$

Start
$\downarrow$
ADDR $=$ First Location
$\mathrm{VcC}=6.5 \mathrm{~V}$
$\mathrm{VPP}=13.0 \mathrm{~V}$


## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

```
PART NUMBERS
```



## 256K (32K x 8) High Speed CMOS EPROM

## FEATURES

- High speed performance
-55ns access time available
- CMOS technology for low power consumption
-55mA active current
$-100 \mu \mathrm{~A}$ standby current (low power option)
- OTP (one time programming) available
- Auto-insertion-compatible plastic packages
- Auto ID ${ }^{\text {TM }}$ aids automated programming
- Organized in $32 \mathrm{~K} \times 8$ - JEDEC Standard Pinouts
-28-pin Dual-in-line and SOIC package
-32-pin Chip carrier (leadless or plastic)
- Extended temperature ranges available:
-Commercial: $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
-Industrial: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
—Automotive: $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
—Military**: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


## DESCRIPTION

The Microchip Technology Inc 27 HC 256 is a CMOS 256 K bit (electrically) Programmable Read Only Memory. The device is organized into 32 K words of 8 bit each. Advanced CMOS technology allows bipolar speed with a significant reduction in power. A low power option (L) allows further reduction in the standby power requirement to $100 \mu \mathrm{~A}$. The 27 HC 256 is configured in a standard 256K EPROM pinout which allows an easy upgrade for present 27C256 users. A complete family of packages are offered to provide the utmost flexibility. The 27 HC 256 allows high performance microprocessors to run at full speed without the need of wait states. CMOS design and processing makes this part suitable for applications where reliability and reduced power consumption are essential.


[^9]| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{A O}{C E}-$ A14 | Address Inputs |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| VPP | Output Enable |
| OO -O7 | Drogramming Voltage Output |
| Vcc | +5 V |
| Vss | Ground |
| NC | No Connection; No Internal Connection |
| NU | Not Used; No External Connection Is |
|  | Allowed |

## ELECTRICAL CHARACTERISTICS Maximum Ratings*

Vcc and input voltages w.r.t. Vss .......... -0.6 V to +7.25 V
VPP voltage w.r.t. Vss during programming $\qquad$ .-0.6 V to +14 V
Voltage on A9 w.r.t. Vss -0.6 V to +13.5 V
Output voltage w.r.t. Vss ...................-0.6V to Vcc +1.0 V
Temperature under bias ..................... $65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Storage temperature ..........................-65 C to $150^{\circ} \mathrm{C}$
Maximum exposure to UV .................... $7258 \mathrm{Wsec} / \mathrm{cm}^{2}$
ESD protection on all pins ..................................2.0kV
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ OPERATION DC Characteristics | $\mathrm{Vcc}=+5 \mathrm{~V} \pm 10 \%$ |  |  |  | Commercial: Industrial: Automotive: |  | $\begin{aligned} & \text { Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \\ & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | all | $\begin{aligned} & \text { Logic "1" } \\ & \text { Logic "0" } \end{aligned}$ | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \\ \hline \end{array}$ | $\begin{gathered} \mathrm{Vcc}+1 \\ 0.8 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage | all |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-0.1 \mathrm{~V}$ to Vcc +1.0 V |
| Output Voltages | all | $\begin{aligned} & \text { Logic "1" } \\ & \text { Loaic "0" } \end{aligned}$ | VOH Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{OH}=-4 \mathrm{~mA} \\ & \mathrm{IOL}=16 \mathrm{~mA} \end{aligned}$ |
| Output Leakage | all |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \text { VOUT }=-0.1 \mathrm{~V} \text { to } \\ & \mathrm{VCC}+0.1 \mathrm{~V} \end{aligned}$ |
| Input Capacitance | all |  | CIN |  | 6 | pF | $\begin{aligned} & \text { VIN }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | all |  | COUT |  | 12 | pF | $\begin{aligned} & \text { VouT }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | $\begin{gathered} \mathrm{S}, \mathrm{~L} \\ \mathrm{X} \end{gathered}$ | TTL input TTL input | $\begin{aligned} & \text { ICC1 } \\ & \text { ICC2 } \end{aligned}$ |  | $\begin{aligned} & 55 \\ & 65 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} ; \mathrm{VPP}=\mathrm{VCC} \\ & \mathrm{f}=2 \mathrm{MHz} ; \\ & \hline \mathrm{OE}=\mathrm{CE}=\mathrm{VIL} ; \\ & \text { lout }=0 \mathrm{~mA} ; \\ & \mathrm{VIL}=-0.1 \text { to } 0.8 \mathrm{~V} ; \\ & \mathrm{VIH}=2.0 \text { to } \mathrm{VCc} ; \\ & \text { Note 1 } \end{aligned}$ |
| Power Supply Current, Standby | $\begin{gathered} \hline \mathrm{S} \\ \mathrm{SX} \end{gathered}$ |  | ICC(S) 1 |  | $\begin{aligned} & 35 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| Power Supply Current, Standby | $\begin{gathered} L \\ L X \\ L, L X \end{gathered}$ | TTL input TTL input CMOS input | $\operatorname{lcc}(\mathrm{S}) 2$ |  | $\begin{gathered} 2 \\ 3 \\ 100 \\ \hline \end{gathered}$ | mA <br> mA <br> $\mu \mathrm{A}$ | $\overline{\mathrm{CE}}=\mathrm{Vcc} \pm 0.2 \mathrm{~V}$ |
| IPP Read Current Vpp Read Voltage | $\begin{aligned} & \text { all } \\ & \text { all } \end{aligned}$ | Read Mode Read Mode | $\begin{aligned} & \text { IPP } \\ & \text { VPP } \end{aligned}$ | $\begin{array}{r} \mathrm{Vcc} \\ -0.7 \\ \hline \end{array}$ | $\begin{aligned} & 100 \\ & \text { Vcc } \end{aligned}$ | $\mu \mathrm{A}$ | $V P P=5.5 \mathrm{~V}$ <br> Note 2 |
| * Parts: $\quad S=$ Standard Power; L = Low Power; $X=$ Industrial and Automotive Temp. Ranges; <br> Notes: (1) AC Power component above $2 \mathrm{MHz}: 3 \mathrm{~mA} / \mathrm{MHz}$ for standard part; $5 \mathrm{~mA} / \mathrm{MHz}$ for extended temperature range part. <br> (2) Vcc must be applied simultaneously or before VPP, and removed simultaneously or after VPP. |  |  |  |  |  |  |  |


| READ OPERATION <br> AC Characteristics |  |  | Testing utput Lo put Rise mbient | Wavef d: and Fall mperat | orm: <br> Time ure: | V 1 5 C C In A | $1=3.01$ <br> TL Load sec mmerc ustrial omotiv | $\begin{aligned} & \text { and } \mathrm{VIL} \\ & 1+30 \\ & \\ & \text { a } \\ & \text { : } \\ & \mathrm{Ta} \\ & \mathrm{Ta} \\ & : \quad \mathrm{Ta} \end{aligned}$ | $\begin{aligned} & =0.0 \mathrm{~V} \\ & \mathrm{~F} \\ & \mathrm{nb}= \\ & \mathrm{nb}=-4 \\ & \mathrm{nb}=-4 \end{aligned}$ | $\begin{aligned} & \mathrm{OH}=\mathrm{VOL}=1.5 \mathrm{~V} \\ & \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \\ & \mathrm{C} \text { to } 125^{\circ} \mathrm{C} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Sym | 27HC2 | 6-55** | 27HC | 56-70 | 27HC | 56-90 | Units | Conditions |
|  |  |  | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | all | tacc |  | 55 |  | 70 |  | 90 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | $\begin{aligned} & L \\ & S \end{aligned}$ | $\begin{aligned} & \text { tCE1 } \\ & \text { tCE2 } \end{aligned}$ |  | $\begin{aligned} & 55 \\ & 45 \end{aligned}$ |  | $\begin{aligned} & 70 \\ & 45 \end{aligned}$ |  | $\begin{aligned} & 90 \\ & 50 \end{aligned}$ | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | all | toe |  | 30 |  | 35 |  | 40 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to $\mathrm{O} / \mathrm{P}$ High Impedance | all | tOFF | 0 | 25 | 0 | 30 | 0 | 35 | ns |  |
| Output Hold from Address $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, which ever goes first | all | tor | 0 |  | 0 |  | 0 |  | ns |  |
| * Parts: S = Standard Power; L = Low Power <br> ** 27HC256-55 is only available in commercial temperature range |  |  |  |  |  |  |  |  |  |  |



## 27HC256

| PROGRAMMING DC Characteristics | Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | $\begin{aligned} & \text { Logic "1" } \\ & \text { Logic "0" } \end{aligned}$ | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{gathered} \text { Vcc }+1 \\ 0.8 \end{gathered}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIn}=\mathrm{OV}$ to Vcc |
| Output Voltages | Logic "1" <br> Logic "0" | VOH <br> Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-4 \mathrm{~mA} \\ & \mathrm{IOL}=16 \mathrm{~mA} \end{aligned}$ |
| Vcc Current, program \& verify |  | ICC |  | 55 | mA |  |
| Vpp Current, program |  | IPP |  | 30 | mA | Note 1 |
| A9 Product Identification |  | VH | 11.5 | 12.5 | V |  |

Note: (1) Vcc must be applied simultaneously or before VPP and removed simultaneously or after VPP.

| PROGRAMMING AC Characteristics for Program, Program Verify and Program Inhibit Modes | AC Testing Waveform: $\mathrm{VIH}=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V} ; \mathrm{VOH}=2.0 \mathrm{~V} ; \mathrm{VOL}=0.8 \mathrm{~V}$ <br> Output Load: $\quad 1$ TTL Load +100 pF <br> Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ <br> $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tAS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Set-Up Time | tDs | 2 |  | $\mu \mathrm{s}$ |  |
| Data Hold Time | tDH | 2 |  | $\mu \mathrm{s}$ |  |
| Address Hold Time | taH | 0 |  | $\mu \mathrm{s}$ |  |
| Float Delay (2) | tDF | 0 | 130 | ns |  |
| Vcc Set-Up Time | tves | 2 |  | $\mu \mathrm{s}$ |  |
| Program Pulse Width (1) | tPW | 95 | 105 | $\mu \mathrm{s}$ | $100 \mu$ stypical |
| OE Set-Up Time | toes | 2 |  | $\mu \mathrm{s}$ |  |
| VPP Set-Up Time | tVPS | 2 |  | $\mu \mathrm{S}$ |  |
| Data Valid from $\overline{\mathrm{OE}}$ | toe |  | 100 | ns |  |
| Notes: (1) For express algorithm, initial programming width tolerance is $100 \mu \mathrm{sec} \pm 5 \%$. <br> (2) This parameter is only sampled and not $100 \%$ tested. Output float is defined as the point where data is no longer driven (see timing diagram). |  |  |  |  |  |

## PROGRAMMING

## Waveforms



Notes: (1) tDF and toE are characteristics of the device but must be accommodated by the programmer
(2) $\mathrm{VcC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ for express algorithm

## FUNCTIONAL DESCRIPTION

The 27HC256 has the following functional modes:
-Operation: The 27 HC 256 can be activated for data read, be put in standby mode to lower its power consumption, or have the outputs disabled.
-Programming: To receive its permanent data, the 27HC256 must be programmed. Both a program and program/verify procedure is available. It can be programmed with Fast or Rapid Pulse algorithm.

Theprogrammingequipmentcanautomaticallyrecognize the devicetype and manufacturerusing the identity mode.

| Operation Mode | $\overline{C E}$ | $\overline{\mathrm{OE}}$ | Vpp | A9 | O0-07 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | VIL | VIL | Vcc | X | Dout |
| Program | VIL | VIH | VH | X | Din |
| Program Verify | VIH | VIL | VH | X | Dout |
| Program Inhibit | VIH | VIH | VH | X | High Z |
| Standby | VIH | X | Vcc | X | High Z |
| Output Disable | VIL | VIH | Vcc | X | High Z |
| Identity | VIL | VIL | Vcc | VH | Identity Code |

X = Don't Care

## Operation

- Read
- Standby
- Output Disable

For the general characteristics in these operation modes, refer to the table above.

## Read Mode

For timing and AC characteristics refer to the tables Read Waveforms and Read Operation AC Characteristics.

The 27HC256's memory data is accessed when

- the chip is enabled by setting the $\overline{\mathrm{CE}}$ pin low.
- the data is gated to the output pins by setting the OE pin low.
For Read operations on the Low Power version, once the addresses are stable, the address access time (tACC) is equal to the delay from CE to output (tCE). A faster CE access time (tCE) is available on the standard part to provide the additional time for decoding the $\overline{C E}$ signal. Data is transferred to the output after a delay (toE) from the falling edge of $\overline{\mathrm{OE}}$.


## Standby Mode

The standby mode is entered when the $\overline{\mathrm{CE}}$ pin is high, and a program mode is not defined. When these conditions are met, the supply current will drop from 55 mA to $100 \mu \mathrm{~A}$ on the low power part, and to 35 mA on the standard part.

## Output Disable

This feature eliminates bus contention in multiple bus microprocessor systems. The outputs go to a high impedance when the $\overline{\mathrm{OE}}$ pin is high, and the program mode is not defined.

## Programming Algorithms

The express algorithm has been developed to improve programming through-put times in a production environment. Up to 10 pulses of $100 \mu \mathrm{sec}$ each are applied until the byte is verified. No overprogramming is required. A flowchart of this algorithm is shown in Figure1.

The programming mode is entered when:
a) Vcc is brought to the proper level
b) VPP is brought to the proper VH level
c) the $\overline{\mathrm{OE}}$ pin is high
d) the CE pin is low

Since the erase state is " 1 " in the array, programming of " 0 " is required. The address of the memory location to be programmed is set via pins A0-A14, and the data is presented to pins $00-07$. When data and address are stable, a low going pulse on the $\overline{\mathrm{CE}}$ line programs that memory location.

## Verify

After the array has been programmed, it must be verified to make sure that all the bits have been correctly programmed. This mode is entered when all of the following conditions are met:
a) $V c c$ is at the proper level
b) VPP is at the proper VH level
c) the $\overline{C E}$ pin is high
d) the $\overline{O E}$ line is low

## Inhibit Mode

When Programming multiple devices in parallel with different data only CE needs to be under seperate control to each device. By pulsing the $\overline{\mathrm{CE}}$ line low on a particular device, that device will be programmed, and all other devices with CE held high will not be programmed with the data although address and data are available on their input pins.

## Identity Mode

In this mode specific data is read from the device that identifies ths manufacturer as Microchip Technology, and the device type. This mode is entered when pin A9 is taken to $\mathrm{VH}(11.5 \mathrm{~V}$ to 12.5 V$)$. The $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ pins must be at VIL. A0 is used to access any of the two nonerasable bytes whose data appears on O0-07.

| Pin $\longrightarrow$ | Input | Output |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Identity | AO | $\begin{aligned} & 0 \\ & 7 \end{aligned}$ | $\begin{aligned} & 0 \\ & 6 \end{aligned}$ | $\left\|\begin{array}{l} 0 \\ 5 \end{array}\right\|$ | $\begin{aligned} & \mathrm{O} \\ & 4 \end{aligned}$ | $\begin{aligned} & 0 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 2 \end{aligned}$ | $0$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $H$ $e$ x |
| Manufacturer | VIL | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 |
| Device Type | VIH | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 94 |

## Erasure

Windowed products offer the ability to erase the memory array. The memory matrix is erased to the all " 1 "s state as a result of being exposed to ultra-violet light at wavelenghts $\leq 4000$ Angstroms $(\AA)$. The recommended procedure is to expose the erasure window of device to a commercial UV source emitting at $2537 \AA$ with an intensity of $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ at $1^{\prime \prime}$. The erasure time at that distance is about 15 to 20 min .
Note: Fluorescent lights and sunlight emit rays at the specified wavelengths. The erasure time is about 3 years or 1 week resp. in these cases. To prevent loss of data, an opaque label should be placed over the erasure window.

PROGRAMMING - Figure 1
Express Algorithm

Conditions:
Tamb $=25+/-5 \mathrm{C}$
$\mathrm{Vcc}=6.5+/-0.25 \mathrm{~V}$
$\mathrm{VPP}=13.0+/-0.25 \mathrm{~V}$


## 27HC256

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing, or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.


## 256K (16K x 16) High Speed CMOS UV Erasable PROM

## FEATURES

- High speed performance
-45ns Maximum access time
- CMOS Technology for low power consumption
-90mA Active current
$-100 \mu \mathrm{~A}$ Standby current (low power option)
- OTP (one time programming) available
- WordWide architecture offers space saving over Bytewide memories
- Two programming algorithms allow improved programming times
-Fast programming
-Express
- Organized $16 \mathrm{~K} \times 16$ : JEDEC standard pinouts
-40-Pin dual in line package
-44-Pin chip carrier (leadless or plastic)
- Extended temperature ranges available:
-Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
—Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
—Military**: $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$


## PIN CONFIGURATION

Top View


## DESCRIPTION

The Microchip Technology Inc. 27HC1616 is a CMOS 256K bit (ultraviolet light) Erasable (electrically) Programmable Read Only Memory. The device is organized as 16 K words of 16 bits each. Advanced CMOS technology allows bipolar speed with a significant reduction in power. A low power option (L) allows further standby power reduction to $100 \mu \mathrm{~A}$. The 27 HC 1616 is configured in the JEDEC WordWide pinout which allows a two for one package savings over Bytewide memories along with a significant PC board savings. This very high speed single chip solution is ideal for $16 / 32$ bit digital signal processors (DSP) or other sophisticated microprocessors. A complete family of packages is offered to provide the utmost flexibility. One Time Programming (OTP) is available for low cost (plastic) applications.


[^10]| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| $\frac{\mathrm{AO}}{\mathrm{CE}}-\mathrm{A} 13$ | Address Inputs |
| $\frac{\mathrm{OE}}{\mathrm{OE}}$ | Chip Enable |
| VPP | Output Enable |
| O0 - O15 | Program Enable |
| Vcc | Programming Voltage |
| Vss | Data Output |
| NC | +5V Power Supply |
|  | Ground |
|  | No Connection; No |
|  | Internal Connection |

## ELECTRICAL CHARACTERISTICS

Maximum Ratings*

Vcc and input voltages w.r.t. Vss .......... -0.6 V to +7.25 V
VPP voltage w.r.t. Vss during
$\qquad$
Voltage on A9 w.r.t. Vss ........................... -0.6 V to +13.5 V
Output voltage w.r.t. Vss ................... -0.6 V to $\mathrm{Vcc}+1.0 \mathrm{~V}$
Temperature under bias ...................... $65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Storage temperature ........................... $65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
ESD protection on all pins .....................................2KV
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ OPERATION DC Characteristics |  |  |  |  | $\begin{array}{ll} \text { Vcc }=+5 \mathrm{~V} \pm 10 \% \\ \text { Commercial: } & \text { Tamb }=00^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \text { Industrial: } & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{array}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | all | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \\ \hline \end{array}$ | $\begin{gathered} \mathrm{Vcc}+1 \\ 0.8 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage | all |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-0.1$ to $\mathrm{VCC}+1.0 \mathrm{~V}$ |
| Output Voltages | all | $\begin{aligned} & \text { Logic "1" } \\ & \text { Logic "0" } \end{aligned}$ | VOH Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-2 \mathrm{~mA} \\ & \mathrm{IOL}=8 \mathrm{~mA} \end{aligned}$ |
| Output Leakage | all |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | VOUT $=-0.1$ to Vcc +1.0 V |
| Input Capacitance | all |  | CIN |  | 6 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | all |  | Cout |  | 12 | pF | $\begin{aligned} & \text { VOUT }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | all | TTL input | ICC1 |  | 90 | mA | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} ; \mathrm{VPP}=\mathrm{VCC} \\ & \mathrm{f}=2 \mathrm{MHz} ; \\ & \overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{VIL} ; \\ & \text { lout }=0 \mathrm{~mA} ; \\ & \mathrm{VIL}=-0.1 \text { to } 0.8 \mathrm{~V} ; \\ & \mathrm{VIH}=2.0 \text { to } \mathrm{VCc} ; \\ & \text { Note } 1 \end{aligned}$ |
| Power Supply Current, Standby | S,SX |  | $\mathrm{ICC}(\mathrm{S}) 1$ |  | 50 | mA |  |
| Power Supply Current, Standby | $\begin{aligned} & \hline \mathrm{L}, \mathrm{LX} \\ & \mathrm{~L}, \mathrm{LX} \end{aligned}$ | TTL input CMOS input | $\operatorname{lcc}(\mathrm{S}) 2$ |  | $\begin{gathered} \hline 3 \\ 100 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mu \mathrm{~A} \end{aligned}$ | $\overline{\mathrm{CE}}=\mathrm{Vcc} \pm 0.2 \mathrm{~V}$ |
| IPP Read Current Vpp Read Voltage | $\begin{aligned} & \text { all } \\ & \text { all } \end{aligned}$ | Read Mode Read Mode | $\begin{aligned} & \text { IPP } \\ & \text { VPP } \end{aligned}$ | Vcc-0.7 | $\begin{aligned} & 100 \\ & \text { Vcc } \end{aligned}$ | $\begin{gathered} \mu \mathrm{A} \\ \mathrm{~V} \end{gathered}$ | $\mathrm{VPP}=5.5 \mathrm{~V}$ <br> Note 2 |
| * Parts: $\quad S=$ Standard Power; L = Low Power; $X=$ Industrial Temp Range; <br> Notes: (1) AC Power component above 2 MHz : $2 \mathrm{~mA} / \mathrm{MHz}$. <br> (2) Vcc must be applied simultaneously or before VPP and be removed simultaneously or after VPP. |  |  |  |  |  |  |  |


| READ OPERATION AC Characteristics |  |  | Test tput L ut Ris bient | Wave d: and Fa mpera | orm: <br> Time ure: | $\mathrm{V}_{\mathrm{IH}}=$ <br> 1 TT <br> : 5 ns <br> Com <br> Indu | 3.0 V <br> Load <br> mercia <br> trial: | d VIL= 30 pF <br> Tamb Tamb | $\begin{aligned} & 0.0 \mathrm{~V} \\ & =\quad 0^{\circ} \mathrm{C} \\ & =-40^{\circ} \end{aligned}$ | $\begin{aligned} & \mathrm{H}=\mathrm{VOL}=1.5 \mathrm{~V} \\ & \text { to } 70^{\circ} \mathrm{C} \\ & \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Sym | 27HC | 16-45 | 27HC | 616-55 | 27HC | 16-70 | Units | Conditions |
|  |  |  | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | all | tacc |  | 45 |  | 55 |  | 70 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ to Output Delay | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~S} \end{aligned}$ | $\begin{aligned} & \text { tCE1 } \\ & \text { tCE2 } \end{aligned}$ |  | 45 |  | 55 35 |  | $\begin{aligned} & 70 \\ & 45 \end{aligned}$ | ns | $\overline{\mathrm{OE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{OE}}$ to Output Delay | all | toe |  | 25 |  | 30 |  | 35 | ns | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ to O/P High Impedance | all | tOFF | 0 | 20 | 0 | 20 | 0 | 25 | ns |  |
| Output Hold from Address $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, which ever occurs first | all | tOH | 0 |  | 0 |  | 0 |  | ns |  |
| * Parts: S = Standard Power; L = Low Power |  |  |  |  |  |  |  |  |  |  |

## READ WAVEFORMS



Notes: (1) toff is specified for $\overline{O E}$ or $\overline{C E}$, whichever occurs first
(2) $\overline{O E}$ may be delayed up to $\operatorname{tCE}$ - toE after the falling edge of $\overline{C E}$ without impact on CCE
(3) This parameter is sampled and is not $100 \%$ tested.

| PROGRAMMING <br> DC Characteristics | Ambient Temperature: $25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ For VPP and Vcc Voltages refer to Programming Algorithms |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \text { VIH } \\ & \text { VIL } \end{aligned}$ | $\begin{gathered} 2.0 \\ -0.1 \end{gathered}$ | $\begin{gathered} \text { Vcc+1 } \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=-.1 \mathrm{~V}$ to $\mathrm{Vcc}+1.0 \mathrm{~V}$ |
| Output Voltages | Logic "1" <br> Logic "0" | VOH <br> Vol | 2.4 | 0.45 | $\begin{aligned} & \text { V } \\ & \mathrm{V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-2 \mathrm{~mA} \\ & \mathrm{lOL}=8 \mathrm{~mA} \end{aligned}$ |
| Vcc Current, program \& verify |  | ICC |  | 90 | mA | Note 1 |
| VPP Current, program |  | IPP |  | 50 | mA | Note 1 |
| A9 Product Identification |  | VH | 11.5 | 12.5 | V |  |

Note: (1) Vcc must be applied simultaneously or before VPP and removed simultaneously or after VPP

| PROGRAMMING <br> AC Characteristics <br> for Program, Program Verify and Program Inhibit Modes | AC Testing Waveform: Output Load: <br> Ambient Temperature: 25 For VpP and Vcc Voltages, | 2.4 V <br> Load <br> $\pm 5^{\circ}$ <br> fer to | $\begin{aligned} & \mathrm{L}=0.45 \\ & 100 \mathrm{pF} \\ & \text { ogramm } \end{aligned}$ | $\text { ; } \mathrm{VOH}=$ | $2.0 \mathrm{~V} \text { and } \mathrm{Vol}=0.8 \mathrm{~V}$ <br> ithms |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Symbol | Min | Max | Units | Remarks |
| Address Set-Up Time | tAS | 2 |  | $\mu \mathrm{s}$ |  |
| Data Set-Up Time | tDs | 2 |  | $\mu \mathrm{s}$ |  |
| Data Hold Time | tDH | 2 |  | $\mu \mathrm{s}$ |  |
| Address Hold Time | tAH | 0 |  | $\mu \mathrm{s}$ |  |
| Float Delay (3) | tDF | 0 | 130 | ns |  |
| Vcc Set-Up Time | tvCs | 2 |  | $\mu \mathrm{s}$ |  |
| Program Pulse Width (1) | tPW | 0.95 | 1.05 | ms | 1 ms typical |
| Program Pulse Width (1) | tPW | 95 | 105 | $\mu \mathrm{s}$ | $100 \mu$ s typical |
| $\overline{\mathrm{CE}}$ Set-Up Time | tCES | 2 |  | $\mu \mathrm{s}$ |  |
| $\overline{\text { OE Set-Up Time }}$ | toes | 2 |  | $\mu \mathrm{s}$ |  |
| Vpp Set-Up Time | tVPS | 2 |  | $\mu \mathrm{s}$ |  |
| Overprogram Pulse Width (2) | topw | 2.85 | 78.75 | ms |  |
| Data Valid from $\overline{\mathrm{OE}}$ | toe |  | 100 | ns |  |
| Notes: (1) For express algorithm, initial programming width tolerance is $100 \mu \mathrm{sec} \pm 5 \%$. For fast programming algorithm, initial program pulse width tolerance is $1 \mathrm{msec} \pm 5 \%$. <br> (2) For fast programming algorithm, the length of the overprogram pulse may vary from 2.85 to 78.75 msec as a function of the iteration counter value. <br> (3) This parameter is only sampled and not $100 \%$ tested. Output float is defined as the point where data is no longer driven (see timing diagram). |  |  |  |  |  |

PROGRAMMING
Waveforms


Notes: (1) tDF and toE are characteristics of the device but must be accomodated by the programmer
(2) $\mathrm{VcC}=6.0 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=12.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$ for fast programming algorithm $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ for express algorithm

## FUNCTIONAL DESCRIPTION

The 27 HC 1616 has the following functional modes:
-Operation: The 27HC1616 can be activated for data read, be put in standby mode to lower its power consumption, or have the outputs disabled.
-Programming: To receive its permanent data, the 27 HC 1616 must be programmed. Both a program and program/verify procedure is available. It can be programmed with Fast or Express algorithm.
The programming equipment can automatically recognize the device type and manufacturer using the identity mode.

For the general characteristics in these operation and programming modes, refer to the table.

## OPERATION

## Read Mode

For timing and $A C$ characteristics refer to the tables Read Waveforms and Read Operation AC Characteristics.

The 27HC1616's memory data is accessed when
-the chip is enabled by setting the $\overline{\mathrm{CE}}$ pin low.
-the data is gated to the output pins by setting the $\overline{\mathrm{OE}}$ pin low.
For Read operations on the Low Power version, once the addresses are stable, the address access time (tACC) is equal to the delay from CE to output (tCE). A faster $\overline{C E}$ access time (tCE) is available on the standard part to provide the additional time for decoding the CE signal. Data is transferred to the output after a delay (tOE) from the falling edge of $O E$.

## Standby Mode

The standby mode is entered when the CE pin is high, and the program mode is not defined. When these conditions are met, the supply current will drop from 90 mA to $100 \mu \mathrm{~A}$ on the low power part, and to 50 mA on the standard part.

## Output Disable

This feature eliminates bus contention in multiple bus microprocessor systems. The outputs go to a high impedance when the $\overline{O E}$ pin is high, and the program mode is not defined.

## Programming/Verification

The 27 HC 1616 has to be programmed, and afterward the programmed information verified. Before these operations, the Identity Code can be read to properly set up automated equipment. Multiple devices in parallel can be programmed using the programming and inhibit modes.

## Programming Algorithms

Two programming algorithms are available: fast programming and express.

The fast programming algorithm is the industry standard programming mode that requires both initial programming pulses and overprogramming pulses. A flowchart of the algorithm is shown in Figure 1.

The express algorithm has been developed to improve programming through-put times in a production environment. Up to 10 pulses of $100 \mu \mathrm{sec}$ each are applied until the byte is verified. No overprogramming is required. A flowchart of this algorithm is shown in Figure 2.

The programming mode is entered when:
a) Vcc is brought to the proper level
b) VPP is brought to the proper VH level
c) the $\overline{O E}$ pin is high
d) the $\overline{\mathrm{CE}}$ pin is low, and
e) the PGM pin is pulsed low.

Since the erase state is " 1 " in the array, programming of " 0 " is required. The address of the memory location to be programmed is set via pins AO-A13, and the data is presented to pins O0-O15. When data and address are stable, a low going pulse on the $\overline{C E}$ line programs that memory location.

## Verify

After the array has been programmed, it must be verified to make sure that all the bits have been correctly programmed. This mode is entered when all of the following conditions are met:
a) VCC is at the proper level
b) VpP is at the proper VH level
c) the $\overline{\mathrm{OE}}$ line is low
d) the CE pin is low, and
e) the PGM line is high.

## Inhibit Mode

When Programming multiple devices in parallel with different data only PGM needs to be under separate control to each device. By pulsing the PGM line low on a particular device, that device will be programmed, and all other devices with corresponding PGM or CE held high will not be programmed with the data although address and data are available on their input pins.

## Identity Mode

In this mode specific data is read from the device that identifies the manufacturer as Microchip Technology, and the device type. This mode is entered when pin A9 is taken to $\mathrm{VH}(11.5 \mathrm{~V}$ to 12.5 V$)$. The $\overline{\mathrm{CE}}$ and OE pins must be at VIL. A0 is used to access any of the two nonerasable bytes whose data appears on O0-07.

| Pin $\longrightarrow$ | Input | Output* |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Identity $\square$ | A0 | $\begin{aligned} & 0 \\ & 7 \end{aligned}$ | $\begin{aligned} & 0 \\ & 6 \end{aligned}$ | $\begin{aligned} & 0 \\ & 5 \end{aligned}$ | $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | $\begin{aligned} & 0 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 2 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $H$ $e$ x |
| Manufacturer | VIL | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 |
| Device Type* | VIH | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 97 |

*Code subject to change.
Note: O15-O8 are 00 for the manufacturer and device type code.

## Erasure

Windowed products offer the ability to erase the memory array. The memory matrix is erased to the all " 1 "s state as a result of being exposed to ultra-violet light at wavelengths $\leq 4000$ Angstroms $(\AA)$ ). The recommended procedure is to expose the erasure window of device to a commercial UV source emitting at $2537 \AA$ with an intensity of $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ at 1 ". The erasure time at that distance is about 15 to 20 min .

Note: Fluorescent lights and sunlight emit rays at the specified wavelengths. The erasure time is about 3 years or 1 week resp. in these cases. To prevent loss of data, an opaque label should be placed over the erasure window.

## PROGRAMMING - FIGURE 1 <br> EXPRESS ALGORITHM

Conditions:
Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ $V c c=6.5 \pm 0.25 \mathrm{~V}$ $\mathrm{VPP}=13.0 \pm 0.25 \mathrm{~V}$

Start
T


## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



Microchip

## 64K (8K x 8) High Speed CMOS UV Erasable PROM

## FEATURES

- Bipolar Performance
- 40ns Maximum Access Time
- CMOS Technology For Low Power Consumption
- 80mA Active Current
- $100 \mu \mathrm{~A}$ Standby Current (Low Power Option)
- OTP (One Time Programming) Available
- Auto-Insertion-Compatible Plastic Packages
- Auto ID ${ }^{\text {M }}$ Aids Automated Programming
- Two Programming Algorithms Allow Improved Programming Times
- Fast Programming
- Express
- Organized $8 \mathrm{~K} \times 8$ : Bipolar PROM Pinouts
-24 Pin Dual in Line Package
- 28 Pin Chip Carrier (Leadless or Plastic)
- Available for Extended Temperature Ranges:
- Commercial: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
- Industrial: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
— Military**: $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$



## DESCRIPTION

The Microchip Technology Inc 27HC641 is a CMOS 64K bit ultraviolet light Erasable (electrically) Programmable Read Only Memory. The device is organized as 8 K words by 8 bits ( 8 K bytes). An advanced CMOS design allows bipolar speed with a significant reduction in power over bipolar PROMs. A low power option (L) allows further standby power reduction to $100 \mu \mathrm{~A}$. The 27 HC 641 is configured in a standard 64 K bipolar PROM pinout, which allows an easy upgrade for PROM sockets. This very high speed device allows digital signal processors (DSP) or other sophisticated microprocessors to run at full speed without the need for WAIT states. CMOS design and processing enables this part to be used in systems where reduced power consumption and reliability are requirements.

A complete family of packages is offered to provide the utmost flexibility in applications. Skinny Cerdip ( 300 mil) and Skinny Plastic are available. One Time Programming (OTP) is available for low cost (plastic) applications.

**See 27HC641 Military Data Sheet DS60007A

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| AO - A12 | Address Inputs |
| CENPP | Chip Enable/VPP Pin |
| OO-O7 | Data Output |
| VCC | +5V Power Supply |
| Vss | Ground |
| NC | No Connection; No |
| NU | Internal Connection |
|  | Not Used; No External |
|  | Connection Is Allowed |

## ELECTRICAL CHARACTERISTICS Maximum Ratings*

Vcc and input voltages
w.r.t. Vss. $\qquad$ -0.6 V to +7.25 V
$\overline{\mathrm{CE}} /$ VPP voltage w.r.t. Vss during programming -0.6 V to +14 V
Voltage on A9 w.r.t. Vss......................... -0.6 V to +13.5 V
Output voltage w.r.t. Vss..................... -0.6 V to $\mathrm{Vcc}+1.0 \mathrm{~V}$
Storage temperature.............................. $65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Ambient temperature with power applied................................ $65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
ESD protection on all pins 2KV
*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| READ OPERATION DC Characteristics |  |  |  |  | Vcc Com Indu | $=+5 \mathrm{~V} \pm$ <br> mercial trial: | $\begin{aligned} & 10 \% \\ & : \text { Tamb }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \text { Tamb }=-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | all | Logic "1" <br> Logic "0" | $\begin{aligned} & \mathrm{VIH}^{2} \\ & \mathrm{VIL}^{2} \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \\ \hline \end{array}$ | $\begin{aligned} & \text { Vcc }+1 \\ & 0.8 \\ & \hline \end{aligned}$ | $\begin{array}{\|l} \hline \mathrm{V} \\ \mathrm{~V} \\ \hline \end{array}$ |  |
| Input Leakage | all |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0 \mathrm{~V}$ to VCC |
| Output Voltages | all | Logic "1" <br> Logic "0" | VOH <br> Vol | 2.4 | 0.45 | $\begin{array}{\|l} \hline \mathrm{V} \\ \mathrm{~V} \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{IOH}=-4 \mathrm{~mA} \\ & \mathrm{OL}=16 \mathrm{~mA} \end{aligned}$ |
| Output Leakage | all |  | ILO | -10 | 10 | $\mu \mathrm{A}$ | Vout $=0 \mathrm{~V}$ to Vcc |
| Input Capacitance | all |  | CIN |  | 6 | pF | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | all |  | COUT |  | 12 | pF | $\begin{aligned} & \text { VOUT }=0 \mathrm{~V} ; \text { Tamb }=25^{\circ} \mathrm{C} ; \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Power Suppy Current, Active | $\begin{aligned} & \hline S, L \\ & S X, L X \end{aligned}$ | TTL input TTL input | $\begin{aligned} & \text { ICC1 } \\ & \text { ICC2 } \end{aligned}$ |  | $\begin{aligned} & 80 \\ & 90 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{VCC}=5.5 \mathrm{~V} ; \overline{\mathrm{CE}} / \mathrm{VPP}=\mathrm{VIL} \\ & \mathrm{f}=2 \mathrm{MHz} ; \\ & \text { lout }=0 \mathrm{~mA} ; \\ & \mathrm{VIL}=-0.1 \mathrm{~V} \text { to } 0.8 \mathrm{~V} ; \\ & \mathrm{VIH}=2.0 \mathrm{~V} \text { to } \mathrm{VCC} ; \\ & \text { Note } 1 \end{aligned}$ |
| Power Supply Current, Standby | $\begin{array}{\|l\|} \hline S \\ S X \end{array}$ |  | ICC(S) 1 |  | $\begin{aligned} & 40 \\ & 50 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| Power Supply Current, Standby | $\begin{aligned} & L \\ & L X \\ & L, L X \end{aligned}$ | TTL input TTL input CMOS input | $\operatorname{lcc}(\mathrm{S}) 2$ |  | $\begin{aligned} & \hline 2 \\ & 3 \\ & 100 \end{aligned}$ | $\begin{array}{\|l} \hline \mathrm{mA} \\ \mathrm{~mA} \\ \mu \mathrm{~A} \end{array}$ | $\overline{\mathrm{CE}} / \mathrm{VPP}=\mathrm{Vcc} \pm 0.2 \mathrm{~V}$ |
| * Parts: . $\mathrm{S}=$ Standard Power; $\mathrm{L}=$ Low Power; $\mathrm{X}=$ Industrial Temp Range; <br> Notes: (1) AC Power component above 2 MHz : $3 \mathrm{~mA} / \mathrm{MHz}$ for standard part; $5 \mathrm{~mA} / \mathrm{MHz}$ for industrial temperature range part. |  |  |  |  |  |  |  |

## 27HC641

| READ OPERATION AC Characteristics |  |  | AC Testing Waveform: Output Load: Input Rise and Fall Times: Ambient Temperature: |  |  |  | ```VIH=3.0V and VIL=0.0V;VOH=VOL=1.5V 1 TTL Load + 30 pF 5 nsec Commercial: Tamb = 0 O C to 70' C Industrial: Tamb = -40 C to 85 ' C``` |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Part* | Sym | 27HC | 41-40** | 27HC | 41-45 | 27HC | 641-55 | 27HC | 41.70 | Units | Conditions |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| Address to Output Delay | all | tacc |  | 40 |  | 45 |  | 55 |  | 70 | ns |  |
| CEN pp to Output Delay | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~S} \end{aligned}$ | $\begin{aligned} & \text { tcE1 } \\ & \text { tce } \end{aligned}$ |  | $\begin{aligned} & 40 \\ & 30 \end{aligned}$ |  | $\begin{aligned} & 45 \\ & 35 \end{aligned}$ |  | $\begin{aligned} & 55 \\ & 35 \end{aligned}$ |  | $\begin{aligned} & 70 \\ & 45 \end{aligned}$ | ns |  |
| CE/Npp to O/P High Impedance | all | toff | 0 | 25 | 0 | 25 | 0 | 30 | 0 | 35 | ns |  |
| Output Hold from Address or CE/VPP, whichever goes first | all | toh | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |

* Parts: S = Standard Power; L = Low Power
** 27HC641-40 is only available in commercial temperature range


## READ WAVEFORMS



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

## 27HC641

| PROGRAMMING <br> DC Characteristics | Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$ <br> For $\overline{C E} /$ VPP and Vcc Voltages refer to Programming Algorithms |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Parameter | Status | Symbol | Min | Max | Units | Conditions |
| Input Voltages | Logic "1" <br> Logic "0" | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{VIL}^{2} \end{aligned}$ | $\begin{array}{r} 2.0 \\ -0.1 \end{array}$ | $\begin{gathered} \mathrm{Vcc}+1 \\ 0.8 \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |  |
| Input Leakage |  | ILI | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{VIN}=O V$ to Vcc |
| Output Voltages during verification | Logic "1" <br> Logic "0" | VOH Vol | 2.4 | 0.45 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-4 \mathrm{~mA} \\ & \mathrm{lOL}=16 \mathrm{~mA} \end{aligned}$ |
| Vcc Current, program \& verify |  | ICC |  | 80 | mA |  |
| VPP Current, program |  | IPP |  | 40 | mA |  |
| A9 Product Identification |  | $\mathrm{V}_{\mathrm{H}}$ | 11.5 | 12.5 | V |  |

PROGRAMMING AC Characteristics
for Program, Program Verify and Program Inhibit Modes

AC Testing Waveform: V IH $=2.4 \mathrm{~V}$ and $\mathrm{VIL}=0.45 \mathrm{~V}$; $\mathrm{VOH}=2.0 \mathrm{~V}$; $\mathrm{VOL}=0.8 \mathrm{~V}$ Output Load: $\quad 1$ TTL Load +100 pF Ambient Temperature: Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$
For $\overline{\mathrm{CE}} /$ VPP and Vcc Voltages, refer to Programming Algorithms

| Parameter | Symbol | Min | Max | Units | Remarks |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Address Set-Up Time | tAS | 2 |  | $\mu \mathrm{~s}$ |  |
| Data Set-Up Time | tDS | 2 |  | $\mu \mathrm{~s}$ |  |
| Data Hold Time | tDH | 2 |  | $\mu \mathrm{~s}$ |  |
| Address Hold Time | tAH | 0 |  | $\mu \mathrm{~s}$ |  |
| Float Delay (3) | tDF | 0 | 130 | ns |  |
| Vcc Set-Up Time | tvcs | 2 |  | $\mu \mathrm{~s}$ |  |
| Program Pulse Width (1) | tPW | 0.95 | 1.05 | ms | 1 ms typical |
| Program Pulse Width (1) | tPW | 95 | 105 | $\mu \mathrm{~s}$ | $100 \mu \mathrm{~s}$ typical |
| Overprogram Pulse Width (2) | toPW | 2.85 | 78.75 | ms |  |
| CE to Output Delay | tCE |  | 100 | ns |  |

Notes: (1) For Express algorithm, initial programming width tolerance is $100 \mu \mathrm{sec} \pm 5 \%$. For fast programming algorithm, initial program pulse width tolerance is $1 \mathrm{msec} \pm 5 \%$.
(2) For fast programming algorithm, the length of the overprogram pulse may vary from 2.85 to 78.75 msec as a function of the iteration counter value.
(3) This parameter is only sampled and not $100 \%$ tested. Output float is defined as the point where data is no longer driven (see timing diagram).

## PROGRAMMING

Waveforms


Notes: (1) tDF is a characteristics of the device but must be accomodated by the programmer
(2) $\mathrm{VCC}=6.0 \mathrm{~V} \pm 0.25 \mathrm{~V}, \overline{\mathrm{CE}} / \mathrm{VPP}=\mathrm{VH}=12.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$ for fast programming algorithm $\mathrm{VCC}=6.5 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{CE} / \mathrm{VPP}=\mathrm{VH}=13.0 \mathrm{~V} \pm 0.25 \mathrm{~V}$ Express programming algorithm

## MODES

| Operating Modes | $\overline{\text { CE/VPP }}$ | A9 | O0-O7 |
| :--- | :---: | :---: | :--- |
| Read/Program Verify | $\mathrm{V}_{\mathrm{L}}$ | X | DouT |
| Program | $\mathrm{VH}_{H}$ | X | DIN |
| Standby/Program Inhibit | $\mathrm{VH}_{H}$ | X | High Z |
| Identify | $\mathrm{VL}_{\mathrm{L}}$ | $\mathrm{VH}_{\mathrm{H}}$ | Identity Code |

X = Don't Care

## Read Mode

(See Timing Diagrams and AC Characteristics)
Read Mode is accessed when
the $\overline{\mathrm{CE}} /$ VPP pin is low to power up (enable) the chip

For Read operations on the low powered version, if the addresses are stable, the address access time (tACC) is equal to the delay from $\overline{\mathrm{CE}} /$ VPP to output (tCE). A faster $\overline{\mathrm{CE}} /$ VPP access time (tCE) is available on the standard part to provide the additional time for decoding for the $\overline{\mathrm{CE}} / \mathrm{VPP}$ signal.

## Standby Mode

The standby mode is defined when the CE/VPP pin is high (VIH).

When this condition is met, the supply current will drop from 80 mA to $100 \mu \mathrm{~A}$ on the low power part and to 40 mA on the standard part.

## Erase Mode

Windowed products offer the ability to erase the memory array. The memory matrix is erased to the all " 1 "'s state as a result of being exposed to ultraviolet light. To ensure complete erasure, a dose of 15 watt-second $/ \mathrm{cm}^{2}$ is required. This means that the device window must be placed within one inch and directly underneath an ultraviolet lamp with a wavelength of 2537 Angstroms, intensity of $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ for 20 minutes.

## Programming Mode

Two programming algorithms are available. The fast programming algorithm is the industry-standard programming mode that requires both initial programming pulses and overprogramming pulses. A flowchart of the fast programming algorithm is shown in Figure 1.

The Express algorithm has been developed to improve on the programming throughput times in a production environment. Up to 10 100-microsecond pulses are applied until the byte is verified. No overprogramming is required. A flowchart of the Express algorithm is shown in Figure 2.

The $\overline{C E} / V P P$ is a multifunction pin that controls the programming of the 27 HC 641 .

Programming takes place when:
a) Vcc is brought to proper voltage,
b) the $\overline{\mathrm{CE}} /$ VPP pin is pulsed at the proper VH level.

Since the erased state is " 1 " in the array, programming of " 0 " is required. The address to be programmed is set via pins AO - A12 and the data to be programmed is presented to pins $00-\mathrm{O7}$. When data and address are stable, a high voltage pulse ( VH ) on the $\overline{\mathrm{CE}} / \mathrm{VPP}$ line programs that location.

## Verify

After the array has been programmed it must be verified to ensure all the bits have been correctly programmed. This mode is entered when all the following conditions are met:
a) VCC is at the proper level,
b) the $\overline{\mathrm{CE}} / \mathrm{VPP}$ line is low.

## Inhibit

When programming multiple devices in parallel with different data, only $\overline{\mathrm{CE}} / \mathrm{VPP}$ needs to be under separate control to each device. By pulsing the $\overline{\mathrm{CE}} / \mathrm{VPP}$ line to a $\mathrm{VH}_{\mathrm{H}}$ on a particular device, that device will be programmed; all other devices with $\overline{\mathrm{CE}} / \mathrm{VPP}$ held high (VIH) will not be programmed with the data, although address and data will be available on their input pins (i.e., when a level $(\mathrm{V} / \mathrm{H})$ is present on $\overline{\mathrm{CE}} / \mathrm{VPP}$ ) and the device is inhibited from programming.

## Identity Mode

In this mode specific data is output which identifies the manufacturer as Microchip Technology Inc., and the device type. This mode is entered when Pin A9 is taken to $\mathrm{VH}(11.5 \mathrm{~V}-12.5 \mathrm{~V})$.

The $\overline{C E} /$ VPP line must be at VIL. A0 is used to access any of the two non-erasable bytes whose data appears on O0 through O7.

| Pin $\longrightarrow$ | Input | Output |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Identity <br> $\downarrow$ | A0 | $\begin{aligned} & 0 \\ & 7 \end{aligned}$ | $\begin{aligned} & 0 \\ & 6 \end{aligned}$ | $\begin{aligned} & 0 \\ & 5 \end{aligned}$ | $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | $\begin{aligned} & 0 \\ & 3 \end{aligned}$ | $\begin{aligned} & 0 \\ & 2 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $H$ $e$ x |
| Manufacturer | VIL | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 |
| Device Type | VIH | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 10 |

[^11]
## PROGRAMMING - FIGURE 1

## EXPRESS ALGORITHM

Conditions:
Tamb $=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}$
$\mathrm{VcC}=6.5 \pm 0.25 \mathrm{~V}$
$\mathrm{VPP}=13.0 \pm 0.25 \mathrm{~V}$


## 27HC641

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS

```
27HC641-45 I/K
```

Package: J Cerdip DIP
K Ceramic Leadless Chip Carrier
L Plastic Leaded Chip Carrier (OTP Available)
P Plastic DIP (OTP Available)
SJ SKINNY CERDIP
SP SKINNY PLASTIC (OTP Available)
Temperature Blank $\quad 0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Range: $\quad 1 \quad-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$

Access Time: $40 \quad 40 \mathrm{nsec}$
$45 \quad 55 \mathrm{nsec}$
$55 \quad 55 \mathrm{nsec}$
$70 \quad 70 \mathrm{nsec}$
27HC641 $64 \mathrm{~K}(8 \mathrm{~K} \times 8$ ) High Speed CMOS EPROM 27HC641L $64 \mathrm{~K}(8 \mathrm{~K} \times 8$ ) High Speed Low Power CMOS EPROM

## 27Cxxx EPROM FAMILY PROGRAMMING ALGORITHM

Microchip Technology Inc supports three programming algorithms for its CMOS EPROM Family. The selection of an algorithm is an important consideration and will impact the programming time, programming yield and programming margins of the EPROM.

## Fast Programming Algorithm

This is the old industry standard programming algorithm with up to 251 -msec programming pulses and a three times overprogramming pulse. It is a very stable algorithm to use, with its major draw back being an increase in throughput time especially at the larger densities.

Rapid Pulse Programming Algorithm
The Rapid Pulse algorithm provides an alternative to the Fast algorithm. The slight increase in Vcc and VPP during programming allows the use of a narrower 100 usec programming pulse and the removal of the overprogramming pulse associated with the Fast Programming. This translates into a decrease in programming times of nearly 40 to 1 and an increase in throughput of nearly 10 to 1. (Throughput is heavily influenced by the machine cycle time of the programmer during the pre-programming blank check, and the post-programming verification. It also varies from programmer to programmer.)

## Express Programming Algorithm

The Express algorithm is an improvement on the Rapid Pulse algorithm. While it exhibits the same excellent throughput as the Rapid Pulse algorithm, its advantage lies in the additional increase in VPP and Vcc applied during programming. The higher VPP and Vcc voltages provide additional charge to the floating gate during programming. After each programming pulse, the cell is verified against Vcc ( 6.5 Volts for Express, 6.25 volts for Rapid Pulse). This verification step with a higher Vcc ensures improvement in programming margins over the Rapid Pulse algorithm.

## Algorithm Selection

The optimization of programmer throughput is a concern to all EPROM users in a production environment. A major contributor to increasing throughput is shorter programming times. The Express algorithm has been developed to minimize programming times. In addition, sufficient programming margins must be developed to insure EPROM functionality over the full range of voltage and temperature variations. The higher Vcc and Vpp voltages generate this increased margin and provide additional guardband against the effects of aging hardware.

| Programming Times (sec) |  |  |  |
| :---: | :---: | :---: | :---: |
| Memory Size | Fast | Rapid | Express |
| 64K | 32.8 | 0.819 | 0.819 |
| 128K | 131.1 | 1.64 | 1.64 |
| 256K | 93/32 | 3.28 | 3.28 |
| 512K | 262.2 | 6.55 | 6.55 |
| $\begin{aligned} & \text { Actual throut } \\ & \text { time of the } \\ & \text { check, and th } \end{aligned}$ | ut time rammer | nds on ing pre-p | achine ming bla |

## Microchip Programming Algorithm Recommendations

Microchip recommends that the Express algorithm be used on all commercial/industrial EPROMs (when available).

The Fast Programming algorithm should be your second choice for the 64 K and the 128 K EPROMs, with Rapid Pulse being the second choice for the 256 K and 512 K EPROMs. The remaining algorithm should be your third choice. This recommendation is based on the maximization of programmer throughput and cell margins. At the smaller density (when Express is not available) the increased margins supplied by the Fast Programming far outweigh the small increase in throughput of Rapid Pulse. As you increase density, programming throughput becomes the dominant criteria.

| Data I/O Family Code and Pin-Outs* |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Device | Size | Fast | Rapid | Express |
| 27 C 64 | 64 K | $93 / 33$ | $5 \mathrm{C} / 33$ | $115 / 033$ |
| 27 C 128 | 128 K | $93 / 51$ | $5 \mathrm{C} / 51$ | $115 / 051$ |
| 27 C 256 | 256 K | $93 / 32$ | $5 \mathrm{C} / 32$ | $115 / 032$ |
| 27 C 512 | 512 K | $4 \mathrm{~B} / \mathrm{A} 4$ | $5 \mathrm{E} / \mathrm{A} 4$ | $116 / 0 \mathrm{~A} 4$ |

[^12]


NOTES:

## SECTION 4 MICROCONTROLLER PRODUCT SPECIFICATIONS

PIC PIC 16xxx Series Microcontroller Family ..... 4- 1
PIC16C5X EPROM-Based 8-Bit CMOS Microcontroller Series ..... 4- 5
PIC1654S 8-Bit Microcontroller ..... 4- 35
PIC1655 8-Bit Microcontroller ..... 4- 51
PIC1670 8 Bit Microcontroller ..... 4- 67

# PIC 16xxx Series Microcontroller Family 



## THE PIC FAMILY

## A History of Innovation and Success

Microchip's history of innovation and its strong commitment to develop and market leading edge products, is best exemplified by its popular 8 -Bit Microcontroller families. Microchip is the first semiconductor company to introduce RISC-like features and offer the time saving flexibility of one-time-programmable (OTP) EPROM 8Bit MCUs. These new design concepts and the integration of advanced CMOS EPROM technology overcomes three major user barriers, namely: efficiency/performance; time to market; and affordability. The benefits of PIC ${ }^{\circledR}$ microcontroller technology are being shared by hundreds of customers worldwide with over 80 million CMOS and NMOS PIC microcontrollers in use.

## FEATURES

## PIC EPROM Technology

PIC's OTP EPROM technology offers a low cost alternative to using competitive ROM based devices for high volume production. EPROM technology also offers several important cost saving advantages namely:

Time-To-Market: Since the financial success of a product is often determined by its time-to-market, through user programmability PIC offers an immediate solution to lengthy market entry delays. Our off-the shelf products eliminate the 10-18 week lead times experienced with conventional ROM based MCU suppliers.

EPROM Flexibility: Means decisions to change codes "on-the-fly" while in development or in mid-production no longer carry a financial or time penalty in the event of error. System performance enhancements which may be critical to market success can now be achieved quickly, effortlessly and cost effectively. Another demonstration of EPROM flexibility is the ability to perform in-circuit-programming. This allows for product variants to be developed cost effectively. Participation in high profit custom business becomes economically feasible with OTP PICs.

Off-The-Shelf: EPROM technology benefits the user by eliminating the need for substantial inventories and limits exposure to product obsolescence; typical of ROM devices. OTP parts also ensure an immediate supply from a variety of worldwide stocking locations. High volume quick-turn-production (QTP) programming services are also available from Microchip for customers who chose not to perform high volume programming themselves.

## PIC's RISC Architecture

PIC's RISC Architecture sets a new standard in performance in the 8-Bit MCU marketplace. The highly efficient and powerful instruction set which supports this architecture requires only 33 single cycle instructions to learn versus 60 to 110 multi-byte instructions common to competitive CISC MCU architectures. Benchmarks have demonstrated that the efficiency of this instruction set provides the user with up to a 2:1 code compaction advantage over competitive products. It has also been demonstrated that this level of efficiency can also reduce code development time by up to 30 percent.

The PIC's single cycle instructions and RISC architecture facilitates up to five million instructions per second execution throughput. This provides the designer with up to a $5: 1$ speed advantage over competitive products. This advanced rate of code execution rivals many 16-Bit MCU designs and opens new real-time, high performance application opportunities. Also, memory inefficient, engineering intensive and inaccurate look-up tables can now be replaced with PIC's high level algorithmic processing speed. Applications such as efficient motor control, high speed I/O and high speed data bit stream manipulation now becomes a reality in the 8-Bit domain.
A new design concept of user definable oscillators allows the chip to execute instructions in four speed ranges from DC to 200ns.

## PIC's CMOS Design

The PIC employs a fully static CMOS design allowing for reliable low power operation. PIC incorporates on-chip POR and Watchdog Timer circuitry thus eliminating expensive off-chip support components.
Bit manipulation is one of PIC's strongest suits. The designer can now utilize very powerful bit manipulation instructions capable of setting, clearing and testing any bit in any register (including I/O registers) in one instruction cycle. This allows the PIC to efficiently interface to external circuitry and be used as a powerful I/O controller. The I/O is software definable bi-directional. Under software control, each pin of a port can be individually
time multiplexed between input and output or can be programmed into a high impedance state thus supporting multi-chip common bus configurations.
The PIC's small die size and Microchip's advanced CMOS technology support a wide performance range but also allow low operating and standby current. These low currents will make long-life battery dependent projects possible.

## PIC's Small Packaging

Microchip has also engineered the world's smallest 8-bit microcontroller package. For highly integrated designs, 300 mil. wide 18 pin PDIP, SOIC and PLCC surface mount packages are available. Tape and reel packaging is also offered for automatic high speed surface mount placement.

## PIC Temperature Ranges

The PIC16C5X family is currently available in commercial and industrial temperatures. There are plans to offer this family in automotive and military temperatures.

## Upward Migration Path

Future CMOS PIC generations will provide a family of products with embedded analog capabilities, additional I/O, sophisticated timers, increased memory and industry leading CPU power. The capability to address offchip extended RAM/EPROM memory and inter-chip communication is currently under development.

## PIC FAMILY PRODUCT GUIDE

High Performance CMOS Microcontrollers...
where performance and power efficiency is prime consideration.

| PIC16C5X CMOS MICROCONTROLLER |  |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Part Number | Pins | I/O | RAM | ROM | EPROM | Oscillator Range | Min.Instr.Cycle | Available |
| PIC16C54 | 18 | 12 | $32 \times 8$ | - | $512 \times 12$ | $25 \mathrm{kHz}-20 \mathrm{MHz}$ | 200 ns | NOW |
| PIC16C55 | 28 | 20 | $32 \times 8$ | - | $512 \times 12$ | $25 \mathrm{kHz}-20 \mathrm{MHz}$ | 200 ns | NOW |
| PIC16C56 | 18 | 12 | $32 \times 8$ | - | $1024 \times 12$ | $25 \mathrm{kHz}-20 \mathrm{MHz}$ | 200 ns | NOW |
| PIC16C57 | 28 | 20 | $80 \times 8$ | - | $2048 \times 12$ | $25 \mathrm{kHz}-20 \mathrm{MHz}$ | 200 ns | NOW |

Low-Cost NMOS Microcontrollers...
for highly cost sensitive applications where the superior performance of the PIC16C5X series is not required.

| PIC16XXX NMOS MICROCONTROLLER |  |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Part Number | Pins | I/O | RAM | ROM | EPROM | Oscillator Range | Min.Instr.Cycle | Available |
| PIC1654S | 18 | 12 | $32 \times 8$ | $512 \times 12$ | - | - | $2 \mu \mathrm{~s}$ | NOW |
| PIC1655 | 28 | 20 | $32 \times 8$ | $512 \times 12$ | - | - | $4 \mu \mathrm{~s}$ | NOW |
| PIC1670 | 40 | 32 | $64 \times 8$ | $1024 \times 13$ | - | - | $2 \mu \mathrm{~s}$ | NOW |

## PC-HOSTED SYSTEMS SIMPLIFY SOFTWARE DEVELOPMENT

Two advanced PC-hosted systems, the PIC-ICE ${ }^{\text {TM }}$ and PIC PAK ${ }^{\mathrm{TM}}$, are available to help users develop applications software and program PIC16C5X devices quickly and easily. Both operate with IBM PC, XT, AT, or compatibles.

## PIC-ICE

The PIC-ICE system provides low-cost in-circuit emulation and debugging and includes an 18-pin and 28-pin EPROM PIC programmer. This low profile module has a handy carrying case and comes with an external power supply, ribbon cabling, cross assembler, PIC16C5X EPROM product samples and a users manual. Key features include a DC to 20 MHz operating range, a builtin disassembler, breakpoints and a symbolic debugger.

## PIC PAK

The PIC PAK (PIC Applications Kit) is a powerful yet lowcost software development tool that combines assembler and simulator software to compile, execute, debug and analyze microcode in a non-real time environment. An EPROM PIC programmer (PIC PRO) and PIC16C5X EPROM product samples are included for code verification.

## PICALC Cross Assembler

The PIC Cross Assembler PICALC is available for several host computer platforms, including IBM PC. Macro assembly and conditional assembly are just a few of the capabilities of PICALC. Besides the PIC16C5x and PIC167x family members. PICALC can generate various object code formats to support Microchip's proprietary development tools as well as third party systems.

## PICSIM Software Simulator

The software simulator PICSIM allows PIC16C5x code development on IBM PCs without any additional hardware. It simulates the PIC16C5x series on instruction level. Software trace, break-points, symbolic debugging, and stimulus file generation are just a few of the features available. PICSIM is particularly useful in the early development stages of an application, or when real-time and/or in-circuit emulation are not necessary for the code development.

## PICPRO EPROM Programmer

PICPRO is a low volume EPROM programmer for the PIC16C5x series. It allows downloading and programming of PIC object code generated with PICALC from any host computer system providing a serial interface (RS232).

## QUALITY FROM THE TOP DOWN AND THE BOTTOM UP

Microchip's sole ownership of its facilities ensures our quality control standards remain consistent throughout all manufacturing steps. Continuous improvement programs are active at every operations level. Equipment for simulation, product testing and failure analysis is constantly updated to the most current levels of sophistication. Our customer support reaches out to the point when a customer ships his product.
To ensure product quality, Microchip conducts accelerated mechanical tests, temperature tests and memory retention tests to explore the many ways failures might occur. Stresses carefully applied over time, guarantee the effective operation of Microchip products. Comprehensive 1,000-hour qualification tests such as high temperature reverse bias, high temperature retention bake, latchup tests and operating life provide precise quality and reliability data. An electrostatic discharge sensitivity test is also conducted in accordance with MILSTD 883-C, method 5005.
Microchip PIC microcontrollers have demonstrated their reliability in several demanding applications such as high noise, high temperature under-hood automotive applications, NASA space shuttle missions and missile safe-arm fuse control.

## PIC 16xxx SERIES

## EXACTING SOLUTIONS FOR DEMANDING APPLICATIONS.....

## Smallest Packaging

For highly integrated insertion or surface mount modules, Microchip produces the smallest microcontroller devices in the world. An 18 pin DIP, SOIC or PLCC package makes space limited applications a design reality, such as:

- Handheld devices
- Automotive modules
- Small PC peripherals
- Consumer products

For even further integration, PIC's in dice form will also be available for Hybrid or COB packaging.

## Fastest Operating Speed

For "High Performance" applications, the PIC's 5 million instruction per second architecture offers a very unique solution. With PIC, system designers are now able to replace inaccurate predetermined look-up table values with high precision, real time, algorithmic processing.
PIC can solve several real-time problems often found in designs of:

- Disk Drives
- Pointing Devices/Scanners
- Motor/Compressor Controls
- I/O Processors
- "Glue" Logic Replacement


## Lowest Power Consumption

The PIC16C5X families possess one of the lowest standby and operating currents in the industry, opening new design opportunities for battery, solar and remotely powered applications, such as

- Cordless Telephones
- Mobile Telephones
- Automobile Electronic Locks
- Secure Access Remote Control
- Consumer Remote Controls
- Remote Smart Sensors
- Cordless Radar Detectors


## A GLOBAL COMMITMENT TO CUSTOMER SUPPORT

Microchip's commitment to microcontroller breakthrough technology is superseded only by our attention to customer support. Through a worldwide network of manufacturing facilities, sales offices and field applinotione support, Microchip delivers total customer service worldwide.


Microchip Technology Inc. • 2355 W. Chandler Blvd. •Chandler, AZ 85224-6199•(602) 963-7373•Printed in USA © 9003
United States: Mid-West (312) 505-0022 - North-East (508) 820-3334 - Mid-Atlantic (516) 232-1930 South-East (404) 642-6933 - South-Central (214) 733-0391 - North-West (408) 436-7950 - South-West (213) 323-1888 - France (1) 43.99.12.63 • West Germany (089) 6096072 • United Kingdom (0628) 776433 • Hong Kong 3/3116103 - Japan 3/2348774 • Singapore 2355326 • Taiwan 2/9146234 • Korea 2/7398543

Microchip

## PIC ${ }^{8}$ 16C5x Series

## EPROM-Based 8-Bit CMOS Microcontroller Series

## FEATURES

- Low power, high speed CMOS EPROM technology
- Wide variety of EPROM and RAM sizes, oscillator types, frequency ranges and I/O configurations
- Fully static chip design
- Operating Frequency Range:
- DC - 8 MHz ( 20 MHz future release)
- Operating voltage range:
- Standard: 4.0 V to 5.5 V
- Low power consumption:
- < 2 mA ( $4 \mathrm{MHz}, 5 \mathrm{~V}$, XTAL oscillator)
- <10 $\mu \mathrm{A}$ standby
- Available in temp ranges:
- Commercial $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
- Industrial $=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- Wide selection of 18 and 28 lead packaging options: PDIP, SOIC, PLCC, or CERDIP Window
- 512 to 2048 words of 12-bit program EPROM
- 32 to 80 words of 8 -bit data RAM
- Only 33 single 12 -bit-word instructions to learn
- 8 bit ALU
- 12 or 20 bidirectional tristate I/O's
- 2 level stack for subroutine nesting
- Direct, indirect, immediate, and relative addressing modes for data and instructions
- 8 bit real time clock/counter (RTCC) with selectable signal source and trigger edge
- Free running on-chip watchdog timer
- 8 bit prescaler, assignable to RTCC or watchdog timer
- Oscillator start up timer
- Security EPROM fuse for code protection
- QTP (factory programming) available

FIGURE 1: PIN CONFIGURATIONS

PDIP, SOIC
CERDIP Window


PLCC


PDIP, SOIC
CERDIP Window

| $\rightarrow$ RTCC $5 \cdot 1$ |  | 28 |
| :--- | :--- | :--- |
| $\rightarrow$ VDD |  | MCLR |
| N/C |  |  |

PLCC

## GENERAL DESCRIPTION

The Microchip Technology PIC16C5x series is based on the proven architecture of the PIC165x NMOS 8-bit microcontroller family. Using Microchip's low-power, high-speed CMOS EPROM technology, the PIC16C5x offers additional features like on-chip watchdog timer, tristate I/O, power-down mode, and several prescaler options.
The advantages of the user programmable CMOS EPROM technology allow extremely flexible applications, as well as reduced development costs and turnaround time compared to mask programmable ROM versions.

## APPLICATIONS

The PIC16C5x series fits perfectly for applications from high speed automotive and appliance motor control to low-power remote transmitters/receivers, pointing devices, and telecom processors. The EPROM technology allows customizing of application programs (transmitter codes, motor speeds, receiver frequencies, etc.) extremely fast and convenient. The small footprint packages for through hole or surface mounting make this microcontroller series perfect for all applications with space limitations. Low cost, high performance, ease of use, and I/O flexibility make the PIC16C5x series very versatile even in areas where no microcontroller use has been considered before (e.g. timer functions, replacement of "glue" logic in larger systems, co-processor applications).

| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| RAO - RA3 | I/O PORT A |
| RB0 - RB7 | I/O PORT B |
| RCO - RC7 | I/O PORT C |
| RTCC | Real Time Clock/Counter |
| MCLR | Master Clear |
| OSC1 | Oscillator (input) |
| OSC2/CLKOUT | Oscillator (output) |
| VDD | Power supply |
| VsS | Ground |
| N/C | No (internal) Connection |

## ARCHITECTURAL DESCRIPTION

## HARVARD ARCHITECTURE

The PIC16C5x single-chip microcomputers are lowpower, high-speed, full static CMOS devices containing EPROM, RAM, I/O, and a central processing unit on a single chip.

The firmware architecture is based on a register file concept with separate bus and memories for data and instructions (Harvard architecture). The data bus and memory (RAM) are 8 bits wide while the program bus and program memory (EPROM) have a width of 12 bits. This concept allows a simple yet powerful instruction set designed to emphasize bit, byte and register operations under high speed with overlapping instruction fetch and execution cycles. That means that, while one instruction is executed, the following instruction is already being read from the program memory. A block diagram of the PIC16C5x series is given in Figure 2.

## DATA REGISTER FILE

The 8 bit data bus connects two basic functional elements together: the Register File composed of up to 80 addressable 8 bit registers including the I/O Ports, and an 8 bit wide Arithmetic Logic Unit. 32 bytes of RAM are directly addressable while a "banking" scheme, with banks of 16 bytes each, is employed to address larger data memories (Figure 3). Data can be addressed direct, or indirect using the file select register (f4). Immediate data addressing is supported by special "literal" instructions which load data from program memory into the W register.
The register file is divided into two functional groups: operational registers and general purpose registers. The operational registers include the Real Time Clock Counter (RTCC) register, the Program Counter (PC), the Status Register, the I/O registers (PORTs), and the File Select Register. The general purpose registers are used for data and control information under command of the instructions.
In addition, special purpose registers are used to control the $I / O$ port configuration, and the prescaler options.

## ARCHITECTURAL DESCRIPTION (CONT.)

## ARITHMETIC/LOGIC UNIT (ALU)

The 8 bit wide ALU contains one temporary working register (W Register) and gating to perform Boolean functions between data held in the W Register and any file register.

## PROGRAM MEMORY

Up to 512 words of 12 bit wide on-chip program memory (EPROM) can be directly addressed. Larger program memories can be addressed by selecting one of up to four available pages with 512 words each (Figure 4).
Sequencing of microinstructions is controlled via the Program Counter (PC) which automatically increments to execute in-line programs. Program control operations, supporting direct, indirect, relative addressing modes, can be performed by Bit Test and Skip instructions, Call instructions, Jump instructions or by loading computed addresses into the PC. In addition, an on-chip two-level stack is employed to provide easy to use subroutine nesting.

FIGURE 2: PIC16C5x SERIES BLOCK DIAGRAM


## PIC16C5X SERIES OVERVIEW

A wide variety of EPROM and RAM sizes, number of I/Opins, oscillator types, frequency ranges, and packaging options is available. Depending on application and production requirements the proper device option can be selected using the following information and tables. When placing orders, please use the "PIC16C5x Product Identification System" on page 32 of this data sheet to specify the correct part number.

## UV ERASABLE DEVICES

Four different device versions, as listed in Table 1, are available to accommodate the different EPROM, RAM , and I/O configurations. These devices are optimal for prototype development and pilot series. The desired oscillator configuration is EPROM programmable as "RC", "XT", or "HS". An erased device is configured as "RC" type by default. Depending on the selected oscillator type and frequency, the operating supply voltage must be within the same range as a OTP/QTP part would be specified for.
The PIC development programmer, "PICPRO", can program all members of the PIC16C5x family for prototyping and small-volume production. See page 432 for high-volume programming support.

## ONE-TIME-PROGRAMMABLE (OTP) DEVICES

The availability of OTP devices is especially useful for customers expecting frequent code changes and updates. OTP devices have the oscillator type pre-configured by the factory, and they are tested only for this special configuration (including voltage and frequency ranges, current consumption). Table 2 below gives an overview about devices available now and planned for future release.

The program EPROM is erased, allowing the user to write his application code into it. In addition, the watchdog timer can be disabled, and/or the code protection logic can be activated by programming special EPROM fuses. The sixteen special EPROM bits for ID code storage are also user programmable.

## QUICK-TURNAROUND-PRODUCTION (QTP) DEVICES

Microchip offers a QTP Programming Service for factory production orders. This service is made available for users who chose not to program a medium to high quantity of units and whose code patterns have stabilized. The devices are identical to the OTP devices (see Table 2) but with all EPROM locations and fuse options already programmed by the factory. Certain code and prototype verification procedures do apply before production shipments are available. Please contact your Microchip Technology sales office for more details.

TABLE 1: OVERVIEW UV-ERASABLE DEVICES

| Part \# | EPROM | RAM | I/O** | Supply Voltage | Osc.Freq.Range | Package Options |
| :--- | :--- | :--- | :---: | :---: | :--- | :--- |
| PIC16C54 | $512 \times 12$ | $32 \times 8$ | 13 | $4.0^{*}-5.5 \mathrm{~V}$ | DC $-8 \mathrm{MHz} * * *$ | 18 ld . Windowed CERDIP |
| PIC16C55 | $512 \times 12$ | $32 \times 8$ | 21 | $4.0^{*}-5.5 \mathrm{~V}$ | DC $-8 \mathrm{MHz} * * *$ | 28 ld . Windowed CERDIP |
| PIC16C56 | $1 \mathrm{~K} \times 12$ | $32 \times 8$ | 13 | $4.0^{*}-5.5 \mathrm{~V}$ | DC $-8 \mathrm{MHz} * * *$ | 18 ld . Windowed CERDIP |
| PIC16C57 | $2 \mathrm{~K} \times 12$ | $80 \times 8$ | 21 | $4.0^{*}-5.5 \mathrm{~V}$ | DC $-8 \mathrm{MHz} * * *$ | 28 ld . Windowed CERDIP |

*. Frequencies above 4 MHz and/or operation in the industrial temperature range $\left(-40\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ require that Vdo is greater than 4.75 V .
** Includes RTCC pin
*** Device operation is currently guaranteed up to 8 MHz oscillator frequency.
Please contact Microchip Technology Inc. for expected release dates of 20 MHz devices.

TABLE 2: OVERVIEW OTP AND QTP DEVICES

| Part \# | EPROM | RAM | I/O* | Supply*** <br> Voltage | Osc. <br> Type | Freq. <br> Range | Package <br> Options (Note) |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| PIC16C54RC | $512 \times 12$ | $32 \times 8$ | 13 | $4.0-5.5 \mathrm{~V}$ | RC | DC-4 MHz | DIP-18, SOIC-18, PLCC-28 |
| PIC16C54XT | $512 \times 12$ | $32 \times 8$ | 13 | $4.0-5.5 \mathrm{~V}$ | XTAL, Ext. | $0.4-4 \mathrm{MHz}$ | DIP-18, SOIC-18, PLCC-28 |
| PIC16C54HS | $512 \times 12$ | $32 \times 8$ | 13 | $4.5-5.5 \mathrm{~V}$ | XTAL, Ext. | $4-8 \mathrm{MHz} * *$ | DIP-18, SOIC-18, PLCC-28 |

* Including RTCC pin
** Device operation is currently guaranteed up to 8 MHz oscillator frequency.
Please contact Microchip Technology for expected release dates of 20 MHz devices.
*** Minimum supply voltage for industrial temperature range is 4.5 V for XT and RC , and 4.75 V for HS versions.
Devices operating at supply voltages below 4.0 V or 4.5 V respectively, are under development.


## REGISTER FILE ARRANGEMENT

FIGURE 3: PIC16C5x DATA MEMORY MAP

(*) NOT A PHYSICALLY IMPLEMENTED REGISTER. SEE SECTION "OPERATIONAL REGISTER FILES" FOR DETAILS
(**) FILE f 7 IS A GENERAL PURPOSE REGISTER ON THE PIC16C54/C56
(**) BANK 0 IS AVAILABLE ON ALL MICROCONTROLLERS WHILE BANK 1 TO BANK 3 ARE ONLY AVAILABLE ON THE PIC16C57. (SEE SECTION "FILE SELECT REGISTER" FOR DETAILS)

## OPERATIONAL REGISTER FILES

## f0 INDIRECT DATA ADDRESSING

Not a physically implemented register. f0 calls for the contents of the File Select Register to be used to select a file register. f0 is useful as indirect address pointer. For example, the instruction ADDWF f0, W will add the contents of the register pointed to by the FSR (f4) to the content of the W Register and place the result in W.

## f1 REAL TIME CLOCK/COUNTER REGISTER (RTCC)

This register can be loaded and read by the program as any other register. In addition, its contents can be incremented by an external signal edge applied to the RTCC pin, or by the internal instruction cycle clock (CLKOUT=fosc/4).

An 8 bit prescaler can be assigned to the RTCC by writing the proper values to the PSA bit and the PS bits in the OPTION register. If the prescaler is assigned to the RTCC, instructions writing to f 1 (e.g. CLRF 1, or BSF1,5, ..etc.) clear the prescaler.

The bit "RTS" (RTCC signal Source) in the OPTION register determines, if f 1 is incremented internally or externally.

RTS=1: The clock source for the RTCC or the prescaler, if assigned to it, is the signal on the RTCC pin. Bit 4 of the OPTION register (RTE) determines, if an increment occurs on the falling (RTE=1) or rising ( $R T E=0$ ) edge of the signal presented to the RTCC pin.

RTS=0: The RTCC register or its prescaler, respectively, will be incremented with the internal instruction clock (= Fosc/4). The "RPIE" bit in the OPTION register and the RTCC pin are "don't care" in this case. However, the RTCC pin must be tied to VDD or Vss, whatever is convenient, to prevent unintended entering of test modes and to reduce the current consumption in low power applications.

As long as clocks are applied to the RTCC (from internal or external source, with or without prescaler), f1 keeps incrementing and just rolls over when the value "0FF16" is reached. All increment pulses for $f 1$ are delayed by two instruction cycles. After writing to f1, for example, no increment takes place for the following two instruction cycles. This is independent if internal or external clock source is selected. If a prescaler is assigned to the RTCC, the output of the prescaler will be delayed by two cycles before f1 is incremented.

## OPERATIONAL REGISTER FILES (CONT.)

## f2 PROGRAM COUNTER

The program counter generates the addresses for the up to $2048 \times 12$ on-chip EPROM cells containing the program instruction words (Figure 4).

Depending on the device type, the program counter and its associated two-level hardware stack is $9-11$ bits wide.

TABLE 3: PROGRAM COUNTER/STACK WIDTH

| Part \# | PC width | Stack width |
| :--- | :---: | :---: |
| PIC16C54/PIC16C55 | 9 bit | 9 bit |
| PIC16C56 | 10 bit | 10 bit |
| PIC16C57 | 11 bit | 11 bit |

The program counter is set to all " 1 "s upon a RESET condition. During program execution it is auto incremented with each instruction unless the result of that instruction changes the PC itself:
a) "GOTO" instructions allow the direct loading of the lower 9 program counter bits.
b) "CALL" instructions load the lower 8 bit of the PC directly while the ninth bit is cleared to " 0 ". The PC value, incremented by one, will be pushed into the stack.
c) "RETLW" instructions load the program counter with the top of stack contents.
d) "MOVWF 2" allows the loading of computed addresses from the W register into the program counter.
e) "ADDWF 2" allows adding of relative addresses to the current PC contents. In this case the PC will also be incremented. That is, adding "000" to $f 2$ results in the $P C$ value $P C+1$.
In the cases d ) and e), the ninth bit of the PC will always be cleared to " 0 ". Thus, indexed addressing is only possible within the lower half of a program memory page (addresses 000-0FF, 200-2FF, 400-4FF, 600-6FF).

## Program Memory Page Select (PIC16C56/ PIC16C57 Only):

The most significant program counter bit(s) will be loaded with the contents of the page preselect bits in the status register f3 upon execution of a "GOTO", "CALL", "ADDWF 2", or "MOVWF 2" instruction.

Incrementing the program counter when it is pointing to the last address of a selected memory page is also possible and will cause the program to continue in the next higher page. However, the page pre-select bits in $f 3$ will not be changed, and the next "GOTO", "CALL", "ADDWF 2", "MOVWF 2" instruction will return to the previous page, unless the page pre-select bits have been updated under program control. For example, a "NOP" at location "1FF"(page 0) increments the PC to "200" (page 1). A "GOTO xxx" at "200" will return the program to address "xxx" on page "0" (assuming that the page preselect bits in $f 3$ are " 0 ".
Upon a RESET condition, page 0 is pre-selected while the program counter addresses the last location in the last page. Thus, a "GOTO" instruction at this location will automatically cause the program to continue in page 0.

## Stack

The PIC16C5x series employs a two level hardware push/pop stack (Figure 4).

CALL instructions push the current program counter value, incremented by " 1 ", into stack level 1 . Stack level 1 is automatically pushed to level 2 . If more than 2 subsequent "CALL"s are executed, only the most recent two return addresses are stored.
For the PIC16C56 and PIC16C57, the page preselect bits of $f 3$ will be loaded into the most significant bits of the program counter. The ninth bit is always cleared to " 0 " upon a CALL instruction. This means that subroutine entry addresses have to be located always within the lower half of a memory page (addresses 000-0FF, 2002FF, 400-4FF, 600-6FF). However, as the stack has always the same width as the PC, subroutines can be called from anywhere in the program.

RETLW instructions load the contents of stack level 1 into the program counter while stack level 2 gets copied into level 1. If more than 2 subsequent "RETLW"s are executed, the stack will be filled with the address previously stored in level 2 . For the PIC16C56 and PIC16C57, the return will be always to the page from where the subroutine was called, regardless of the current setting of the page pre-select bits in file register f3. Note that the W register will be loaded with the literal value specified in the RETLW instruction. This is in particular useful for the implementation of "data" tables within the program memory.

## PIC ${ }^{\circledR} 16 C 5 x$ Series

## OPERATIONAL REGISTER FILES (CONT.)

FIGURE 4: PROGRAM MEMORY ORGANIZATION


## OPERATIONAL REGISTER FILES (CONT.)

## f3 STATUS WORD REGISTER

This register contains the arithmetic status of the ALU, the RESET status, and the page preselect bits for larger program memories than 512 words (PIC16C56, PIC16C57).
f3 can be altered under program control only via bit set, bit clear, or MOVWF 3 instructions except for the "TO" and "PD" bits.
For other instructions, affecting any status bits, see section "Instruction Set Summary."

## Time out and power down status bits (TO, PD)

The "TO" and "PD" bits in the status register f 3 can be tested to determine if a RESET condition has been caused by a watchdog timer time-out, a power-up condition, or a wake-up from SLEEP by the watchdog timer or $\overline{M C L R}$ pin.
These status bits are only affected by events listed in Table 4.

```
STATUS WORD REGISTER f3
```



```
For ADDWF and SUBWF instructions, this bit is set if there is a carry out from the most significant bit of the resultant. Note that a subtraction is executed by adding the two's complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high or low order bit of the source register.
DIGIT CARRY BIT:
For ADDWF and SUBWF instructions, this bit is set if there is a carry out from the 4th low order bit of the resultant.
ZERO BIT:
Set if the result of an arithmetic or logic operation is zero.
POWER DOWN BIT:
Set to "1" during power up or by a CLRWDT command. This bit is reset to " 0 " by a SLEEP instruction.
TIME-OUT BIT:
Set to "1" during power up and by the CLRWDT and SLEEP command. This bit is reset to " 0 " by a watchdog timer time out.
PIC16C54/C55 : Two general purpose read/write bits
PIC16C56 : BIT 5 ... Page preselect bit \(0=\) Page 0 (000-1FF) 1 = Page 1 (200-3FF)
BIT 6 ... General purpose read/write bit
PIC16C57 : Two page preselect bits
\[
\begin{aligned}
& 00=\text { Page } 0(000-1 \text { FF }) \\
& 01=\text { Page } 1(200-3 F F) \\
& 10=\text { Page } 2(400-5 F F) \\
& 11=\text { Page } 3(600-7 F F)
\end{aligned}
\]
BIT 7: General purpose read/write bit
(reserved for future use)
```


## OPERATIONAL REGISTER FILES (CONT.)

| TABLE 4: |  |  |  |
| :--- | :---: | :---: | :--- |
| EVENTS AFFECTING PD/TO STATUS BITS |  |  |  |
| Event | TO | PD | Remarks |
| Power-up | 1 | 1 |  |
| WDT Timeout | 0 | $X$ | No effect on PD |
| SLEEP instruction | 1 | 0 |  |
| CLRWDT instruction | 1 | 1 |  |

Note: A WDT timeout will occur regardless of the status of the TO bit. A SLEEP instruction will be executed, regardless of the status of the PD bit. Table 5 reflects the status of PD and TO after the corresponding event.

| то | PD | RESET was caused by |
| :---: | :---: | :---: |
| 0 | 0 | WDT wake-up from SLEEP |
| 0 | 1 | WDT time-out (not during SLEEP) |
| 1 | 0 | $\overline{M C L R}$ wake-up from SLEEP |
| 1 | 1 | Power-up |
| x | x | = Low pulse on $\overline{\text { MCLR }}$ input |

Note: The PD and TO bit maintain their status (X) until an event of Table 4 occurs. A low-pulse on the $\overline{M C L R}$ input does not change the PD and TO status bits.

## Program Page Preselect (PIC16C56, PIC16C57 ONLY)

Bits 5-6 of the STATUS register are defined as PAGE address bits PA0 - PA1, and are used to preselect a program memory page. When executing a GOTO, CALL, MOVWF 2, or ADDWF 2 instruction, PAO-PA1 are loaded into bit A9-A10 of the program counter, selecting one of the available program memory pages. The direct address specified in the instruction is only valid within this particular memory page.
RETLW instructions do not change the page preselect bits.
Upon a RESET condition, PAO-PA2 are cleared to "0"s.

## f4 FILE SELECT REGISTER (FSR) PIC16C54/C55/C56

Bits 0-4 select one of the 32 available file registers in the indirect addressing mode (that is, calling for file f0 in any of the file oriented instructions).
Bits 5-7 of the FSR are read-only and are always read as "one"s.
If no indirect addressing is used, the FSR can be used as a 5 bit wide general purpose register.

## PIC16C57 ONLY

Bit 5 and 6 of the FSR select the current data memory bank (Figure 3).
The lower 16 bytes of each bank are physically identical and are always selected when bit 4 of the FSR (in case of indirect addressing) is " 0 ", or bit 4 of the direct file register address of the currently executing instruction is "0" (e.g. MOVWF 08).
Only if bit 4 in the above mentioned cases is "1", bits 5 and 6 of the FSR select one of the four available register banks with 16 bytes each.
Bit 7 is read-only and is always read as "one."

## I/O REGISTERS (PORTS)

The I/O registers can be written and read under program control like any other register of the register file. However, "read" instructions (e.g. MOVF 6,W) read always the I/O pins, regardless if a pin is defined as "input" or "output." Upon a RESET condition, all I/O ports are defined as "input" (= high impedance mode) as the I/O control registers (TRISA, TRISB, TRISC) are all set to "ones."
The execution of a "TRIS f" instruction with corresponding "zeros" in the W-register is necessary to define any of the I/O pins as output.

## f5 (PORT A)

4-bit I/O register. Low order 4 bits only are used (RAO RA3). Bit 4-7 are defined as "zeros."

## f6 (PORT B)

8-bit I/O register.

## f7 (PORT C)

PIC16C55/C57 : 8-bit I/O register
PIC16C54/C56 : General purpose register.

## I/O INTERFACING

The equivalent circuit for an l/O port bit is shown in Figure 5. All ports may be used for both input and output operations. For input operations these ports are nonlatching. Any input must be present until read by an input instruction (e.g. MOVF 6, W). The outputs are latched and remain unchanged until the output latch is rewritten. For use as an output, the I/O control register (TRISA,TRISB, TRISC) must be zero in order to enable the output buffer. For use as an input the I/O control register must be "one" in order to allow an external device to drive the port high or low. This principle is the same whether operating on individual pins or the entire port. Any I/O pin can be programmed individually as input, output or bidirectional pin.

FIGURE 5: EQUIVALENT CIRCUIT FOR A SINGLE I/O PIN


## I/O PROGRAMMING HINTS

## BIDIRECTIONAL I/O PORTS

a) Some instructions operate internally as input followed by output operations. The BCF and BSF instructions, for example, read the entire port into the CPU, execute the bit operation, and re-output the result. Caution must be used when these instructions are applied to a port where one or more pins are used as input/outputs. As an example, a BSF operation on bit 5 of $f 6$ (Port B) will cause all eight bits of $f 6$ to be read into the CPU. Then the BSF operation takes place on bit 5 and $f 6$ is re-output to the output latches. If another bit of $f 6$ is used as a bidirectional I/O pin (say bit 0 ) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and re-written to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the input mode, no problem occurs. However, if bit 0 is switched into output mode later on, the content of the data latch may now be unknown.
b) A pin actively outputting a " 0 " or " 1 " should not be driven from external devices at the same time in order to change the level on this pin ("wired-or", "wired-and"). The resulting high output currents may disturb an otherwise clean power supply, and proper device functionality is not guaranteed.
For "wired-or" outputs (assuming negative logic), it is recommended to use external pull-up resistors on the corresponding pins. The pin should be left in high-impedance mode, unless a " 0 " has to be output. Thus, external devices can drive this pin " 0 " as well. "Wired-and" outputs can be realized in the same way, but with external pull-down resistors and only actively driving the " 1 " level from the PIC. The resistor values are user selectable, but should not force output currents above the specified limits (see DC Characteristics).

## SUCCESSIVE OPERATIONS ON I/O PORTS

Writing to an I/O port happens always at the end of an instruction cycle, while for reading, the data have to be valid as shown in Figure 20.
Therefore, care must be exercised if successive instructions operate on the same I/O port. The sequence of instructions should be such to allow the pin voltage to stabilize (load dependent) before the next instruction which causes that file to be read into the CPU is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. When in doubt, it is better to separate these instructions with a NOP or an other instruction not accessing this I/O port.

## OPERATION IN NOISY ENVIRONMENT

In noisy application environments, for example keyboards which are exposed to ESD (Electro Static Discharge), register contents can get corrupted due to noise spikes.
The on-chip watchdog timer will take care of all situations involving program sequence "lock-ups." However, if a l/O control register gets corrupted, the program sequence may still be executed properly although an input pin may have switched unintentionally to an output. In this case, the program would always read the same value on this pin. This may result, for example, in a keyboard "lock-up" situation without leading to a watchdog timer timeout. Thus, it is recommended to redefine all I/O pins in regular time intervals (inputs as well as outputs). The optimal strategy is to update the I/O control register every time before reading or putting data out.

## GENERAL PURPOSE REGISTERS

## PIC16C54/C55/C56 :

f0816-f1F16: are general purpose register files.

## PIC16C57 ONLY:

f0816-f0F16: are general purpose register files which are always selected, independent of bank select.
f1016-f1F16: general purpose register files in memory bank 0
f2016-f2F16: physically identical to f00-f0F
f 3016 - $\mathrm{f} 3 \mathrm{~F}_{16}$ : general purpose register files in memory bank 1
f4016-f4F16: physically identical to f00-f0F
f5016-f5F16: general purpose register files in memory bank 2
f6016-f6F16: physically identical to f00-f0
f7016-f7F16: general purpose register files in memory bank 3

## SPECIAL PURPOSE REGISTERS

## W WORKING REGISTER

Holds second operand in two operand instructions and/ or supports the internal data transfer.

## TRISA I/O CONTROL REGISTER FOR PORT A (f5)

Bit 0-3 only available. The corresponding I/O port (f5) is only 4 bit wide.

## TRISB I/O CONTROL REGISTER FOR PORT B (f6)

## TRISC I/O CONTROL REGISTER FOR PORT C (f7)

The I/O control registers will be loaded with the content of the W register by executing of the TRIS finstruction. A "1" in the I/O control register puts the corresponding I/O pin into a high impedance mode. A "0" puts the contents of file register $f 5, \mathrm{f} 6$, or $\mathrm{f7}$, respectively, out on the selected I/O pins.
These registers are "write-only" and are set to all "ones" upon a RESET condition.

## OPTION PRESCALER/RTCC OPTION REGISTER

Defines prescaler assignment (RTCC or WDT), prescaler value, signal source and signal edge for the RTCC. The OPTION register is "write-only" and is 6 bit wide. By executing the "OPTION" instruction, the contents of the " W " register will be transferred to the option register. Upon a RESET condition, the option register will be set to all "ones."

OPTION REGISTER


## RESET CONDITION

A RESET condition can be caused by applying power to the chip (power-up), pulling the $\overline{M C L R}$ input "low", or by a Watchdog Timer Timeout. The device will stay in RESET as long as the oscillator start-up timer (OST) is active or the $\overline{M C L R}$ input is "low."
During a RESET condition the PIC function is defined as:

- The oscillator is running, or will be started (powerup or wake-up from SLEEP)
- All I/O port pins (RAO - RA3, RB0 - RB7, RC0 RC7) are put into the high-impedance state (tristated) by setting the "TRIS" registers to all "ones" (= input mode).
- The Program Counter is set to all "ones"
- The OPTION register is set to all "ones"
- The Watchdog Timer and prescaler are cleared
- The upper three bits (page select bits) in the Status Register (f3) are cleared to "zero."
- "RC" devices only: The "CLKOUT" signal on the OSC2 pin is held at a"low" level.


## PRESCALER

An 8-bit counter is available as prescaler for the RTCC, or as post-scaler for the watchdog timer, respectively (Figure6). For simplicity, this counter is being referred to as "prescaler" throughout this data sheet. Note that there is only one prescaler available which is mutually exclusively shared between the RTCC and the watch
dog timer. Thus, a prescaler assignment for the RTCC means that there is no prescaler for the watchdog timer, and vice versa.
The PSA and PS0-PS2 bits in the OPTION register determine the prescaler assignment and ratio.
The prescaler will be cleared whenever the circuit to which it is assigned is being written to. That is, when assigned to the RTCC, all instructions writing to the RTCC (e.g. CLRF 1, MOVWF 1, BSF 1,x ....etc.) will clear the prescaler.

## PRESCALER PROGRAMMING CAUTIONS

The prescaler assignment is fully under software control. Thus, it can be changed "on the fly" during program execution. To avoid an unintended device RESET, the following instruction sequence has to be executed when changing the prescaler assignment from RTCC to WDT:

## 1.MOVLW B'xxx00xxx' 2.OPTION <br> 3.CLRF 1 <br> 4.MOVLW B'xxxx1x10' 5.OPTION

;Select internal RTCC clock ;
;Clear RTCC and prescaler
;Select WDT prescaler with ratio $\geq 1: 4$
Step 1 and 2 are only required if an external RTCC source is used with a clock period less than Tcy +20 ns . In all other cases, only steps 3-5 are necessary.
No precaution is required when changing the prescaler assignment from WDT to RTCC.

FIGURE 6: BLOCK DIAGRAM RTCC/WDT PRESCALER


## BASIC INSTRUCTION SET SUMMARY

Each PIC instruction is a 12-bit word divided into an OP code which specifies the instruction type and one or more operands which further specify the operation of the instruction. The PIC instruction set summary in Table 6 lists byte-oriented, bit-oriented, and literal and control operations.

For byte-oriented instructions, "f" represents a file register designator and " d " represents a destination designator. The file register designator specifies which one of the 32 PIC file registers is to be utilized by the instruction. For the PIC16C57, bit 5 and 6 in the FSR determine the selected register bank.
The destination designator specifies where the result of the operation is to be placed. If "d" is zero, the result is placed in the W register. If " d " is one, the result is placed in the file register specified in the instruction.

For bit-oriented instructions, "b" represents a bit field designator which selects the number of the bit affected by the operation, while " f " represents the number of the file in which the bit is located.
For literal and control operations, " $k$ " represents an eight or nine bit constant or literal value.

All instructions are executed within one single instruction cycle, unless a conditional test is true or the program counter is changed as a result of an instruction. In this case, the execution takes two instruction cycles. One instruction cycle consists of four oscillator periods. Thus, for an oscillator frequency of 4 MHz , the normal instruction execution time is $1 \mu \mathrm{sec}$. If a conditional test is true or the program counter is changed as a result of an instruction, the instruction execution time is $2 \mu \mathrm{sec}$.

## NOTES TO TABLE 6

Note1: The 9th bit of the program counter will be forced to a "zero" by CALL , MOVWF 2 , or ADDWF 2 instructions.
Note 2: When an I/O register is modified as a function of itself ( e.g. MOVF 6,1), the value used will be that value present on the pins themselves. For example, a tristated pin which data latch is "1" but is driven low by an external device, will be relatched in the low state.
Note 3: The instruction "TRIS $f$ ", where $f=5$ or 6 or 7 causes the contents of the $W$ register to be written to the tristate latches of the specified file (port). A "one" forces the pin to a high impedance state and disables the output buffers.
Note 4: If this instruction is executed on file register f1 ( and, where applicable, $d=1$ ), the prescaler will be cleared if assigned to the RTCC.


Notes: See previous page

## WATCHDOG TIMER (WDT)

The watchdog timer is realized as a free running on-chip RC oscillator which does not require any external components. That means that the WDT will run, even if the clock on the OSC1/OSC2 pins of the device has been stopped, for example, by execution of a SLEEP instruction. A WDT timeout generates a device RESET condition. The WDT can be permanently disabled by programming a "zero" into a special EPROM fuse which is not part of the normal program memory EPROM. The PIC development tools "PIC-ICE" and "PICPRO" provide special commands to program this fuse.

## WDT PERIOD

The WDT has a time-out period of approx. 18 ms . If longer time-out periods are desired, a prescaler with a division ratio of up to 1:128 can be assigned to the WDT under software control by writing to the OPTION register. Thus, time-out periods up to 2.5 seconds can be realized.
The "CLRWDT" and "SLEEP" instructions clear the WDT and the prescaler, if assigned to the WDT, and prevent it from timing out and generating a device RESET condition.
The status bit "TO" in file register f 3 will be cleared upon a watchdog timer timeout.
The WDT period is a function of the supply voltage, operating temperature, and may also vary from unit to unit due to variations in the manufacturing process. Please refer to the ELECTRICAL CHARACTERISTICS section and Figures 21, 22 for more details.

## SPECIAL WDT PROGRAMMING CAUTIONS:

## 1. PIC16C54/C55:

If no prescaler is assigned to the WDT, its typical timeout period is 18 ms . However, a CLRWDT or SLEEP instruction has to occur before $1 / 2$ of the time-out period (i.e. 9 ms ) is over. Otherwise, the CLRWDT or SLEEP instruction itself will cause a device RESET. If the WDT has a prescaler assigned, the full WDT period is available for a CLRWDT instruction.
This precaution is not necessary for the PIC16C56 and PIC16C57.
2. In a noisy application environment the OPTION register can get corrupted. The OPTION register should be updated at regular intervals.
It should also be taken in account that under worst case conditions (VDD = Min., Temperature = Max., max. WDT prescaler) it may take several seconds before a WDT timeout occurs.

## OSCILLATOR CIRCUITS OSCILLATOR TYPES

The PIC16C5x series is available with 4 different oscillator circuits. On windowed devices, a particular oscillator circuit can be selected by programming the configuration EPROM accordingly. The PIC development tools (e.g. PIC-ICE, PICPRO) provide special commands to select the desired oscillator configuration.
On OTP and QTP devices, the oscillator configuration is determined by the factory and the parts are tested only to the according specifications.

## CRYSTAL OSCILLATOR

The PIC16C5x-XT, -HS needs a crystal or ceramic resonator connected to the OSC1 and OSC2 pins to establish oscillation (Fig. 7). Note that the series resistor Rs is only required for the "HS" oscillator.

## RC OSCILLATOR

For timing uncritical applications the "RC" device option offers additional cost savings. The RC oscillator frequency is a function of the supply voltage, the resistor (Rext) and capacitor (Cext) values, and the operation temperature. In addition, there will be variation from unit to unit due to normal process variation. Figure 9 shows how the R/C combination is connected to the PIC16C5x. Some typical values for the oscillator frequency at given $R$ and $C$ values and supply voltages are listed in Table 7. For Rext values below 2.2 kOhm , the oscillator operation will become unstable, or stop completely. For very high Rext values (e.g. 1 MOhm), the oscillator becomes sensitive to noise and humidity. Thus, we recommend to keep Rext between 5 kOhm and 100 kOhm.

| TABLE 7: |  |  |  | RC OSCILLATOR FREQUENCIES |
| :--- | :--- | :--- | :--- | :--- |
| Rext | Cext | Vod | Fosc | $\mathrm{t}=\mathbf{2 5}^{\circ} \mathbf{~ C}$ |
| 5 kOhm | 0 pF | 5.0 V | 4.0 MHz |  |
| 5 kOhm | 20 pF | 6.0 V | 2.2 MHz |  |
| 5 kOhm | 20 pF | 3.5 V | 2.5 MHz |  |
| 10 kOhm | 130 pF | 5.0 V | 480 kHz |  |
| 10 kOhm | 290 pF | 5.0 V | 245 kHz |  |
| 100 kOhm | 300 pF | 3.5 V | 30 kHz |  |
| Rext. min. $=2.2 \mathrm{kOhm}$, Cext. min. $=0 \mathrm{pF}$ | (see text) |  |  |  |

Although the oscillator will operate with no external capacitor (Cext $=0 \mathrm{pF}$ ), we recommend using values above 20 pF for noise and stability reasons.
Figure 10 shows the typical dependency of the oscillator frequency from VDD for given Rext/Cext values. Figure 11 shows the frequency as a typical function of the
operating temperature with given R, C, and VDD values. Note that this graph is normalized to $25^{\circ} \mathrm{C}$.

The oscillator frequency, divided by 4 , is available on the OSC2/CLKOUT pin, and can be used for test purposes or to synchronize other logic (see Fig. 20 for timing).

FIGURE 7: CRYSTAL OPERATION (OR CERAMIC RESONATOR) (HS, XT TYPES ONLY)


TYPICAL VALUES FOR C: $\quad 20 \mathrm{pF}$ (CRYSTAL 4 MHz )
30 pF (CERAMIC RESONATOR 4 MHz )
Rs IS ONLY REQUIRED FOR "HS" DEVICES ( $100 \Omega$ < Rs < $1 \mathrm{~K} \Omega$ )

FIGURE 8: EXTERNAL CLOCK INPUT OPERATION (HS, XT TYPES ONLY)


FIGURE 10: TYPICAL RC OSCILLATOR FREQUENCY vs. VDD


FIGURE 9: R/C OSCILLATOR (RC TYPE ONLY)


FIGURE 11: TYPICAL RC OSCILLATOR FREQUENCY vs. TEMPERATURE


## OSCILLATOR START-UP TIMER (OST)

Oscillator circuits based on crystals or ceramic resonators require a certain time after power-up to establish a stable oscillation. An on-chip oscillator start-up timer is provided which keeps the device in a RESET condition for approx. 18 ms after the voltage on the $\overline{M C L R}$ pin has reached the ViHmc input level. Thus, external RC networks connected to the MCLR input are not required in most cases, allowing for savings in cost-sensitive and/or space restricted applications.
The OST will also be triggered upon a watchdog timer timeout. This is in particular important for applications using the WDT to awake the PIC16C5x from SLEEP mode automatically.

## POWER DOWN MODE (SLEEP)

The power down mode is entered by executing a SLEEP instruction.
When enabled, the watchdog timer will be cleared but keeps running, the bit "PD" in the status register (f3) is cleared, the "TO" bit is set, and the oscillator driver is turned off. The I/O ports maintain the status they had, before the SLEEP command was executed (High, Low, $\mathrm{Hi}-\mathrm{Z}$ ).
For lowest current consumption in this mode, all I/O pins should be either at VDD, or Vss, with no external circuitry drawing current from the I/O pin. If the I/O pins are in the High-Z mode they must be pulled high or low externally in order to avoid switching currents caused by floating inputs.
The MCLR pin must be at Viнmc. The RTCC pin must be at Vilrt or Vihrt.

## WAKE-UP

The device can be awakened by a watchdog timer timeout (if it is enabled) or an externally applied "low" pulse at the $\overline{M C L R}$ pin. In both cases the PIC will stay in RESET mode for one oscillator start-up timer period (triggered from rising edge on $\overline{M C L R}$ or WDT timeout) before normal program execution resumes.

The "PD" bit in the STATUS register, which is set to one during power on, but cleared by the "SLEEP" command, can be used to determine if the processor was powered up or awakened from the power down mode (Table 5). The TO bit in the Status register can be used to determine, if the "wake up" was caused by an external MCLR signal or a watchdog timer time out.

NOTE: Some applications may require external R/C networks on the $\overline{M C L R}$ pin in order to allow for oscillator startup times longer than one OST period. In this case, a WDT wake up from power down mode is not recommended, because a RESET generated by a WDT time out does not discharge the external capacitor, and the PIC will be in RESET only for the oscillator start-up timer period.

## CONFIGURATION EPROM

The configuration EPROM consists of four EPROM fuses which are not part of the normal EPROM for program storage.
Two are for the selection of the oscillator type (program only on parts in package with window), one is the watchdog timer enable fuse, and one is the code protection fuse.
The PIC development tools allow the setting of these fuses with special commands.
OTP or QTP devices have the oscillator configuration programmed by the factory and the parts are tested accordingly. The packages are marked with the suffixes "XT", "RC", "HS" following the part number to identify the oscillator type and operating range.

## CUSTOMER ID CODE

The PIC16C5x series has 16 special EPROM bits which are not part of the normal program memory. These bits are available to the user to store an Identifier (ID) code, checksum, or other informative data. They cannot be accessed during normal program execution. The PIC16C5x programmers (PICPRO) provide special commands to read or write these ID bits.

## CODE PROTECTION

The program code written into the EPROM can be protected by programming the code protection fuse with " 0 ".
If the code protection logic is activated, the contents of the program EPROM cannot be read out in a way that the program code can be reconstructed. In addition, all memory locations starting at 04016 and above are protected against programming.
It is still possible to program locations 00016-03F16, the 16 ID bits, the watchdog timer disable fuse, and, for windowed parts only, the oscillator configuration.
Note that the configuration fuses and the ID bits can still be read, even if the code protection logic is active.

## ELECTRICAL CHARACTERISTICS

ABSOLUTE MAXIMUM RATINGS*
Ambient temperature under bias ............-55 to $+125^{\circ} \mathrm{C}$ Storage Temperature ....................... - $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on any pin with respect to Vss
(except VDD and MCLR) $\qquad$ -0.6 V to $\mathrm{VDD}+0.6 \mathrm{~V}$
Voltage on VDD with respect to Vss .............. 0 to +9.5 V
Voltage on $\overline{M C L R}$ with respect to Vss (Note 2) $\qquad$ 0 to +14 V
Total power Dissipation (Note 1) .................... 800 mW
Max. Current out of Vss pin .............................. 150 mA
Max. Current into VDD pin .................................. 50 mA
Max. Output Current sinked by any I/O pin ....... 25 mA
Max. Output Current sourced by any I/O pin ..... 20 mA
Max. Output Current sourced by a single
I/O port (Port A, B, or C) $\qquad$ 40 mA
Max. Output Current sinked by a single
I/O port (Port A, B, or C) 50 mA
"Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

Notes: 1. Total power dissipation should not exceed 800 mW for the package. Power dissipation is calculated as follows:
Pdis $=$ VDD $\times\{$ lDD $-\Sigma$ loh $\}+\sum\{($ VDD-Voh $) \times$ loh $\}$ $+\Sigma(\mathrm{Vol} \times \mathrm{lol})$
2. Voltage spikes below Vss at the $\overline{M C L R}$ pin, inducing currents greater than 80 mA , may cause latch-up. Thus, a series resistor of 50$100 \Omega$ should be used when applying a "low' level to the MCLR pin rather than pulling this pin directly to Vss.

| PIN DESCRIPTIONS |  |  |
| :---: | :---: | :---: |
| Name | Function | Observation |
| RA0-RA3 | I/O PORT A | 4 input/output lines |
| RB0-RB7 | I/O PORT B | 8 input/output lines |
| RC0-RC7 | I/O PORT C | 8 input/output lines, (PIC16C55/C57 only ) |
| RTCC | Real Time Clock/Counter | Schmitt Trigger Input <br> Clock input to RTCC register. Must be tied to Vss or VDD if not in use to avoid unintended entering of test modes and to reduce current consumption. |
| $\overline{\mathrm{MCLR}}$ | Master Clear | Schmitt Trigger Input <br> A "Low" voltage on this input generates a RESET condition for the PIC16C5x microcontroller. <br> A rising voltage triggers the on-chip oscillator start-up timer which keeps the chip in RESET mode for about 18 ms . This input must be tied directly, or via a pull-up resistor, to VDD. |
| OSC1 | Oscillator (input) | "XT", "HS" devices: Input terminal for crystal, ceramic resonator, or external clock generator. <br> "RC" devices : Driver terminal for external RC combination to establish oscillation. |
| OSC2/CLKOUT | Oscillator (output) | For "XT", "HS" devices: Output terminal for crystal and ceramic resonator. Do not connect any other load to this output. Leave open if external clock generator is used. For "RC" devices: A "CLKOUT" signal with a frequency of $1 / 4$ Fosc1 is put out on this pin. |
| VdD | Power supply |  |
| Vss | Ground |  |
| N/C | No (internal) Connection |  |


| DC CHARACTERISTICS, POWER SUPPLY PINS | Standard Operating Conditions PIC16C5x Operating temperature PiC 16 C5xi Operating temperature |  |  |  |  | $\begin{aligned} 0 & \leq T_{A} \leq+70^{\circ} \mathrm{C} \\ -40 & \leq T_{A} \leq+85^{\circ} \mathrm{C} \text {, unitess otherwise stated } \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | $\begin{array}{\|c\|} \hline \text { Min } \\ \text { PIC } \\ 16 C 5 x \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline \text { Min } \\ \text { PIC } \\ 16 C 5 \times 1 \end{array}$ | $\begin{gathered} \text { Typ } \\ \text { (Note 1) } \end{gathered}$ | Max | Units | Conditions |
| Supply Voltage <br> PIC16C5xXT (Note 3) <br> PIC16C5xRC (Note 3) <br> PIC16C5xHS (Notes 3,8) <br> PIC16C5xHS (Notes 3,8) | Vddxt <br> VdDrc <br> VDDhs <br> VDohs | $\begin{aligned} & 4.0 \\ & 4.0 \\ & 4.5 \end{aligned}$ | $\begin{aligned} & 4.5 \\ & 4.5 \\ & 4.75 \end{aligned}$ |  | $\begin{aligned} & 5.5 \\ & 5.5 \\ & 5.5 \\ & 5.25 \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \text { Fosc }=4 \mathrm{MHz} \\ & \text { Fosc }=4 \mathrm{MHz} \\ & \text { Fosc }=8 \mathrm{MHz} \\ & \text { Fosc }=8 \mathrm{MHz} \end{aligned}$ |
| RAM Data Retention Voltage (Notes 3, 4 ) | VDR |  |  | 1.5 |  | V | Device in SLEEP mode |
| Power-on trip voltage to set 'TO" and "PD" status bit | VPOR |  |  | 1.2 |  | V | at Vod pin (Note 7), MCLR pin tied to VDD |
| ```Supply Current (Notes 2, 3) PIC16C5xXT PIC16C5xRC (Note 6) PIC16C5xHS (Note 8)``` | IdDxt Iddrc IDDhs |  |  | $\begin{aligned} & 1.8 \\ & 1.8 \\ & 4.8 \end{aligned}$ | $\begin{aligned} & 3.3 \\ & 3.3 \\ & 10.0 \end{aligned}$ | $\begin{gathered} \mathrm{mA} \\ \mathrm{~mA} \\ \mathrm{~mA} \end{gathered}$ | $\begin{aligned} & \text { Fosc }=4 \mathrm{MHz}, \mathrm{VDD}=5.5 \mathrm{~V}, \mathrm{~T}=-40^{\circ} \mathrm{C} \\ & \text { Fosc }=4 \mathrm{MHz}, \mathrm{VDD}=5.5 \mathrm{~V}, \mathrm{~T}=-40^{\circ} \mathrm{C} \\ & \text { Fosc }=8 \mathrm{MHz}, \mathrm{VDD}=5.5 \mathrm{~V}, \mathrm{~T}=-40^{\circ} \mathrm{C} \end{aligned}$ |
| Power Down Current <br> (Notes 3, 5) <br> PIC16C5x | $\begin{aligned} & \text { IPD1 } \\ & \text { IPD2 } \end{aligned}$ |  |  | $\begin{aligned} & 10 \\ & 5 \end{aligned}$ | $\begin{aligned} & \text { TBD } \\ & \text { TBD } \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ | SLEEP, All I/Os at Vdd or Vss. VDD $=3.5 \mathrm{~V}$, WDT enabled, @ $25^{\circ} \mathrm{C}$ SLEEP, All I/Os at Vdd or Vss. VDD $=3.5 \mathrm{~V}$, WDT disabled, $@ 25^{\circ} \mathrm{C}$ |

Note 1: Data in the column labeled "Typical" is based on characterization results at $25^{\circ} \mathrm{C}$. This data is for design guidance only and is not tested for, or guaranteed by Microchip Technology.
Note 2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern, and temperature also have an impact on the current consumption.
a) The test conditions for all IDD measurements in active operation mode are:

OSC1=external square wave, from rail to rail; all I/O pins tristated, pulled to VDD, RT = VDD, MCLR = VDD; WDT enabled/disabled as specified.
b) For stand-by current measurements, the conditions are the same, except that the device is in SLEEP mode.

Note 3: Data include PIC16C54/PIC16C55 only.
Note 4: This is the limit to which VDD can be lowered in SLEEP mode without losing RAM data.
Note 5: The power down current in SLEEP mode does not depend on the oscillator type. Maximum values will be available when characterization of all product variants is complete.
Note 6: Does not include current through Rext. The current through the resistor can be estimated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
Note 7: On the rising edge of VDD, when VDD exceeds VPOR the device will be in RESET until the oscillator start-up timer times out.
Note 8: 20 MHz for future release.

## PIC ${ }^{\circledR}$ 16C5x Series

| DC CHARACTERISTICS, ALL PINS EXCEPT POWER SUPPLY |  |  | Standard Operating Conditions <br> Operating temperature $-40<\mathrm{TA}<+85^{\circ} \mathrm{C}$, unless otherwise stated |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typ <br> (Note 1) | Max | Units | Conditions |
| Input Low Voltage <br> I/O ports <br> MCLR <br> RTCC <br> OSC1 <br> OSC1 | VIL <br> Vilmc <br> VIlrt <br> Vilosc <br> Vilosc | Vss <br> Vss <br> Vss <br> Vss <br> Vss | 0.3 VdD | $\begin{aligned} & 0.2 \mathrm{VDD} \\ & 0.15 \mathrm{VDD} \\ & 0.15 \mathrm{VDD} \\ & 0.15 \mathrm{VDD} \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \end{aligned}$ | Pin "tristated" <br> PIC16C5xRC only! (Note 6) Driven with external clock. Not PIC16C5xRC. |
| Input High Voltage <br> I/O ports <br> MCLR <br> RTCC <br> OSC1 <br> OSC1 | V IH <br> Vінмс <br> Vihrt <br> ViHOSC <br> ViHosc | 2.0 <br> VDD-0.2 <br> VDD-0.2 <br> VDD-0. 2 | 0.7 VdD | VDD <br> VDD <br> VDD <br> VDD <br> VDD | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \end{aligned}$ | Pin "tristated" <br> PIC16C5xRC only ! (Note 6) Driven with external clock. Not PIC16C5xRC. |
| Input Leakage Curren <br> (Notes 3, 4) <br> I/O ports <br> MCLR <br> MCLR <br> RTCC <br> OSC1 | IIL <br> IILMCL <br> ilmach <br> IILRT <br> Illosc1 | $\begin{aligned} & -1 \\ & -5 \\ & -3 \\ & -3 \end{aligned}$ | $\begin{aligned} & +1 \\ & +-1 \\ & +-1 \end{aligned}$ | $\begin{aligned} & +1 \\ & \\ & +5 \\ & +3 \\ & +3 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ | Vss < VPIN < VDD, <br> Pin "tristated" $\begin{aligned} & \text { VPIN }=\text { VSS }+0.25 \mathrm{~V} \\ & \text { VPIN }=\text { VDD } \\ & \text { VSS < VPIN < VDD } \end{aligned}$ <br> " " " , Not PIC16C5xRC |
| Output Low Voltage <br> I/O Ports OSC2/CLKOUT (PIC16C5xRC) | Vol Vol | - | $0.1 \mathrm{VDD}$ | 0.6 | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \mathrm{IOL}=9.2 \mathrm{~mA}, \mathrm{VDD}=5.5 \mathrm{~V} \\ & \mathrm{loL}=\mathrm{TBD} \end{aligned}$ |
| Output High Voltage I/O Ports (Note 4,5) OSC2/CLKOUT (PIC16C5xRC) | VoH Voн | Vdd-0.7V | $0.9 \text { VDD }$ | - | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-3.4 \mathrm{~mA}, \mathrm{VDD}=5.5 \mathrm{~V} \\ & \mathrm{IOH}=\mathrm{TBD} \end{aligned}$ |

Note 1: Data in the column labeled "Typical" is based on characterization results at $25^{\circ} \mathrm{C}$. This data is for design guidance only and is not tested for, or guaranteed by Microchip Technology.
Note 2 : Total power dissipation as stated under absolute maximum ratings must not be exceeded.
Note 3 : The leakage current on the $\overline{M C L R}$ pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.
Note 4 : Negative current is defined as coming out of the pin.
Note 5 : The maximum currents per I/O pin, port, or total device under normal operating conditions must not exceed $80 \%$ of the "Absolute Maximum Ratings."
Note 6 : For PIC16C5xRC devices, the OSC1 pin is a Schmitt trigger input.

## TYPICAL DC CHARACTERISTICS

 GRAPHS (PIC16C5x-XT, PIC16C5x-RC)FIGURE 12: IDD vs. Vdd (NORMALIZED)


NOTE: The following graphs are based on characterization data and are for design guidance only. Most graphs are normalized to the worst case conditions to allow easy extrapolation for different operating conditions. For example, IDD max at $2.0 \mathrm{MHz}, 5.0 \mathrm{~V}$ can be derived from $3.3 \mathrm{~mA} \cdot 0.7 \cdot 0.65 \approx 1.5 \mathrm{~mA}$.

FIGURE 13: IDD vs. FREQUENCY (NORMALIZED)


FIGURE 14: IDD vs. Temperature (NORMALIZED)


## TYPICAL DC CHARACTERISTICS GRAPHS (PIC16C5x-XT, PIC16C5x-RC) (Cont.)

FIGURE 15: IDD vs. Vdd (SLEEP MODE)


FIGURE 16: loL vs. Vol
(SINGLE I/O PORT PIN)


FIGURE 17: IOH vs. Voh


## AC CHARACTERISTICS

| AC CHARACTERISTI |  | Standard Conditions (unless otherwise noted) Operating temperature $\mathrm{T} A=-40$ to $+85^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | $\begin{array}{\|c\|} \hline \text { Typ } \\ \text { (Note 1) } \\ \hline \end{array}$ | Max | Units | Conditions |
| Instruction cycle time | TCYXT <br> TCYRC <br> TCYHS | $\begin{aligned} & 1.0 \\ & 1.0 \\ & 0.5 \end{aligned}$ |  | 10 DC $1.0$ | usec <br> usec <br> usec | PIC16C5xXT, (Note 2) <br> Vdd within VdDXT specification <br> PIC16C5xRC, (Note 2) <br> Vdd within VddRC specification <br> PIC16C5xHS, (Note 2, 4) <br> VdD within VdDHS specification |
| RTCC Input Timing <br> Period High Pulse Width <br> Low Pulse Width Prescaler Toggling Freq. | TRT <br> Trth <br> Trtl <br> Fpmax | (TcY+20)/N <br> Tcy/2N <br> Tcy/2N | $32$ |  | nsec <br> nsec <br> nsec <br> MHz | external RTCC input ( $\mathrm{N}=$ selected prescaler ratio) Note 3 <br> Note 3 |
| Watchdog timer period/ Oscillator start-up timer period (no prescaler) | TwdT/ <br> TOST | TBD | $18$ | TBD | msec | $\text { VDD }=5.0 \mathrm{~V}, \text { Temp. }=+25^{\circ} \mathrm{C}$ |

Note 1: Data in the column labeled "Typical" is based on characterization results at $25^{\circ} \mathrm{C}$. This data is for design guidance only and is not tested for, or guaranteed by Microchip Technology.
Note 2: Instruction cycle period (Tcy ) equals four times the input oscillator time base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these spec. limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min." values with an external clock applied to the OSC1 pin.
When an external oscillator is used, the "Max." cycle time limit is "DC" (no clock) for all devices.
Note 3: The prescaler is designed as a simple ripple counter. Its maximum input frequency is theoretically only limited by the maximum toggling frequency of the first counter stage. However, as the prescaler output has to be synchronized before fed into the RTCC, FPMAX is also a function of TCY and the number of selected prescaler stages ( N ). Thus, the relationship

$$
\frac{1}{T R T}=\frac{\mathrm{N}}{\mathrm{TCY}+20}<\text { FPMAX must be obeyed. }
$$

Note 4: TcYHs min. $=0.2 \mu \mathrm{~s}$ for 20 MHz oscillator (future release).

FIGURE 18: RTCC TIMING


## AC CHARACTERISTICS (CONT.)

FIGURE 19: OSCILLATOR START-UP TIMING (PIC16C5xRC*)


CLKOUT


FIGURE 20: INPUT/OUTPUT TIMING FOR I/O PORTS (PIC16C5xRC*)


FIGURE 21: TYPICAL WDT PERIOD vs. TEMP. (NORMALIZED TO +25 ${ }^{\circ} \mathrm{C}$ )


FIGURE 22: TYPICAL WDT PERIOD vs. VDD (NORMALIZED TO +5.5V)


## DEVELOPMENT SUPPORT

## PIC-ICE ${ }^{\text {TM }}$

The PIC-ICE In-Circuit Emulation System from Microchip allows real time emulation of all chip functions with frequencies up to 20 MHz . Symbolic debugging, hardware breakpoints, software tracing, sample programming are just a few of the capabilities of this IBM PC hosted development system. Please contact your nearest sales office for details.

## PICPAK DEVELOPMENT KIT

PICPAK is a low-cost PIC Applications and development Kit, consisting of PICALC, PICSIM, PICPRO, and PIC16C54/PIC16C55 samples.

## PICALC CROSS-ASSEMBLER

The PIC Cross Assembler PICALC is available for several host computer platforms, including IBM PC. Macro assembly and conditional asssembly are just a few of the capabilities of PICALC. Besides the PIC16C5x Series, PICALC can also generate code for all of Microchip's NMOSPIC1600 microcontrollers, including the PIC165x and PIC167x family members. PICALC can generate various object code formats to support Microchip's proprietary development tools as well as third party systems.

## PICSIM SOFTWARE SIMULATOR

The software simulator PICSIM allows PIC16C5x code development on IBM PCs without any additional hardware. It simulates the PIC16C5x series on instruction level. Software trace, breakpoints, symbolic debugging, and stimulus file generation are just a few of the features available. PICSIM is particularly useful in the early development stages of an application, or when real-time and/or in-circuit emulation are not necessary for the code development.

## PICPRO EPROM PROGRAMMER

PICPRO is a low volume EPROM programmer for the PIC16C5x series. It allows downloading and programmming of PIC object code generated with PICALC from any host computer system providing a serial interface (RS232).

## EPROM PROGRAMMING <br> PROTOTYPE PROGRAMMERS

Microchip's proprietary PIC16C5x series Development System and PICPRO, were not designed for high volume production programming but were designed strictly to support engineering development level programming
of PIC16C5x EPROM and OTP units. Microchip assumes no responsibility for the replacement of programming rejects when these development tools are used to support high volume production level programming.

## VOLUME PROGRAMMERS

High volume programming by the customer should be supported by production quality programmers from approved third party sources. Currently the approved sources are Data I/O "Unisite (Site 48)" model and Logical Devices' "ALLPRO" model.

Microchip assumes no responsibility for replacing defective units related to mechanical and/or electrical problems of any third party programming equipment or the improper use of such equipment.

Programming of the code protection bit (also called "security bit" or "security fuse") implies that the contents of the PIC16C5x EPROM can no longer be verified, thus making programming related failure analysis an impossibility.

Microchip warrants that PIC16C5x units will not exceed a programming failure rate of $1 \%$ of shipment quality. Programming related failures beyond this level can be returned for replacement, again, if the security bit has not been programmed.

## FACTORY PROGRAMMING

High volume factory programming (QTP) is an available service from Microchip Technology. A small price adder and minimum quantity requirements apply.

## CURRENT PRODUCT AVAILABILITY

The following selections are currently available (for the Part-Number coding, refer to the back-page):

| Oscillator Type | Temp/ Package | Descriptions |
| :---: | :---: | :---: |
| RC, XT or HS | /P | PDIP, $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| RC, XT or HS | I/P | PDIP, $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| RC, XT or HS | ISO | SOIC, $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| RC, XT or HS | I/SO | SOIC, $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| RC, XT or HS | 儿 | PLCC, $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| RC, XT or HS | I/L | PLCC, $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| (Fuse-Programmed)* | /JW | Window CERDIP, $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

* JW has UV erasable fuses which determine
oscillator types RC, XT or HS.


## NOTES:

## PIC ${ }^{8} 16 C 5 x$ Series

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices. For the currently available code-combinations, refer to previous page.


Notes: * For UV-erasable devices, the oscillator type is RC by default ( = erased device). The user can select XT or HS oscillators by programming the according fuses with PICPRO.

# 8-Bit Microcontroller 

## FEATURES

- 32 8-bit RAM registers
- $512 \times 12$-bit program ROM
- Arithmetic Logic Unit
- Real Time Clock/Counter
- Self contained oscillator for crystal or ceramic resonator
- Access to RAM registers inherent to instruction
- Available in three temperature ranges: $0^{\circ}$ to $70^{\circ} \mathrm{C},-40^{\circ}$ to $85^{\circ} \mathrm{C}$ and $-40^{\circ}$ to $110^{\circ} \mathrm{C}$
- 18 pin package
- 2 level stack for subroutine nesting
- Open drain option on all I/O lines
- 12 bi-directional I/O lines
- $2 \mu \mathrm{sec}$ instruction execution time


## PIN CONFIGURATION

18 Lead Dual In Line
18 Lead SOIC
Top View

| $\leftrightarrow$ RA2 | -1 | 18 | RA1 $\leftrightarrow$ |
| :---: | :---: | :---: | :---: |
| $\leftrightarrow$ RA3 | 2 | 17 | RAO $\leftrightarrow$ |
| $\rightarrow \overline{\text { RTCC }}$ | 3 | 16 | OSC1 $\leftarrow$ |
| $\rightarrow \overline{\text { MCLR }}$ | 4 | 15 | OSC2 $\longrightarrow$ |
| $\rightarrow$ GND | 5 | 14 | $\mathrm{V}_{\mathrm{DD}} \leftrightarrow$ |
| $\leftrightarrow$ RBO | 6 | 13 | RB7 $\leftrightarrow$ |
| $\leftrightarrow$ RB1 | 7 | 12 | RB6 $\leftrightarrow$ |
| $\leftrightarrow \mathrm{RB} 2$ | 8 | 11 | RB5 $\longleftrightarrow$ |
| $\leftrightarrow$ RB3 | 9 | 10 | RB4 $\leftrightarrow$ |

## DESCRIPTION

The PIC1654S microcontroller is a MOS/LSI device containing RAM, I/O, and a central processing unit as well as customer-defined ROM on a single chip. This combination produces a low cost solution for applications which require sensing individual inputs and controlling individual outputs. Keyboard scanning, display driving, and other system control functions can be done at the same time due to the power of the 8 -bit CPU.

The internal ROM contains a customer-defined program using the PIC's powerful instruction set to specify the overall functional characteristics of the device. The 8 -bit input/output registers provide latched lines for interfacing to a limitless variety of applications. The PIC can be used to scan keyboards, drive displays, control electronic games and provide enhanced capabilities for motor control, telecommunication equipment, radios, television, consumer appliances, industrial timing and control applications. The 12 -bit instruction word format provides a powerful yet easy to use instruction repertoire emphasizing single bit manipulation as well as logical and arithmetic operations using bytes.

The PIC1654S is fabricated with N-Channel Silicon Gate technology resulting in a high performance product with proven reliability and production history. Only a single wide range power supply is required for operation, and an on-chip oscillator provides the operating clock with an external crystal or ceramic resonator to establish the frequency. Inputs and outputs are TTLcompatible.

Extensive hardware and software support is available to aid the user in developing an application program and to verify performance before committing to mask tooling. Programs can be assembled into machine language using PICALC, a powerful macroassembler. PICALC is available in various versions that can be run on many popular computer systems. Once the application program is developed several options are available to insure proper performance. The PICES II real time InCircuit Emulation System, PIC Field Demo boards (PFD), and the ROM-less version of the PIC1654S, the PIC1664, provide all required development and debugging tools.

## PIC1654S

PIC1654S BLOCK DIAGRAM


## ARCHITECTURAL DESCRIPTION

The firmware architecture of the PIC series microcontroller is based on a register file concept with simple yet powerful commands designed to emphasize bit, byte, and register transfer operations. The instruction set also supports computing functions as well as these control and interface functions.

Internally, the PIC is composed of three functional elements connected together by a single bidirectional bus: the Register File composed of 32 addressable 8 -bit registers, an Ârithmetic Logic Unit, and a user-defined Program ROM composed of 512 words each 12 bits in width. The Register File is divided into two functional groups: operational registers and general registers. The operational registers include, among others, the Real Time Clock/Counter (RTCC), the Program Counter (PC), the Status Register, and the I/O Registers. The general purpose registers are used for data and control information under command of the instructions.

The Arithmetic Logic Unit contains one temporary working register (W Register) and gating to perform Boolean functions between data held in the working register and any file register.

The Program ROM contains the operational program for the rest of the logic within the controller. Sequencing of microinstructions is controlled via the Program Counter (PC) which automatically increments to execute in-line programs. Program control operations can be performed by Bit Test and Sikip instructions, jump instructions, Call instructions, or by loading computed addresses into the PC. In addition, an on-chip two-level stack is employed to provide easy to use subroutine nesting. Activating the $\overline{M C L R}$ input on power up initializes the ROM program to address 7778.

| PIN FUNCTION TABLE |  |
| :---: | :---: |
| Signal | Definition |
| OSC1 (Input), OSC2 (Output) | These pins are the time base inputs to which a crystal, ceramic resonator, or external single phase clock may be connected. The frequency of oscillation is 8 times the instruction cycle frequency. |
| $\overline{\text { RTCC }}$ (Input) | Real Time Clock/Counter. Used by the microprogram to keep track of elapsed time between events. The Real Time Clock/Counter Register increments on falling edges applied to this pin. This register (F1) can be loaded and read by the program. This is a Schmitt trigger input. A mask option will allow an internal clock signal whose period is equal to the instruction execution time to drive the real time clock counter register. In this mode, transitions in the RTCC pin will be disregarded. However, the pin must be tied to either VSs or VDD to avoid unintended test mode activation. |
| RAO-3 (Input/Output) | 4 user programmable I/O lines (F5). The four MSB's are always read as logic O's. All inputs and outputs are under direct control of the program. A mask option will allow any I/O pin at the time of ROM pattern definition to be open drain. |
| RB0-7 (Input/Output) | 8 user programmable I/O lines (F6). <br> All inputs and outputs are under direct control of the program. A mask option will allow any I/O pin at the time of ROM pattern definition to be open drain. |
| $\overline{\text { MCLR }}$ (Input) | Master Clear. Used to initialize the internal ROM program to address 7778 and latch all I/O registers high. Should be held low $10-75 \mathrm{~ms}$ past the time when VDD $\geq 4.5 \mathrm{~V}$ depending on the crystal start up time. <br> This is a Schmitt trigger input. |
| VDD | Power supply. |
| Vss | Ground pin. |



## BASIC INSTRUCTION SET SUMMARY

Each PIC instruction is a 12-bit word divided into an OP code that specifies the instruction type and one or more operands specifying the operation of the instruction. The following PIC instruction summary lists byte-oriented, bit-oriented, and literal and control operations.

For byte-oriented instructions, "f" represents a file register designator and " d " represents a destination designator. The file register designator specifies which one of the 32 PIC file registers is to be utilized by the instruction. The destination designator specifies where the result of the operation performed by the instruction is to be placed. If "d" is zero, the result is placed in the PIC W register. If "d" is one, the result is returned to the file register specified in the instruction.

For bit oriented instructions, "b" represents a bit field designator that selects the number of the bit affected by the operation, while " $f$ " represents the number of the file in which the bit is located.

For literal and control operations, " $k$ " represents an eight- or nine-bit constant or literal value.

For an oscillator frequency of 4 MHz the instruction execution time is $2 \mu \mathrm{sec}$, unless a conditional test is true or the program counter is changed as a result of an instruction*. In these two cases, the instruction execution time is $4 \mu \mathrm{sec}$.

* (GOTO, CALL, RETLW, MOVWF2, ADDWF2).

| BYTE-ORIENTED FILE REGISTER <br> For $d=0, f \rightarrow W$ (PICAL accepts $d=0$ or $d=W$ in the mnemonic) $d=1, f \rightarrow f \quad$ (if $d$ is omitted, assembler assigns $d=1$ ). |  |  |  |  |  |  |  | $\frac{(11-6)}{O P \operatorname{CODE}}$ | (5) | (4-0) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | f(FILE \#) |  |
|  |  |  |  |  |  |  |  |  |  |
| Instruction- <br> Binary (Octal) |  |  |  |  | Name | Mnemonic, Operands |  |  | Operation |  | Status <br> Affected |
| 000 | 000 | 000 | 000 | (0000) | No Operation | NOP | - |  | - |  | None |
| 000 | 000 | 1 ff | fff | (0040) | Move W to f (Note 1) | MOVWF | - | $W \rightarrow f$ |  | None |
| 000 | 001 | 000 | 000 | (0100) | Clear W | CLRW | - | $0 \rightarrow \mathrm{~W}$ |  | z |
| 000 | 001 | 1 ff | fff | (0140) | Clear f | CLRF | f | $0 \rightarrow f$ |  | Z |
| 000 | 010 | dff | fff | (0200) | Subtract W from $f$ | SUBWF | f,d | $\mathrm{f}-\mathrm{W} \rightarrow \mathrm{d}[\mathrm{f}+\overline{\mathrm{W}}+1 \rightarrow \mathrm{~d}]$ |  | C,DC, Z |
| 000 | 011 | dff | fff | (0300) | Decrement $f$ | DECF | f,d | $\mathrm{f}-1 \rightarrow \mathrm{~d}$ |  | Z |
| 000 | 100 | dff | fff | (0400) | Inclusive OR W and f | IORWF | f,d | $\mathrm{Wvf} \rightarrow \mathrm{d}$ |  | Z |
| 000 | 101 | dff | fff | (0500) | ANDbW and $f$ | ANDWF | f,d | $\mathrm{W} \cdot f \rightarrow \mathrm{~d}$ |  | Z |
| 000 | 110 | dff | fff | (0600) | Exclusive OR W and $\ddagger$ | XORWF | f,d | $\mathrm{W} \oplus \mathrm{f} \rightarrow \mathrm{d}$ |  | Z |
| 000 | 111 | dff | fff | (0700) | Add W and $f$ | ADDWF | f,d | $\mathrm{W}+\mathrm{F} \rightarrow \mathrm{d}$ |  | C,DC, Z |
| 001 | 000 | dff | fff | (1000) | Move f | MOVF | f,d | $\mathrm{f} \rightarrow \mathrm{d}$ |  | Z |
| 001 | 001 | dff | fff | (1100) | Complement f | COMF | f,d | $f \rightarrow \mathrm{~d}$ |  | Z |
| 001 | 011 | dff | fff | (1200) | Increment f | INCF | f,d | $f+1 \rightarrow \mathrm{~d}$ |  | Z |
| 001 | 011 | dff | fff | (1300) | Decrement $\mathfrak{f}$, Skip to Zero | DECFSZ | f,d | $\mathrm{f}-1 \rightarrow \mathrm{~d}$, skip if Zero |  | None |
| 001 | 100 | dff | fff | (1400) | Rotate Right $\dagger$ | RRF | f,d | $\mathrm{f}(\mathrm{n}) \rightarrow \mathrm{d}(\mathrm{n}-1), \mathrm{C} \rightarrow \mathrm{d}(7)$, | $f(0) \rightarrow C$ | C |
| 001 | 101 | dff | fff | (1500) | Rotate Left f | RLF | f,d | $\begin{aligned} & f(n) \rightarrow d(n+1), C \rightarrow d(0) \\ & f(7) \rightarrow C \end{aligned}$ |  | C |
|  | 110 | dff |  | (1600) | Swap halves f | SWAPF | f,d | $f(0-3) \leftrightarrow f(4-7) \rightarrow d$ |  | None |
| 001 | 111 | dff | fff | (1700) | Increment $f$, Skip if Zero | INCFSZ | f,d | $\mathrm{f}+1 \rightarrow \mathrm{~d}$, skip if Zero |  | None |


| BIT-ORIENTED FILE REGISTER OPERATIONS |  |  |  |  |  | $\frac{(11-8)}{\text { OP CODE }}$ |  |  | (7-5) | (4-0) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | b (BIT \#) | f(FILE \#) |
| InstructionBinary (Octal) |  |  |  |  | Name |  |  |  | Mnemonic, Operands |  | Operation |  | Status <br> Affected |
| 010 | Obb | bff | fff | (2000) | Bit Clear f | BCF | f,b | $0 \rightarrow f(b)$ |  | None |
|  | 1bb | bff | fff | (2400) | Bit Set $f$ | BSF | f,b | $1 \rightarrow f(b)$ |  | None |
|  | Obb | bff | fff | (3000) | Bit Test f, skip if Clear | BTFSC | f,b | Bit Test f(b): skip | clear | None |
|  | 1bb | bff | ff | (3400) | Bit Test $\mathfrak{f}$, skip if Set | BTFSS | f,b | Bit Test f(b): skip | set | None |



## NOTES:

1. The 9th bit of the program counter in the PIC is zero for a CALL and a MOVWF F2. Therefore, subroutines must be located in program memory locations 0-3778. However, subroutines can be called from anywhere in the program memory since the Stack is 9 bits wide.
2. When an I/O register is modified as a function of itself, the value used will be that value present on the output pins. For example, an output pin which has been latched high but is driven low by an external device, will be relatched in the low state.

## SUPPLEMENTAL INSTRUCTION SET SUMMARY

The following supplemental instructions summarized below represent specific applications of the basic PIC instructions. For example, the "CLEAR CARRY" supplemental instruction is equivalent to the basic instruc-
tion BCF 3.0 ("Bit Clear, File 3, Bit 0"). These instruction mnemonics are recognized by the PIC Cross Assembler (PICAL).

| SUPPLEMENTAL INSTRUCTION SET SUMMARY |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| InstructionBinary (Octal) |  |  |  |  | Name | Mnemonic, Operands | Operation | Status Affected |
| 010 | 000 | 000 | 011 | (2003) | Clear Carry | CLRC | BCF 3, 0 | - |
| 010 | 100 | 000 | 011 | (2403) | Set Carry | SETC | BSF 3, 0 | - |
| 010 | 000 | 100 | 011 | (2043) | Clear Digit Carry | CLRDC | BCF 3, 1 | - |
| 010 | 100 | 100 | 011 | (2443) | Set Digit Carry | SETDC | BSF 3, 1 | - |
| 010 | 001 | 000 | 011 | (2103) | Clear Zero | CLRZ | BCF 3, 2 | - |
| 010 | 101 | 000 | 011 | (2503) | Set Zero | SETZ | BSF 3, 2 | - |
| 011 | 100 | 000 | 011 | (3403) | Skip on Carry | SKPC | BTFSS 3, 0 | - |
| 011 | 000 | 000 | 011 | (3003) | Skip on No Carry | SKPNC | BTFSC3, 0 | - |
| 011 | 100 | 100 | 011 | (3443) | Skip on Digit Carry | SKPDC | BTFSS 3, 1 | - |
| 011 | 000 | 100 | 011 | (3043) | Skip on No Digit Carry | SKPNDC | BTFSC 3,1 | - |
| 011 | 101 | 000 | 011 | (3503) | Skip on Zero | SKPZ | BTFSS 3, 2 | - |
| 011 | 001 | 000 | 011 | (3103) | Skip on No Zero | SKPNZ | BTFSC3, 2 | - |
| 001 | 000 | 1 ff | fff | (1040) | Test File | TSTF $\ddagger$ | MOVF f, 1 | Z |
| 001 | 000 | Off | fff | (1000) | Move File to W | MOVFW f | MOVF f, 0 | Z |
| 001 | 001 | 1 ff | fff | (1140) | Negate File | NEGF f,d | COMF f, 1 |  |
| 001 | 010 | dff | fff | (1200) |  |  | NCFf,d | z |
| 011 | 000 | 000 | 011 | (3003) | Add Carry to File | ADDCF f,d | BTFSC 3,0 |  |
| 001 | 010 | dff | fff | (1200) |  |  | INCF f,d | Z |
| 011 | 000 | 000 | 011 | (3003) | Subtract Carry from File | SUBCF f,d | BTFSC 3, 0 |  |
| 000 | 011 | dff | fff | (0300) |  |  | DECF f, d | Z |
| 011 | 000 | 100 | 011 | (3043) | Add Digit Carry to File | ADDDCF f,d | BTFSG 3, 1 |  |
| 001 | 010 | dff | fff | (1200) |  |  | INCF f, d | Z |
| 011 | 000 | 100 | 011 | (3043) | Subtract Digit Carky from File | SUBDCF f,d | BTFSC 3, 1 |  |
| 000 | 011 | dff | fff | (0300) |  |  | DECF fid | z |
| 101 | kkk | kkk | kkk | (5000) | Branch | Bk | GOTO k | - |
| 011 | 000 | 000 | 011 | (3003) | Branch on Carry | BC k | BTFSC 3, 0 |  |
| 101 | kkk | kkk | kkk | (5000) |  |  | GOTO k | - |
| 011 | 100 | 000 | 011 | (3403) | Branch on No Carry | BNC k | BTFSS 3, 0 |  |
| 101 | kkk | kkk | kkk | (5000) |  |  | GOTO k | - |
| 011 | 100 | 100 | 011 | (3043) | Branch on Digit Carry | BDC k | BTFSC 3, 1 |  |
| 101 | kkk | kkk | kkk | (5000) |  |  | GOTO k | - |
| 011 | 001 | 000 | 011 | (3443) | Branch on No Digit Carry | BNDC k | BTFSS 3, 1 |  |
| 101 | kkk | kkk | kkk | (5000) |  |  | GOTO k | - |
| 011 | 101 | 000 | 011 | (3103) | Branch on Zero | BZ k | BTFSC 3, 2 |  |
| 101 | kkk | kkk | kkk | (5000) |  |  | GOTO k | - |
| 011 | 101 | 000 | 011 | (3503) | Branch on No Zero | BNZ k | BTFSS 3, 2 |  |
| 101 | kkk | kkk | kkk | (5000) |  |  | GOTO k | - |

## I/O INTERFACING

The equivalent circuit for an I/O port bit is shown below as it would interface with either the input of a TTL device (PIC is outputting) or the output of an open collector TTL device (PIC is inputting). Each I/O port bit can be individually time multiplexed between input and output functions under software control. When outputting through a PIC I/O Port, the data is latched at the port and
the pin can be connected directly to a TTL gate input. When inputting data through an I/O Port, the port latch must first be set to a high level under program control. This turns off $Q_{2}$, allowing the TTL open collector device to drive the pad, pulled up by $Q_{1}$, which carı source a minimum of $100 \mu \mathrm{~A}$. Care, however, should be exercised when using open collector devices due to the potentially high TTL leakage current which can exist in the high logic state.

TYPICAL INTERFACE-BIDIRECTIONAL I/O LINE


NOTE: TRANSISTOR Q CAN BE REMOVED PER MASK OPTION TO FORM AN OPEN-DRAIN OUTPUT.

## PROGRAMMING CAUTIONS

The use of the bidirectional I/O ports are subject to certain rules of operation. These rules must be carefully followed in the instruction sequences written for I/O operation.

## BIDIRECTIONAL I/O PORTS

The bidirectional ports may be used for both inut and output operations. For input operations these ports are non-latching. Any input must be present until read by an input instruction. The outputs are latched and remain unchanged until the output latch is rewritten. For use as an input port the output latch must be set in the high state. Thus the external device inputs to the PIC circuit by forcing the latched output line to the low state or keeping the latched output high. This principle is the same whether operating on individual bits or the entire port.

Some instructions operate internally as input followed by output operations. The BCF and BSF instructions, for example, read the entire port into the CPU, execute the bit operation, and re-output the result. Caution must be used when using these instructions. As an example a BSF operation on bit 5 of F6 (port RB) will cause all eight bits of F6 to be read into the CPU. Then the BSF operation takes place on bit 5 and F6 is re-output to the output latches. If another bit of F6 is used as an inut (say bit 0 ) then bit 0 must be latched high. If during the BSF instruction on bit 5 an external device is forcing bit 0 to the low state then the input/output nature of the BSF instruction will leave bit 0 latched low after execution. In this state bit 0 cannot be used as an input until it is again latched high by the programmer. Refer to the examples on the next page.

## Successive Operations on Bidirectional I/O Ports

Care must be exercised if successive instructions operate on the same I/O port. The sequence of instructions should be such to allow the pin voltage to stabilize (load dependent) before the next instruction which causes

## EXAMPLE 1



What is thought to be happening:
BSF 6,5

| Read into CPU: | 00001111 |
| :--- | :--- |
| Set bit 5: | 00101111 |
| Write to F6: | 00101111 |

If no inputs were low during the instruction execution, there would be no problem.
that file to be read into the CPU (MOVF, BIT SET, BIT CLEAR, and BIT TEST) is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. This will happen if tpd (See I/ O Timing Diagram) is greater than $1 / 4 \mathrm{tcy}(\mathrm{min})$. When in doubt, it 's better to separate these instructions with a NOP or other instruction.

## EXAMPLE 2



What could happen if an input were low: BSF 6,5

$$
\begin{array}{ll}
\text { Read into CPU: } & 00001110 \\
\text { Set bit 5: } & 00101110 \\
\text { Write to F6: } & 00101110
\end{array}
$$

In this case bit 0 is now latched low and is no longer useful as an input until set high again.

## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Ambient temperature under bias......................... $125^{\circ} \mathrm{C}$
Storage Temperature ...................... $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on any pin with respect to Vss (except open
drain) $\qquad$ -0.3 V to +9.0 V
Voltage on any pin with respect to Vss (open drain)
$\qquad$ $-0.3 V$ to $+13 V$
Power Dissipation (Note 1) $\qquad$ 800 mW

* Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Data labeled "typical" is presented for design guidance only and is not guaranteed.

| DC CHARACTERISTICS - PIC16C54S <br> Operating temperature $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typt | Max | Units | Conditions |
| Power Supply Voltage | VDD | 4.5 | - | 7.0 | V |  |
| Primary Supply Current | IDD | - | 30 | 50 | mA | All I/O pins @ Vdd (See Primary Supply Current Chart for additional information). |
| Input Low Voltage | VIL | -0.2 | - | 0.8 | V |  |
| Input High Voltage (except $\overline{M C L R}, \overline{R T C C}$ \& OSC1) Input High Voltage | VIH | 2.4 | - | Vdo | V |  |
| (MCLR, $\overline{\text { RTCC }}$ \& OSC1) | VIH2 | VDD-1 | - | Vdd | V | (Note 4) |
| Output High Voltage | Vor | 2.4 | - | Vdd | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ provided by internal pullups (Note 2) |
| Output Low Voitage (l/O only) | Vol1 | - | $\bigcirc$ | 0.45 | V | $\mathrm{lOL}=-1.6 \mathrm{~mA},($ Note 3$)$ |
| Input RTCC Current | IRTCC | - | 7 | 20 | $\mu \mathrm{A}$ | $\mathrm{VsS} \leq \mathrm{VIN} \leq \mathrm{VDD}$ |
| Input Leakage Current (MCLR) | lic | -5 | - | + 5 | $\mu \mathrm{A}$ | $\mathrm{Vss} \leq \mathrm{VIN} \leq \mathrm{VdD}$ |
| Output Leakage Current (open drain pins) | IOL | - | - | 10 | $\mu \mathrm{A}$ | Vss $\leq$ VPIN $\leq 12 \mathrm{~V}$ |
| Input Low Current (all I/O ports) | IIL | -0.2 | - | -1.6 | mA | $\mathrm{VIL}=0.4 \mathrm{~V}$ (internal pullup) |
| Input High Current (all I/O ports) | IIH | -0.1 | -0.4 | - | mA | $\mathrm{VIH}=2.4 \mathrm{~V}$ |

$\dagger$ Typical data is at $T A=25^{\circ} \mathrm{C}, \mathrm{VDD}=5.0 \mathrm{~V}$.

## NOTES:

1. Total power dissipation for the package is calculated as follows:
$P D=(V D D)(I D D)+\Sigma(V D D-V I L)(I O H I)+\Sigma(V O L)$ (loL).
The term I/O refers to all interface pins; input, output or I/O.
2. Positive current indicates current into pin.

Negative current indicates current out of pin.
3. Total lol for all output pins must not exceed 175 mA .
4. Instantaneous voltage on the $\overline{\mathrm{RTCC}}$ and $\overline{\mathrm{MCLR}}$ input must not exceed VDD + 1 V otherwise the test mode may be entered. If the $\overline{\mathrm{RTCC}}$ pin is not used in an application it must be tied to Vss or Vod.

## DC CHARACTERISTICS-PIC1654S-I

Operating temperature $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

| Characteristic | Sym | Min | Typ† | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply Voltage | Vdd | 4.5 | - | 7.0 | V |  |
| Primary Supply Current | IDD | - | 30 | 54 | mA | All I/O pins @ Vdd (See Primary Supply Current Chart for additional information). |
| Input Low Voltage | VIL | -0.2 | - | 0.8 | V |  |
| Input High Voltage (except MCLR, RTCC \& OSC1) | VIH | 2.4 | - | VDD | V |  |
| $\begin{aligned} & \text { Input High Voltage } \\ & \text { (MCLR, } \overline{\text { RTCC }} \text { \& OSC1) } \end{aligned}$ | VIH2 | VDD-1 | - | VDD | V | (Note 4) |
| Output High Voltage | VOH | 2.4 | - | VDD | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ provided by internal pullups (Note 2) |
| Output Low Voltage (I/O only) | Vol1 | - | - | 0.45 | V | $\mathrm{IOL}=-1.6 \mathrm{~mA}($ Note 3$)$ |
| Input $\overline{\text { RTCC }}$ Current | IRTCC | - | 7 | 20 | $\mu \mathrm{A}$ | Vss $\leq$ VIN. $\leq$ VDD |
| Input Leakage Current ( $\overline{\mathrm{MCLR}}$ ) | ILC | -5 | - | + 5 | $\mu \mathrm{A}$ | VSS $\leq$ VIN. $\leq$ VDD |
| Output Leakage Current (open drain pins) | loL | - | - | 10 | $\mu \mathrm{A}$ | $\mathrm{Vss} \leq \mathrm{VPIN} \leq 9 \mathrm{~V}$ |
| Input Low Current (all I/O ports) | IIL | - 0.2 | - | -1.6 | mA | $\begin{aligned} & \mathrm{VIL}=0.4 \mathrm{~V} \text { (internal pullup) } \\ & \mathrm{TA}=0^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ |
| Input High Current (all I/O ports) | IIH | -0.1 | -0.4 | - | mA | $\mathrm{VIH}=2.4 \mathrm{~V}$ |

[^13]
## NOTES:

1. Total power dissipation for the package is calculated as follows:
$P D=(V D D)(I D D)+\Sigma(V D D-V I L)(I l L I)+\sum(V D D-V O H)$ $(\mathrm{IOHI})+\Sigma(\mathrm{VOL})$ (IOL).
2. Positive current indicates current into pin.

Negative current indicates current out of pin.
3. Total lol for all output pins must not exceed 175 mA .
4. Instantaneous voltage on the $\overline{\operatorname{RTCC}}$ and $\overline{M C L R}$ input must not exceed VDD + 1V otherwise the test mode may be entered. If the $\overline{\text { RTCC }}$ pin is not used in an application, it must be tied to Vss or VDD.

| DC CHARACTERISTICS - PIC1654S-H Operating temperature $\mathrm{TA}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typt | Max | Units | Conditions |
| Power Supply Voltage Primary Supply Current | $\begin{aligned} & \text { VDD } \\ & \text { IDD } \end{aligned}$ | 4.5 | $35$ | $\begin{aligned} & 5.5 \\ & 58 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~mA} \end{aligned}$ | All I/O pins @ VdD (See Primary Supply Current Chart for additional information). |
| Input Low Voltage Input High Voltage (except | VIL | -0.2 |  | 0.8 | V |  |
| $\overline{M C L R}$, RTCC \& OSC 1 ) Input High Voltage | VIH | 2.4 |  | VDD | V |  |
| (MCLR, RTCC \& OSC 1 ) | $\mathrm{VIH}_{2}$ | VDD - 1 |  | VDD | V | (Note 4) |
| Output High Voltage | Vон | 2.4 | - | VDD | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}$ provided by internal pullups (Note 2) |
| Output Low Voltage (//O only) | Vol 1 |  |  | 0.45 | V | $\mathrm{loL}=-1.6 \mathrm{~mA}$ ( Note 3) |
| Input RTCC Current | IRTCC |  | 7 | 20 | $\mu \mathrm{A}$ | VSS $\leq$ VIN $\leq$ VDD |
| Input Leakage Current (MCLR) | ILC | - 5 |  | + 5 | $\mu \mathrm{A}$ | Vss $\leq$ VIN $\leq$ VDD |
| Output Leakage Current (open drain I/O pins) | IoL | - | - | 20 | $\mu \mathrm{A}$ | Vss $\leq$ VPIN $\leq 9 \mathrm{~V}$ |
| Input Low Current (all $/$ / O ports) | IIL | -0.2 |  | -1.6 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V} \text { (internal pullup) } \\ & \mathrm{TA}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 110^{\circ} \mathrm{C} \end{aligned}$ |
| Input High Current (all $/$ /O ports) | IIH | -0.1 | -0.4 |  | mA | $\mathrm{VIH}=2.4 \mathrm{~V}$ |
| $\dagger$ Typical data is at $\mathrm{TA}^{\text {a }}=25^{\circ} \mathrm{C}, \mathrm{VDD}=5.0 \mathrm{~V}$. |  |  |  |  |  |  |
| NOTES: |  |  |  |  |  |  |
| 1. Total power dissipation for the package is calculated as follows: |  |  | 3. Total loL for all output pins must not exceed 17 5 mA . |  |  |  |
| $\begin{aligned} & \mathrm{PD}=(\mathrm{VDD})(\mathrm{IDD})+\sum(\mathrm{VDD}-\mathrm{VIL})(\mathrm{IILI})+\sum(\mathrm{VDD}-\mathrm{VOH}) \\ & (\mathrm{I} \mathrm{IOHI})+\sum(\mathrm{VOL})(\mathrm{IOL}) . \end{aligned}$ |  | - - VOH) |  | 4. Instantaneous voltage on the $\overline{\mathrm{RTCC}}$ and $\overline{\mathrm{MCLR}}$ input must not exceed VDD +1 V otherwise the test |  |  |

## AC CHARACTERISTICS - PIC1654S

Operating temperature $T A=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ and $-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$

| Characteristic | Sym | Min | Typ | Max | Units | Conditions |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Instruction Cycle Time | tcy | 2 | - | 10 | $\mu \mathrm{~s}$ | $0.8 \mathrm{MHz}-4.0 \mathrm{MHz}$ external <br> time base (Notes 1 and 2) |
| $\overline{\text { RTCC Input }}$ |  |  |  |  |  |  |
| Period | tRT | tCY $=0.2 \mu \mathrm{~s}-$ | - | - | - | Note 3 |
| High Pulse Width | tRTH | $1 / 2$ tRT | - | - | - |  |
| Low Pulse Width | tRTL | $1 / 2$ tRT | - | - | - |  |

## NOTES:

1. Instruction cycle period ( tcy ) equals eights times the input oscillator time base period.
2. The oscillator frequency may deviate to 4.08 MHz to allow for tolerance of a crystal or ceramic resonator time base element.
3. The maximum frequency which may be input to the $\overline{\operatorname{RTCC}}$ pin is calculated as follows:
$f(\max )=\frac{1}{\operatorname{tRT}(\min )}=\frac{1}{\operatorname{tCY}(\min )+0.2 \mu \mathrm{~S}}$
For example: if $\mathrm{tCY}=4 \mu \mathrm{~s}, \mathrm{f}(\max )=\frac{1}{4.2 \mu \mathrm{~s}}=238 \mathrm{KHz}$.

RTCC TIMING


## OSCILLATOR OPTIONS (TYPICAL CIRCUITS) (Cont.)

## CRYSTAL INPUT OPERATION



* Or ceramic resonator


## EXTERNAL CLOCK INPUT OPERATION



PRIMARY SUPPLY CURRENT AT SELECTED TEMPERATURES

|  |  | PIC1654S <br> PIC1654S-I |  | PIC1654S-H |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Typ | Max | Typ | Max | Units | Conditions |
| Primary Supply Current | IDD | 40 | 54 | 48 | 58 | mA | $-40^{\circ} \mathrm{C}$, All I/O pins at VDD |
|  |  | 35 | 50 | 44 | 54 | mA | $0^{\circ} \mathrm{C}$, All I/O pins at VDD |
|  |  | 24 | 45 | 39 | 49 | mA | $70^{\circ} \mathrm{C}$, All I/O pins at VDD |
|  |  | 22 | 42 | 36 | 46 | mA | $85^{\circ} \mathrm{C}$, All I/O pins at VDD |
|  |  | - | - | 30 | 40 | mA | $110^{\circ} \mathrm{C}$, All I/O pins at VDD |

## MASTER CLEAR (TYPICAL CIRCUIT)



The $\overline{M C L R}$ pin must be pulsed low for a minimum of one complete instruction cycle ( t CY ) for the master clear function to be guaranteed, assuming that power is applied and the oscillator is running. For initial power application, a delay is required for the external oscillator time base element to start up before MCLR is brought high. To achieve this, an external RC configuration, as shown, can be used. This provides approximately a 10 ms delay (assuming $V_{D D}$ is applied as a step function), which may be insufficient for some time base elements. Consult the manufacturer of the time base element for the specific start-up times.

## OUTPUT SINK CURRENT GRAPH (TYPICAL)



## PIC1654S

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



Notes: *SOIC and PLCC available in Commercial Temperature $\left(0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$ only

Microchip

## 8-Bit Microcontroller

## FEATURES

- User programmable
- Intelligent controller for stand-alone applications
- 32 8-bit RAM registers
- $512 \times 12$-bit program ROM
- Arithmetic Logic Unit
- Real Time Clock/Counter
- External or RC input oscillator mask option
- Self-contained oscillator
- Access to RAM registers inherent in instruction
- Wide power supply operating range ( 4.5 V to 7.0 V )
- Available in three temperature ranges: $0^{\circ}$ to $70^{\circ} \mathrm{C}$, $-40^{\circ}$ to $85^{\circ} \mathrm{C}$ and $-40^{\circ}$ to $110^{\circ} \mathrm{C}$
- 4 inputs, 8 outputs, 8 bi-directional I/O lines
- 2 level stack for subroutine nesting


## DESCRIPTION

The PIC®1655 microcontroller is an MOS/LSI device containing RAM, I/O, and a central processing unit as well as customer-defined ROM on a single chip. This combination produces a low cost solution for applications which require sensing individual inputs and controlling individual outputs. Keyboard scanning, display driving, and other system control functions can be done at the same time due to the power of the 8 -bit CPU.

The internal ROM contains a customer-defined program using the PIC's powerful instruction set to specify the overall functional characteristics of the device. The 8-bit input/output registers provide latched lines for interfacing to a limitless variety of applications. The PIC can be used to scan keyboards, drive displays, control electronic games and provide enhanced capabilities for motor controls, telecommunication equipment, radios, television, consumer appliances, industrial timing and control applications. The 12-bit instruction word format provides a powerful yet easy to use instruction repertoire emphasizing single bit manipulation as well as logical and arithmetic operations using bytes.
The PIC1655 is fabricated with N-Channel Silicon Gate technology resulting in a high performance product with proven reliability and production history. Only a single wide range power supply is required for operation, and an on-chip oscillator provides the operating clock with only an external RC network (or buffered crystal oscillator signal, for greater accuracy) to establish the frequency. Inputs and outputs are TTL-compatible.

## PIN CONFIGURATION

28 LEAD DUAL INLINE

Top View
 aid the user in developing an application program and to verify performance before committing to mask tooling. Programs can be assembled into machine language using PICALC, a powerful macroassembler. PICALC is available in a MS-DOS version that can be run on an IBM PC or compatible computer system. Once the application program is developed several options are available to insure proper performance. The PIC's operation can be verified in any hardware application by using the PIC1664. The PIC1664 is a ROMless PIC microcomputer with additional pins to connect external PROM or RAM and to accept HALT commands. The PFD1000 Field Demo System is available containing a PIC1664 with sockets for erasable CMOS PROM's. Finally, the PICES II (PIC In-Circuit Emulation System) provides the user with emulation and debugging capability in either a stand-along mode or operation as a peripheral to a larger computer system. Easy program debugging and changing is facilitated because the user's program is stored in RAM. With these development tools, the user can quickly and confidently order the masking of the PIC's ROM and bring his application into the market.

## ARCHITECTURAL DESCRIPTION

The firmware architecture of the PIC series microcontroller is based on a register file concept with simple yet powerful commands designed to emphasize bit, byte, and register transfer operations. The instruction set also supports computing functions as well as these control and interface functions.
Internally, the PIC is composed of three functional elements connected together by a single bidirectional bus: the Register File composed of 32 addressable 8bit registers, an Arithmetic Logic Unit, and a userdefined Program ROM composed of 512 words each 12 bits in width. The Register File is divided into two functional groups: operational registers and general registers. The operational registers include, among others, the Real Time Clock Counter (PC), the Status Register, and the I/O Registers. The general purpose registers are used for data and control information under command of the instructions.

The Arithmetic Logic Unit contains one temporary working register or accumulator (W Register) and gating to perform Boolean functions between data held in the working register and any file register.
The Program ROM contains the operational program for the rest of the logic within the controller. Sequencing of microinstructions is controlled via the Program Counter (PC) which automatically increments to execute in-line programs. Program control operations can be performed by Bit Test and Skip instructions, Jump instructions, Call instructions, or by loading computed addresses into the PC. In addition, an on-chip two-level stack is employed to provide easy to use subroutine nesting. Activating the MCLR input on power up initializes the ROM program to address 7778.

## PIC1655 BLOCK DIAGRAM



| PIN FUNCTION TABLE |  |
| :--- | :--- |
| Name | Function |
| OSC1 (Input) | Oscillator input. This signal can be driven by an external oscillator if a precise frequency <br> of operation is required or an external RC network can be used to set the frequency of <br> operation of the internal clock generator. This is a Schmitt trigger input. <br> Real Time Clock Counter. Used by the microprogram to keep track of elapsed time <br> between events. The RTCC register increments on falling edges applied to this pin. <br> This register can be loaded and read by the program. This is a Schmitt trigger input. |
| RAO-3 (input) | 4 input lines. <br> RBO-7 (output) <br> RCO-7 (input/output) |
| 8 output lines. <br> 8 user programmable input/output lines. <br> MCLR (input) <br> Master Clear. Used to initialize the internal ROM program to address 7778 and latch <br> all l/O register high. Should be held low at least 1 ms past the time when the power <br> supply is valid. This is a Schmitt trigger input. RAM registers are not initialized by <br> Master Clear |  |
| CLKOUT (output) | A signal derived from the internal oscillator. Used by external devices to synchronize <br> themselves to PIC timing. <br> Used for testing purposes only. Must be grounded for normal operation. |
| TEST | Primary power supply. <br> VDD |
| Output Buffer power supply. Used to enhance output current sinking capability. |  |
| Ground. |  |



## BASIC INSTRUCTION SET SUMMARY

Each PIC instruction is a 12-bit word divided into an OP code that specifies the instruction type and one or more operands specifying the operation of the instruction. The following PIC instruction summary lists byte-oriented, bit-oriented, and literal and control operations.

For byte-oriented instructions, "f" represents a file register designator and "d" represents a destination designator. The file register designator specifies which one of the 32 PIC file registers is to be utilized by the instruction. The destination designator specifies where the result of the operation performed by the instruction is to be placed. If " $d$ " is zero, the result is placed in the PIC W
register. If "d" is one, the result is returned to the file register specified in the instruction.
For bit oriented instructions, "b" represents a bit field designator that selects the number of the bit affected by the operation, while " $f$ " represents the number of the file in which the bit is located.

For literal and control operations, " $k$ " represents an eight- or nine-bit constant or literal value.
For an oscillator frequency of 1 MHz the instruction execution time is $4 \mu \mathrm{sec}$, unless a conditional test is true or the program counter is changed as a result of an instruction. In these cases, the instruction execution time is $8 \mu \mathrm{sec}$.

## BYTE-ORIENTED FILE REGISTER OPERATIONS

For $d=0, f \rightarrow W$ (PICAL accepts $d=0$ or $d=W$ in the mnemonic)

| $(11-6)$ | $(5)$ | $(4-0)$ |
| :---: | :---: | :---: |
| OP CODE | $d$ | $f($ FILE \#) |

$d=1, f \rightarrow f$ (if $d$ is omitted, assembler assigns $d=1$ ).

| INSTRUCTION- <br> BINARY (Octal) |  |  |  |  | NAME | MNEMO OPERA |  | OPERATION | STATUS AFFECTED |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 000 | 000 | 000 | 000 | (0000) | No Operation | NOP | - | - | None |
| 000 | 000 | 1 ff | fff | (0040) | Move W to f (Note 1) | MOVWF | - | $W \rightarrow f$ | None |
| 000 | 001 | 000 | 000 | (0100) | Clear W | CLRW | - | $0 \rightarrow W$ | Z |
| 000 | 001 | 1 ff | fff | (0140) | Clear f | CLRF | f | $\mathrm{O} \rightarrow \mathrm{f}$ | Z |
| 000 | 010 | dff | fff | (0200) | Subtract W from f | SUBWF | f,d | $\mathrm{f}-\mathrm{W} \rightarrow \mathrm{d}[\mathrm{f}+\overline{\mathrm{W}}+1 \rightarrow \mathrm{~d}]$ | C,DC,Z |
| 000 | 011 | dff | fff | (0300) | Decrement f | DECF | f,d | $\mathrm{f}-1 \rightarrow \mathrm{~d}$ | Z |
| 000 | 100 | dff | fff | (0400) | Inclusive OR W and f | IORWF | f,d | Wvf $\rightarrow$ d | Z |
| 000 | 101 | dff | fff | (0500) | ANDbW and f | ANDWF | f,d | $W \cdot f \rightarrow d$ | Z |
| 000 | 110 | dff | fff | (0600) | Exclusive OR W and $\dagger$ | XORWF | f,d | $W \oplus f \rightarrow d$ | Z |
| 000 | 111 | dff | fff | (0700) | Add $W$ and $f$ | ADDWF | f,d | $W+F \rightarrow d$ | C,DC,Z |
| 001 | 000 | dff | fff | (1000) | Move f | MOVF | f,d | $f \rightarrow d$ | Z |
| 001 | 001 | dff | fff | (1100) | Complement f | COMF | f,d | $f \rightarrow \mathrm{~d}$ | Z |
| 001 | 011 | dff | fff | (1200) | Increment f | INCF | f,d | $\mathrm{f}+1 \rightarrow \mathrm{~d}$ | Z |
| 001 | 011 | dff | fff | (1300) | Decrement f, Skip to Zero | DECFSZ | f,d | $\mathrm{f}-1 \rightarrow \mathrm{~d}$, skip if Zero | None |
| 001 | 100 | dff | fff | (1400) | Rotate Right f | RRF | f,d | $f(n) \rightarrow d(n-1), C \rightarrow d(7), f(0) \rightarrow C$ | C |
| 001 | 101 | dff | fff | (1500) | Rotate Left f | RLF | f,d | $\begin{aligned} & f(n) \rightarrow d(n+1), C \rightarrow d(0), \\ & f(7) \rightarrow C \end{aligned}$ | C |
| 001 | 110 | dff | fff | (1600) | Swap halves f | SWAPF | f,d | $f(0-3) \leftrightarrow f(4-7) \rightarrow \mathrm{d}$ | None |
| 001 | 111 | dff | fff | (1700) | Increment f, Skip if Zero | INCFSZ | f,d | $\mathrm{f}+1 \rightarrow \mathrm{~d}$, skip if Zero | None |

BIT-ORIENTED FILE REGISTER OPERATIONS
$(11-8) \quad(7-5) \quad(4-0)$

| OP CODE | b (BIT \#) | f(FILE \#) |
| :--- | :--- | :--- |


| INSTRUCTIONBINARY (Octal) |  |  |  |  | NAME | MNEM OPER |  | OPERATION | STATUS AFFECTED |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 010 | Obb | bff | fff | (2000) | Bit Clear f | BCF | f,b | $0 \rightarrow f(b)$ | None |
| 010 | 1 bb | bff | fff | (2400) | Bit Set f | BSF | f,b | $1 \rightarrow f(\mathrm{~b})$ | None |
| 011 | Obb | bff | fff | (3000) | Bit Test f , skip if Clear | BTFSC | f,b | Bit Test $f(b)$ : skip if clear | None |
| 011 | 1 bb | bff | fff | (3400) | Bit Test f, skip if Set | BTFSS | f,b | Bit Test $f(b)$ : skip if set | None |

LITERAL AND CONTROL OPERATIONS

| INSTRUCTIONBINARY (Octal) |  |  |  |  | NAME | MNEMONIC, OPERANDS | OPERATION | STATUS AFFECTED |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 100 | Okk | kkk | kkk | (4000) | Return and place Literal in W | RETLW k | $\mathrm{k} \rightarrow \mathrm{w}$, Stack $\rightarrow \mathrm{PC}$ | None |
| 100 | 1kk | kkk | kkk | (4400) | Call subroutine (Note 1) | CALL k | $\mathrm{PC}+1 \rightarrow$ Stack, $\mathrm{k} \rightarrow \mathrm{PC}$ | None |
| 101 | kkk | kkk | kkk | (5000) | Go to address ( $k$ is 9 bits) | GOTO k | $\mathrm{k} \rightarrow \mathrm{PC}$ | None |
| 110 | Okk | kkk | kkk | (6000) | Move Literal to W | MOVLW k | $\mathrm{k} \rightarrow \mathrm{W}$ | None |
| 110 | ikk | kkk | kkk | (6400) | Inclusive OR Literal and W | IORLW k | $k \vee W \rightarrow W$ | Z |
| 111 | okk | kkk | kkk | (7000) | AND Literal and W | ANDLW k | $\mathrm{k} \cdot \mathrm{W} \rightarrow \mathrm{W}$ | Z |
| 111 | 1kk | kkk | kkk | (7400) | Exclusive OR Literal and W | XORLW k | $k \oplus \mathrm{~W} \rightarrow \mathrm{~W}$ | Z |

## NOTES:

1. The 9 th bit of the program counter in the PIC is zero or a CALL and a MOVWF F2. Therefore, subroutines must be located in program memory locations $0-3778$. However, subroutines can be called from anywhere in the program memory since the Stack is 9 bits wide.
2. When an I/O register is modified as a function of itself, the value used will be that value present on the pins. For example, an output pin which has been latched high but is driven low by an external device, will be relatched in the low state. See example 2 on page 7.

## I/O INTERFACING

The equivalent circuit for an I/O port bit is shown below as it would interface with either the input of a TTL device (PIC is outputting) or the output of an open collector TTL device (PIC is inputting). Each I/O port bit can be individually time multiplexed between input and output functions under software control. When outputting through a PIC I/O Port, the data is latched at the port and
the pin can be connected directly to a TTL gate input. When inputting data through an I/O Port, the port latch must first be set to a high level under program control. This turns off Q2, allowing the TTL open collector device to drive the pad, pulled up by Q1, which can source a minimum of $100 \mu \mathrm{~A}$. Care, however, should be exercised when using open collector devices due to the potentially high TTL leakage current which can exist in the high logic state.

## TYPICAL INTERFACE-BIDIRECTIONAL I/O LINE



Note: Q1 can be disconnected via mask option to form an "open drain" pin.

## Bidirectional $1 / 0$ Ports

The bidirectional ports may be used for both inut and output operations. For input operations these ports are non-latching. Any input must be present until read by an input instruction. The outputs are latched and remain unchanged until the output latch is rewritten. For use as an input port the output latch must be set in the high state. Thus the external device inputs to the PIC circuit by forcing the latched output line to the low state or keeping the latched output high. This principle is the same whether operating on individual bits or the entire port.
Some instructions operate internally as input followed by output operations. The BCF and BSF instructions, for
example, read the entire port into the CPU, execute the bit operation, and re-output the result. Caution must be used when using these instructions. As an example a BSF operation on bit 5 of 77 (port RC) will cause all eight bits of F7 to be read into the CPU. Then the BSF operation takes place on bit 5 and F7 is re-output to the output latches. If another bit of F7 is used as an inut (say bit 0 ) then bit 0 must be latched high. If during the BSF instruction on bit 5 an external device is forcing bit 0 to the low state then the input/output nature of the BSF instruction will leave bit 0 latched low after execution. In this state bit 0 cannot be used as an input until it is again latched high by the programmer. Refer to the examples below.

## Input Only Port: (Port RA)

The input only port of the PIC1655 consists of the four LSB's of F5 (port RA). An internal pull-up device is provided so that external pull-ups on open collector logic are unnecessary. The four MSB's of this port are always read as zeros. Output operations to F5 are not defined. Note that the BTFSC and BTFSS instructions are input only operations and so can be used with F5. Also, file register instructions which leave the results in W can be used.

## Output Only Port: (Port RB)

The output only port of the PIC1655 consists of F6 (port RB). This port contains no input circuitry and is therefore not capable of instructions requiring an input followed by an output operation. The only instructions which can validly use F6 are MOVWF and CLRF.

EXAMPLE 1:


What is thought to be happening: BSF 7,5

| Read into CPU: | 00001111 |
| :--- | :--- |
| Set bit 5: | 00101111 |
| Write to F7: | 00101111 |

If no inputs were low during the instruction execution, there would be no problem.

## Successive Operations on Bidirectional I/O Ports

Care must be exercised if successive instructions operate on the same I/O port. The sequence of instructions should be such to allow the pin voltage to stabilize (load dependent) before the next instruction which causes that file to be read into the CPU (MOVF, BIT SET, BIT CLEAR, and BIT TEST) is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. This will happen if tpd (See I.O Timing Diagram) is greater than $1 / 4$ tcy ( min ). When in doubt, it is better to separate these instructions with a NOP or other instruction.

EXAMPLE 2:


## ELECTRICAL CHARACTERISTICS


*Notice: Stresses above those listed under "Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

| DC CHARACTERISTICS/PIC1655 |  | Operating temperature $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typt | Max | Units | Conditions |
| Primary Supply Voltage | Vcc | 4.5 | - | 7.0 | V |  |
| Output Buffer Supply Voltage | Vxx | 4.5 | - | 10.0 | V | (Note 2) |
| Primary Supply Current | IDD | - | 30 | 65 | mA | All I/O pins @ Vdd (Note 6) |
| Output Buffer Supply Current | IxX | - | 1 | 5 | mA | All I/O pins @ VDD (Note 3) |
| Input Low Voltage | VIL | -0.2 | - | 0.8 | V |  |
| Input High Voltage (except |  |  |  |  |  |  |
| $\overline{\text { MCLR, }}, \overline{\text { RTCC }}$ \& OSC) | VIH | 2.4 | - | VDD | V |  |
| Input High Voltage |  |  |  |  |  |  |
| ( $\overline{\text { MCLR }}, \overline{\text { RTCC }}$ \& OSC) | Vilh | VDD - 1 | - | Vdd | V |  |
| Output High Voltage | VOH | 2.4 | - | Vdd | V | $\mathrm{IOH}=-100 \mu \mathrm{~A}($ Note 4) |
|  |  | 3.5 | - | Vdd | V | $\mathrm{IOH}=0$ |
| Output Low Voltage | Vol1 | - | - | 0.45 | V | $\mathrm{lOL}=-1.6 \mathrm{~mA}, \mathrm{Vxx}=4.5 \mathrm{~V}$ |
| (I/O only) |  | - | - | 0.90 | V | $\mathrm{lOL}=5.0 \mathrm{~mA}, \mathrm{Vxx}=4.5 \mathrm{~V}$ |
|  |  | - | - | 0.90 | V | $\mathrm{loL}=5.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V}$ |
|  |  | - | - | 1.20 | V | $\mathrm{IOL}=10.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V}$ |
|  |  | - | - | 2.0 | V | $\begin{aligned} & \mathrm{IOL}=20.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V} \\ & \text { (Note 5) } \end{aligned}$ |
| Output Low Voltage (CLK OUT) | VoL2 | - | - | 0.45 | V | $\mathrm{loL}=-1.6 \mathrm{~mA},($ Note 5$)$ |
| Input Leakage Current (MCLR, RTCC) | ILC | - 5 | - | + 5 | $\mu \mathrm{A}$ | VSS $\leq$ VIN $\leq$ VDD |
| Leakage Current (open drain I/O pins) | lolc | - | - | 10 | $\mu \mathrm{A}$ | Vss $\leq$ VPIN $\leq 10 \mathrm{~V}$ |
| Input Low Current (all I/O ports) | IIL | -0.2 | -0.6 | -1.6 | mA | $\mathrm{VIL}=0.4 \mathrm{~V}$ internal pullup |
| Input High Current (all I/O ports) | liH | -0.1 | -0.4 | -1.4 | mA | $\mathrm{VIH}=2.4 \mathrm{~V}$ |

$\dagger$ Typical data is at $\mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{VDD}=5.0 \mathrm{~V}$.

## NOTES:

1. Total power dissipation for the package is calculated as follows:
$P D=(\mathrm{VDD})(\mathrm{IDD})+\Sigma(\mathrm{VDD}-\mathrm{VIL})(\mathrm{IOHI})+\Sigma(\mathrm{VOL})$
(IOL).
The term I/O refers to all interface pins; input, output or I/O.
2. Vxx supply drives only the I/O ports.
3. The maximum Ixx current will be drawn when all I/O ports are outputting a High.
4. Positive current indicates current into pin. Negative.current indicates current out of pin.
5. Total loL for all output pins (I/O ports plus CLK OUT) must not exceed 225 mA .
6. See Primary Supply current Chart for additional information.

| DC CHARACTERISTICS/PIC1655I |  |  |  | Operating temperature $\mathrm{TA}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typ $\dagger$ | Max | Units | Conditions |
| Primary Supply Voltage | VDD | 4.5 | - | 7.0 | V |  |
| Output Buffer Supply Voltage | Vxx | 4.5 | - | 10.0 | V | (Note 2) |
| Primary Supply Current | IDD | - | 30 | 70 | mA | All I/O pins @ VDD (Note 6) |
| Output Buffer Supply Current | IxX | - | 1 | 5 | mA | All l/O pins @ VDD (Note 3) |
| Input Low Voltage | VIL | -0.2 | - | 0.7 | V |  |
| Input High Voltage (except $\overline{\text { MCLR }}$, RTCC \& OSC) | VIH | 2.4 | - | VDD | V |  |
| Input High Voltage |  |  |  |  |  |  |
| ( $\overline{\text { MCLR }}, \overline{\text { RTCC }}$ \& OSC) | Vili | VDD-1 | - | VDD | V |  |
| Output High Voltage | VOH | 2.4 | - | VDD | V | $\mathrm{loH}=-100 \mu \mathrm{~A}($ Note 4) |
|  |  |  |  |  |  | $\mathrm{lOH}=0$ |
| Output Low Voltage | Vol1 | - | - | 0.45 | V | $\mathrm{lOL}=-1.6 \mathrm{~mA}, \mathrm{Vxx}=4.5 \mathrm{~V}$ |
| (I/O only) |  | - | - | 0.90 | V | $\mathrm{lOL}=5.0 \mathrm{~mA}, \mathrm{Vxx}=4.5 \mathrm{~V}$ |
|  |  | - | - | 0.90 | V | $\mathrm{IOL}=5.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V}$ |
|  |  | - | - | 1.20 | V | $\mathrm{lOL}=10.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V}$ |
|  |  | - | - | 2.0 | V | $\begin{aligned} & \mathrm{IOL}=20.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V} \\ & \text { (Note 5) } \end{aligned}$ |
| Output Low Voltage (CLK OUT) | Vol2 | - | - | 0.45 | V | $\mathrm{lOL}=-1.6 \mathrm{~mA},($ Note 5$)$ |
| Input Leakage Current (MCLR, $\overline{\text { RTCC }})$ | ILC | - 5 | - | + 5 | $\mu \mathrm{A}$ | $\mathrm{VSS} \leq \mathrm{VIN} \leq \mathrm{VDD}$ |
| Leakage Current (drain I/O pins) | Iolc | - | - | 10 | $\mu \mathrm{A}$ | VSS $\leq$ VPIN $\leq 10 \mathrm{~V}$ |
| Input Low Current (all I/O ports) | IIL | -0.2 | -0.6 | -1.8 | mA | V IL $=0.4 \mathrm{~V}$ internal pullup |
| Input High Current (all I/O ports) | IIH | -0.1 | -0.4 | -1.8 | mA | $\mathrm{VIH}=2.4 \mathrm{~V}$ |
| $\dagger$ Typical data is at $\mathrm{TA}^{2}=25^{\circ} \mathrm{C}, \mathrm{VDD}=5.0 \mathrm{~V}$. |  |  |  |  |  |  |
| NOTES: |  |  |  |  |  |  |
| 1. Total power dissipation for the package is calculated as follows: |  |  | 4. Positive current indicates current into pin. Negative current indicates current out of pin. |  |  |  |
| $\begin{aligned} & \mathrm{PD}=(\mathrm{VDD})(\mathrm{IDD})+\Sigma(\mathrm{VDD}-\mathrm{VIL})(\mathrm{IOHI})+\Sigma(\mathrm{VOL}) \\ & \text { (IOL). } \end{aligned}$ |  |  | 5. Total lol for all output pins (l/O ports plus CLK OUT) must not exceed 225 mA . |  |  |  |
| The term I/O refers to all interface pins; input, output or I/O. |  |  | 6. See Primary Supply current Chart for additional information. |  |  |  |
| 2. Vxx supply drives only the I/O ports. <br> 3. The maximum Ixx current will be drawn when all I/O ports are outputting a High. |  |  |  |  |  |  |
|  |  |  |  |  |  |  |


| DC CHARACTERISTICS/PIC1655H |  |  |  | Operating temperature $\mathrm{TA}=-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typ $\dagger$ | Max | Units | Conditions |
|  | VDD | 4.5 | - | 5.5 | V |  |
| Output Buffer Supply Voltage | Vxx | 4.5 | - | 10.0 | V | (Note 2) |
| Primary Supply Current | IDD | - | 30 | 70 | mA | All I/O pins @ VDD (Note 6) |
| Output Buffer Supply Current Input Low Voltage | IxX | - | 1 | 5 | mA | All I/O pins @ VDD (Note 3) |
|  | VIL | -0.2 | - | 0.7 | V |  |
| Input High Voltage (except $\overline{M C L R}$, RTCC $\& ~ O S C)$ | VIH | 2.4 | - | VdD | V |  |
| Input Low-to-High Threshold |  |  |  |  |  |  |
| Voltage ( $\overline{\text { MCLR }}, \overline{\text { RTCC }}$ \& OSC) | VILH | VDD-1 | - | VDD | V |  |
| Output High Voltage | VOH | 2.4 | - | Vdd | V | $\begin{aligned} & \mathrm{IOH}=-100 \mu \mathrm{~A}(\text { Note } 4) \\ & \mathrm{IOH}=0 \end{aligned}$ |
| Output Low Voltage (I/O only) | VoL1 | - | - | 0.45 | V | $\mathrm{lOL}=-1.6 \mathrm{~mA}, \mathrm{Vxx}=4.5 \mathrm{~V}$ |
|  |  | - | - | 0.90 | V | $\mathrm{IOL}=5.0 \mathrm{~mA}, \mathrm{Vxx}=4.5 \mathrm{~V}$ |
|  |  |  | - | 0.90 | V | $1 \mathrm{LL}=5.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V}$ |
|  |  | - | - | 1.20 | V | $\mathrm{IOL}=10.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V}$ |
|  |  | - | - | 2.0 | V | $\begin{aligned} & \mathrm{IOL}=20.0 \mathrm{~mA}, \mathrm{Vxx}=8.0 \mathrm{~V} \\ & \text { (Note 5) } \end{aligned}$ |
| Output Low Voltage (CLK OUT) | Vol2 | - | - | 0.45 | V | $\mathrm{lOL}=-1.6 \mathrm{~mA},($ Note 5$)$ |
| Input Leakage Current (MCLR, $\overline{\text { RTCC }}$ ) | ILC | - 5 | - | + 5 | $\mu \mathrm{A}$ | $\mathrm{VSS} \leq \mathrm{VIN} \leq \mathrm{VDD}$ |
| Leakage Current (open drain I/O pins) | lolc | - | - | 10 | $\mu \mathrm{A}$ | $\text { Vss } \leq \text { VPIN } \leq 10 \mathrm{~V}$ |
| Input Low Current (all I/O ports) | IIL | -0.2 | -0.6 | -1.8 | mA | $\mathrm{VIL}=0.4 \mathrm{~V}$ internal pullup |
| Input High Current (all I/O ports) | IIH | -0.1 | -0.4 | -1.8 | mA | $\mathrm{VIH}=2.4 \mathrm{~V}$ |
| $\dagger$ Typical data is at $\mathrm{TA}^{\text {a }}=25^{\circ} \mathrm{C}, \mathrm{VDD}=5.0 \mathrm{~V}$. |  |  |  |  |  |  |
| NOTES: |  |  |  |  |  |  |
| 1. Total power dissipation for the package is calculated as follows: $P D=(V D D)(I D D)+\Sigma(V D D-V I L)(I O H I)+\Sigma(V O L)$ (loL). <br> The term I/O refers to all interface pins; input, output or I/O. <br> 2. Vxx supply drives only the $/ / O$ ports. <br> 3. The maximum Ixx current will be drawn when all I/O ports are outputting a High. |  |  |  | 4. Positive current indicates current into pin. Negative current indicates current out of pin. <br> 5. Total loL for all output pins (I/O ports plus CLK OUT) must not exceed 225mA. <br> 6. See Primary Supply current Chart for additional information. |  |  |


| AC CHARACTERISTICS/PIC1655, PIC1655I AND PIC1655H |  |  |  | Operating temperature $\mathrm{TA}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ and $-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typt | Max | Units | Conditions |
| Instruction Cycle Time | tcy | 4 | - | 20 | $\mu \mathrm{S}$ | $0.2 \mathrm{MHz}-1.0 \mathrm{MHz}$ external time base (Notes 1, 2 and 5) |
| RTCC Input |  |  |  |  |  |  |
| Period | tRT | $\mathrm{tcY}=0.2 \mu \mathrm{~s}-$ | - | - |  |  |
| High Pulse Width | trith | 1/2 tRT | - | - | - |  |
| Low Pulse Width | tRTL | 1/2 tRT | - | - | - | (Notes 2 and 3) |
| I/O Ports |  |  |  |  |  |  |
| Data Input Setup Time | ts | - | - | 1/4tCy - 125 | ns |  |
| Data Input Hold Time |  | 0 | - | - | ns |  |
| Data Output Propagation | tPD | - | 600 | 1000 | ns | Capacitive load $=50 \mathrm{pF}$ |
| Delay |  |  |  |  |  |  |
| OSC Input |  |  |  |  |  |  |
| External Input Impedance | Rosch | 120 | 800 | 3500 | $\Omega$ | Vosc $=5 \mathrm{~V}$ Applies to external |
| High |  |  |  |  |  |  |
| External Input Impedance | Roscl | - | $10^{6}$ | - | $\Omega$ | Vosc $=0.4 \mathrm{~V}$ OSC drive only |
| Low |  |  |  |  |  |  |
| $\dagger$ Typical data is at $\mathrm{TA}^{\text {a }}=25^{\circ} \mathrm{C}, \mathrm{VDD}=5.0 \mathrm{~V}$. |  |  |  |  |  |  |
| NOTES: |  |  |  |  |  |  |
| 1. Instruction cycle period (tcY) equals four times the inut oscillator time base period. |  |  |  |  |  |  |
| 2. Due to the synchronous timing nature between CLK OUT and the sampling circuit used on the RTCC input, CLK OUT may be directly tied to the RTCC input. |  |  |  |  |  |  |
| 3. The maximum frequency which may be input to the RTCC pin is calculated as follows: |  |  |  |  |  |  |
| $f(\max )=\frac{1}{\operatorname{tRT}(\min )}=\frac{1}{\operatorname{tCY}(\min )+0.2 \mu \mathrm{~S}}$ |  |  |  |  |  |  |
| For example: if $\mathrm{tcy}=4 \mu \mathrm{~s}, \mathrm{f}(\max )=\frac{1}{4.2 \mu \mathrm{~s}}=238 \mathrm{KHz}$. |  |  |  |  |  |  |
| 4. Caution must be exercised to allow for unit to unit variation of oscillator frequency when using RC option. (See RC Option Operation Graph). |  |  |  |  |  |  |

PRIMARY SUPPLY CURRENT AT SELECTED TEMPERATURES:
PIC1655, PIC1655I, PIC1655H

| Characteristic | Sym | Max | Units | Conditions |
| :--- | :---: | :---: | :---: | :---: |
| Primary Supply Current | IDD | 70 | mA | $-40^{\circ} \mathrm{C}, \mathrm{All}$ I/O pins at VDD |
|  |  | 65 | mA | $0^{\circ} \mathrm{C}$, All I/O pins at VDD |
|  |  | 48 | mA | $70^{\circ} \mathrm{C}, \mathrm{All}$ I/O pins at VDD |
|  |  | 45 | mA | $85^{\circ} \mathrm{C}$, All I/O pins at VDD |
|  |  | 42 | mA | $110^{\circ} \mathrm{C}$, All I/O pins at VDD |



## CLOCK OUT TIMING



## RTCC TIMING



## SCHMITT TRIGGER CHARACTERISTICS (RTCC, MCLR AND OSC PINS)

TA $=25^{\circ} \mathrm{C}$ (TYPICAL)


## RC OPTION OPERATION



TYPICAL RC OSCILLATOR FREQUENCY RANGE



$$
\begin{aligned}
& \mathrm{V} D \mathrm{DD}=5.0 \mathrm{~V} \\
& \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{Cext}=100 \mathrm{pF}
\end{aligned}
$$

Unit to Unit Variation @ $5.0 \mathrm{~V}, 25^{\circ} \mathrm{C}$ is $\pm 25 \%$
Variation from $V_{D D}=4.5 \mathrm{~V}-7.0 \mathrm{~V}$ referenced to 5.0 V is $-3 \%,+9 \%$
Variation from $T_{A}=0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ referenced to $25^{\circ} \mathrm{C}$ is $+3 \%,-5 \%$


The buffer must be capable of driving $120 \Omega, \min .(800 \Omega$, typ.) to 2.0 V . However, it is recommended that the pull-down transistor on the OSC pin be removed (an option) if OSC is to be driven externally.

## EXTERNAL CLOCK INPUT OPERATION

CLOCK FROM EXTERNAL SYSTEM
 TO OSC PIN \#27

## MASTER CLEAR (TYPICAL CIRCUIT)



Master Clear requires $>1.0 \mathrm{~ms}$ delay before activation after power is applied to the VDD pin, for the oscillator to start up. To achieve this, an external RC configuration as shown can be used (assuming $V_{D D}$ is applied as a step function).

## OUTPUT SINK CURRENT GRAPH



The Output Sink Current is dependent on the VXX supply and the output load. This chart shows the typical curves used to express the output drive capability.


## PIC1655 EMULATION CAUTIONS

When emulating a PIC1655 using a PICES II development system certain precautions should be taken.
A. Be sure that the PICES II Module being used is programmed for the PIC1655 mode. (Refer to the PICES Manual). The PIC1655 contained within the module should have the MODE pin \#22 set to a high state.

1. This causes the $\overline{M C L R}$ to force all I/O registers high.
2. The OSC 1 pin \#59 becomes a single clock input pin.
3. The interrupt system becomes disabled and the RTCC always counts on the trailing edges.
4. Bits 3 through 7 on file register F3 are all ones.

## POWER SUPPLY CURRENT VS TEMPERATURE (TYPICAL LIMITS)


B. Make sure to only use two levels of stack within the program.
C. Make sure all I/O cautions contained in this spec sheet are used.
D. Be sure to use the 28 pin socket for the module plug.
E. Make sure that during an actual application the MCLR input swings from a low to high level a minimum of 1 msec after the supply voltage is applied.
F. If an oscillator drive is used, be sure that it can drive the $120 \Omega$ input impedance of the OSC pin on the PIC1664.
G. The cable length and internal variations may cause some parameter values to differ between the PICES II module and a production PIC1655.

## PIC1655

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the sales offices. For the currently available code-combinations, refer to previous page.

## PART NUMBERS



Microchip

## 8 Bit Microcontroller

## FEATURES

- $1024 \times 13$-bit Program ROM
- $64 \times 8$-bit RAM (16 special purpose registers)
- Arithmetic Logic Unit
- Sophisticated interrupt structure
- 6 level pushdown stack
- Versatile self contained oscillator
- $2.0 \mu \mathrm{~s}$ instruction execution time
- Wide power supply operating range (4.5-5.5 volts)
- 4 sets of 8 user defined TTL compatible I/O lines
- Available in two temperature ranges: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ and $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$


## DESCRIPTION

The PIC1670 microcontroller is an MOS/LSI device containing RAM, I/O, and a central processing unit as well as customer-defined ROM on a single chip. This combination produces a low cost solution for applications which require sensing individual inputs and controlling individual outputs. Keyboard scanning, display driving, and system control functions can be done at the same time due to the power of the 8-bit CPU.

The internal ROM contains a customer-defined program using the PIC's powerful instruction set to specify the overall functional characteristics of the device. The 8-bit input/output registers provide latched lines for interfacing to a limitless variety of applications. The PIC can be used to scan keyboards, drive displays, control electronic games and provide enhanced capabilities to vending machines, traffic lights, radios, television, consumer appliances, industrial timing and control applications. The 13 -bit instruction word format provides a powerful yet easy to use instruction repertoire emphasizing single bit manipulation as well as logical and arithmetic operations using bytes.

The PIC1670 is fabricated with N-Channel Silicon Gate technology resulting in a high performance product. Only a single wide range power supply is required for operation. An on-chip oscillator provides the operating clock with an external crystal or ceramic resonator to establish the frequency. Inputs and outputs are TTLcompatible, with open-drain option available.


Extensive hardware and software support is available to aid the user in developing an application program and to verify performance before committing to mask tooling. Programs can be assembled into machine language using PICALC, eliminating the burden of coding with ones and zeros. Once the application program is developed, several options are available to insure proper performance. The PIC's operation can be verified in any hardware application by using the PIC1665. The PIC1665 is a ROM-less PIC1670 microcontroller with additional pins to connect external EPROM or RAM and to accept HALT commands. The PFD 1020 Field Demo System is available containing a PIC1665 with sockets for erasable PROMS. Finally, the PICES II (PIC In-Circuit Emulation System) provides the user with emulation and debugging capability in either a stand-alone mode or operation as a peripheral to a larger computer system. Easy program debugging and changing is facilitated because the user's program is stored in RAM. With these development tools, the user can quickly and confidently order the masking of the PIC's ROM and bring his application into the market.

## PIC1670 BLOCK DIAGRAM



## ARCHITECTURAL DESCRIPTION

The firmware architecture of the PIC1670 microcontroller is based on a register file concept with simple yet powerful instruction commands designed to optimize the code for bit, byte, and register transfer operations. The instruction set also supports computing functions as well as these control and interface functions.
Internally, the functional blocks of the PIC1670 are connected by an 8 -bit bidirectional bus: the 648 -bit registers of which the first 16 are special purpose, an Arithmetic Logic Unit, and a user defined program ROM composed of $1024 \times 13$ words. The register file is divided into two functional groups: operational registers and general purpose registers. The first sixteen are the operational registers and they include the Real Time Clock Counter A and B , four $1 / \mathrm{O}$ registers, two Status registers, a Program Counter and a File Select Register. The general purpose registers are used for data and control information under command of the instructions.

The Arithmetic Logic Unit contains one temporary working register (W Register), an adder, and hardware for decimal adjust. Manipulation between data in the working register and any other register can be performed.

The Program ROM contains the user defined application program and is supported by an instruction decoder and instruction register. Sequencing of microinstructions is controlled via the Program Counter (PC) which automatically increments to execute in-line programs. The Program Counter is modified by bit test, jump, call or branch instructions and the lower 8-bits can be modified for computed addresses by file register instructions. In addition, an on-chip six level stack is employed to push and pull the contents of the program counter. This provides easy to use subroutine nesting. Activating the $\overline{M C L R}$ input on power-up initializes the ROM program to address 17778.

## REGISTERS

| REGISTER FILE ARRANGEMENT |  |
| :---: | :---: |
| File | Function |
| F08 | Not a physical register. FO calls for contents of the FSR (F4) to be used to select a file register. F4 is used as an indirect address pointer. |
| F18 | W Register: The working register. |
| F28 | Program Counter: Points to the next program ROM address to be executed (8 lower bits only). |
| F38 | Arithmetic Status Register |
| F48 | File Select Register: The FSR is used in generating effective file register addresses under program control. |
| F58 | Interrupt Status Register: Used to control interrupts and registers F6 and F7. (See "Interrupt System") |
| F68, F78 | RTCCA and RTCCB: Real Time Clock Counters A \& B respectively can be configured as a single 16 bit counter, an 8 bit counter and an 8 bit general purpose register or two general purpose registers when no external counting is required. The RTCC registers can be loaded and read by the program, as well as count negative transitions on the $\overline{R T}$ pin or count at $1 / 8$ the frequency of the oscillator. If data are being stored into RTCCA simultaneous with a negative transition on the $\overline{\mathrm{RT}}$ pin (and CNTE $=1$ and CNTS = 1), RTCCA will contain the new stored value and the external transition will be ignored by the microcomputer. (See "Real Time Clock Interrupt" for further details about the RTCC). |
| F108, 118 | I/O Port A |
| F128, 138 | I/O Port B |
| F148, 158 | I/O Port C |
| F168, 178 | I/O Port D |
| F208, 778 | General Purpose Registers: Used for temporary and general purpose storage during program execution time. |
| Note: F108, 128, 148 \& 168 are the $1 / O$ registers and F118, $138,158 \& 178$ are used for reading the actual pin levels. |  |


| ARITHMETIC STATUS REGISTER F3 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1 | 1 | A9 | A8 | OV | Z | DC | C |
| Bit | Name | Function |  |  |  |  |  |
| 0 | C | Bit 0 is the carry flag and is usually the carry from the A.L.U., also used as a borrow subtract instructions. |  |  |  |  |  |
| 1 | DC | Bit 1 is the half carry (decimal carry) and is used to indicate a carry from bit 3 in the A.L.U. as the result of an addition (byte). This bit is used in the decimal adjust instruction to allow B.C.D. decimal addition. |  |  |  |  |  |
| 2 | Z | Bit 2 is the zero flag and is set to a one if the results of the previous operation was identically zero. |  |  |  |  |  |
| 3 | OV | Bit 3 is the overflow flag and is set to a one by operations which cause a signed <br> two's complement arithmetic overflow. The bit is set when the carry from the MSB in the A.L.U. is opposite to the carry from the MSB-1 bit. |  |  |  |  |  |
| 4 | A8 |  | is the | 9th | a | $\begin{aligned} & \text { progr } \\ & \text { id onl } \end{aligned}$ |  |
| 5 | A9 |  |  |  |  |  |  |



## BASIC INSTRUCTION SET AND PIN FUNCTIONS

Each PIC instruction is a 13-bit word divided into an OP code which specifies the instruction type and one or more operands which further specify the operation of the instruction. The following PIC instruction summary lists byte-oriented, bit-oriented, and literal and control operations.

For byte-oriented instructions, "f" represents a file register designator and "d" represents a destination designator. The file register designator specifies which one of the PIC file registers is to be utilized by the instruction. The destination designator specifies where the result of the operation performed by the instruction is to be placed if "d" is zero. The result is placed in the W register if " d " is one. The result is returned to the file register specified in the instruction.

For bit-oriented instructions, "b" represents a bit field designator which selects the number of the bit affected by the operation while "f" represents the number of the file in which the bit is located.

For literal and control operations, " $k$ " represents an eight or nine bit constant or literal value.
For an oscillator frequency of 4 MHz the instruction execution time is $2.0 \mu \mathrm{sec}$ unless a conditional test is true or the program counter is changed as a result of an instruction. In these two cases, the instruction execution time is $4.0 \mu \mathrm{sec}$.

| BYTE ORIENTED FILE REGISTER OPERATIONS |  |  |  |  |  |  | (12-7) |  |  |  | (6) | (5-0) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | OPCODE |  |  | d | f(FILE | E) |
|  | structio | n-Bin |  |  | (Octal) | Name Mnem | Mnemonic, Operands |  | Operation |  |  | Status Affected |  |
| 0 | 000 | 000 | 000 | 100 | (00004) | Decimal adjust W | DAW | - | (Note 1) |  |  |  | C |
| 0 | 000 | 001 | fff | fff | (00100) | Move W to file | MOVWF | $f$ | W $\rightarrow$ |  |  |  | . |
| 0 | 000 | 1d | fff | fff | (00200) | Subtract W from file w/borrow | SUBBWF | f,d | $f+\bar{W}$ | $\bar{W}+\mathrm{C}$ |  |  | OV,C,DC,Z |
| 0 | 000 | 10d | fff | fff | (00400) | Subtract W from file | SUBWF | f,d | $f+\bar{W}$ | $\bar{W}+1$ |  |  | OV,C,DC,Z |
| 0 | 000 | 11d | fff | fff | (00600) | Decrement file | DECF | f,d | f-1 | $\rightarrow \mathrm{d}$ |  |  | OV,C,DC,Z |
| 0 | 001 | 00d | fff | fff | (01000) | Inclusive or W with file | IORWF | f,d | WVf | $\rightarrow \mathrm{d}$ |  |  | Z |
| 0 | 001 | 01d | fff | fff | (01200) | And $W$ with file | ANDWF | f,d | W-1 | $1 \rightarrow d$ |  |  | Z |
| 0 | 001 | 10d | ff | fff | (01400) | Exclusive OR W with file | XORWF | f,d | $W \oplus$ | $\oplus \mathrm{f} \rightarrow$ |  |  | Z |
| 0 | 001 | 11d | fff | ff | (01500) | Add $W$ with file | ADDWF | f,d | W+f | $+\mathrm{f} \rightarrow$ |  |  | OV,C,DC,Z |
| 0 | 010 | 00d | fff | fff | (02000) | Add $W$ to file with carry | ADCWF | f,d | W + f | $+f+c$ |  |  | OV,C,DC,Z |
| 0 | 010 | 01d | fff | fff | (02200) | Complement file | COMPF | f,d | $\bar{f} \rightarrow$ |  |  |  | Z |
| 0 | 010 | 10d | fff | ff | (02400) | Increment file | INCF | f,d | $f+1$ | $1 \rightarrow d$ |  |  | OV,C,DC,Z |
| 0 | 010 | 11d | fff | fff | (02600) | Decrement file, skip if zero | DECFSZ | f,d | $f \cdot 1$ | $1 \rightarrow$ d, | kip if zero |  | - |
| 0 | 011 | 00d | fff | fff | (03000) | Rotate file right through carry | RRCF | f,d | $f(n) \rightarrow$ | $\rightarrow \mathrm{d}(\mathrm{n}$ | 1), $c \rightarrow d$ | $f(0) \rightarrow c$ | C |
| 0 | 011 | 01d | fff | fff | (03200) | Rotate file left through carry | RLCF | f,d | $f(n) \rightarrow$ | $\rightarrow \mathrm{d}(\mathrm{n}$ | 1), $c \rightarrow d(0$ | , $\mathrm{f}(7) \rightarrow \mathrm{c}$ | c C |
| 0 | 011 | 01d | fff | fff | (03400) | Swap upper and lower nibble of file | le SWAPF | f,d |  | 3) $\leftrightarrow$ | (4-7) $\rightarrow$ d |  | . |
| 0 | 011 | 11d | fff | fff | (03600) | Increment file, skip if zero | INCFSZ | f,d | $f+1$ | $1 \rightarrow \mathrm{~d}$ | skip if zero |  | - |
| 1 | 000 | 000 | ff | fff | (0004) | Move file to W | MOVFW | $f$ | $f \rightarrow$ | $\rightarrow$ W |  |  | Z |
| 1 | 000 | 001 | fff | fff | (00100) | Clear file | CLRF | , | $0 \rightarrow$ | $\rightarrow \mathrm{f}$ |  |  | Z |
| 1 | 000 | 010 | fff | ff | (00200) | Rotate file right/no carry | RRNCF | f | $f(\mathrm{n})$ | $\rightarrow \mathrm{d}$ | 1), $f(0)$ |  | . |
| 1 | 000 | 011. | ff | fff | (00300) | Rotate file left/nocarry | RLNCF | f | $f(\mathrm{n})$ | $\rightarrow \mathrm{d}(\mathrm{n}$ | 1), $f(7) \rightarrow$ |  |  |
| 1 | 000 | 100 | ff | fff | (00400) | Compare file to W, skip if F < W | CPFSLT | f | $\mathrm{f}-\mathrm{W}$, | W, skip | $C=0$ |  |  |
| 1 | 000 | 101 | fff | ff | (00500) | Compare file to W skip if $\mathrm{F}=\mathrm{W}$ | CPFSEO | f | f-W, | W, skip | $Z=1$ |  | - |
| 1 | 000 | 110 |  | fff | (00800) | Compare file to W, skip if F> W | CPFSGT | f | f-W, | W, skip | $Z \cdot C=1$ |  | - |
| 1 | 000 | 111 | fff | fff | (01000) | Move file to itself | TESTF | $f$ | f-1 |  |  |  | Z |

Note 1: The DAW instruction adjusts the eight bit number in the W register to form two valid BCD (binary coded decimal) digits, one in the lower and in the upper nibble. (The results will only be meaningful if the number in $W$ to be adjusted is the result of adding together two valid two digit BCD numbers). The adjustment obeys the following two step algorithm.

1. If the lower nibble is greater than 9 or the digit carry flag (DC) is set, 06 is added to the $W$ register.
2. Then, if the upper nibble is greater than 9 or the carry from the original or step 1 addition is set, 60 is added to the W register. The carry bit is set if there is a carry from the original step 1 or step 2 addition.


| PIN FUNCTIONS |  |  |
| :---: | :---: | :---: |
| Signal Name | Signal Type | Function |
| OSC1, OSC2 | Input Output | Oscillator pins. The on-board oscillator can be driven by an external crystal ceramic resonator or an external clock via these pins. |
| $\overline{\mathrm{RT}}$ | Input | Real Time Input. Negative transitions on this pin increment the RTCC (F6) register. This pin can also be used for an interrupt input. This pin uses a Schmitt trigger input. There is no internal active pull-up device. |
| RA0-7, RB-7, RC0-7, RD0-7 | Input Output | User programmable input/output lines. These lines can be used as inputs and/ or outputs and are under direct control of the program. |
| MCLR | Input | Master Clear: Used to initialize the internal ROM program to address 17778 latch all I/O registers high, and disables the interrupts. This pin uses a Schmitt trigger input. There is no internal active pull-up device. |
| TEST | Input | Test pin. This pin is used for testing purposes only. It must be grounded for normal operation. |
| VdD | - | Power supply pin. |
| Vss | - | Ground pin. |
| CLKOUT | Output | Clock Output: A signal derived from the internal oscillator. May be used by external circuitry to synchronize with PIC1670 timing. |

## INTERRUPT SYSTEM

The interrupt system of the PIC1670 is comprised of an external interrupt and a real-time clock counter interrupt. These have different interrupt vectors, enable bits and status bits. Both interrupts are controlled by the status register (F5) shown below.


Notes: 1. Bit 7 is unused and is read as zero.
2. The Status Register F5 will power up to all zeroes.

## External Interrupt

On any high to low transition of the $\overline{\mathrm{RT}}$ pin the external interrupt request (XIR) bit will be set. This request will be serviced if the external interrupt enable (XIE) bit is set or if it is set at a later point in the program. The latter allows the processor to store a request (without interrupting) while a critical timing routine is being executed. Once external interrupt service is initiated, the processor willclear the XIR bit, delay one cycle (to execute the current instruction), then push the current program counter onto the stack and execute the instruction at location 17608. It takes three to four instruction cycles from the transition on the RT pin until the instruction at 17608 is executed. No new interrupts can be serviced until a return from interrupt (RETFI) instruction has been executed.

## Real-Time Clock Interrupt

The real-time clock counter (RTCCA \& RTCCB, file registers F6 and F7) have a similar mechanism of interrupt service. The RTCCA register will increment if the count enable (CNTE) bit is set: If this bit is not set the RTCCA \& RTCCB will maintain their present contents and can therefore be used as general purpose RAM registers. The count source (CNTS) bit selects the clocking source for RTCCA. If CNTS is cleared to a ' 0 ', then RTCCA will use the internal instruction clock and increment at $1 / 8$ the frequency present on the OSC pins. If CNTS is set to a ' 1 ', then RTCCA will increment on each high to low transition of the RT pin. RTCCB can only be incremented when RTCCA makes a transition from 3778 to 0 and the $A / B$ status bit is set. This condition links the two eight bit registers together to form one sixteen bit counter. An interrupt request under these conditions will occur when the combined registers make a transition from 1777778 to 0 . If, however, the $A / B$ bit is not set, then RTCCA will be the only incrementing register and an interrupt request will occur when RTCCA makes a transition from 3778 to 0 . (In this setup the RTCCB register will not increment and can be used as a general purpose RAM register). Once a request has come from the real-time clock counter, the real-time clock interrupt request (RTCIR) bit will be set. At this point, the request can either be serviced immediately if the real-time clock interrupt enable (RTCIE) bit is set or be stored if RTCIE is not set. The latter allows the


## Interrupt System (Cont.)

processor to store a real-time clock interrupt while a critical timing routine is being executed. Once interrupt service is initiated, the processor will clear the RTCIR bit, delay one cycle (to execute the current instruction), then push the present program counter onto the stack and execute the instruction at location 17408 . It takes three instruction cycles from when the RTCC(A or B) overflows until the instruction 17408 is executed. No new interrupts can be serviced until a RETFI instruction has been executed.

The RETFI instruction (000028) must be used to return from any interrupt service routine if any pending interrupts are to be serviced. External interrupts have priority over RTCC driven interrupt in the event both types occur simultaneously. Interrupts cannot be nested but will be serviced sequentially. The existance of any pending interrupts can be tested via the state of the XIR (bit 2) and RTCIR (bit 1) in the status word F5.

## INPUT/OUTPUT CAPABILITY

The PIC1670 provides four complete quasi-bidirectional input/output ports. A simplified schematic of an I/O pin is shown below. The ports occupy address locations in the register file space of the PIC1670. Thus, any instruction that can operate on a general purpose register can operate on an I/O port. Two locations in the register file space are allocated for each I/O port. Port RA0-7 is addressable as either F 108 or F 118 . Port RB07 is addressable as either F 128 or F 138 . Port RC0-7 is addressable as either F148 or F158. An I/O port READ
on its odd-numbered location will interrogate the chip pins while an I/O port READ on its even-numbered location will interrogate the internal latch in that I/O port. This simplifies programming in cases where a portion of a single port is used for inputting only while the remainder is used for outputting as illustrated in the following example.
Here, the low 3 bits of port RA are used as output-only, while the high 5 bits are used as input-only. During power on reset (MCLR low), the latches in the I/O ports will be set high, turning off all pull down transistors as represented by Q 2 in the figure below. During program execution if we wish to interrogate an input pin, then, for example,

## BTFSS 11,6

will test pin RA6 and skip the next instruction if that pin is set. If we wish to modify a single output, then, for example,

$$
\text { BCF 10, } 2
$$

will force RA2 to zero because its internal latch will be cleared to zero. This will turn on Q2 and pull the pin to zero.
The way this instruction operates internally is the CPU reads file 10 into the A.L.U., modifies the bit and reoutputs the data to file 10 . If the pins were read instead, any input which was grounded externally would cause a zero to be read on that bit. When the CPU re-outputted the data to the file, that bit would be cleared to zero, no longer useful as an input until set high again.
During program execution, the latches in bits 3-7 should remain in the high state. This will keep Q2 off, allowing external circuitry full control of pins RA3-RA7, which are being used here as input.

## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Temperature Under Bias .................................. $125^{\circ} \mathrm{C}$
Storage Temperature . $55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on any pin with
respect to Vss $\qquad$ -0.3 V to +10.0 V
Power Dissipation $\qquad$ 1000 mW

* Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Data labeled "typical" is presented for design guidance only and is not guaranteed.

| DC CHARACTERISTICS |  |  |  | Operating temperature: <br> - Commercial: <br> - Industrial: |  | ure: $\begin{aligned} & \mathrm{TA}=0{ }^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \mathrm{TA}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typ* | Max | Units | Conditions |
| Power Supply Voltage | VDD | 4.5 | - | 5.5 | V |  |
| Primary Supply Current | IDD | - | - | 100 | mA | All I/O pins high |
| Input Low Voltage (except $\overline{\text { MCLR }} \& \overline{\mathrm{RT}}$ ) | VIL | Vss | - | 0.8 | V |  |
| Input High Voltage (except $\overline{M C L R}, \overline{R T}, \mathrm{OSC} 1)$ | VIHI | 2.4 | - | VDD | V |  |
| Input High Voltage <br> ( $\overline{M C L R}, \overline{R T}, \mathrm{OSC} 1$ ) | VIH2 | VDD-1 | - | VDD | V |  |
| Output High Voltage | VOH | 2.4 | - | VdD | V | IOH - $100 \mu \mathrm{~A}$ provided by internal pullups (Note 2) |
| Output Low Voltage (I/O and CLK OUT) | Vol | - | - | 0.45 | V | $\mathrm{loL}=1.6 \mathrm{~mA}$ |
| Input Leakage Current ( $\overline{\mathrm{MCLR}}, \overline{\mathrm{RT}}, \mathrm{OSC} 1$ ) | ILC | -5 | - | +5 | $\mu \mathrm{A}$ | VSS $=$ VIN - VDD |
| Input Low Current (All I/O ports) | IIL | -0.2 | -0.6 | $-2.0$ | mA | $\mathrm{VIL}=0.4 \mathrm{~V}$ internal pullup |
| Input High Current (All I/O ports) | IIH | -0.1 | -0.4 | - | mA | $\mathrm{VIH}=2.4 \mathrm{~V}$ |

* Typical data is at $\mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{VDD}=0 \mathrm{~V}$.

Notes: 1. Total power dissipation for the package is calculated as follows:
$\mathrm{PO}=(\mathrm{VDD})(\mathrm{IDD})+\sum\{(\mathrm{VDD}-\mathrm{VIL}) \cdot|\mathrm{VIL}|\}+\sum\{(\mathrm{VDD}-\mathrm{VOH}) \cdot|\mathrm{IOH}|\}+\Sigma\{(\mathrm{VOL}) \cdot \mid \mathrm{OL}\}$.
2 Positive current indicates current into pin. Negative current indicates current out of pin.
3. Total lol for all output pin (I/O ports plus CLK OUT) must not exceed 175 mA .

| AC CHARACTERISTICS |  |  |  | Operating temperature: <br> - Commercial: <br> - Industrial: |  | ure: $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=0{ }^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typ | Max | Units | Conditions |
| Instruction Cycle Time <br> $\overline{R T}$ input <br> Period - Commercial <br> Period -Industrial <br> High Pulse Width <br> Low Pulse Width <br> I/O Ports <br> Data Input Setup Time <br> Data Input Hold Time <br> Data Output Propagation Delay | tCY <br> tRT <br> tRT <br> tRTH <br> tRTL <br> tR <br> th <br> tRT | 2.0 $\begin{gathered} \text { tcY }+175 \mathrm{~ns} \\ \text { tCY }+200 \mathrm{~ns} \\ 1 / 2 \mathrm{tRT} \\ 1 / 2 \mathrm{tRT} \end{gathered}$ | - - - - 500 | $\begin{gathered} 1 / 4 \mathrm{tCY}-125 \\ - \\ 800 \end{gathered}$ | $\mu \mathrm{s}$ <br> - <br> - <br> - <br> ns <br> ns <br> ns | 4 MHz external time base (Notes 1, 2, 4)) <br> (Note 3) <br> Commercial: $\mathrm{TA}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ <br> Industrial: $T A=85^{\circ} \mathrm{C}$ <br> Commercial: $\mathrm{TA}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ <br> Commercial: $\mathrm{TA}=70^{\circ} \mathrm{C}$ <br> Capacitance load $=50 \mathrm{pF}$ |
| Notes: <br> 1. Instruction cycle period (tcy) equals eight times the oscillator time base period. <br> 2. The oscillator frequency may deviate to 4.08 MHz to allow for tolerance of the time base element (LC, crystal, or ceramic resonator). <br> 3. Due to the synchronous timing nature between CLK OUT and the sampling circuit used on the $\overline{\mathrm{RT}}$ input, CLK OUT may be directly tied to the $\overline{\mathrm{RT}}$ input. The minimum times specified represent theoretical limits. <br> 4. The maximum frequency which may be input to the $\overline{\mathrm{RT}}$ pin is calculated as follows: <br> where: $\partial=175$ ns for Commercial $f_{\max }=\frac{1}{t_{R T \min }}=\frac{1}{t_{\text {CYmint }}+\delta}$ <br> $\partial=200$ ns for Industrial <br> Examples: Commercial: if tcY $=2 \mu \mathrm{~s}, \mathrm{f}(\max )=1 / 2.175 \mu \mathrm{~s}=460 \mathrm{KHz}$ <br> Industrial: $\quad$ if $\mathrm{tCY}=2 \mu \mathrm{~s}, \mathrm{f}(\max )=1 / 2.2 \mu \mathrm{~s}=455 \mathrm{KHz}$. |  |  |  |  |  |  |

## PIC1670



## SCHMITT TRIGGER CHARACTERISTICS (TYPICAL)



## TYPICAL OSCILLATOR CIRCUITS



## EXT. INPUT OPERATION



## MASTER CIRCUIT (TYPICAL)



Note:The $\overline{\text { MCLR }}$ pin must be pulsed low for a minimum of one complete instruction cycle (tcy) for the master clear function to be guaranteed, assuming that power is applied and the oscillator is running. For inititial power application, a delay is required for the external oscillator time base element to start up before MCLR is brought high. To achieve this, an external RC configuration as shown can be used. This provides approximately a 10 ms delay (assuming VDD is applied as a step function), which may be insufficient for some time base elements. Consult the manufacturer of the time base element for specific start-up times.

POWER DISSIPATION DERATING GRAPH


Notes: $1.70^{\circ} \mathrm{C}$ is the maximum operating temperature for standard parts.
2. $85^{\circ} \mathrm{C}$ is the maximum operating temperature for "I" suffix parts.

IOH
(mA)


VOH VS IOH (I/O PORTS) (TYPICAL)


## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



LIFE SUPPORT SYSTEM - Microchip's products are not authorized for use as critical components in life support devices or systems without the express written approval of Microchip Technology, Inc.

Microchip

## SECTION 5 LOGIC PRODUCT SPECIFICATIONS

AY2661 Enhanced Programmable Communication Interface ..... 5- 1
AY3-1015D UAR/T: Universal Asynchronous Receiver/Transmitter ..... 5- 17
AY58116/36 Dual Baud Rate Generator ..... 5- 29
AY58126/46 Single Baud Rate Generator ..... 5-37
AY38910A/12A Programmable Sound Generator ..... 5-45
AY8930 Enhanced Programmable Sound Generator ..... 5- 61
AY0438-1 32-Segment CMOS LCD Driver ..... 5-81

## Enhanced Programmable Communication Interface

## FEATURES

- Synchronous and Asynchronous full or half duplex operation
- On-chip baud rate generator - 3 standards
- Double buffering of data
- TTL compatible
- Single +5 volt power supply
- Compatible with SC2661, COM2661


## DESCRIPTION

The AY2661 is a universal synchronous /asynchronous receiver/transmitter designed for microcomputer system data communications. It may be programmed by the processor to communicate in commonly used asynchronous and synchronous serial data transmission techniques including Bi-Sync. The AY2661 receives serial data streams and converts them into parallel data characters for the processor. While receiving serial data, the device will also accept data characters from the processor in parallel format, convert them to serial format and transmit. The AY2661 will signal the processor when it has completely received or transmitted a

character and requires service. Complete status information including data format errors and control signals is available to the processor at any time.


## PIN FUNCTIONS

| Pin Name | Function |
| :---: | :---: |
| BRCLK | Clock input to the internal baud rate generator. Not required if external receiver and transmitter clocks are used. |
| $\overline{\mathrm{R} \times \mathrm{C}} / \mathrm{BKDET}$ | Receiver clock. If external receiver clock is programmed, this input controls the rate at which the character is to be received. Its frequency is $1 \mathrm{X}, 16 \mathrm{X}$ or 64 X the baud rate, as programmed by mode register 1 . Data are sampled on the rising edge of the clock. If internal receiver clock is programmed, this pin can be a $1 \mathrm{X} / 16 \mathrm{X}$ clock or a break detect output pin. |
| $\overline{T \times C / X S Y N C}$ | Transmitter clock. If external transmitter clock is programmed, this input controls the rate at which the character is transmitted. Its frequency is $1 \mathrm{X}, 16 \mathrm{X}$ or 64 X the baud rate, as programmed by mode register 1 . The transmitted data changes on the falling edge of the clock. If internal transmitter clock is programmed, this pin can be $\mathrm{a} 1 \mathrm{X} / 16 \mathrm{X}$ clock output for an external jam synchronization input. |
| $R \times D$ | Serial data input to the receiver. "Mark" is high, "space" is low. |
| Tx D | Serial data output from the transmitter. "Mark" is high, "space" is low. Held in mark condition when the transmitter is disabled. |
| $\overline{\text { DSR }}$ | General purpose input which can be used for data set ready or ring indicator condition. Its complement appears as status register bit SR7. It causes a low output on TxEMT/ DSCHG when its state changes and CR2 or CRO $=1$. |
| DCD | Data carrier detect input. Must be low in order for the receiver to operate. Its complement appears as status register bit SR6. Causes a low output on TxEMT/DSCHG when its state changes and $C R 2$ or $C R 0=1$. If $D C D$ goes high while receiving, the $R \times C$ is internally inhibited. |
| $\overline{C T S}$ | Clear to send input. Must be low in order for the transmitter to operate. If it goes high during transmission, the character in the transmit shift register will be transmitted before termination. |
| $\overline{\text { DTR }}$ | General purpose output which is the complement of command register bit CR1. Normally used to indicate data terminal ready. |
| $\overline{\text { RTS }}$ | General purpose output which is the complement of command register bit CR5. Normally used to indicate request to send. If the transmit shift register is not empty when CR5 is reset ( 1 to 0 ), then RTS will go high one $\mathrm{T} \times \mathrm{C}$ time after the last serial bit is transmitted. |
| RESET | A high on this input performs a master reset on the AY2661. This signal asynchronously terminates any device activity and clears the mode, command and status registers. The device assumes the idle state and remains there until initialized with the appropriate control words. |
| $A_{1}-A_{0}$ | Address lines used to select internal EPCI registers. |
| $\overline{\mathrm{R}} / \mathrm{W}$ | Read command when low, write command when high. |
| $\overline{C E}$ | Chip enable command. When low, indicates that control and data lines to the EPCI are valid and that the operation specified by the $\bar{R} / W, A_{1}$ and $A_{0}$ inputs should be performed. When high, places the $D_{0}-D_{7}$ lines in the three-state condition. |

PIN FUNCTIONS (CONTINUED)

| Pin Name | Function |
| :---: | :---: |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | 8-bit, three-state data bus used to transfer commands, data and status between EPCI and the CPU. $D_{0}$ is the least significant bit; $D_{7}$ the most significant bit. |
| $\overline{T \times R D Y}$ | This output is the complement of status register bit SRO. When low, it indicates that the transmit data holding register (THR) is ready to accept a data character from the CPU. It goes high when the data character is loaded. This output is valid only when the transmitter is enabled. It is an open drain output which can be used as an interrupt to the CPU. |
| $\overline{\mathrm{R} \times \mathrm{RDY}}$ | This output is the complement of status register bit SR1. When low, it indicates that the receive data holding register (RHR) has a character ready for input to the CPU. It goes high when the RHR is read by the CPU, and also when the receiver is disabled. It is an open drain output which can be used as an interrupt to the CPU. |
| $\begin{aligned} & \overline{\text { TxEMT/ }} \\ & \overline{\text { DSCHG }} \end{aligned}$ | This output is the complement of status register bit SR2. When low, it indicates that the transmitter has completed serialization of the last character loaded by the CPU, or that a change of state of the $\overline{\mathrm{DSR}}$ or $\overline{\mathrm{DCD}}$ inputs has occured. This output goes high when the status register is read by the CPU, if the TxEMT condition does not exist. Otherwise, the THR must be loaded by the CPU for this line to go high. It is an open drain output which can be used as an interrupt to the CPU. |

## AY2661 OPERATION

The functional operation of the AY2661 is programmed by a set of control words supplied by the processor. These control words specify items such as synchronous or asynchronous mode, baud rate, number of bits per character, etc.

## Receiver

The AY2661 is conditioned to receive data when the DCD input is low and RxEN bit in the command register is true. In the asynchronous mode, the receiver looks for a high to low (mark to space) transition of the start bit on the RxD input line. If a transition is detected, the state of the RxD line is sampled again after a delay of one-half of a bit time. If $R x D$ is now high, the search for a valid start bit is begun again. If RxD is still low, a valid start bit is assumed and the receiver continues to sample the input line at one bit time intervals until the proper number of data bits, the parity bit, and one stop bit have been assembled. The data is then transferred to the Receive Data Holding Register, the RxRDY bit in the status register is set, and the RxRDY output is asserted. If the character length is less than 8 bits, the high order unused bits in the Holding Register are set to zero. The Parity Error, Framing Error, and Overrun Error status bits are strobed into the status register on the positive going edge of $\overline{\mathrm{RxC}}$ corresponding to the received character boundary. If the stop bit is present, the receiver will immediately begin its search for the next start bit. If the stop bit is absent (framing error), the receiver will interpret a space as a start bit if it persists into the next bit time interval. If a break condition is
detected ( $R \times D$ is low for the entire character as well as the stop bit), only one character consisting of all zeros (with the Framing error status bit set) will be transferred to the Holding Register. The RxD input must return to a high condition before a search for the next start bit begins.

Pin 25 can be programmed to be a break detect output by appropriate setting of MR27-MR24. If so, a detected break will cause that pin to go high. When RxD returns to mark for one RxC time, pin 25 will go low. Refer to the break detection timing diagram.
When the AY2661 is initialized into the synchronous mode, the receiver first enters the hunt mode on a 0 to 1 transition of RxEN (CR2). In this mode, as data is shifted into the Receiver Shift Register a bit at a time, the contents of the register are compared to the contents of the SYN1 register. If the two are not equal, the next bit is shifted in and the comparison is repeated. When the two registers match, the hunt mode is terminated and character assembly begins. If the single SYN operation is programmed, the SYN DETECT status bit is set. If double SYN operation is programmed, the first character assembled after SYN1 must be SYN2 in order for the SYN DETECT bit to be set.
Otherwise, the AY2661 returns to the hunt mode. (note that the sequence SYN1-SYN1-SYN2 will not achieve synchronization). When synchronization has been acheived, the AY2661 continues to assemble charac-
ters and transfers them to the Holding Register. The RxRDY status bit is set and the RxRDY output is asserted each time a character is assembled and transferred to the Holding Register. The Overrun error (OE) and Parity error (PE) status bits are set as appropriate. Further receipt of the proper SYN sequence sets the SYN DETECT status bit. If the SYN stripping mode is commanded, SYN characters are not transferred to the Holding Register. Note that the SYN characters used to establish initial synchronization are not transferred to the Holding Register in any case.

External jarn synchronization can be achieved via pin 9 by appropriate setting of MR27-MR24. When pin 9 is an XSYNC input, the internal SYN1-SYN2, and DLE-SYN1 detection is disabled. Each positive going signal on XSYNC will cause the receiver to establish synchronization on the rising edge of the next RxC pulse. Character assembly will start with the RxD input at this edge. XSYNC may be lowered on the next rising edge of RxC. This external synchronization will cause the SYN DETECT status bit to be set until the status register is read. Refer to XSYNC timing diagram.

## Transmitter

The AY2661 is conditioned to transmit when the CTS input is low and the TXEN command register bit is set. The AY2661 indicates to the processor that it can accept a character for transmission by setting the TxRDY status bit and asserting the TxRDY output. When the processor writes a character into the Transmit Data Holding Register, the TxRDY status bit is reset and the TxRDY output is returned to a high (false) state. Data is transferred from the Holding Register to the Transmit Shift Register when it is idle or has completed transmission of the previous character. The TxRDY conditions are then asserted again. Thus, one full character time of buffering is provided.
In the asynchronous mode, the transmitter automatically sends a start bit followed by the programmed number of data bits, the least significant bit being sent first. It then appends an optional odd or even parity bit and the programmed number of stop bits. If, following transmission of the data bits, a new character is not available in the Transmit Holding Register, the TxD output remains in the marking (high) condition and the $\overline{\text { TxEMT/ }} / \overline{\mathrm{DSCHG}}$ output and its corresponding status bit are asserted. Transmission resumes when the processor loads a new character into the Holding Register. The transmitter can be forced to output a continuous low (BREAK) condition by setting the Send Break command bit high.
In the synchronous mode, when the AY2661 is initially conditioned to transmit, the TxD output remains high and the TxRDY condition is asserted until the first character to be transmitted (usually a SYN character) is loaded by the processor. Subsequent to this, a continuous stream of characters is transmitted. No extra bits (other than parity if commanded) are generated by the AY2661 unless the processor fails to send a new char-
acter to the AY2661 by the time the transmitter has completed sending the previous character. Since synchronous communication does not allow gaps between characters, the AY2661 asserts TxEMT and automatically "fills" the gap by transmitting SYN1s, and SYN1SYN2 doublets, or DLE-SYN1 doublets, depending on the state of MR16 and MR17. Normal transmission of the message resumes when a new character is available in the Transmit Data Holding Register. If the SEND DLE bit in the command register is true, the DLE character is automatically transmitted prior to transmission of the message character in the transmit holding register.

## AY2661 Programming

Prior to initiating data communications, the AY2661 operational mode must be programmed by performing write operations to the mode and command registers. In addition, if synchronous operation is programmed, the appropriate SYN/DLE registers must be loaded. The AY2661 can be reconfigured at any time during program execution. A flow chart of the initialization process follows.

The internal registers of the AY2661 are accessed by applying specific signals to the $\overline{C E}, \overline{\mathrm{R}} / \mathrm{W}$ A1 and A0 inputs. The conditions necessary to address each register are shown in Fig. 3.
The SYN1, SYN2, and DLE registers are accessed by performing write operations with the conditions $\mathrm{A} 1=0$, $A 0=1$, and $\overline{\mathrm{R}} / \mathrm{W}=1$. The first operation loads the SYN1 register. The next loads the SYN2 register, and the third loads the DLE register. Reading or loading the mode registers is done in a similar manner. The first write (or read) operation addresses Mode Register 1 and subsequent operation addressed Mode Register 2. If more than the required number of accesses are made, the internal sequencer recycles to point at the first register. The pointers are reset to SYN1 Register and Mode Register 1 by a RESET input or by performing a "Read Command Register" operation, but are unaffected by any other read or write operation.
The AY2661 register formats are summarized in Tables 6, 7, 8 and 9 . Mode Registers 1 and 2 define the general operational characteristics of the AY2661, while the Command Register controls the operation within this basic framework. The AY2661 indicates its status in the Status Register. These registers are cleared when a RESET input is applied.

## AY2661 INITIALIZATION FLOW CHART



| AY2661 REGISTER ADDRESSING |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| CE | A1 | A0 | R/W | Function |
| 1 | X | X | X | Tri-state data bus |
| 0 | 0 | 0 | 0 | Read receive holding register |
| 0 | 0 | 0 | 1 | Write transmit holding register |
| 0 | 0 | 1 | 0 | Read status register |
| 0 | 0 | 1 | 1 | Write SYN1/SYN2/DLE registers |
| 0 | 1 | 0 | 0 | Read mode registers 1 and 2 |
| 0 | 1 | 0 | 1 | Write mode registers 1 and 2 |
| 0 | 1 | 1 | 0 | Read command register |
| 0 | 1 | 1 | 1 | Write command register |
| NOTE |  |  |  |  |
| AC | risti | tim | men |  |


| MODE REGISTER 1 (MR1) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MR17 | MR16 | MR15 | MR14 | MR13 | MR12 | MR11 | MR10 |
| Sync/Async |  | Parity <br> Type | Parity Control | Character Length |  | Mode and Baud Rate Factor |  |
| Async: Stop Bit Length <br> $00=$ Invalid <br> $01=1$ stop bit <br> $10=11 / 2$ stop bits <br> $11=2$ stop bits |  | $\begin{aligned} & 0=\text { Odd } \\ & 1=\text { Even } \end{aligned}$ | $\begin{aligned} & 0=\text { Disabled } \\ & 1=\text { Enabled } \end{aligned}$ | $\begin{aligned} & 00=5 \text { bits } \\ & 01=6 \text { bits } \\ & 10=7 \text { bits } \\ & 11=8 \text { bits } \end{aligned}$ |  | $00=$ Synchronous $1 X$ rate <br> 01 = Asynchronous 1X rate <br> $10=$ Asynchronous 16X rate <br> 11 = Asynchronous 64X rate |  |
| Sync: <br> Number of SYN char $\begin{gathered} 0=\text { Double } \\ \text { Syn } \\ 1=\text { Single } \\ \text { Syn } \end{gathered}$ | Sync: <br> Transparency Control <br> $0=$ Normal <br> 1 = Transparent |  |  |  |  |  |  |
| NOTE <br> Baud rate factor in asynchronous applies only if external clock is selected. Factor is 16 X if internal clock is selected. |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## MODE REGISTER 2 (MR2)

MR27 - MR24
MR23 - MR20

|  | TxC | RxC | Pin 9 | Pin 25 |  | TxC | RxC | Pin 9 | Pin 25 | Mode | Baud Rate Selection |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0000 | E | E | TxC | RxC | 1000 | E | E | XSYNC ${ }^{1}$ | RxC/TxC | Sync | See baud rates in baud rate standards |
| 0001 | E | I | TxC | 1X | 1001 | E | I | TxC | BKDET | Async |  |
| 0010 | 1 | E | 1X | RxC | 1010 | 1 | E | XSYNC ${ }^{1}$ | RxC | Sync |  |
| 0011 | 1 | 1 | 1X | 1X | 1011 | 1 | 1 | 1X | BKDET | Async |  |
| 0100 | E | E | TxC | RxC | 1100 | E | E | XSYNC ${ }^{1}$ | RxC/TxC | Sync |  |
| 0101 | E | 1 | TxC | 16X | 1101 | E | 1 | TxC | BKDET | Async |  |
| 0110 | I | E | 16X | RxC | 1110 | 1 | E | XSYNC ${ }^{1}$ | RxC | Sync |  |
| 0111 | 1 | 1 | 16X | 16X | 1110 | 1 | I | 16X | BKDET | Async |  |

## NOTES

1. When pin 9 is programmed as XSYNC input, SYN1, SYN1-2, and DLE-SYN1 detection is disabled.
$\mathrm{E}=$ External clock
I = Internal clock (BRG)
1 X and 16 X are clock outputs

| COMMAND REGISTER (CR) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CR7 | CR6 | CR5 | CR4 | CR3 | CR2 | CR1 | CRO |
| Operating Mode |  | Request To Send | Reset Error | Sync/Async |  | Data Terminal Ready | Transmit Control (TxEN) |
| $00=$ Normal operation <br> 01 = Async: <br> Automatic <br> echo mode <br> Sync: SYN and/ <br> or DLE stripping mode <br> 10 = Local loop back <br> 11 = Remote loop back |  | $0=$ Force $\overline{\text { RTS }}$ output high one clock time after TxSR serialization 1 = Force $\overline{\text { RTS }}$ output low | $0=$ Normal <br> 1 = Reset error flags in status register (FE, OE, PE/DLE detect). | Async: <br> Force break <br> $0=$ Normal <br> 1 = Force <br> break <br> Sync: <br> Send DLE <br> $0=$ Normal <br> 1 = Send <br> DLE | $\begin{aligned} & 0=\text { Disable } \\ & 1=\text { Enable } \end{aligned}$ | $\begin{aligned} & 0=\text { Force } \overline{\mathrm{DIR}} \\ & \text { output high } \\ & 1=\text { Force } \overline{\mathrm{DIR}} \\ & \text { output low } \end{aligned}$ | $\begin{aligned} & 0=\text { Disable } \\ & 1=\text { Enable } \end{aligned}$ |


| STATUS REGISTER (SR) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SR7 | SR6 | SR5 | SR4 | SR3 | SR2 | SR1 | SRO |
| Data Set Ready | Data Carrier Detect | FE/SYN Detect | Overrun | PE/DLE Detect | TxEMT/ DSCHG | RxRDY | TxRDY |
| $\begin{aligned} & 0=\overline{\mathrm{DSR}} \text { input } \\ & \text { is high } \\ & 1=\overline{\mathrm{DSR}} \text { input } \\ & \text { is low } \end{aligned}$ | $\begin{aligned} & 0=\overline{D C D} \text { input } \\ & \text { is high } \\ & 1=\overline{D C D} \text { input } \\ & \text { is low } \end{aligned}$ | Async: <br> $0=$ Normal <br> 1 = Framing Error <br> Sync: <br> $0=$ Normal <br> 1 = SYN CHAR <br> detected | $\begin{array}{c\|} \hline 0=\text { Normal } \\ 1=\text { Overrun } \\ \text { Error } \end{array}$ | Async: <br> $0=$ Normal <br> 1 = Parity Error <br> Sync: <br> $0=$ Normal <br> 1 = Parity error or DLE received | $0=$ Normal <br> 1 = Change in $\overline{\mathrm{DSR}}$ or $\overline{D C D}$, or transmit shift register is empty | $0=$ Receive holding register empty 1 = Receive holding register has data | $0=$ <br> Transmit <br> holding <br> register <br> busy <br> $1=$ <br> Transmit <br> holding <br> register <br> empty |

## TIMING DIAGRAMS

TxRDY, TxEMT (shown for 5-bit characters, no parity, 2 stop bits [in asynchronous mode]



## NOTES

## A = Start bit

B $=$ Stop bit 1
C $=$ Stop bit 2
$\mathrm{D}=\mathrm{T} \times \mathrm{D}$ marking condition
TxEMT goes low at the beginning of the last data bit or if parity is enabled at the beginning of the parity bit

## TIMING DIAGRAMS (Cont.)

RxRDY (Shown for 5-bit characters, no parity, 2 stop bits [in asynchronous mode])



NOTES
A = Start bit
B $=$ Stop bit 1
C $=$ Stop bit 2
$D=T \times D$ marking condition

TIMING DIAGRAMS (Cont.)


## TIMING DIAGRAMS (Cont.)



RECEIVE


READ AND WRITE


## TIMING DIAGRAMS (Cont.)

## EXTERNAL SYNCHRONIZATION WITH XSYNC



BREAK DETECTION TIMING


## ELECTRICAL CHARACTERISTICS

Maximum Guaranteed Ratings*
Operating Temperature Range $\qquad$ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range $\qquad$ $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec .) $\qquad$ $+325^{\circ} \mathrm{C}$
Positive Voltage on any Pin,
with respect to ground $\qquad$ $+18.0 \mathrm{~V}$
Negative Voltage on any Pin, with respect to ground $\qquad$ -0.3V

* Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Data labeled "typical" is presented for design guidance only and is not guaranteed.

DC CHARACTERISTICS
Operating temperature $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%$

| Characteristics | Sym | Min | Typ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input Voltage |  |  |  |  |  |  |
| Low | $\mathrm{V}_{1}$ | - | - | 0.8 | V |  |
| High | $\mathrm{V}_{\mathrm{H}}$ | 2.0 | - | - | - |  |
| Output voltage |  |  |  |  |  |  |
| Low | $\mathrm{V}_{\mathrm{oL}}$ | - | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$ |
| High | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | - |  | $\mathrm{I}_{\mathrm{OH}}=400 \mu \mathrm{~A}$ |
| Input leakage current | $I_{\text {LI }}$ | - | - | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.5 V |
|  |  |  |  |  |  |  |
| Data bus high | $\mathrm{I}_{\text {LH }}$ | - |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=4.0 \mathrm{~V}$ |
| Data bus low | $\mathrm{I}_{\mathrm{LL}}$ | - | - | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{o}}=0.45 \mathrm{~V}$ |
| Power supply current | $\mathrm{l}_{\text {cc }}$ | - | - | 150 | mA |  |
| Capacitance |  |  |  |  |  |  |
| Input | $\mathrm{C}_{\text {IN }}$ |  |  | 20 | pF | fc $=1 \mathrm{MHz}$ |
| Output | $\mathrm{C}_{\text {OUt }}$ | - | - | 20 | pF | Unmeasured pins tied |
| Input/Output | $\mathrm{C}_{10}$ | - | - | 20 | pF | to ground |



BAUD RATE STANDARDS

| AY2661-A <br> (BRCLK = 4.9152MHz) |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| MR23-20 | Baud Rate | Actual Frequency <br> 16X Clock | Percent <br> Error | Divisor |  |
| 0000 | 50 | 0.8 kHz | - | 6144 |  |
| 0001 | 75 | 1.2 | - | 4096 |  |
| 0010 | 110 | 1.7598 | -0.01 | 2793 |  |
| 0011 | 134.5 | 2.152 | - | 2284 |  |
| 0100 | 150 | 2.4 | - | 2048 |  |
| 0101 | 200 | 3.2 | - | 1536 |  |
| 0110 | 300 | 4.8 | - | 1024 |  |
| 011 | 600 | 9.6 | - | 512 |  |
| 1000 | 1050 | 16.8329 | 0.196 | 292 |  |
| 1001 | 1200 | 19.2 | - | 256 |  |
| 1010 | 1800 | 28.7438 | -0.19 | 171 |  |
| 1011 | 2000 | 31.9168 | -0.26 | 154 |  |
| 1100 | 2400 | 38.4 | - | 128 |  |
| 1101 | 4800 | 76.8 | - | 64 |  |
| 1110 | 9600 | 153.6 | - | 32 |  |
| 1111 | 19200 | 307.2 | - | 16 |  |

## AY2661-B

(BRCLK $=4.9152 \mathrm{MHz}$ )

| MR23-20 | Baud Rate | Actual Frequency <br> 16X Clock | Percent <br> Error | Divisor |
| :---: | :---: | :---: | :---: | :---: |
| 0000 | 45.5 | 0.7279 kHz | 0.005 | 6752 |
| 0001 | 50 | 0.8 | - | 6144 |
| 0010 | 75 | 1.2 | - | 4096 |
| 0011 | 110 | 1.7598 | -0.01 | 2793 |
| 0100 | 134.5 | 2.152 | - | 2284 |
| 0101 | 150 | 2.4 | - | 2048 |
| 0110 | 300 | 4.8 | - | 1024 |
| 0111 | 600 | 9.6 | - | 512 |
| 1000 | 1200 | 19.2 | -0.19 | 256 |
| 1001 | 1800 | 28.7438 | -0.26 | 171 |
| 1010 | 2000 | 31.9168 | - | 154 |
| 1011 | 2400 | 38.4 | - | 128 |
| 1100 | 4800 | 76.8 | - | 64 |
| 1101 | 9600 | 153.6 | - | 32 |
| 1110 | 19200 | 307.2 | 16 |  |
| 1111 | 38400 | 614.4 | 8 |  |

## BAUD RATE STANDARDS (CONT.)

| AY2661-C <br> (BRCLK $=5.0688 \mathrm{MHz}$ ) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| MR23-20 | Baud Rate | Actual Frequency 16X Clock | Percent Error | Divisor |
| 0000 | 50 | 0.8 kHz | - | 6336 |
| 0001 | 75 | 1.2 | - | 4224 |
| 0010 | 110 | 0.76 | - | 2880 |
| 0011 | 134.5 | 2.1523 | 0.016 | 2355 |
| 0100 | 150 | 2.4 | - | 2112 |
| 0101 | 300 | 4.8 | - | 1056 |
| 0110 | 600 | 9.6 | - | 528 |
| 0111 | 1200 | 19.2 | - | 264 |
| 1000 | 1800 | 28.8 | - | 176 |
| 1001 | 2000 | 32.081 | -0.253 | 158 |
| 1010 | 2400 | 38.4 | - | 132 |
| 1011 | 3600 | 57.6 | - | 88 |
| 1100 | 4800 | 76.8 | - | 66 |
| 1101 | 7200 | 115.2 | - | 44 |
| 1110 | 9600 | 153.6 | - | 33 |
| 1111 | 19200 | 316.8 | 3.125 | 16 |
| NOTE <br> 16X clock is used in asynchronous mode. In synchronous mode, clock multiplier is 1 X and BRG can be used only for TxC. |  |  |  |  |

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.


## UAR/T: UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER

## FEATURES

- DTL and TTL compatible - no interfacing circuits required - drives one TTL load
- Fully Double Buffered - eliminates need for system synchronization, facilitates high-speed operation
- Full Duplex Operation - can handle multiple bauds (receiving - transmitting) simultaneously
- Start Bit Verification - decreases error rate with center sampling
- Receiver center sampling of serial input; $46 \%$ distortion immunity
- High Speed Operation
- Three-State Outputs - bus structure capability
- Low Power - minimum power requirements
- Input Protected - eliminates handling problems
- Single Supply Operation: +4.75 V to +5.25 V
- 1 1/2 stop bit mode
- External reset of all registers except control bits register
- N-channel Ion Implant Process
- 0 to 25 K baud
- Pull-up resistors to Vcc on all inputs


## DESCRIPTION

The Universal Asynchronous Receiver/Transmitter (UAR/T) is an LSI subsystem which accepts binary characters from either a terminal device or a computer and receives/transmits this character with appended control and error detecting bits. All characters contain a start bit, 5 to 8 data bits, 1, 1-1/2, or 2 stop bit capability, and either odd/even parity or no parity. In order to make the UAR/T universal, the baud, bits per word, parity mode, and the number of stop bits are externally selectable. The device is constructed on a single monolithic chip. All inputs and outputs are directly compatible with TTL/DTL/CMOS logic without the need for interfacing components. All strobed outputs are three-state logic.

| PIN CO 40 LEA | ATION NLINE |
| :---: | :---: |
| $\mathrm{Vcc}(+5 \mathrm{~V})=1$ | $40 \square$ TCP |
| No Connect 2 | 39 EPS |
| GND 3 | 38 NB1 |
| FDE 4 | 37 NB2 |
| RD8 5 | 36 ZTSB |
| RD7 6 | 35 DP |
| RD6 7 | $34 \square \mathrm{CS}$ |
| RD5 8 | 33 DB8 |
| RD4 9 | $32 \square$ DB7 |
| RD3 - 10 | 31 DB6 |
| RD2 11 | $30 \square$ DB5 |
| RD1 12 | 29 D DB4 |
| PE 13 | 28 DB3 |
| FE 14 | 27 日. DB2 |
| OR 15 | 26 DB1 |
| SWE 16 | 25 SO |
| RCP 17 | $24 \square$ EOC |
| RDAV 18 | $23 \square \overline{\mathrm{DS}}$ |
| DAV 19 | 22 ¢ TBMT |
| SI 20 | $21]$ PR |



## PIN FUNCTIONS

| Pin <br> Number | Signal Name | Input/ Output | Function |
| :---: | :---: | :---: | :---: |
| 1 | VCC | 1 | VCC Power Supply: +5V Supply |
| 2 | N.C. | - | (Not Connected) |
| 3 | Ground | - | Ground |
| 4 | RDE |  | Received Data Enable: A logic " 0 " on this input places the received data onto the output lines (RD8..RD1). |
| 5-12 | RD8..RD1 | 1 | Received Data Bits: These are the 8 data output lines. Received characters are right justified: the LSB always appears on RD1. These lines have tri-state outputs; i.e., they have the normal TTL output characteristics when RDE is " 0 " and a high impedence state when RDE is "1". Thus, the data output lines can be bus structure oriented. |
| 13 | PE | 0 | Parity Error: This line goes to a logic "1" if the received character parity does not agree with the selected parity. Tri-state when SWE (pin 16) is " 1 ". |
| 14 | FE | 0 | Framing Error: This line goes to a logic "1" if the received character has no valid stop bit. Tri-state when SWE (pin 16) is " 1 ". |
| 15 | OR | 0 | Over-Run: This line goes to a logic "1"if the previously received character is not read (DAV line not reset) before the present character is transferred to the receiver holding register. Tri-state when SWE (pin 16) is "1". |
| 16 | $\overline{\text { SWE }}$ | 1 | Status Word Enable: A logic "0" on this line places the status word bits (PE, FE, OR, DAV, TBMT) onto the output lines. A logic "1" puts the status word bit outputs into a high impedance state. |
| 17 | RCP | 1 | Receiver Clock: This input line requires a clock whose frequency is 16 times (16X) the desired receiver baud rate. |
| 18 | $\overline{\text { RDAV }}$ | 1 | Reset Data Available: A logic "0" will reset the DAV line. The DAV F/F is the only thing that is reset. |
| 19 | DAV | 0 | Data Available: This line goes to a logic "1" when an entire character has been received and transferred to the receiver holding register. Tri-state when SWE (pin $16)$ is " 1 ". Fig. 8. |
| 20 | SI | 1 | Serial Input: This line accepts the serial bit input stream. A marking (logic "1") to spacing (logic " 0 ") transition is required for initiation of data reception. Fig. 7, 8. |
| 21 | XR | 1 | External Reset: Resets all registers. Sets SO, EOC, and TBMT to a logic "1". Resets DAV, and error flags to "0". Clears input data buffer. Must be tied to logic " 0 " when not in use. |


| PIN F | FUNCTION | NS (CON | NT.) |
| :---: | :---: | :---: | :---: |
| Pin Number | Signal <br> Name | Input/ Output | Function |
| 22 | TBMT | 0 | Transmitter Buffer Empty: The transmitter buffer empty flag goes to a logic "1" when the data bits holding register may be loaded with another character. Tri-state. See Fig. 14, 16. Tristate when SWE (pin 16) is " 1 ". |
| 23 | DS | 1 | Data Strobe: A strobe on this line will enter the data bits into the data bits holding register. Initial data transmission is initiated by the rising edge of DS. Data must be stable during entire strobe. |
| 24 | EOC | 0 | End of Character: This line goes to a logic "1" each time a full character is transmitted. It remains at this level until the start of transmission of the next character. See Fig. 13, 15. |
| 25 | SO | 0 | Serial Output: This line will serially, by bit, provide the entire transmitted character. It will remain at a logic " 1 " when no data is being transmitted. |
| $26 . .33$ | DB1..DB8 | 1 | Data Bit Inputs: There are up to 8 data bit input lines available. |
| 34 | CS | 1 | Control Strobe: A logic "1" on this lead will enter the control bits (EPS, NB1, NB2, TSB, NP) into the control bits holding register. This line can be strobed or hard wired to a logic "1" level. |
| 35 | NP | 1 | No Parity: A logic "1" on this lead will eliminate the parity bit from the transmitted and received character (no PE indication). The stop bit(s) will immediately follow the last data bit. If not used, this lead must be tied to a logic " 0 ". |
| 36 | TSB | 1 | Number of Stop Bits: This lead will select the number of stop bits, 1 or 2 to be appended immediately after the parity bit. A logic " 0 " will insert 1 stop bit and a logic " 1 " will insert 2 stop bits. The combined selection of 2 stop bits and 5 bits/character will produce $11 / 2$ stop bits. |
| 37-38 | NB2, NB1 | 1 | Number of Bits/Character: These two leads will be internally decoded to select either $5,6,7$ or 8 data bits/character. |
|  |  |  | NB2 NB1 Bits/Character <br> 0 0 5 <br> 0 1 6 <br> 1 0 7 <br> 1 1 8 |
| 39 | EPS | 1 | Odd/Even Parity Select: The logic level on this pin selects the type of parity which will be appended immediately after the data bits. It also determines the parity that will be checked by the receiver. A logic " 0 " will insert odd parity and a logic "1" will insert even partiy. |
| 40 | TCP | 1 | Transmitter Clock: This input line requires a clock whose frequency is 16 times (16X) the desired transmitter baud rate. |

## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Vcc(with Respect to GND) $\qquad$ -0.3 to +16 V
Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temperature (Soldering, 10 sec ) $\qquad$ $+330^{\circ} \mathrm{C}$

## Standard Conditions

(unless otherwise noted)
Vcc $\qquad$ +4.75 V to +5.25 V
Operating Temperature (TA) $\qquad$ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
*Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Data labeled "typical" is presented for design guidance only and is not guaranteed.

| DC CHARACTERISTICS |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristics | Min | Typ | Max | Units | Conditions |
| Input Logic Levels (AY31015D) |  |  |  |  |  |
| Logic 0 | 0 | - | 0.8 | Volts |  |
| Logic 1 | 2.0 | - | $\mathrm{V}_{\mathrm{cc}}+0.3$ | Volts | Has internal pull-up resistors to $\mathrm{V}_{\mathrm{cc}}$ |
| Input Capacitance |  |  |  |  |  |
| All inputs | - | - | 20 | pF | 0 volts bias, $f=1 \mathrm{MHz}$ |
| Output Impedance |  |  |  |  |  |
| Hi-Impedance Outputs | 0.5 | - | - | M ohms | $\mathrm{V}_{\text {IN }}=5 \mathrm{~V}$ |
| Data Output Levels |  |  |  |  |  |
| Logic\% 0 | - | - | 0.8 | Volts | $\mathrm{I}_{\mathrm{oL}}=1.6 \mathrm{~mA}$ (sink) |
| Logic 1 | 2.4 | - |  | Volts | $\mathrm{I}_{\mathrm{oL}}=40 \mu \mathrm{~A}$ (source) - at $\mathrm{V}_{\text {cc }}=+5 \mathrm{~V}$ |
| Output Capacitance | - | 10 | 15 | pF |  |
| Power Supply Current |  |  |  |  |  |
| $\mathrm{l}_{\mathrm{cc}}$ at $\mathrm{V}_{\mathrm{cc}}=+5 \mathrm{~V}$ | - | 10 | 15 | mA |  |


| AC CHARACTERISTICS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristics | Min | Typ | Max | Units | Conditions | Remarks |
| Clock Frequency | DC | - | 400 | kHz | at $\mathrm{V}_{\mathrm{cc}}=+4.75 \mathrm{~V}$ | All AC testing |
| Baud | 0 | - | 25 | kbaud | at $\mathrm{V}_{\mathrm{cc}}=+4.75 \mathrm{~V}$ | waveforms at: |
| Pulse Width |  |  |  |  |  | $\mathrm{V}_{\mathrm{H}}=2.4 \mathrm{~V}$ |
| Clock Pulse | 1.0 | - | - | $\mu \mathrm{s}$ | See Fig. 5 | $\mathrm{V}_{\text {LL }}=0.8 \mathrm{~V}$ |
| Control Strobe | 200 | - | - | ns | See Fig. 11 | $\mathrm{V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ |
| Data Strobe | 200 |  | - | ns | See Fig. 10 | $\mathrm{V}_{\text {OL }}=0.8 \mathrm{~V}$ |
| External Reset | 500 |  | - | ns | See Fig. 9 |  |
| Status Word Enable | 500 | - | - | ns | See Fig. 17 |  |
| Reset Data Available | 200 | - | - | ns | See Fig. 18 |  |
| Received Data Enable | 500 | - | - | ns | See Fig. 17 |  |
| Set Up \& Hold Time |  |  |  |  |  |  |
| Input Data Bits | 20 |  | - | ns | See Fig. 10 |  |
| Input Control Bits | 20 | - | - | ns | See Fig. 11 |  |
| Output Propagation Delay |  |  |  |  |  |  |
| TPDO | - |  | 500 | ns | See Figs. 17 and 20 |  |
| TPD1 | - | - | 500 | ns | See Figs. 17 and 20 |  |

## TIMING DIAGRAMS

FIG. 1 UAR/T - TRANSMITTER TIMING


NOTES: SEE FIGURES 2, 3, 4 FOR DETAILS
TRANSMITTER INITIALLY ASSUMED INACTIVE AT START OF DIAGRAM. SHOWN FOR 8 LEVEL CODE AND PARITY AND TWO STOPS.
1: BIT TIME $=16$ CLOCK CYCLES.
2: IF TRANSMITTER IS INACTIVE THE START PULSE WILL APPEAR ON LINE SO 1 TO 2 CLOCK CYCLES AFTER THE DATA STROBE OCCURS. SEE DETAIL.

3: SINCE TRANSMITTER IS DOUBLE BUFFERED ANOTHER DATA STROBE CAN OCCUR ANYWHERE DURING TRANSMISSION OF CHARACTER 1 AFTER TBMT GOES HIGH.

DETAIL:


FIG. 2 TRANSMITTER AT START BIT NOT A TEST POINT

TRANSMITTER INACTIVE TRANSMIT BUFFER LOADED WHEN EOC HIGH


FIG. 4 ALLOWABLE POINTS TO USE


NOTE 1:
DS AND CS MAY OCCUR SIMULTANEOUSLY WHEN TRANSMITTER INACTIVE.

NOTE:
IF CONTROL STROBE IS HARDWIRED TO "1".
THEN THE CONTROL DATA BITS MUST BE STABLE DURING "ILLEGAL CS" TIME.

FIG. 3 TRANSMITTER AT START BIT

TRANSMITTER ACTIVE
TRANSMIT BUFFER LOADED WHEN EOC LOW


FIG. 5 ALLOWABLE TCP, RCP


ANY PULSE WIDTH WHICH MEETS ABOVE CRITERIA IS ALLOWABLE.

## TIMING DIAGRAMS (CONT.)

FIG. 6 UAR/T - RECEIVER TIMING


FIG. 7 TRUE RECEIVER CENTER SAMPLING


FIG. 9 XR PULSE


WHEN NOT IN USE, XR MUST BE HELD AT GND.
XR RESETS EVERY REGISTER EXCEPT THE CONTROL REGISTER. SO, TBMT EOC ARE RESET TO LOGIC "1" , ALL OTHER OUTPUTS RESET TO LOGIC "0".

FIG. 8 RECEIVER DURING 1ST STOP BIT


FIG. 10 DS


## TIMING DIAGRAMS (CONT.)

FIG. 11A CS


CONTROL BITS MUST BE STABLE FOR LAST 200 ns OF CS.

FIG. 12


LEADING EDGE OF CONTROL DATA IS NOT CRITICAL AS LONG AS TRAILING EDGE AND PULSE WIDTH SPECS ARE OBSERVED.
*20ns MIN.

FIG. 11B


CONTROL STROBE AND CONTROL BITS MUST BE 500 ns MINIMUM.
*2Ons MIN.

FIG. 13 EOC TURN - ON


FIG. 14 TBMT TURN - OFF


FIG. 15 EOC TURN - OFF


## TIMING DIAGRAMS

FIG. 16 TBMT TURN - ON


FIG. 18 RDAV


FIG. 20 RD1-RD8, PE, FE, OR, TBMT, DAV


FIG. 17 RDE, SWE


FIG. 19 SHORT CIRCUIT OUTPUT CURRENT (only 1 output may be shorted at a time)


FIG. 21 +5 VOLT SUPPLY CURRENT

FIG. 22 TRANSMITTER OPERATION


## TRANSMITTER

Power is applied, external reset is enabled and clock pulse is applied having a frequency of 16 times the desired baud. The above conditions will set TBMT, EOC, and SO to logic " 1 " (line is marking).
After initialization is complete, user may set control bits and data bits. Control bits selection should occur before data bit selection, however, one may set both DS and CS simultaneously if minimum pulse width specifications are followed. Once Data Strobe ( $\overline{\mathrm{DS}}$ ) is pulsed the TBMT signal will change from a logic " 1 " to a logic " 0 " indicating that the data bits holding register is filled with a previous character and is unable to receive new data bits and transmitter shift register is transmitting previously loaded data. TBMT will return to a logic "1". When transmitter shift register is empty, data bits in the holding register are immediately loaded into the transmitter shift register for transmission. The shifting of information from the holding register to the transmitter shift register will be followed by SO and EOC going to a logic " 0 " and TBMT will also go to a logic "1" indicating that the shifting operation is completed and that the data bits holding register is ready to accept new data. It should be remembered that one full character time is now available for loading of the next character without loss of transmission speed due to double buffering (separate data bits holding register and transmitter shift register).

Data transmission is initiated with transmission of a start bit, data bits, parity bit (if desired) and stop bit(s). When the last stop bit has been on line for one bit time, EOC will go to a logic "1" indicating that new character is ready for transmission. This new character will be transmitted only if TBMT is a logic " 0 " as was previously discussed.

FIG. 23 RECEIVER OPERATION


## RECEIVER

Power is applied, external reset is enabled and clock pulse is applied having a frequency of 16 times the desired baud. The previous conditions will set data available (DAV) to a logic "0".
After initialization is complete, user should note that one set of control bits will be used for both receiver and transmitter making individual control bit setting unnecessary. Data reception starts when serial input signal changes from marking (logic "1") to spacing (logic "0") which initiates start bit. The start bit is valid if, after transition from logic "1" to logic " 0 ", the SI line continues to be at logic " 0 ", when center sampled, 8 clock pulses later. If, however, line is at a logic " 1 " when center sampling occurs, the start bit verification process will be reset. If the Serial Input line transitions from a logic "1" to a logic "0" (marking to spacing) when the $16 x$ clock is in a logic "1" state, the bit time for center sampling will begin when the clock line transitions from a logic "1" to a logic "0"state. After verification of a genuine start bit, data bit reception, parity bit reception and stop bit(s) reception proceeds in an orderly manner.
While receiving parity and stop bit(s), the receiver will compare transmitted parity and stop bit(s) with control data bits (parity and number of stop bits) previously set and indicate an error by changing the parity error flip flop and/ or the framing error flip flop to a logic "1". It should be noted that if the No Parity Mode is selected, the PE (parity error) will be unconditionally set to a logic " 0 ".

Once a full character is received, internal logic looks at the data available (DAV) signal to determine if data has been read out. If the DAV signal is at a logic " 1 ", the receiver will assume data has not been read out and the over run flipflop of the status word holding register will be set to a logic " 1 ". If the DAV signal is at a logic " 0 ", the receiver will assume that data has been read out. After DAV goes to a logic "1", the receiver shift register is now ready to accept the next character and has one full character time to remove the received character.

FIG. 24 TRANSMITTER BLOCK DIAGRAM


FIG. 25 RECEIVER BLOCK DIAGRAM


## AY31015D

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



Dual Baud Rate Generator

## FEATURES

- Single +5 V power supply
- On-chip crystal oscillator 8116/8136 or external frequency input 8116/8116T/8136/8136T
- Direct compatibility with UART/USRT
- Dual selectable $16 x$ clock outputs
- High frequency reference output (Available only on 8136/8136T)
- Reprogrammable ROM allowing generation of nonstandard frequencies
- TTL, MOS compatibility
- Pin for pin and functionally compatible with SMC's COM 8116/8116T/8136/8136T
- Microchip Technology Advanced N-Channel Silicon Gate Process


## DESCRIPTION

The Microchip Technology AY58116/8136 Series is a very versatile family of Dual Baud Rate Generators. The AY58116/8116T and AY58136/8136T are pin for pin functionally equivalent to SMC's COM 8116/8116T and COM 8136/8136T, respectively.

The AY58116/8136 is designed to generate the full spectrum of 16 asynchronous /synchronous data communication frequencies for use with $16 x$ and $32 x$ UART/ USRT devices.

An on-chip crystal oscillator available on the 8116 and 8136 is capable of providing a master reference frequency. Alternatively, complimentary TTL level clock signals can be input to pins 1 and 18. The 8116T and 8136 T are only suitable for this external TTL reference. When using TTL outputs to drive the XTAL/EXT inputs, they should not be used to drive other TTL inputs due to excessive loading which may result in a reduction of noise immunity.

Dividers are used on the output of the oscillator/buffer which generate the output frequencies $f_{1}$ and $f_{R}$. These dividers can divide any integer from 6 to $2^{19}+1$, inclusive. When using an even divisor, the output will be square; an odd divisor will cause the output to be high longer than it is low by one clock period $\left(1 / f_{x}\right)$. The clock

frequency $\left(f_{x}\right)$ is used by the $8136 / 8136 T$ to provide a high frequency output ( $f / 4$ ).

The $8116 / 8136$ family allows generation of other frequencies with the use of its two divisor ROMs which contain 16 divisors, each 19 bits wide, allowing for up to 32 different divisors on custom parts.

Externally strobed data latches are used to hold the divisor select bits, $R_{A}-R_{D}$ and $T_{A}-T_{D}$. The strobe inputs, STR or STT, allow data to pass directly through the data latch when in the high state. A new frequency is initiated within $3.5 \mu \mathrm{sec}$ of a change in any of the four divisor select bits read by the device. Pull-up resistors are provided on the divisor select inputs which are not present on the strobe inputs.

## PIN FUNCTIONS

| Pin Number | Signal | Function |
| :---: | :---: | :---: |
| 1 | XTAL/EXT1 | Input is either one pin of the crystal package or one polarity of the external input. |
| 2 | $\mathrm{V}_{\mathrm{cc}}$ | Positive power supply - normally +5 V . |
| 3 | $\mathrm{f}_{\mathrm{R}}$ | This output runs at a frequency selected by the Receiver divisor select data bits. |
| 4-7 | $\mathrm{R}_{A}, \mathrm{R}_{\mathrm{B}}, \mathrm{R}_{\mathrm{C}}, \mathrm{R}_{\mathrm{D}}$ | These inputs, as shown in Table 1, select the receiver output frequency, $f_{R}$. |
| 8 | STR | A high level input strobe loads the receiver data ( $R_{A}, R_{B}, R_{C}, R_{D}$ ) into the receiver divisor select register. This input may be strobed or hard-wired to a high level. |
| 9 | NC |  |
| 10 | NC or $\mathrm{f}_{\mathrm{x}} / 4$ | NC (8116/8116T), $\mathrm{f}_{\mathrm{x}} / 4$ (8136/8136T). |
| 11 | GND | Ground. |
| 12 | STT | A high level inut strobe loads the transmitter data ( $T_{A}, T_{B}, T_{C}, T_{D}$ ) into the transmitter divisor select register. This input may be strobed or hard-wired to a high level. |
| 13-16 | $\mathrm{T}_{\mathrm{D}}, \mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{B}}, \mathrm{T}_{\mathrm{A}}$ | These inputs, as shown in Table 1, select the transmitter output frequency, $f_{T}$. |
| 17 | $\mathrm{f}_{T}$ | This output runs at a frequency selected by the transmitter divisor select data bits. |
| 18 | XTAL/EXT2 | This input is either the other pin of the crystal package or the other polarity of the external input. |

## TIMING DIAGRAM



## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Operating Temperature Range ............... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range ............. $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground. $\qquad$ $+8.0 \mathrm{~V}$
Negative Voltage on any Pin, with respect to ground -0.3V

* Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Data labeled "typical" is presented for design guidance only and is not guaranteed.

Standard Conditions (unless otherwise noted):
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$

## DC CHARACTERISTICS

| Characteristic | Sym | Min | Typ | Max | Unit | Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Input Voltage Levels |  |  |  |  |  |  |
| Low Level | $\mathrm{V}_{\mathrm{IL}}$ | - | - | 0.8 | V |  |
| High Level | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | - | V | excluding XTAL inputs |
| Output Voltage Levels |  |  |  |  |  |  |
| Low Level | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$, for $\mathrm{f}_{\mathrm{X}} / 4$, |
|  |  | - | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$, for $\mathrm{f}_{\mathrm{R}}, \mathrm{f}_{\mathrm{T}}$ |
| High Level | $\mathrm{V}_{\mathrm{OH}}$ | 3.5 | - | - | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
| Input Current |  |  |  |  |  |  |
| Low Level | $\mathrm{I}_{\mathrm{IL}}$ | - | - | -0.1 | mA | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{GND}, \mathrm{R}_{\mathrm{A}}-\mathrm{R}_{\mathrm{D}}$ \& $\mathrm{T}_{\mathrm{A}}-\mathrm{T}_{\mathrm{D}}$ only |
| Input Capacitance All inputs |  | - | 5 | 10 | pF | $\mathrm{V}_{\mathrm{IN}}=\mathrm{GND}, \mathrm{excluding} \mathrm{XTAL} \mathrm{inputs}$ |
| Power Supply Current | $\mathrm{I}_{\mathrm{CC}}$ | - | - | 50 | mA |  |

## AC CHARACTERISTICS

| Characteristic | Sym | Min | Typ | Max | Unit | Conditions |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Clock Frequency | $\mathrm{f}_{\mathrm{x}}$ | 0.01 | - | 5.1 | MHz | XTAL/EXT, 50\% Duty Cycle $\pm 5 \%$ |
| Strobe Pulse Width | $\mathrm{t}_{\mathrm{Pw}}$ | 150 | - | DC | ns |  |
| Input Set-up Time | $\mathrm{t}_{\mathrm{DS}}$ | 200 | - | - | ns |  |
| Input Hold Time | $\mathrm{t}_{\mathrm{DH}}$ | 50 | - | - | ns |  |
| Strobe to new Frequency |  | - | - | 3.5 | $\mu \mathrm{~s}$ | @f $\mathrm{f}_{\mathrm{x}}=5.0 \mathrm{MHz}$ |
| Delay |  |  |  |  |  |  |

## CRYSTAL SPECIFICATIONS

Temperature range $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Series resistance $\leq 50 \Omega$
Series resonant
Overall tolerance $\pm 0.01 \%$

## CRYSTAL OPERATION AY58116/8136

## EXTERNAL INPUT OPERATION AY58116/ 8116T/8136/8136T




74XX - TOTEM POLE OR OPEN COLLECTOR OUTPUT (EXTERNAL PULL-UP RESISTOR REQUIRED)

## BLOCK DIAGRAM: AY58116/8116T/8136/8136T



Table 1 Output Frequency AY58116/8116T/8136/8136T REFERENCE FREQUENCY $=5.068800 \mathbf{M H z}$

| Divisor Select DCBA | Desired Baud Rate | Clock Factor | Desired Frequency (KHz) | Divisor | Actual Baud Rate | Actual Frequency (KHz) | Deviation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0000 | 50.00 | 16X | 0.80000 | 6336 | 50.00 | 0.800000 | 0.0000\% |
| 0001 | 75.00 | 16X | 1.20000 | 4224 | 75.00 | 1.200000 | 0.0000\% |
| 0010 | 110.00 | 16X | 1.76000 | 2880 | 110.00 | 1.760000 | 0.0000\% |
| 0011 | 134.50 | 16X | 2.15200 | 2355 | 134.52 | 2.152357 | 0.0166\% |
| 0100 | 150.00 | 16X | 2.40000 | 2112 | 150.00 | 2.400000 | 0.0000\% |
| 0101 | 300.00 | 16X | 4.80000 | 1056 | 300.00 | 4.800000 | 0.0000\% |
| 0110 | 600.00 | 16X | 9.60000 | 528 | 600.00 | 9.600000 | 0.0000\% |
| 0111 | 1200.00 | 16X | 19.20000 | 264 | 1200.00 | 19.200000 | 0.0000\% |
| 1000 | 1800.00 | 16X | 28.80000 | 176 | 1800.00 | 28.800000 | 0.0000\% |
| 1001 | 2000.00 | 16X | 32.00000 | 158 | 2005.06 | 32.081013 | 0.2532\% |
| 1010 | 2400.00 | 16X | 38.40000 | 132 | 2400.00 | 38.400000 | 0.0000\% |
| 1011 | 3600.00 | 16X | 57.60000 | 88 | 3600.00 | 57.600000 | 0.0000\% |
| 1100 | 4800.00 | 16X | 76.80000 | 66 | 4800.00 | 76.800000 | 0.0000\% |
| 1101 | 7200.00 | 16X | 115.20000 | 44 | 7200.00 | 115.200000 | 0.0000\% |
| 1110 | 9600.00 | 16X | 153.60000 | 33 | 9600.00 | 153.600000 | 0.0000\% |
| 1111 | 19200.00 | 16X | 307.20000 | 16 | 19800.00 | 316.800000 | 3.1250\% |

Table 1 (Cont.) Output Frequency AY58116/8116T/8136/8136T-005
REFERENCE FREQUENCY $=4.915200 \mathrm{MHz}$

| Divisor <br> Select DCBA | Desired Baud Rate | Clock Factor | Desired Frequency (KHz) | Divisor | Actual Baud Rate | Actual Frequency (KHz) | Deviation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0000 | 50.00 | 16X | 0.80000 | 6144 | 50.00 | 0.800000 | 0.0000\% |
| 0001 | 75.00 | 16X | 1.20000 | 4096 | 75.00 | 1.200000 | 0.0000\% |
| 0010 | 110.00 | 16X | 1.76000 | 2793 | 109.93 | 1.758983 | 0.0100\% |
| 0011 | 134.50 | 16X | 2.15200 | 2284 | 134.50 | 2.152000 | 0.0000\% |
| 0100 | 150.00 | 16X | 2.40000 | 2048 | 150.00 | 2.400000 | 0.0000\% |
| 0101 | 300.00 | 16X | 4.80000 | 1024 | 300.00 | 4.800000 | 0.0000\% |
| 0110 | 600.00 | 16X | 9.60000 | 512 | 600.00 | 9.600000 | 0.0000\% |
| 0111 | 1200.00 | 16X | 19.20000 | 256 | 1200.00 | 19.200000 | 0.0000\% |
| 1000 | 1800.00 | 16X | 28.80000 | 171 | 1796.49 | 28.743859 | 0.1949\% |
| 1001 | 2000.00 | 16X | 32.00000 | 154 | 1994.81 | 31.916883 | 0.2597\% |
| 1010 | 2400.00 | 16X | 38.40000 | 128 | 2400.00 | 32.000000 | 0.0000\% |
| 1011 | 3600.00 | 16X | 57.60000 | 85 | 3614.11 | 57.825882 | 0.3921\% |
| 1100 | 4800.00 | 16X | 76.80000 | 64 | 4800.00 | 76.800000 | 0.0000\% |
| 1101 | 7200.00 | 16X | 115.20000 | 43 | 7144.19 | 114.306976 | 0.7751\% |
| 1110 | 9600.00 | 16X | 153.60000 | 32 | 9600.00 | 153.600000 | 0.0000\% |
| 1111 | 19200.00 | 16X | 307.20000 | 16 | 19200.00 | 307.200000 | 0.0000\% |

Table 1 (Cont.) Output Frequency AY58116/8116T/8136/8136T-006 REFERENCE FREQUENCY $=5.068800 \mathbf{M H z}$

| Divisor Select DCBA | Desired <br> Baud <br> Rate | Clock <br> Factor | Desired Frequency (KHz) | Divisor | Actual Baud Rate | Actual Frequency (KHz) | Deviation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0000 | 50.00 | 32 X | 1.60000 | 3168 | 50.00 | 1.60000 | 0.0000\% |
| 0001 | 75.00 | 32 X | 2.40000 | 2112 | 75.00 | 2.40000 | 0.0000\% |
| 0010 | 110.00 | 32 X | 3.52000 | 1440 | 110.00 | 3.52000 | 0.0000\% |
| 0011 | 134.50 | 32 X | 4.30400 | 1177 | 134.52 | 4.30600 | 0.0600\% |
| 0100 | 150.00 | 32X | 4.80000 | 1056 | 150.00 | 4.80000 | 0.0000\% |
| 0101 | 200.00 | 32 X | 6.40000 | 792 | 200.00 | 6.40000 | 0.0000\% |
| 0110 | 300.00 | 32 X | 9.60000 | 528 | 300.00 | 9.60000 | 0.0000\% |
| 0111 | 600.00 | 32 X | 19.20000 | 264 | 600.00 | 19.20000 | 0.0000\% |
| 1000 | 1200.00 | 32 X | 38.40000 | 132 | 1200.00 | 38.40000 | 0.0000\% |
| 1001 | 1800.00 | 32X | 57.60000 | 88 | 1800.00 | 57.60000 | 0.0000\% |
| 1010 | 2400.00 | 32 X | 76.80000 | 66 | 2400.00 | 76.80000 | 0.0000\% |
| 1011 | 3600.00 | 32 X | 115.20000 | 44 | 3600.00 | 115.20000 | 0.0000\% |
| 1100 | 4800.00 | 32 X | 153.60000 | 33 | 4800.00 | 153.60000 | 0.0000\% |
| 1101 | 7200.00 | 32 X | 230.40000 | 22 | 7200.00 | 230.40000 | 0.0000\% |
| 1110 | 9600.00 | 32 X | 307.20000 | 16 | 9900.00 | 316.80000 | 3.1250\% |
| 1111 | 19200.00 | 32 X | 614.40000 | 8 | 19800.00 | 633.60000 | 3.1250\% |

AY58136/8136T

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.


Microchip

## AY58126/8126T AY58146/8146T

## SINGLE BAUD RATE GENERATOR

## FEATURES

- Single +5 V power supply
- On-chip crystal oscillator 8126/8146 or external frequency input 8126/8126T/8146/8146T
- Direct compatibility with UART/USRT
- Choice of $16 x$ clock outputs
- High frequency reference output (Available only on 8146/8146T)
- Reprogrammable ROM allowing generation of nonstandard frequencies
- TTL, MOS compatibility
- Pin for pin and functionally compatible with SMC's COM 8126/8126T/8146/8146T
- Microchip Technology Advanced N-Channel Silicon Gate Process


## DESCRIPTION

The Microchip Technology AY58126/8146 Series is a very versatile family of Single Baud Rate Generators. The AY58126/8126T and AY58146/8146T are pin for pin functionally equivalent to SMC's COM 8126/8126T and COM 8146/8146T, respectively.

The AY58126/8146 is designed to generate the full spectrum of 16 asynchronous /synchronous data communication frequencies for use with 16x and $32 x$ UART/ USRT devices.

An on-chip crystal oscillator available on the 8126 and 8146 is capable of providing a master reference frequency. Alternatively, complimentary TTL level clock signals can be input to pins 1 and 2. The 8126T and 8146 T are only suitable for this external TTL reference. When using TTL outputs to drive the XTAL/EXT inputs, they should not be used to drive other TTL inputs due to excessive loading which may result in a reduction of noise immunity.

Dividers are used on the output of the oscillator/buffer which generate the output frequency $\mathrm{f}_{\mathrm{T}}$. This divider can divide any integer from 6 to $2^{19}+1$, inclusive. When using an even divisor, the output will be square; an odd divisor will cause the output to be high longer than it is

PIN CONFIGURATIONS
14 LEAD DUAL INLINE

AY58126/8126T
Top View


AY58146/8146T
Top View

low by one clock period ( $1 / \mathrm{f}_{\mathrm{x}}$ ). The clock frequency ( $\mathrm{f}_{\mathrm{x}}$ ) is used by the 8146/8146T to provide a high frequency output ( $f_{x} / 4$ ).

The $8126 / 8146$ family allows generation of other frequencies with the use of its two divisor ROMs which contain 16 divisors, each 19 bits wide, allowing for up to 32 different divisors on custom parts.

Externally strobed data latches are used to hold the divisor select bit $T_{A}-T_{D}$. The strobe input STT allows data to pass directly through the data latch when in the high state. A new frequency is initiated within 3.5 usec of a change in any of the four divisor select bits read by the device. Pull-up resistors are provided on the divisor select inputs which are not present on the strobe inputs.

| PIN FUNCTIONS |  |  |
| :---: | :---: | :---: |
| Pin Number | Signal | Function |
| 1 | XTAL/EXT1 | Input is either one pin of the crystal package or one polarity of the external input. |
| 2 | XTAL/EXT2 | This input is either the other pin of the crystal package or the other polarity of the external input. |
| 3 | $\mathrm{V}_{\mathrm{cc}}$ | Positive power supply - normally +5 V . |
| 4 | NC |  |
| 5 | GND | Ground. |
| 6-7 | NC |  |
| 8 | NC or $\mathrm{f}_{\mathrm{x}} / 4$ | NC (8126/8126T), f. $/ 4$ (8146/8146T). |
| 9 | STT | A high level input strobe loads the transmitter data $\left(T_{A}, T_{B}, T_{C}\right.$, $T_{D}$ ) into the transmitter divisor select register. This input may be strobed or hard-wired to a high level. |
| 10-13 | $\mathrm{T}_{\mathrm{D}}, \mathrm{T}_{\mathrm{C}}, \mathrm{T}_{\mathrm{B}}, \mathrm{T}_{\mathrm{A}}$ | These inputs, as shown in the Tables $p .5 \mathrm{ff}$, select the transmitter output frequency, $\mathrm{f}_{\mathrm{T}}$. |
| 14 | $\mathrm{f}_{\mathrm{T}}$ | This output runs at a frequency selected by the transmitter divisor select data bits. |

## TIMING DIAGRAM



## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Operating Temperature Range $\qquad$ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range ............. $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Positive Voltage on any Pin, with respect to ground $+8.0 \mathrm{~V}$
Negative Voltage on any Pin, with respect to ground $\qquad$ -0.3V

## Standard Conditions

(unless otherwise noted):
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$


#### Abstract

* Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Data labeled "typical" is presented for design guidance only and is not guaranteed.


| DC CHARACTERISTICS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Sym | Min | Typ | Max | Unit | Conditions |
| Input Voltage Levels |  |  |  |  |  |  |
| Low Level | $\mathrm{V}_{\text {IL }}$ | - | - | 0.8 | V |  |
| High Level | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | - | V | excluding XTAL inputs |
| Output Voltage Levels |  |  |  |  |  |  |
| Low Level | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$, for $\mathrm{f}_{\mathrm{x}} / 4$, |
|  |  | - | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$, for $\mathrm{f}_{\mathrm{R}}, \mathrm{f}_{T}$ |
| High Level | $\mathrm{V}_{\mathrm{OH}}$ | 3.5 | - | - | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
| Input Current |  |  |  |  |  |  |
| Low Level | $\mathrm{I}_{1}$ | - | - | $-0.1$ | $\mathrm{mA}$ |  |
| Input Capacitance All inputs |  | - | 5 | 10 | $\mathrm{pF}$ | $V_{\mathbb{I N}}=G N D$, excluding XTAL inputs |
| Power Supply Current | $I_{\text {cc }}$ | - | - | 50 | mA |  |


| AC CHARACTERISTICS |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Characteristic | Sym | Min | Typ | Max | Unit | Conditions |
| Clock Frequency | $\mathrm{f}_{\mathrm{x}}$ | 0.01 | - | 5.1 | MHz | XTAL/EXT, 50\% Duty Cycle $\pm 5 \%$ |
| Strobe Pulse Width | $\mathrm{t}_{\mathrm{PW}}$ | 150 | - | DC | ns |  |
| Input Set-up Time | $\mathrm{t}_{\mathrm{DS}}$ | 200 | - | - | ns |  |
| Input Hold Time | $\mathrm{t}_{\mathrm{DH}}$ | 50 | - | - | ns |  |
| Strobe to new Frequency |  | - | - | 3.5 | $\mu \mathrm{~s}$ | @ $_{\mathrm{x}}=5.0 \mathrm{MHz}$ |
| Delay |  |  |  |  |  |  |

## CRYSTAL SPECIFICATIONS

```
Temperature range }\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to }+7\mp@subsup{0}{}{\circ}\textrm{C
Series resistance \leq50\Omega
Series resonant
Overall tolerance }\pm0.01
```



## BLOCK DIAGRAM: AY58126/8126T/8146/8146T



| OUTPUT FREQUENCY <br> AY58126/8126T/8146/8146 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Divisor <br> Select <br> DCBA | Desired <br> Baud <br> Rate | Clock <br> Factor | Desired <br> Frequency <br> (KHz) | Divisor | Actual <br> Baud <br> Rate | Actual <br> Frequency <br> (KHz) | Deviation |  |
| 0000 | 50.00 | 16 X | 0.80000 | 6336 | 50.00 | 0.800000 | $0.0000 \%$ |  |
| 0001 | 75.00 | 16 X | 1.20000 | 4224 | 75.00 | 1.200000 | $0.0000 \%$ |  |
| 0010 | 110.00 | 16 X | 1.76000 | 2880 | 110.00 | 1.760000 | $0.0000 \%$ |  |
| 0011 | 134.50 | 16 X | 2.15200 | 2355 | 134.52 | 2.152357 | $0.0166 \%$ |  |
| 0100 | 150.00 | 16 X | 2.40000 | 2112 | 150.00 | 2.400000 | $0.0000 \%$ |  |
| 0101 | 300.00 | 16 X | 4.80000 | 1056 | 300.00 | 4.800000 | $0.0000 \%$ |  |
| 0110 | 600.00 | 16 X | 9.60000 | 528 | 600.00 | 9.600000 | $0.0000 \%$ |  |
| 0111 | 1200.00 | 16 X | 19.20000 | 264 | 1200.00 | 19.200000 | $0.0000 \%$ |  |
| 1000 | 1800.00 | 16 X | 28.80000 | 176 | 1800.00 | 28.800000 | $0.0000 \%$ |  |
| 1001 | 2000.00 | 16 X | 32.00000 | 158 | 2005.06 | 32.081013 | $0.2532 \%$ |  |
| 1010 | 2400.00 | 16 X | 38.40000 | 132 | 2400.00 | 38.400000 | $0.0000 \%$ |  |
| 1011 | 3600.00 | 16 X | 57.60000 | 88 | 3600.00 | 57.600000 | $0.0000 \%$ |  |
| 1100 | 4800.00 | 16 X | 76.80000 | 66 | 4800.00 | 76.800000 | $0.0000 \%$ |  |
| 1101 | 7200.00 | 16 X | 115.20000 | 44 | 7200.00 | 115.200000 | $0.0000 \%$ |  |
| 1110 | 9600.00 | 16 X | 153.60000 | 33 | 9600.00 | 153.600000 | $0.0000 \%$ |  |
| 19200.00 | 16 X | 307.20000 | 16 | 19800.00 | 316.800000 | $3.1250 \%$ |  |  |


| OUTPUT FREQUENCY <br> AY58126/8126T/8146/8146T-005 |  |  |  | Reference Frequency $=4.915200 \mathrm{MHz}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Divisor <br> Select <br> DCBA | Desired Baud Rate | Clock <br> Factor | Desired Frequency (KHz) | Divisor | Actual Baud Rate | Actual Frequency (KHz) | Deviation |
| 0000 | 50.00 | 16X | 0.80000 | 6144 | 50.00 | 0.800000 | 0.0000\% |
| 0001 | 75.00 | 16X | 1.20000 | 4096 | 75.00 | 1.200000 | 0.0000\% |
| 0010 | 110.00 | 16X | 1.76000 | 2793 | 109.93 | 1.758983 | 0.0636\% |
| 0011 | 134.50 | 16X | 2.15200 | 2284 | 134.50 | 2.152000 | 0.0000\% |
| 0100 | 150.00 | 16X | 2.40000 | 2048 | 150.00 | 2.400000 | 0.0000\% |
| 0101 | 300.00 | 16X | 4.80000 | 1024 | 300.00 | 4.800000 | 0.0000\% |
| 0110 | 600.00 | 16X | 9.60000 | 512 | 600.00 | 9.600000 | 0.0000\% |
| 0111 | 1200.00 | 16X | 19.20000 | 256 | 1200.00 | 19.200000 | 0.0000\% |
| 1000 | 1800.00 | 16X | 28.80000 | 171 | 1796.49 | 28.743859 | 0.1949\% |
| 1001 | 2000.00 | 16X | 32.00000 | 154 | 1994.81 | 31.916883 | 0.2597\% |
| 1010 | 2400.00 | 16X | 38.40000 | 128 | 2400.00 | 38.400000 | 0.0000\% |
| 1011 | 3600.00 | 16X | 57.60000 | 85 | 3614.11 | 57.825882 | 0.3921\% |
| 1100 | 4800.00 | 16X | 76.80000 | 64 | 4800.00 | 76.800000 | 0.0000\% |
| 1101 | 7200.00 | 16X | 115.20000 | 43 | 7144.19 | 114.306976 | 0.7751\% |
| 1110 | 9600.00 | 16X | 153.60000 | 32 | 9600.00 | 153.600000 | 0.0000\% |
| 1111 | 19200.00 | 16X | 307.20000 | 16 | 19200.00 | 307.200000 | 0.0000\% |


| OUTPUT FREQUENCY <br> AY58126/8126T/8146/8146T-006 |  |  |  | Reference Frequency $=5.068800 \mathrm{MHz}$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Divisor <br> Select <br> DCBA | Desired Baud Rate | Clock <br> Factor | Desired Frequency (KHz) | Divisor | Actual Baud Rate | Actual Frequency (KHz) | Deviation |
| 0000 | 50.00 | 32 X | 1.60000 | 3168 | 50.00 | 1.60000 | 0.0000\% |
| 0001 | 75.00 | 32 X | 2.40000 | 2112 | 75.00 | 2.40000 | 0.0000\% |
| 0010 | 110.00 | 32 X | 3.52000 | 1440 | 110.00 | 3.52000 | 0.0000\% |
| 0011 | 134.50 | 32 X | 4.30400 | 1177 | 134.52 | 4.30600 | 0.0600\% |
| 0100 | 150.00 | 32 X | 4.80000 | 1056 | 150.00 | 4.80000 | 0.0000\% |
| 0101 | 200.00 | 32 X | 6.40000 | 792 | 200.00 | 6.40000 | 0.0000\% |
| 0110 | 300.00 | 32 X | 9.60000 | 528 | 300.00 | 9.60000 | 0.0000\% |
| 0111 | 600.00 | 32 X | 19.20000 | 264 | 600.00 | 19.20000 | 0.0000\% |
| 1000 | 1200.00 | 32 X | 38.40000 | 132 | 1200.00 | 38.40000 | 0.0000\% |
| 1001 | 1800.00 | 32 X | 57.60000 | 88 | 1800.00 | 57.60000 | 0.0000\% |
| 1010 | 2400.00 | 32 X | 76.80000 | 66 | 2400.00 | 76.80000 | 0.0000\% |
| 1011 | 3600.00 | 32 X | 115.20000 | 44 | 3600.00 | 115.20000 | 0.0000\% |
| 1100 | 4800.00 | 32 X | 153.60000 | 33 | 4800.00 | 153.60000 | 0.0000\% |
| 1101 | 7200.00 | 32 X | 230.40000 | 22 | 7200.00 | 230.40000 | 0.0000\% |
| 1110 | 9600.00 | 32 X | 307.20000 | 16 | 9900.00 | 316.80000 | 3.1250\% |

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



Microchip

## PROGRAMMABLE SOUND GENERATOR

## FEATURES

- Industry standard programmable sound generator
- Register oriented architecture for ease of use
- Full software control of sound generation
- Easily interfaces to most 8-bit and 16-bit microprocessors
- Three independently programmable analog outputs
- One or two 8-bit I/O ports
- Single 5 volt supply
- $0^{\circ}$ to $70^{\circ} \mathrm{C}$ operation
- 40 pin or 28 pin package option


## APPLICATIONS

- Arcade games
- Warning alarms
- Special effects
- Personal computers
- Music synthesis


## DESCRIPTION

The AY38910A/38912A Programmable Sound Generator (PSG) is an LSI circuit which can produce a wide variety of complex sounds under software control. The AY38910A/38912A is manufactured in Microchip Technologys N -Channel Ion Implant Process. Operation requires a single +5 V power supply, a compatible clock, and a microprocessor controller, such as the PIC series of 8 -bit microcomputers.

The PSG is easily interfaced to any bus oriented system. Its flexibility makes it useful in applications such as music synthesis, sound effects generation, audible alarms, tone signaling, and personal computer usage. In order to generate sound effects while allowing the processor to perform other tasks, the PSG can continue to produce sound after the initial commands have been given by the control processor. The fact that realistic sound production often involves more than one component is satisfied by the three independently controllable analog sound output channels can each provide 4 bits of logarithmic digital to analog conversion, greatly enhancing the dynamic range of the sounds produced.

## PIN CONFIGURATION

Top View

| 40 LEAD DUAL INLINE - AY38910A |  |  |
| :---: | :---: | :---: |
| Vss (GND) 1 | 40 | $\mathrm{Vcc}(+5 \mathrm{~V})$ |
| No Connect 2 | 39 | No Connect |
| Analog Channel B ${ }^{3}$ | 38 | Analog Channel C |
| Analog Channel A 4 | 37 | DAO |
| No Connect 5 | 36 | DA1 |
| IOB7 ${ }^{\text {c }}$ | 35 | DA2 |
| IOB6 $\square_{7}$ | 34 | DA3 |
| IOB5 8 | 33 | DA4 |
| IOB4 9 | 32 | DA5 |
| IOB3 - 10 | 31 | DA6 |
| IOB2 11 | 30 | DA7 |
| IOB1 - 12 | 29 | BC1 |
| IOBO - 13 | 28 | BC2 |
| IOA7 14 | 27 | BDIR |
| IOA6 -15 | 26 | No Connect |
| IOA5 -16 | 25 | A8 |
| IOA4 - 17 | 24 | A9 |
| IOA3 -18 | 23 | RESET |
| IOA2 19 | 22 | Clock |
| IOA1 20 | 21 | IOAO |


| 28 LEAD DUAL INLINE - AY38912A |  |  |  |
| :---: | :---: | :---: | :---: |
| Analog Channel C | 1 | 28 | DAO |
| No Connect | 2 | 27 | DA1 |
| Vcc ( +5 V ) | 3 | 26 | DA2 |
| Analog Channel B | 4 | 25 | DA3 |
| Analog Channel A | 5 | 24 | DA4 |
| Vss (GND) | 6 | 23 | DA5 |
| IOA7 | 7 | 22 | DA6 |
| IOA6 | 8 | 21 | DA7 |
| IOA5 | 9 | 20 | BC1 |
| IOA4 | 10 | 19 | BC2 |
| IOA3 | 11 | 18 | BDIR |
| IOA2 | 12 | 17 | A8 |
| IOA1 | 13 | 16 | RESET |
| IOAO | 14 | 15 | Clock |

## DESCRIPTION (CTD.)

All circuit control signals are digital in nature and may be provided directly by a microprocessor/microcomputer. Therefore, one PSG can produce the full range of required sounds with no change in external
circuitry. Since the frequency response of the PSG ranges from sub-audible at its lowest frequency to post-audible at its highest frequency, there are few sounds which are beyond reproduction.

## AY389XXA BLOCK DIAGRAM



## PIN FUNCTIONS

## DA7-DAO (Input/Output/High Impedence) <br> Data/Address Bits 7-0: Pins 30-37 (AY38910A) <br> Pins 21-28 (AY38912A)

These 8 lines comprise the 8 -bit bidirectional bus used by the microprocessor to send both data and addresses to the PSG and to receive data from the PSG. In the address mode, DA3-DAO select the internal register address ( $0-17_{8}$ ) and DA7-DA4 in conjunction with address inputs $\overline{A 9}$ and A8, form the chip select function. When the high order address bits are "incorrect", the bidirectional buffers are forced to a high impedence state.

## Address 9, Address 8

A8 (input):
Pin 25 (AY38910A)
Pin 17 (AY38912A)
$\overline{\mathrm{A} 9}$ (input):
Pin 24 (AY38910A)
Not available (AY38912A)
High order address bits $\overline{\mathrm{A} 9}$ and A8 are fixed to recognize a " 01 "code. They may be left unconnected as each is provided with either an on chip pull-down ( $\overline{\mathrm{A} 9}$ ) or pull-up (A8) resistor. In noisy environments, however, it is recommended that $\overline{\mathrm{A} 9}$ and A 8 be tied to external ground and +5 V respectively if they are not to be used.

## RESET (Input)

> Pin 23 (AY38910A)
> Pin 16 (AY38912A)

For initialization/power-on purposes, applying a low level input to the RESET pin will reset all registers to 08 . The RESET pin is provided with an on-chip pull-up resistor.

## CLOCK (Input)

Pin 22 (AY38910A)
Pin 15 (AY38912A)
This TTL compatible input supplies the timing reference for the Tone, Noise, and Envelope Generators.

## BDIR, BC2, BC1 (Inputs)

Pins 27,28,29 (AY38910A)
Pins 18,19,20 (AY38912A)
The Bus DIRection, Bus Control 2 and Bus Control 1 are used to control the PSG.

For example, if these bus control signals are generated directly by a microprocessor to control all bus operations internal and external to the PSG, then the following Bus Control Function Table applies.
Interfacing to a processor simply requires simulating the decoding shown in the Function Table. The redundancies in the PSG functions vs. bus control signals can be used as an advantage in that only four of the eight possible decoded bus functions are required by the PSG. This could reduce the programming of the bus control signals to the following Simplified Bus Control Function Table which would only require that the processor generate two bus control signals (BDIR and BC 1 , with BC 2 tied to +5 V ).

| BUS CONTROL FUNCTION TABLE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| BDIR | Inputs BC2 | BC1 | Microprocessor Function | PSG Function |
| 0 | 0 | 0 | NACT | INACTIVE. See 010 (IAB) below. |
| 0 | 0 | 1 | ADAR | LATCH ADDRESS. See 111 (INTAK) below. |
| 0 | 1 | 0 | IAB | INACTIVE. The PSG/CPU bus is inactive. DA7-DAO are in a high impedance state. |
| 0 | 1 | 1 | DTB | READ FROM PSG. This signal causes the contents of the register which is currently addressed to appear on the PSG/CPU bus. DA7-DAO are in the output mode. |
| 1 | 0 | 0 | BAR | LATCH ADDRESS. See 111 (INTAK) below. |
| 1 | 0 | 1 | DW | INACTIVE. See 010 (IAB) above. |
| 1 | 1 | 0 | DWS | WRITE TO PSG. This signal indicates that the bus contains register data which should be latched into the currently addressed register. DA7-DAO are in the input mode. |
| 1 | 1 | 1 | INTAK | LATCH ADDRESS. This signal indicates that the bus contains a register address which should be latched in the PSG. DA7-DA0 are in the input mode. |


| SIMPLIFIED BUS CONTROL FUNCTION TABLE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| BDIR | $\begin{gathered} \text { Inputs } \\ \text { BC2 } \end{gathered}$ | BC1 | PSG Function |  |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ |  | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | INACTIVE. READ FROM PSG. WRITE TO PSG. LATCH ADDRESS. |  |

## Analog Channel A, B, C (Outputs)

Pins 4,3,38 (AY38910A)
Pins 5,4,1 (AY38912A)
Each of these signals is the output of its corresponding digital to analog converter and provides 1 V peak-peak (max) signal representing the complex sound waveshape generated by the PSG.

## No Connect

Pins 2,5,26,39 (AY38910A)
Pins 2 (AY38912A)
These pins are for Microchip Technology test purposes only and should be left open. Do not use as tie-points.

## Vcc

Pins 40 (AY38910A)
Pin 3 (AY38912A)
Nominal +5 Volt power supply to the PSG.
Vss
Pin 1 (AY38910A)
Pin 6 (AY38912A)
Ground reference for the PSG.

## ARCHITECTURE

The AY38910A/AY38912A is a register oriented Programmable Sound Generator (PSG). Communication between the processor and the PSG is based on the concept of memory-mapped I/O. Control commands are issued to the PSG by writing to 16 memory-mapped registers. Each of the 16 registers within the PSG is also readable so that the microprocessor can determine, as necessary, present states or stored data values. All functions of the PSG are controlled through the 16 registers which, once programmed, generate and sustain the sounds, thus freeing the system processor for other tasks.

## Register Array

The principle element of the PSG is the array of $16 \mathrm{read} /$ write control registers. These 16 registers look to the CPU as a block of memory and as such occupy a 16 word block out of 1,024 possible addresses. The 10 address bits ( 8 bits on the common data/address bus, and 2 separate address bits) are decoded as follows:


The four low order address bits select one of the 16 registers (R08-R178). The six high order address bits function as chip selects to control the tri-state bidirectional buffers (when the high order address bits are incorrect, the bidirectional buffers are forced to a high impedance state). High order address bits A9, A8 are fixed in the PSG design to recognize a "01" code; high order address bits DA7-DA4 are programmed to recognize only a " 0000 " code. All addresses are latched internally. This internally latched address is updated and modified on every latch address signal presented to the PSG via the BDIR, BC2 and BC1 inputs. A latched address will remain valid until the receipt of a new address, enabling multiple reads and writes of the same register contents without the need for redundant readdressing.

Conditioning of the Register Address Latch/Decoder and the Bidirectional Buffers to recognize the bus function required (Inactive, Latch Address, Write Data) is accomplished by the Bus Control Decode block.

## Sound Generating Blocks

The basic blocks in the PSG which produce the programmed sounds include:

Tone Generators Produce the basic square wave tone frequencies for each channel (A, B, C).
Noise Generator Produces a pulse width modulated pseudo-random square wave output.
Mixers Combine the outputs of the Tone Generators and the Noise Generator; per channel ( $A, B, C$ ).
Envelope Generator Produces an envelope pattern which can be used to amplitude modulate the output of each Mixer.
Amplitude Control Provides the D/A Converters with either a fixed or variable amplitude pattern. Fixed amplitude is under direct CPU control. Variable amplitude is accomplished via the output of the Envelope Generator.
The three D/A Converters each produce a 16 level (max) output signal as determined by the Amplitude Control.

## OPERATION

Since all PSG functions are processor controlled by writing to the internal registers (see table). A detailed description of the PSG operation may best be accomplished by relating each PSG function to control of the corresponding register. The function of creating or programming a specific sound effect logically follows the control sequence shown in the figure below.

## Tone Generator Control (RO-R5)

The frequency of each square wave generated by the three Tone Generators (one each for Channels A, B, and $C$ ) is obtained by first dividing the input clock by 16 then by further dividing the result by the programmed 12 bit Tone Period value. Each 12-bit tone period value is obtained by combining the contents of the respective Coarse and Fine Tune registers, as illustrated.

| INTERNAL REGISTERS |  |  |
| :--- | :--- | :--- |
| Operation | Register | Function |
| Tone Generator <br> Control | R0-R5 | Program tone periods |
| Noise Generator <br> Control <br> Mixer Control | R6 | Program noise period |
| Amplitude | R108-R128 | Enable tone and/or <br> Control <br> noise on selected <br> channels <br> Select fixed or variable <br> (envelope) amplitudes <br> rator Control |
| ri38-R158 | Rrogram envelope pe <br> riod, select envelope <br> pattern |  |


| TUNE REGISTERS |  |  |
| :---: | :---: | :---: |
| Coarse Tune <br> Register | Channel | Fine Tune <br> Register |
| R1 | A | R0 |
| R3 | B | R2 |

## Noise Generator Control (R6)

The frequency of the noise source is obtained by dividing the input clock by 16 , then by further dividing the result by the programmed 5 bit Noise Period value. This 5 bit value consists of the lower 5 bits (B4-B0) of register R6, as illustrated:

## NOISE PERIOD REGISTER (R6)



Not Used
5-bit Noise Period(NP) to Noise Generator

CONTROL SEQUENCE


12-bit Tone Period (TP) to Tone Generator
Notes: 1. The period of the output of the tone generator is therefore determined by: $16 \times \mathrm{TP} \times \mathrm{P}$ where $\mathrm{P}=$ the period of the input clock.
2. If the Coarse and Fine Tune registers are both set to 0008 , the resulting period will be minimum, ie., the generated tone period will be as if the Coarse Tune register was set to 0008 and the Fine Tune register set to 0018.

## AY38910A/AY38912A

## Mixer Control - //O Enable (R7)

Register R7 is a multi-function ENABLE register which controls the three Noise/Tone Mixers.

The mixers, as previously described, combine the noise and tone frequencies for each of the three channels. The determination of combining neither/either/both noise and tone frequencies on each channel is made by the state of bits B5-B0 of register R7, as illustrated.

The direction (input or output) of the general purpose $/ /$ O ports (l/OA and I/OB) is determined by the state of bits B7 and B6 of R7, as illustrated.


| NOISE ENABLE TRUTH TABLE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { R7 Bits } \\ \text { B5 B4 B2 } \end{gathered}$ |  |  | Noise Enabled on Channel |  |  |
| 0 | 0 | 0 | C | B | A |
| 0 | 0 | 1 | C | B | - |
|  | 1 | 0 |  | - | A |
|  | 1 | 1 | C | - | - |
|  | 0 | 0 |  | B | A |
|  | 0 |  |  | B | - |
|  | 1 | 0 |  | - | A |
|  | 1 | 1 | - | - | - |


| TONE ENABLE TRUTH TABLE |  |  |  |
| :---: | :---: | :---: | :---: |
| R7 Bits |  | Tone Enabled |  |
| B2 B1 B0 | on Channel |  |  |
| 0 | 0 | 0 |  |
| 0 | 0 | 1 |  |$|$| C |
| :---: |


| I/O PORT TRUTH TABLE |  |  |
| :---: | :---: | :--- |
| R7 bits |  | I/O Port Status |
| B7 B6 | I/OB | I/OA |
| 0 | 0 | Input |
| 0 | 1 | Input |
| 1 | 0 | Input |
| 1 | 1 | Output |
| Output |  |  |
| Onput |  |  |

NOTE: Disabling noise and tone does not turn off a channel. Turning a channel off can only be accomplished by writing all zeros into the corresponding Amplitude Control Register.

## Amplitude Control (R108,R118,R128)

The amplitude of the signals generated by each of the three D/A Converters (one each for Channels A,B, and $C$ ) is determined by the content of the lower bits (B4-B0) of registers R108, R118, and R128 as illustrated.

These five bits consist of a 1-bit mode select ("M" bit) and a 4-bit "fixed" amplitude level (L3-LO). When the $M$ bit is low, the output level of the analog channel is defined by the 4-bit "fixed" amplitude level of the Amplitude Control Register. This amplitude level is fixed in the sense that the amplitude

| CHANNEL CONTROL |  |
| :---: | :---: |
| Register | Channel |
| R108 | A |
| R118 | B |
| R128 | C |

AMPLITUDE CONTROL BITS


| AMPLITUDE CONTROL REGISTER |  |  |
| :---: | :---: | :---: |
| Amplitude Mode | 4 bit fixed Amplitude Level | Note |
| O | 0000 | Amplitude Defined By LO-L3 |
| ' | ' ' |  |
| 0 | 1111 |  |
| 1 | $\mathrm{x} \times \mathrm{x}$ | Amplitude Defined By E0-E3 |

is under direct control of the system processor. When the $M$ bit is high, the output level of the analog channel is defined by the 4-bits of the Envelope Generator (bits $\mathrm{E} 3-\mathrm{EO}$ ). The amplitude mode bit can also be thought of as an "envelope enable" bit.

## Envelope Generator Control

To accomplish the generation of complex envelope patterns, two independent methods of control are provided: first, it is possible to vary the frequency of the envelope using registers R138 and R148; second, the relative shape and cycle pattern of the envelope can be varied using register R158. The following paragraphs explain the details of the envelope control functions, describing first the envelope period control and then the envelope shape/cycle control. (See Figure 1 and 2).

## Envelope Period Cotrol (R138,R148)

The frequency of the envelope is obtained by first dividing the input clock by 256 , then by further dividing the result by the programmed 16 bit Envelope Period value. This 16 bit value is obtained by combining the contents of the Envelope Coarse and Fine Tune registers, as illustrated:


## Envelope Shape/Cycle Control (R158)

The Envelope Generator further divides the envelope period by 16 , producing a 16 -state per cycle envelope pattern as defined by the 4 -bit counter output, E3, E2, E1 and EO . The particular shape and cycle pattern of any desired envelope is accomplished by controlling the count pattern of the 4 -bit counter. (See Figure 4 and 5).

This envelope shape/cycle control is contained in the lower 4 bits (B3-BO) of register R15. Each of these 4 bits controls a function in the envelope generator, as illustrated:

| ENVELOPE SHAPE/CYCLE CONTROL |  |  |
| :--- | :--- | :--- |
| Bit | Signal | Function |
| 0 | HOLD | When this is set high (logic 1) <br> the envelope is limited to one <br> cycle, the value of the enve- <br> lope at the end of the cycle <br> being held. <br> When set high (logic 1) the <br> envelope counter reverses di- <br> rection at end of each cycle <br> (i.e. performs as an up/down <br> counter). <br> When set high (logic 1) the <br> envelope counter will count up <br> (attack). When set low (logic 0) <br> the counter will count down <br> (decay). <br> When set high (logic 1) the <br> cycle pattern will be defined by <br> the HOLD bit. When set low <br> (logic 0) the envelope counter <br> will resetto oooo0afterone cycle <br> and hold that value. |
| 3 | ALTERNACK |  |

## 16-BIT ENVELOPE PERIOD (EP) TO ENVELOPE GENERATOR



Refer to Programmable Sound Generator Data Manual for calculation example.
NOTE: If the Coarse and Fine Tune registers are both set to 0008 , the resulting period will be minimum, i.e., the generated tone period will be as if the Coarse Tune register was set to 0008 and the Fine Tune register set to 0018.

## D/A Converter

Since the primary use of the PSG is to produce sound for the non-linear amplitude detection mechanism of the human ear, the D/A conversion is performed in logarithmic steps with a normalized voltage range from 0 to 1 volt. The specific amplitude control of each of the three D/A Converters is accomplished by the three sets of 4 bit outputs of the Amplitude Control block while the Mixer outputs provide the base signal frequency (Noise and/or Tone). (See Fig. 3).

FIG. 1 ENVELOPE SHAPE /CYCLE OPERATION


FIG. 2 DETAIL OF TWO CYCLES (REF. WAVEFORM "1010" IN FIG. 1)


FIG. 3 D/A CONVERTER OUTPUT


FIG. 4 SINGLE TONE WITH ENVELOPE SHAPE/CYCLE PATTERN 1010


FIG. 5 MIXTURE OF THREE TONES WITH FIXED AMPLITUDES


## ELECTRICAL CHARACTERISTICS

## Maximum Ratings*

Storage Temperature. $\qquad$
Operating Temperature $\qquad$ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Vcc and all other Input/Output
Voltages with Respect to Vss. $\qquad$ -0.3 V to +8.0 V

## Standard Conditions

$V c c=+5 \mathrm{~V} \pm 5 \%$
$\mathrm{Vss}=\mathrm{GND}$
Operating Temperature $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
(Unless otherwise noted)
*Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Data labeled "typical" is presented for design guidance only and is not guaranteed.

| DC CHARACTERISTICS | Sym | Min | Typ** | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| All Inputs |  |  |  |  |  |  |
| Low Level | VIL | -0.2 | - | 0.8 | V |  |
| High Level | VIH | 2.2 | - | Vcc | V |  |
| Data Bus (DA7-DA0) Output Levels |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
| Low Level | Vol | 0 | - | 0.4 | V | $\mathrm{lOL}=1.6 \mathrm{~mA}, 150 \mathrm{pF}$ |
| High Level | VOH | 2.4 | - | Vcc | V | $\mathrm{lOH}=100 \mathrm{~A}, 150 \mathrm{pF}$ |
| Data Bus(DA7-DA0) |  |  |  |  |  |  |
| Analog Channel Outputs |  |  |  |  |  |  |
| Output Volume | Vo | 0 | - | 60 | dB | Test Circuits: Fig. 6 |
| Power Supply Current | ICC | - | 70 | 90 | mA |  |
| Max. Current (per channel) | - | 0.4 | 2.0 | - | mA | Vout $=0.7 \mathrm{~V}$, Amplitude Control Set to $F$ |
| I/O Ports |  |  |  |  |  |  |
| Pull Up Current Low | IIL | 20 | - | 200 | A | $\mathrm{VIN}=0.4 \mathrm{~V}$, Outputs disabled |
| - as Outputs (A7-A0, B7-B0) |  |  |  |  |  |  |
| Low Level | Vol | 0 | - | 0.5 | V | $\mathrm{IIL}=1.6 \mathrm{~mA}$ |
| High Level | Vohn | 3.5 | - | Vcc | V | $\mathrm{IOHh}=10 \mathrm{~A}$ See |
|  | VOH 1 | 2.4 | - | Vcc | V | $\mathrm{IOH1}=85 \mathrm{~A}$ Note 1 |
| - as Inputs (A7-A0,B7-B0) |  |  |  |  |  |  |
| Low Level | VIL | 0 | - | 0.8 | V |  |
| High Level | VIH | 2.4 | - | Vcc | V |  |
| - $\overline{\text { A8 }}$ and Reset Input |  |  |  |  |  |  |
| Pull up Current | Illpu | -10 | - | -100 | A | $\mathrm{VIN}=0.4 \mathrm{~V}$ |
|  | ІІнpu | -10 | - | -50 | A | $\mathrm{VIN}=2.4 \mathrm{~V}$ |
| - A9 |  |  |  |  |  |  |
| Pull down Current | lıppd | 10 | - | 100 | A | $\mathrm{VIN}=2.4 \mathrm{~V}$ |
| - BC1,BDIR, Clock Inputs |  |  |  |  |  |  |
| Input Leakage | IICL | -10 | - | 10 | A | $\mathrm{VIN}=0.4 \mathrm{~V}$ to Vcc |

[^14]| AC CHARACTERISTICS | Sym | Min | Typ** | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Input |  |  |  |  |  |  |
| Frequency | fc | 1 | - | 2 | MHz |  |
| Rise Time | tr | - | - | 50 | ns | Fig. 7 |
| Fall Time | tf | - | - | 50 | ns |  |
| Duty Cycle | - | 40 | 50 | 60 | \% |  |
| Bus Signals (BDIR, BC2, BC1) |  |  |  |  |  |  |
| Reset |  |  |  |  |  |  |
| Reset Pulse Width | tRW | 500 | - | - | ns | Fig. 8 |
| $\overline{\mathrm{A9}}, \mathrm{~A} 8, \mathrm{DA7}-\mathrm{DAO}$ |  |  |  |  |  |  |
| Address Setup Time | tas | 300 | - | - | ns |  |
| Address Hold Time | tah | 65 | - | - | ns | Fig. 9 |
| DA7-DAO (Write Mode) |  |  |  |  |  |  |
| Write Data Pulse Width | tDw | 500 | - | 10,000 | ns |  |
| Write Data Setup Time | tos | 300 | - | - | ns | Fig. 10 |
| Write Data Hold Time | tD | 65 | - | - | ns |  |
| DA7-DA0 (Read Mode) |  |  |  |  |  |  |
| Data Access Time from DTB | tDA | - | - | 200 | ns | Fig. 11 |
| DA7-DAO (Inactive Mode) |  |  |  |  |  |  |
| Tri-state Delay Time from DTB | tTs | - | - | 100 | ns |  |
| I/O Ports (A7-A0, B7-B0) |  |  |  |  |  |  |
| Pull up Recovery Time | tPN | - | - | 50 | $\mu \mathrm{sec}$ | $\mathrm{VOH}=3.5 \mathrm{~V}$ |
|  |  |  |  |  |  | CLOAD $=100 \mathrm{pF}$ |
|  |  |  |  |  |  | See Note 2 |

**Typical values are at $+25^{\circ} \mathrm{C}$ and nominal voltages
NOTE 2: Pull up recovery time is defined as the time required for any I/O pin A7-A0 or B7-B0 to change up to a 100pf capacitor load from 0.0 volts to 3.5 volts. This recovery time is conditional on the output function of Port A or Port B being deselected via Bits B7 and B6 of register R10.

Fig. 6 ANALOG CHANNEL OUTPUT TEST CIRCUIT


## TIMING CONDITIONS FOR AC CHARACTERISTICS

FIG. 7 CLOCK AND BUS SIGNAL TIMING

a.

b.

FIG. 8 RESET TIMING


FIG. 9 LATCH ADDRESS TIMING


BUS CONTROL
SIGNALS CHANGING
$\rightarrow \quad 50 \mathrm{~ns}$ Max., Including Skew.

FIG. 10 WRITE DATA TIMING
BUS CONTROL DECODE

*BDIR
1
BC1

## AY38910A/AY38912A

## TIMING DIAGRAMS

## State Timing

While the state flow for many microprocessors can be somewhat involved for certain operations, the sequence of events necessary to control the PSG is simple and straightforward. Each of the three major state sequences (Latch Address, Write to PSG, and Read from

PSG) consists of several operations (indicated below by rectangular blocks) defined by the pattern of bus control signals (BDIR, BC1).
The functional operation and relative timing of the PSG control sequences are described in the following sections.


## Address PSG Register Sequence

The Latch Address sequence is normally an integral part of the write or read sequences but for simplicity is illustrated here as in individual sequence. Depending
upon the processor used, the program sequence will normally require four principal microstates: (1) send NACT (inactive); (2) send INTAK (latch address): (3) put address on bus; (4) send NACT (inactive).


## AY38910A/AY38912A

## Write Data to PSG Sequence

The Write to PSG sequence, which would normally follow immediately after an address sequence, requires
four principal microstates: (1) send NACT (inactive);(2) put data on bus; (3) send DWS (write to PSG); (4) send NACT (inactive).


## Read Data From PSG Sequence

As with the Write to PSG sequence, the READ from PSG sequence would also normally follow immediately after an address sequence. The four principal microstates of
the read sequence are: (1) send NACT (inactive); (2) send DTB (read from PSG); (3) read data on bus; (4) send NACT (inactive).

## AY38910A/AY38912A

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## Enhanced Programmable Sound Generator

## FEATURES

- Two Modes Available On-Chip
- AY8930 Expanded Mode
- AY38910A-Compatible Mode
- Improved Frequency Range
- Three Independently Programmable Analog Output Channels with Separate Frequency, Duty Cycle and Envelope Controls for Each Channel
- 5 Bits of Logarithmic Digital-to-Analog Conversion Per Channel
- Bus Interface Independent of Clock Frequency
- Input Clock Frequency: 2 or 4 MHz
- Two 8-Bit General Purpose I/O Ports


## DESCRIPTION

The AY8930 Enhanced Programmable Sound Generator (EPSG) is an LSI circuit that can produce a wide variety of complex sounds under software control. The AY8930 is manufactured in the Microchip Technology Inc. n-channel silicon gate process. The AY8930 is an enhanced version of the company's industry standard AY38910A sound generator. Enhanced features include improved frequency range and noise synthesis and independent control of each channel's envelope and duty cycle.

The PSG is easily interfaced to any bus-oriented system. Its flexibility makes it useful in applications such as music synthesis, sound effects generation, audible alarms, tone signalling, and personal computer usage. In order to generate sound effects while allowing the processor to perform other tasks, the PSG can continue to produce sound after the initial commands have been given by the control processor. The fact that realistic sound production often involves more than one effect is satisfied by the three independently controllable analog sound output channels available in the device. These analog sound output channels can each provide five bits of logarithmic digital-to-analog conversion, greatly enhancing the dynamic range of the sounds produced.


All circuit control signals are digital in nature and can be provided directly by a microprocessor/microcomputer. Therefore, one PSG can produce the full range of required sounds with no change in external circuitry. Since the frequency response of the PSG ranges from sub- audible at its lowest frequency to post-audible at its highest frequency, there are few sounds which are beyond reproduction with only the simplest electrical connections.

## DEVICE ARCHITECTURE

The AY8930 is a register oriented PSG. Communication between the microprocessor and the PSG is based on the concept of memory mapped I/O. Control commands are issued to the PSG by writing to these memory mapped registers. Each of the registers within the PSG is readable so that the microprocessor can determine, as necessary, present states or stored data values.

## PIN FUNCTIONS

DA7-DA0 (Input /Output/High Impedance)
Data/Address Bits 7-0: Pins 30-37

These 8 lines comprise the 8 -bit bidirectional bus used by the microprocessor to send both data and addresses to the PSG, and to receive data from the PSG. In the address mode, DA3-DA0 select the internal register address ( $0-\mathrm{Fn}$ ) and DA7-DA4 in conjunction with address inputs $\overline{\mathrm{A} 9}$ and A 8 , form the chip select function. When the high order address bits are "incorrect," the bidirectional buffers are forced to a high impedance state.

## Address 9, Address 8 <br> A8 (input): Pin 25 <br> $\overline{\mathrm{A} 9}$ (input): $\quad$ Pin 24

High order address bits $\overline{\mathrm{A} 9}$ and A8 are fixed to recognize a "01" code. They may be left unconnected, as each is provided with either an on chip pull-down ( $\overline{\mathrm{Ag}}$ ) or pull-up (A8) resistor. In noisy environments, however, it is recommended that $\overline{A 9}$ and $A 8$ be tied to external ground and +5 V respectively, if they are not to be used.

RESET (Input): Pin 23
For initialization/power-on purposes, applying a low level input to the RESET pin will reset all registers to 0 . (See following table). The $\overline{\operatorname{RESET}}$ pin is provided with an on-chip pull-up resistor.

| Register (in Hex) | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| RO/R0A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R1/R1A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R2/R2A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R3/R3A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R4/R4A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R5/R5A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R6/R6A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R7/R7A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R8/R8A | $\#$ | $\#$ | 0 | 0 | 0 | 0 | 0 | 0 |
| R9/R9A | $\#$ | $\#$ | 0 | 0 | 0 | 0 | 0 | 0 |
| RA/RAA | $\#$ | $\#$ | 0 | 0 | 0 | 0 | 0 | 0 |
| RB/RBA | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| RC/RCA | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| RD/RDA/PDB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| RE/REA | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| RF/RFA | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R0B | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R1B | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R2B | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R3B | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R4B | $\#$ | $\#$ | $\#$ | $\#$ | $X$ | $X$ | $X$ | $X$ |
| R5B | $\#$ | $\#$ | $\#$ | $\#$ | $X$ | $X$ | $X$ | $X$ |
| R6B | $\#$ | $\#$ | $\#$ | $\#$ | $X$ | $X$ | $X$ | $X$ |
| R7B | $\#$ | $\#$ | $\#$ | $\#$ | $X$ | $X$ | $X$ | $X$ |
| R8B | $\#$ | $\#$ | $\#$ | $\#$ | $X$ | $X$ | $X$ | $X$ |
| R9B | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| RAB | $X$ | $X$ | $X$ | $X$ | $X$ | $X$ | $X$ | $X$ |
| RFB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

- X indicates a don't care.
- \# indicates that there is no physical memory element for a bit; if read, a 0 will be returned.
- All counter work registers will be initialized to zeros.
- The noise generator 17-bit shift register will be initialized to ones.
- The noise value register will be initialized to zeros.


## CLOCK (Input): Pin 22

This TTL compatible input supplies the timing reference for the Tone, Noise, and Envelope Generators.

## CLOCK DIVIDE - SELECT (Input): Pin 26

| Select $=0$ | Input Clock $=4 \mathrm{MHz}$ max. <br> (Divided internally by 2) |
| :--- | :--- |
| Select $=1$ | Input Clock $=2 \mathrm{MHz}$ max. |

The select pin is provided with an internal pull-up resistor such that the pin default condition is Select $=1$.

BDIR, BC2, BC1 (Inputs): Pins 27, 28, 29
Bus Direction, Bus Control 2*, Bus Control 1

* Not connected

Analog Channel A, B, C (Outputs): Pins 4, 3, 38
Each of these signals is the output of its corresponding digital-to-analog converter, and provides 1 V peak-peak (max) signal representing the complex sound waveshape generated by the PSG.

No Connect: Pins 2, 5, 39
These pins are for Microchip Technology test purposes only and should be left open. Do not use as tie-points.

Vcc: Pin 40, Nominal +5 Volt power supply to the PSG.

Vss: Pin 1, Ground reference for the PSG.

## INPUT CONTROL SIGNALS

Interfacing to the AY8930 requires the generation of only two of the three AY38910A input control signals, BDIR and BC1. BC2 is shown on the pinout diagram for reference only; the pin is not internally connected.

| INPUT CONTROL SIGNALS |  |  |
| :---: | :---: | :--- |
| BDIR | BC1 | Function |
| 0 | 0 | INACTIVE: The PSG/CPU bus is <br> inactive. DA7-DAO are in a high <br> impedance state. |
| 0 | 1 | READ FROM PSG: This signal causes <br> the contents of the register which is <br> currently addressed to appear on the <br> PSG/CPU bus. DA7-DAO are in the <br> output mode. |
| 1 | 0 | WRITE TO PSG: This signal indicates <br> that the bus contains register data <br> which should be latched into the cur- <br> rently addressed register. DA7-DA0 are <br> in the input mode. |
| 1 | 1 | LATCH ADDRESS: This signal indi- <br>  <br> cates that the bus contains a register <br> address which should be latched by the <br> PSG. DA7- DA0 are in the input mode. |

## REGISTER ARRAY

The principal element of the AY8930 is an array of 27 control registers arranged in one bank of 16 and one bank of 11 registers. These registers occupy 16 address locations of the 1,024-word memory space in which the PSG resides.

The configuration of this register array is shown on the following pages. Note the two modes of operation: 8910A-compatibility mode and 8930 expanded mode.

The registers are addressed via the combination of the bidirectional data bus (DA0-DA7) and address input pins A8 and $\overline{\mathrm{A} 9}$.

| $\overline{\text { A9 }}$ | A8 | DA7 | DA6 | DA5 | DA4 | DA3 | DA2 | DA1 | DA0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 0 | 0 | 0 | $x$ | $x$ | $x$ | $x$ |

DAO-DA3 These four low-order address bits are used to select one of the internal registers within a bank.

DA4-DA7,
A8, $\overline{\text { A9 }}$ These sixhigh-order address bits function as chip selects and are used to position the register bank(s) within the 1,024 -word memory space. In the deselected state, the data bus is in the high impedance state.

The address enable code for bits DA4-DA7 is all zeros.

Inputs A8 and $\overline{\mathrm{A} 9}$ are enabled by a high on A8 and a low on $\overline{\mathrm{A} 9}$; all other input level combinations result in a deselected condition. Pins A8 and $\overline{\mathrm{A} 9}$ have an on-chip pull-up and pulldown resistor, respectively, and will assume the correct logic level if left unconnected.

Address bits DA7-DA0 are latched internally. This internally latched address is updated and modified on every "latch address" signal presented to the PSG via the BDIR and BC1 control lines.

The AY8930 initializes in the AY38910A-compatibility mode. To utilize the expanded features of the AY8930, an access code must be input to register R15 upon program initialization.

Entering a "101" code in bits B7-B5 of register R15 selects the 8050 expanded mode. In the 8930 expanded mode, bit $B 4=0$ (R15) selects BANK $A$ and $B 4=1$ selects BANK B. All other bit selections are defined as 8910Acompatibility mode. Registers R15A and R15B are mapped into the same physical register.

Switching modes causes loss of all register data from the previous mode. All registers will be initialized except for the Mode Select code of R15.

Shown on the next page is the register configuration for the AY8930. Note that Bank A of the expanded mode is virtually identical to the single register array of the 8910Acompatibility mode.

| AY8930 REGISTER ARRAY: AY38910A-COMPATIBILITY MODE |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register |  | Function | Bit |  |  |  |  |  |  |  |
| Hex | Octal |  | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |
| R0 | Ro | Channel A <br> Tone Period | - |  |  |  |  |  |  |  |
| R1 | R1 |  |  |  |  |  |  |  |  |  |
| R2 | R2 | Channel B <br> Tone Period | - |  |  |  |  |  |  |  |
| R3 | R3 |  |  |  |  |  |  |  |  |  |
| R4 | R4 | Channel C <br> Tone Period | 8-Bit Fine Tune |  |  |  |  |  |  |  |
| R5 | R5 |  |  |  |  |  |  | 4-Bit Coarse Tune |  |  |
| R6 | R6 | Noise Period |  |  |  | 5-Bit Period Control |  |  |  |  |
|  |  |  | IN/OUT |  | NOISE |  |  | TONE |  |  |
| R7 | R7 | $\overline{\text { Enable }}$ | IOB | IOA | C | B | A | c | B | A |
| R8 | R10 | Channel A Amplitude |  |  |  | M | L3 | L2 | L1 | L0 |
| R9 | R11 | Channel B Amplitude |  |  |  | M | L3 | L2 | L1 | LO |
| RA | R12 | Channel C Amplitude |  |  |  | M | L3 | L2 | L1 | LO |
| RB | R13 | Envelope Period | 8-Bit Fine Tune |  |  |  |  |  |  |  |
| RC | R14 |  | 8 -Bit Coarse Tune |  |  |  |  |  |  |  |
| RD | R15 | Envelope Shape/Cycle | MODE SELECT |  |  |  | CONT | ATT. | ALT. | HOLD |
| RE | R16 | I/O Port A | 8 -Bit Parallel I/O on Port A |  |  |  |  |  |  |  |
| RF | R17 | I/O Port B | 8 -Bit Parallel I/O on Port B |  |  |  |  |  |  |  |


| AY8930 REGISTER ARRAY: EXPANDED CAPABILITY MODE - BANK A |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register |  | Function | Bit |  |  |  |  |  |  |  |
| Hex | Octal |  | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |
| ROA | ROA | Channel A <br> Tone Period | 8 -Bit Fine Tune |  |  |  |  |  |  |  |
| R1A | R1A |  | 8-Bit Coarse Tune |  |  |  |  |  |  |  |
| R2A | R2A | Channel B <br> Tone Period | 8-Bit Fine Tune |  |  |  |  |  |  |  |
| R3A | R3A |  | 8-Bit Coarse Tune |  |  |  |  |  |  |  |
| R4A | R4A | Channel C <br> Tone Period | 8 -Bit Fine Tune |  |  |  |  |  |  |  |
| R5A | R5A |  | 8 -Bit Coarse Tune |  |  |  |  |  |  |  |
| R6A | R6A | Noise Period | 8 -Bit Noise Period |  |  |  |  |  |  |  |
|  |  |  | IN/OUT |  | NOISE |  |  | TONE |  |  |
| R7A | R7A | Enable | IOB | IOA | c | B | A | c | B | A |
| R8A | R10A | Channel A Amplitude |  |  | M | L4 | L3 | L2 | L1 | L0 |
| R9A | R11A | Channel B Amplitude |  |  | M | L4 | L3 | L2 | L1 | LO |
| RAA | R12A | Channel C Amplitude |  |  | M | L4 | L3 | L2 | L1 | L0 |
| RBA | R13A | Channel A <br> Envelope Period | 8 -Bit Fine Tune |  |  |  |  |  |  |  |
| RCA | R14A |  | 8 -Bit Coarse Tune |  |  |  |  |  |  |  |
| RDA | R15A | Bank A/B: Envelope A | 1 | 0 | 1 | 0 | CONT. | ATT. | ALT. | HOLD |
| REA | R16A | I/O Port A | 8 -Bit Parallel I/O on Port A |  |  |  |  |  |  |  |
| RFA | R17A | I/O Port B | 8-Bit Parallel I/O on Port B |  |  |  |  |  |  |  |


| AY8930 REGISTER ARRAY: EXPANDED CAPABILITY MODE - BANK B |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register |  | Function | Bit |  |  |  |  |  |  |  |
| Hex | Octal |  | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |
| ROB | ROB | Channel B <br> Envelope Period | 8 -Bit Fine Tune |  |  |  |  |  |  |  |
| R1B | R1B |  | 8-Bit Coarse Tune |  |  |  |  |  |  |  |
| R2B | R2B | Channel C <br> Envelope Period | 8 -Bit Fine Tune |  |  |  |  |  |  |  |
| R3B | R3B |  | 8-Bit Coarse Tune |  |  |  |  |  |  |  |
| R4B | R4B | Envelope Shape/Cycle B |  |  |  |  | CONT. <br> CONT. <br> 4-Bit <br> 4-Bit | ATT. | ALT. | HOLD |
| R5B | R5B | Envelope Shape/Cycle C |  |  |  |  | ATT. | ALT. | HOLD |
| R6B | R6B | Channel A Duty Cycle |  |  |  |  |  |  |  |
| R7B | R7B | Channel B Duty Cycle |  |  |  |  |  |  |  |
| R8B | R10B | Channel C Duty Cycle |  |  |  |  |  |  |  |
| R9B | R11B | Noise "And" Mask | 8-Bit |  |  |  |  |  |  |  |
| RAB | R12B | Noise "Or" Mask | 8-Bit |  |  |  |  |  |  |  |
| RBB |  |  |  |  |  |  |  |  |  |  |
| RBC |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RBD | R15B | Bank A/B: Envelope A | 1 | 0 | 1 | 1 |  | CONT. | ATT. | ALT. | HOLD |
| RBC | R16B* |  |  |  |  |  |  |  |  |  |
| RBF | R17B* | TEST | NOT TO BE ACCESSED BY THE USER |  |  |  |  |  |  |  |

* Not accessible in AY8930 mode.

NOTE: All unused bits will be read back as " 0 ".

## SOUND GENERATING BLOCKS

The basic blocks in the PSG that produce the programmed sounds include:

Tone
Generators - Produce the basic pulse tone frequencies for each channel (A, B, C).

Noise
Generator

Mixers

Amplitude Control

Envelope
Generators

- Produce an envelope pattern that can be used to amplitude modulate the output of the mixer, one for each channel ( $A, B, C$ ).


## D/A

Converters - The three D/A converters each produce up to a 32 -level output signal as determined by the amplitude control.

## OPERATION

Since all functions of the PSG are controlled by a host processor via a series of register loads, a detailed description of the PSG operation can best be accomplished by relating each PSG function to its corresponding register. The function of creating or programming a specific sound or sound effect logically follows the control sequence listed:

| Operation | Registers* | Function |
| :--- | :--- | :--- |
| Tone Generator <br> Control | R0A-R5A | Program tone <br> periods |
| Duty Cycle <br> Control | R6B-R8B | Select duty cycle |
| Noise Generator <br> Control | R6A, <br> R9B-RAB | Program noise <br> period |
| Mixer Control | R7A | Enable tone/noise <br> on selected <br> channels |
| Amplitude <br> Control | R8A-RAA | Select "fixed" or <br> "variable" <br> amplitudes |
| Envelope <br> Generator <br> Control | RBA-RDA, <br> ROB-R5B | Program envelope <br> period and <br> envelope pattern |
| D/A Converters |  | Produces a 32-bit <br> output signal |

*All registers referenced are for the AY8930 Expanded Mode.

## TONE GENERATOR CONTROL

Each analog output channel has associated with it two registers which specify the tone period for that channel, the coarse tune and the fine tune registers. The tone period for each channel is obtained by combining the coarse and fine tune registers as shown.

Note that the value programmed in the combined coarse and fine tune registers is a period value- the higher the value in the registers, the lower the resultant frequency.

| Coarse Tune <br> Registers | Channel | Fine Tune <br> Register |
| :---: | :---: | :---: |
| R1A | A | R0A |
| R3A | B | R2A |
| R5A | C | R4A |

## 12-BIT TONE PERIOD (TP) VALUE: AY38910A-COMPATIBILITY MODE



## 16-BIT TONE PERIOD (TP) VALUE: AY8930 EXPANDED MODE



```
PERIOD OF OUTPUT = 16 x TP }\times
WHERE P = PERIOD OF INPUT CLOCK AND
TP = DECIMAL EQUIVALENT OF TONE PERIOD BITS
TP15-TP0
```

If the coarse and fine tune registers are both set to 00h, the resulting period will be minimum, i.e. the generated tone period will be as if the coarse tune register were set to 00h and the fine tune register were set to 01h. The counter will count the period value down to zero. When zero is reached, the period value will be reloaded into the counter.

## DUTY CYCLE CONTROL

The duty cycle of each pulse generated by the three tone generators is controlled by an associated 4-bit duty cycle register (R6B, R7B, and R8B).

The following duty cycles are selectable:

| \% <br> Duty Cycle | Duty Cycle | Register <br> Value |
| :---: | :---: | :---: |
| $3.125 \%$ | 0 | 0000 |
| $6.25 \%$ | 1 | 0001 |
| $12.50 \%$ | 2 | 0010 |
| $25.00 \%$ | 3 | 0011 |
| $50.00 \%$ | 4 | 0100 |
| $75.00 \%$ | 5 | 0101 |
| $87.50 \%$ | 6 | 0110 |
| $93.75 \%$ | 7 | 0111 |
| $96.875 \%$ | $8^{\star}$ | 1000 |

* NOTE: Any value greater than 810 decodes as an 810 .

NOTE:

The percent duty cycles refers to the high (logic high) portion of the duty cycle. The low portion is then $100 \%$ duty cycle. For example, a $10 \%$ duty cycle is then $10 \%$ up and $90 \%$ down, as shown below.


In AY8910A-compatibility mode, the duty cycle is fixed at $50 \%$. The capability for a variable duty cycle exists only in the expanded AY8930 mode.

In order to change a duty cycle, the appropriate duty cycle register must be updated. The new duty cycle will then remain constant at this value until the duty cycle register is modified. The new duty cycle value will take effect immediately. This may result in one period with a "random" duty cycle at the time the register is updated.

## NOISE GENERATOR CONTROL

## AY38910A-COMPATIBILITY MODE:

Noise is generated by a 17-bit polynominal shift register. The period of the clock to this shift register is specified by the 8 -bit binary value NP.

The noise period value is derived from the lower five bits (B4-B0) of the noise period register (R6) as shown.

NOISE PERIOD REGISTER (R6)


5 BIT NOISE PERIOD (NP) VALUE

NOTE:

As with the tone period, the lowest period value is 01 h (divide by 1 ), an entry of 00 h will have the same value as 01 h ; the highest period value is 1 Fh (divide by 3110 ).


## AY8930 EXPANDED MODE:

In the AY8930 expanded mode, noise is generated using a 17-bit polynomial shift register, an "AND" mask, an "OR" mask, and an 8-bit noise period value. The least significant byte of the polynomial shift register is logically AND'ed with the "AND" mask specified in Register 11B, then logically OR'ed with the "OR" mask specified in Register 12B. The result is stored in a temporary register which is clocked each time the counter associated with the 8 -bit noise period register (R6A) reaches zero. When the noise value reaches zero, a new value is fetched from the polynomial shift register and the process is repeated. The noise output is toggled each time the noise value reaches zero.

## NOISE PERIOD REGISTER (R6A)

| B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
| $\begin{gathered} \mathrm{NP} \\ 7 \end{gathered}$ | $\begin{gathered} \text { NP } \\ 6 \end{gathered}$ | $\begin{gathered} \mathrm{NP} \\ 5 \end{gathered}$ | $\begin{gathered} \text { NP } \\ 4 \end{gathered}$ | $\begin{gathered} \mathrm{NP} \\ 3 \end{gathered}$ | $\begin{gathered} \mathrm{NP} \\ 2 \end{gathered}$ | $\begin{gathered} N P \\ 1 \end{gathered}$ | $\begin{gathered} \mathrm{NP} \\ 0 \end{gathered}$ |

The lowest period value is 01 h (divide by 1 ), an entry 00 h will have the same value as 01 h ; the highest period value is FFh (divide by 25510 .)

AY8930 EXPANDED MODE NOISE BLOCK DIAGRAM


## MIXER CONTROL - I/O ENABLE

Register 7A is a multi-function Enable register which controls the three Noise/Tone Mixers and the two general purpose I/O Ports. The mixers, as previously described, combine the noise and tone frequencies for each of the three channels. The determination of combining neither/either/both noise and tone frequencies on each channel is made by the state of bits B5-B0 of R7A.

The direction (input or output) of the two general purpose I/O Ports (IOA and IOB) is determined by the state of bits $B 7$ and B6 of R7A.

These functions are illustrated in the following:


Noise Enable Truth Table
Tone Enable Truth Table

| R7A Bits |  |  | Noise <br> Enabled On Channel |  |
| :---: | :---: | :---: | :---: | :---: |
| B5 | B4 | B3 |  |  |
| 0 | 0 | 0 | C B | A |
| 0 | 0 | 1 | C B | - |
| 0 | 1 | 0 | C - | A |
| 0 | 1 | 1 | C - | - |
| 1 | 0 | 0 | - B | A |
| 1 | 0 | 1 | - B | - |
| 1 | 1 | 0 | - - | A |
| 1 | 1 | 1 | - - | - |


| R7A Bits |  |  | Tone <br> Enabled On Channel |  |
| :---: | :---: | :---: | :---: | :---: |
| B2 | B1 | B0 |  |  |
| 0 | 0 | 0 | C B | B A |
| 0 | 0 | 1 | C B | B |
| 0 | 1 | 0 | C - | - A |
| 0 | 1 | 1 | C - | - |
| 1 | 0 | 0 | - B | B A |
| 1 | 0 | 1 | - B | B |
| 1 | 1 | 0 | - - | - A |
| 1 | 1 | 1 | - | - - |

The direction of the I/O Port(s) is determined as follows:
I/O Port Truth Table

| R7A Bits |  | I/O Direction |  |
| :---: | :---: | :---: | :--- |
| B7 | B6 | IOB | IOA |
| 0 | 0 | In | In |
| 0 | 1 | In | Out |
| 1 | 0 | Out | In |
| 1 | 1 | Out | Out |

Note: The Mixer - I/O Control function is identical in both modes of operation.

Disabling noise and tone does not turn off a channel. Turning off a channel can only be accomplished by writing all zeros into corresponding amplitude control register.

## I/O PORT DATA STORE

Registers REA and RFA function as intermediate data storage registers between the PSG/CPU data bus (DA0DA7) and the two I/O ports (IOAO-IOA7, IOB0-IOB7). Both I/O ports are available on the AY8930.

Using registers REA and RFA for the transfer of I/O data has no effect on sound generation.

To output data from the CPU Bus to a peripheral device connected to I/O port A:

1. Address the enable register (R7A).
2. Set the port A direction bit to output (write "1" to bit B6 of R7A).
3. Address the I/O port A register (REA).
4. Write data to $I / O$ port A register. The data will pass through the PSG I/O port A register to the I/O port bus.

To input data from I/O port A to the CPU bus:

1. Address the enable register (R7A).
2. Set the port A direction bit to input (write a "0" to bit B6 of R7A).
3. Address the I/O port A register (REA). The contents of the port register will follow the signals applied to the I/O port.
4. Read data from I/O port A register. The data will be transferred from the PSG I/O port A register to the CPU bus as in a normal read operation.

If a logic 1 has been written to any bit position of register REA or register RFA and the corresponding I/O pins of port $A$ or port $B$ are externally pulled below the logic 0 ,. (VIL) level, a subsequent CPU read instruction of registers REA or RFA will actually contain a logic 0 in the pulled down bit positions. The output pins will return to logic 1 if the pull down condition is removed.

If a logic 0 has been written to any bit position of the I/O registers and the external world wishes to pull these pins to a 1, the user should be aware that an impedence conflict will exist between the pull down transistor and the external driver.

## AMPLITUDE CONTROL

The amplitudes of the signals generated by each of the three D/A converters (one each for channels A, B, and C) are determined by the contents of the amplitude control registers as illustrated in the following:

| Amplitude Control <br> Register \# | Channel |
| :---: | :---: |
| R8A | A |
| R9A | B |
| RAA | C |

## AY38910A-COMPATIBILITY MODE:



## AY8930 EXPANDED MODE:



The amplitude "mode" (bit M) selects either fixed level amplitude ( $M=0$ ) or variable level amplitude $(M=1)$. It follows that bits L4-LO, defining the value of a "fixed" level amplitude, are only active when $M=0$. The amplitude is only "fixed" in the sense that the amplitude level is under the direct control of the system processor via an address latch/write data sequence.

When "variable amplitude" is selected ( $M=1$ ), the amplitude of each channel is determined by the envelope pattern as defined by the envelope generators 5 -bit output (E4 - EO). The amplitude "mode" bit (bit M) can also be thought of as an envelope enable bit, i.e. when $M=1$, the envelope is enabled.

The following is a chart describing all combinations of the 6-bit Amplitude Control.

M L4 L3 L2 L1 L0
$\begin{array}{llllll}0 & 0 & 0 & 0 & 0 & 0^{*}\end{array}$ The amplitude is fixed at 1 of 31
$\begin{array}{lllllll}0 & 0 & 0 & 0 & 0 & 1^{*} & \text { levels as determined by L4, L3, }\end{array}$
-••••• L2, L1, LO.
-•••••
$\begin{array}{llllll}0 & 1 & 1 & 1 & 1 & 1\end{array}$
The amplitude is variable at 31
$1 \times \times \times \times$ levels as determined by the output of the Envelope Generator.
( $\mathrm{X}=$ Don't care)
NOTE:

In the AY38910A-compatibility mode, the externally driven "fixed" amplitude is limited to a total of 16 possible levels determined by amplitude bits L4-L1.

## ENVELOPE GENERATOR CONTROL

## ENVELOPE PERIOD CONTROL

The period of the sound envelope, in the AY38910Acompatibility mode, is controlled by two 8 -bit registers, RB and RC (the envelope fine and coarse tune, respectively). In the 8930 expanded mode, each analog output channel has its own independent sound envelope. Changes to the envelope period counter will occur at envelope period boundary or when envelope shape/cycle register is loaded.

| Coarse Tune <br> Register | Channel | Fine Tune <br> Register |
| :---: | :---: | :---: |
| RCA | A | RBA |
| R1B | B | ROB |
| R3B | C | R2B |

## 16-BIT ENVELOPE PERIOD TO ENVELOPE GENERATOR



Note that the value programmed in the combined coarse and fine tune registers is a period value - the higher the value in the registers, the lower the resultant frequency.

Note also, that as with the tone period, the lowest period value is 0001 h (divided by 1 ); the highest period value is FFFFh (divided by 65,53510 ).

## ENVELOPE SHAPE/CYCLE CONTROL

The AY8930 envelope generator further counts down the envelope frequency by 32 , producing a 32-state per cycle envelope pattern defined by its 5 -bit counter output, E4, E3, E2, E1, and E0. The particular shape and cycle pattern of any desired envelope is accomplished by controlling the count pattern (count up/ count down) of the 5-bit counter and by defining a single cycle repeatcycle pattern. The AY38910A mode envelope generator further divides the envelope period by 16 , producing a 16 -state per cycle envelope pattern as defined by the 4bit counter output, E3, E2, E1 and E0.

Loading of the envelope shape/cycle control register will reset the associated counter to the appropriate initial state and reset the envelope period counter for that channel.

The envelope shape/cycle control is contained in the lower 4 bits (B3-B0) of the respective envelope control registers. Each of these 4 bits controls a function in the envelope generator, as illustrated in the following:

ENVELOPE SHAPE/CYCLE
CONTROL REGISTER


The definition of each function is as follows:

Hold - When set to logic "1" in AY38910A mode, limits the envelope to one cycle, holding the last count of the envelope counter ( $\mathrm{E} 3-\mathrm{EO}=0000$ or 1111, depending on whether the envelope counter was in a count-down or count-up mode, respectively).

Alternate - When set to logic " 1 ", the envelope counter reverses count direction (up-down) after each cycle.

NOTE: When both the hold bit and the alternate bit are ones, the envelope counter is reset to its initial count before holding.

Attack - When set to logic "1" in AY38910A mode, the envelope counter will count up (attack) from E3, E2, E1, $E 0=0000$ to $E 3, E 2, E 1, E 0=1111$; when set to logic " 0 ", the envelope counter will count down (decay) from 1111 to 0000 .

Continue - When set to logic "1", the cycle pattern will be as defined by the hold bit; when set to logic " 0 ", the envelope generator will be reset to 0000 after one cycle and hold at that count.

Further description of the above functions could be accomplished by numerous charts of the binary count sequence of E3, E2, E1, E0 for each combination of hold, alternate, attack and continue. However, since these ouputs are used (when selected by the amplitude control registers) to amplitude modulate the output of the mixers, a better understanding of their effect can be accomplished via a graphic representation of their value for each condition selected, as illustrated in the Envelope Shape/Cycle Control figure to the right and the Detail of Two Cycles figure below.

For AY8930 mode, hold, alternate, attack and continue is the same, however the pattern is defined by 5 bits (E4, E3, E2, E1, E0.)

## ENVELOPE SHAPE/CYCLE CONTROL



## DETAIL OF TWO CYCLES - AY38910A MODE



## DIGITAL TO ANALOG CONVERTER

The Digital to Analog conversion is performed in logarithmetic steps with a normalized voltage range of 0 V to 1.0 V . The specified amplitude of each converter is controlled by a 5 -bit word from either the amplitude
control register* or the envelope generator. The signal of the output is the Noise/Tone specified for that channel.

* Except in the 8910A-compatibility mode, which only allows for 4 bits of external amplitude control.


## D/A CONVERTER OUTPUT - AY8930 EXPANDED MODE



THIS FIGURE ILLUSTRATES THE D/A CONVERTER OUTPUT WHICH WOULD RESULT IF NOISE AND TONES WERE DISABLED AND AN ENVELOPE CONTROLLED VARIABLE AMPLITUDE WERE SELECTED.

NOTE: THE RESET CONDITION IS ZERO CURRENT.

## ELECTRICAL CHARACTERISTICS

Maximum Ratings*
Storage temperature........................ $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Maximum temperature under bias ............. $+125^{\circ} \mathrm{C}$
VDD and all other input/output
voltages with respect to Vss............... 0.3 V to +7.0 V

Standard Conditions (Unless otherwise noted)
Free air ambient operating
temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
VDD +4.5 V to +5.5 V
Vss $\qquad$ 0.0 V (Ground)
*Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Data labeled "typical" is presented for design guidance only and is not guaranteed.

## DC CHARACTERISTICS

| Parameters | Sym | Min | Typ | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input Logic Levels Logic 0 Logic 1 | $\begin{aligned} & \text { VIL } \\ & \mathrm{VIH}^{2} \end{aligned}$ | $\begin{aligned} & -0.3 \\ & +2.4 \end{aligned}$ | - | $\begin{gathered} +0.4 \\ \text { VDD } \end{gathered}$ | Volts <br> Volts |  |
| Input Leakage Clock BC1, BDIR |  | - |  | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |  |
| Inputs with Pullups A8, RESET, Select | IIL | 10 | - | 100 | $\mu \mathrm{A}$ | $\mathrm{VIN}=+0.4 \mathrm{~V}$ |
| Inputs with Pulldowns A9 | 1 H | 10 | - | 50 | $\mu \mathrm{A}$ | $\mathrm{VIN}=+2.4 \mathrm{~V}$ |
| I/O with Pullups <br> A7-A0, B7-B0 | IIL <br> VOH <br> VoL | $\begin{aligned} & 20 \\ & +2.4 \\ & 0.0 \end{aligned}$ |  | $\begin{aligned} & 150 \\ & \text { VDD } \\ & +0.4 \end{aligned}$ | $\mu \mathrm{A}$ Volts Volts | $\begin{aligned} & \mathrm{VIN}=+0.4 \mathrm{~V} \\ & \mathrm{IOH}=100 \mu \mathrm{~A} / 100 \mathrm{pF} \\ & \mathrm{IOL}=1.6 \mathrm{~mA} \mathrm{w} / 100 \mathrm{pF} \end{aligned}$ |
| Data/Address DA7-DA0 | VOH Vol | $\begin{aligned} & +2.4 \\ & 0.0 \end{aligned}$ |  | $\begin{aligned} & \text { VDD } \\ & +0.4 \end{aligned}$ | Volts <br> Volts | $\begin{aligned} & \mathrm{lOH}=100 \mu \mathrm{~A} \mathrm{w} / 100 \mathrm{pF} \\ & \mathrm{lOL}=1.6 \mathrm{~mA} \mathrm{w} / 100 \mathrm{pF} \end{aligned}$ |
| Power Supply | IDD | - | - | 85 | mA | All inputs and outputs tied to Vss or VDD. |

## AC CHARACTERISTICS *

| Parameters | Sym | Min | Typ | Max | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Input Frequency Rise/Fall Time | $\mathrm{tr}, \mathrm{tf}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ |  | $\begin{aligned} & 4 \\ & 50 \end{aligned}$ | $\mathrm{MHz}$ <br> ns | 40/60 asymmetry allowed |
| Master Reset RESET | tms | * | - | - | ns | *Two Clock Periods |
| Control Signals BC1, BC2, BDIR Skew Valid | $\begin{aligned} & \text { tcs } \\ & \text { tccs } \end{aligned}$ | $300$ |  | $40$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| Data Address Bus DA7-DA0, A8, $\overline{A 9}$ Address Setup Time Address Hold Time | $\begin{aligned} & \text { tas } \\ & \text { tah } \end{aligned}$ | $\begin{aligned} & 300 \\ & 65 \end{aligned}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| Read Mode Data Setup Time Data Hold Time | $\begin{aligned} & \text { tab } \\ & \text { ttd } \end{aligned}$ | $20$ |  | $\begin{aligned} & 200 \\ & 100 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| Write Mode <br> Data Setup Time <br> Data Hold Time <br> Input/Output Port IOA7-IOA0, IOB7-IOB0 <br> Output Mode Data Setup Time | tds tdh <br> tpw | $\begin{aligned} & 300 \\ & 65 \end{aligned}$ <br> 500 | - |  | ns ns ns |  |
| Input Mode Data Setup Time Data Hold Time | $\begin{aligned} & \text { tprs } \\ & \text { tprh } \end{aligned}$ | $\begin{aligned} & 200 \\ & 65 \end{aligned}$ | - |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |

* The address/data read cycle is latch address followed by an inactive state then the read command. The address/data write cycle would be the same with the substitution of the write command in place of the read. An inactive state is required between each cycle (or active command).


## TIMING DIAGRAMS

## READ MODE



## WRITE MODE

> BUS CONTROL BC1, BDIR


## BUS CONTROL SIGNALS



## TIMING DIAGRAMS (Cont.)

MASTER RESET


## I/O PORT OUTPUT MODE: WRITE DATA FROM CPU BUS TO I/O PORT*



I/O PORT INPUT MODE: WRITE DATA FROM I/O PORT TO CPU BUS*


[^15]
## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## 32-Segment CMOS LCD Driver

## FEATURES

- Drives up to 32 LCD segments of arbitrary configuration
- CMOS process for: wide supply voltage range, low power operation, high noise immunity, wide temperature range
- CMOS, NMOS and TTL-compatible inputs
- Electrostatic discharge protection on all pins
- Cascadable
- On-chip oscillator
- Requires only three control lines
- Can be used to drive relays, solenoids, print head drives, etc.


## APPLICATIONS

- Industrial displays
- Consumer product displays
- Telecom product displays
- Automotive dashboard displays


## DESCRIPTION

The AY0438-I is a CMOS LSI circuit that drives a liquid crystal display, usually under microprocessor control. The part acts as a smart peripheral that drives up to 32 LCD segments. It needs only three control lines due to its serial input construction. It latches the data to be displayed and relieves the microprocessor from the task of generating the required waveforms.
The AY0438-I can drive any standard or custom parallel drive LCD display, whether it be field effect or dynamic scattering; 7-, 9-, 14-, or 16-segment characters; decimals; leading + or -; or special symbols. Several AY0438-I devices can be cascaded. The AC frequency of the LCD waveforms can either be supplied by the user or generated by attaching a capacitor to the LCD input, which controls the frequency of an internal oscillator.



The device also acts as a versatile peripheral, able to drive displays, motors, relays, and solenoids within its output limitations.
The AY0438-l is available in 40 lead dual-in-line ceramic and plastic packages. Unpackaged dice are also available.

| PIN DESCRIPTION |  | Name | Direction |
| :---: | :---: | :--- | :--- |

FIGURE 1 TIMING DIAGRAM


## OPERATING NOTES

1. The shift register loads, shifts, and outputs on the falling edge of the clock.
2. A logic 1 on Data In causes a segment to be visible.
3. A logic 1 on Load causes a parallel load of the data in the shift register into latches that control the segment drivers.
4. If $\operatorname{LCD} \Phi$ is driven, it is in phase with the backplane output.
5. To cascade units, either connect backplane of one circuit to LCD $\Phi$ of all other circuits (thus one capacitor provides frequency control for all circuits) or connect LCD $\Phi$ of all circuits to a common driving signal. If the former is chosen, tie just one backplane to the LCD and use a different backplane output to drive the LCD $\Phi$ inputs. The data can be loaded to all circuits in parallel or else Data Out can be connected to Data In to form a long serial shift register.
6 The supply voltage of the AY04381 is equal to half the peak driving voltage of the LCD.
6. The LCD $\Phi$ pin can be used in two modes, driven or oscillating. If LCD $\Phi$ is driven, the circuit will sense this

FIGURE 2 OSCILLATOR FREQUENCY GRAPH (TYPICAL @ $\mathbf{2 5}^{\circ} \mathrm{C}$ )

condition and pass the LCD $\Phi$ input to the backplane output. If the LCDФ pin is allowed to oscillate, its frequency is inversely proportional to capacitance and the LCD drivingwaveforms have a frequency $2^{8}$ slower than the oscillator itself. The relationship is shown graphically (see Figure 2). The frequency is nearly independent of supply voltage. If LCD $\Phi$ is oscillating, it is important to keep coupling capacitance to backplane and segments as low as possible. Similarly, it is recommended that the load capacitance on LCDФ be as large as is practical.
8. There are two obvious signal races to be avoided in this circuit, (1) changing Data In when the clock is falling, and (2) changing Load when the clock is falling.
9. The number of a segment corresponds to how many pulses have occurred since its data was present at the input. For example, the data on SEG 17 was input 17 clock pulses earlier.
10. It is acceptable to tie the load line high. In this case the latches are transparent. Also, remote control would only require two signal lines, clock and Data In.

## ELECTRICAL CHARACTERISTICS

Maximum Ratings*
Vdo. -0.3 V to +12 V
Inputs (CLK, Data In, Load) ............. Vcc to VDD +0.3 V
LCD $\Phi$ Input $\qquad$ 0.3 V to $\mathrm{VDD}+0.3 \mathrm{~V}$

Power Dissipation $\qquad$ 250 mW
Storage Temperature $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Operating Temperature Industrial $\qquad$ $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
*Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied. Operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Data labeled "typical" is presented for design guidance only and is not guaranteed.

| $V_{D D}=+5 \mathrm{~V}$ unless otherwise noted <br> DC CHARACTERISTICS $T \mathrm{~A}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristics | Sym | Min | Typ | Max | Units | Conditions |
| Supply Voltage | VDD | +3.0 | - | +10.5 | V |  |
| Supply Current | IDD |  | $\begin{aligned} & 25 \\ & 13 \end{aligned}$ | $\begin{aligned} & 60 \\ & 30 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \text { LCD } O S C<15 \mathrm{kHz} \\ & \text { LCD } \text { OSC < } 100 \mathrm{~Hz} \end{aligned}$ |
| Input High Level <br> Input Low Level Clock, Data, Input Leakage Current Load Input Capacitance | VIH <br> VIL1 <br> VIL2 <br> IL <br> Cl | $\begin{gathered} 0.5 \mathrm{VDD} \\ 0 \\ 0 \\ - \end{gathered}$ | $\begin{gathered} - \\ - \\ - \\ 0.01 \end{gathered}$ | $\begin{gathered} \text { VDD } \\ +0.6 \\ +1.0 \\ \pm 10 \\ 5.0 \end{gathered}$ | $\begin{gathered} \mathrm{V} \\ \mathrm{~V} \\ \mathrm{~V} \\ \mu \mathrm{~A} \\ \mathrm{pF} \end{gathered}$ | $\begin{aligned} & \mathrm{VDD}=+3.0 \mathrm{~V} \\ & \mathrm{VDD}=+10.5 \mathrm{~V} \\ & \mathrm{VIN}=0 \mathrm{~V} \text { and }+5.0 \mathrm{~V} \\ & \mathrm{VDD}=+5.0 \mathrm{~V} \end{aligned}$ |
| Segment Output Voltage | Vон Vol | $\begin{gathered} 0.8 \mathrm{VDD} \\ 0 \end{gathered}$ |  | $\begin{gathered} \text { VDD } \\ 0.1 V_{D D} \end{gathered}$ | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-100 \mu \mathrm{~A} \\ & \mathrm{IOL}=100 \mu \mathrm{~A} \end{aligned}$ |
| LCD¢ Input High Level | VIn | 0.9 VdD | - | VDD | v |  |
| LCDФ Input Low Level <br> LCDФ Input Leakage Current Level |  | 0 | - | $\begin{gathered} 0.1 \mathrm{VDD} \\ 10 \end{gathered}$ | V <br> $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VIN}=0 \mathrm{~V} \text { and }+5.0 \mathrm{~V} \\ & \mathrm{VDD}=+5.0 \mathrm{~V} \end{aligned}$ |


| AC CHARACTERISTICS |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| Characteristics | Sym | Min | Typ | Max | Units | Conditions |
| Clock Rate | f | DC | - | 1.5 | MHz | $50 \%$ duty cycle |
| Data Set-up Time | tds | 150 | - | - | nsec | Data change to Clk <br> falling edge |
| Data Hold Time | tdh | 50 | - | - | nsec |  |
| Load Pulse Width | tpw | 175 | - | - | nsec |  |
| Data Out Prop. Delay | tpd | - | - | 500 | nsec | $\mathrm{CL}=55 \mathrm{pF}$ |

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS



## SECTION 6 <br> DIGITAL SIGNAL PROCESSING PRODUCT SPECIFICATIONS

DSP Product Portfolio ..... 6- 1DSP320C10
DSP320C10CMOS Digital Signal Processor (B Version)6- 5
Development Tools ..... 6-23

## DSP Product Portfolio

COMMERCIAL DSP ( $0^{\circ}$ TO $70^{\circ}$ )

| CMOS DSP - COMMERCIAL ( $0^{\circ}$ TO $70^{\circ}$ ) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Microchip Part Number | Speed (MHz) / <br> TI Part Number | Maximum Instruction Cycle Time (ns) | Internal Mask ROM Version Available | Package |
| DSP320C10-32/P | 15.0 to 32.8 | 122 | X | 40L Plastic DIP |
| DSP320C10-32/L | 15.0 to 32.8 | 122 | X | 44L PLCC |
| DSP320C10-25/P | $\begin{aligned} & \hline 15.0 \text { to } 25.6 / \\ & \text { TMS320C } 10 \mathrm{NL}-25 \end{aligned}$ | 156 | X | 40L Plastic DIP |
| DSP320C10-25/L | $\begin{aligned} & 15.0 \text { to } 25.6 / \\ & \text { TMS320C10FNL-25 } \end{aligned}$ | 156 | X | 44L PLCC |
| DSP320C10/P | $\begin{aligned} & 6.7 \text { to } 20.5 \mathrm{I} \\ & \text { TMS320C } 10 \mathrm{NL} \end{aligned}$ | 195 | X | 40L Plastic DIP |
| DSP320C10/L | $\begin{aligned} & 6.7 \text { to } 20.51 \\ & \text { TMS320C10FNL } \end{aligned}$ | 195 | X | 44LPLCC |
| DSP320C10-14/P | $\begin{aligned} & \text { 6.7 to } 14.4 / \\ & \text { TMS } 320 \mathrm{C} 10 \mathrm{NL}-14 \end{aligned}$ | 277 | X | 40 L Plastic DIP |
| DSP320C10-14/L | 6.7 to 14.4 | 277 | X | 44LPLCC |

INDUSTRIAL DSP $\left(-45^{\circ} \mathrm{TO}+85^{\circ} \mathrm{C}\right)$

| CMOS DSP - INDUSTRIAL ( $-45^{\circ} \mathrm{TO}+85^{\circ} \mathrm{C}$ ) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Microchip Part Number | Speed (MHz) / <br> TI Part Number | Maximum Instruction Cycle Time (ns) | Internal Mas ROM Version Available | Package |
| DSP320C10-321/P | 15.0 to 32.8 | 122 | X | 40L Plastic DIP |
| DSP320C10-32/L | 15.0 to 32.8 | 122 | X | 44L PLCC |
| DSP320C10-251/P | $\begin{aligned} & \hline 15.0 \text { to } 25.6 / \\ & \text { TMS } 320 \mathrm{C} 10 \mathrm{NA}-25 \end{aligned}$ | 156 | X | 40L Plastic DIP |
| DSP320C10-251/L | $\begin{aligned} & 15.0 \text { to } 25.6 / \\ & \text { TMS320C10FNA-25 } \end{aligned}$ | 156 | X | 44L PLCC |
| DSP320C10I/P | $\begin{aligned} & 6.7 \text { to } 20.5 / \\ & \text { TMS320C10NA } \end{aligned}$ | 195 | X | 40L Plastic DIP |
| DSP320C101/L | $\begin{aligned} & 6.7 \text { to } 20.51 \\ & \text { TMS320C10FNA } \end{aligned}$ | 195 | X | 44L PLCC |
| © 1990 Microchip Technology Inc. |  | 6-1 |  | DS21025 |

## DIGITAL SIGNAL PROCESSORS

MILITARY DSP $\left(-55^{\circ}\right.$ TO $\left.+110^{\circ} \mathrm{C}\right)$
Please refer to the "MILITARY DATA BOOK"

| CMOS DSP - MILITARY (-55 ${ }^{\circ} \mathrm{TO}+125^{\circ} \mathrm{C}$ ) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Microchip | DESC SMD <br> Part Number | Speed (MHz) <br> Part Number <br> Number | Maximum TI Part Cycle Time (ns) | Package Instruction | Lead <br> Finish | Internal <br> Masked ROM <br> Version |
| DSP320C10-B/QA | 5962-8763301QA | 6.7 to 20.5 SMJ320C10JDM | 195 | 40L Ceramic <br> Side-Braze | Solder | - |
| DSP320C10-B/QC | 5692-8763301QC | 6.7 to 20.5 | 195 | 40L Ceramic Side-Braze | Gold | - |
| DSP320C10-B/UA | 5962-8763301XA | 6.7 to 20.5 SMJ320C10FDM | 195 | 44 Terminal LCC | Solder | - |
| DSP320C10-B/UC | 5692-8763301XC | 6.7 to 20.5 | 195 | 44 Terminal LCC | Gold | - |
| DSP320C10-25B/QA | 5962-8763302QA | 15.0 to 25.6 | 156 | 40L Ceramic Side-Braze | Solder | - |
| DSP320C10-25B/QC | 5962-8763302QC | 15.0 to 25.6 | 156 | 40L Ceramic Side-Braze | Gold | - |
| DSP320C10-25B/UA | 5692-8763302XA | 15.0 to 25.6 | 156 | 44 Terminal LCC | Solder | - |
| DSP320C10-25B/UC | 5962-8763302XC | 15.0 to 25.6 | 156 | 44 Terminal LCC | Gold | - |
| DSP320CF10-25B/QA | 5962-8763305QA | 6.7 to 25.6 | 156 | 40L Ceramic Side-Braze | Solder | - |
| DSP320CF10-25B/QC | 5962-8763305QC | 6.7 to 25.6 | 156 | 40L Ceramic Side-Braze | Gold | - |
| DSP320CF10-25B/UA | 5962-8763305XA | 6.7 to 25.6 | 156 | 44 Terminal LCC | Solder | - |
| DSP320CF10-25B/UC | 5962-8763305XC | 6.7 to 25.6 | 156 | 44 Terminal LCC | Gold | - |
| DSP320CM10-B/QA | $\begin{aligned} & \text { 5962-8763303QA } \\ & X \end{aligned}$ | 6.7 to 20.5 | 195 | 40L Ceramic Side-Braze | Solder | - |
| DSP320CM10-B/QC | 5962-8763303QC | 6.7 to 20.5 | 195 | 40L Ceramic Side-Braze | Gold | X |
| DSP320CM10-B/UA | $\begin{aligned} & 5962-8763303 X A \\ & X \end{aligned}$ | 6.7 to 20.5 | 195 | 44 Terminal LCC | Solder | - |
| DSP320CM10-B/UC | 5962-8763303XC | 6.7 to 20.5 | 195 | 44 Terminal LCC | Gold | X |
| DSP320CM10-25B/QA | $\begin{aligned} & 5962-8763304 Q A \\ & X \\ & \hline \end{aligned}$ | 15.0 to 25.6 | 156 | 40L Ceramic Side-Braze | Solder | - |
| DSP320CM10-25B/QC | 5962-8763304QC | 15.0 to 25.6 | 156 | 40L Ceramic Side-Braze | Gold | X |
| DSP320CM10-25B/UA | $\begin{aligned} & 5962-8763304 X A \\ & \mathrm{X} \\ & \hline \end{aligned}$ | 15.0 to 25.6 | 156 | $44 \text { Terminal }$ LCC | Solder | - |
| DSP320CM10-25B/UC | 5962-8763304XC | 15.0 to 25.6 | 156 | 44 Terminal LCC | Gold | X |

## DIGITAL SIGNAL PROCESSORS

## MILITARY DSP (-55 ${ }^{\circ}$ TO $+110^{\circ} \mathrm{C}$ ) (CONT.)

| NMOS DSP - MILITARY (-55 $\left.{ }^{\circ} \mathrm{TO}+110^{\circ} \mathrm{C}\right)$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Microchip Part Number | DESC SMD <br> Part Number | Speed (MHz) <br> Tl Part <br> Number | Maximum Instruction Cycle Time (ns) | Package | Lead <br> Finish |
| DSP32010-B/QA | 5962-8405301QA | 6.7 to 20.0 | 200 | 40L Ceramic Side-Braze | Solder |
| DSP32010-B/QC | 5692-8405301QC | 6.7 to 20.0 | 200 | 40L Ceramic <br> Side-Braze | Gold |
| DSP32010-B/UA | 5962-8405301ZA | 6.7 to 20.0 | 200 | 44 Terminal LCC | Solder |
| DSP32010-B/UC | 5692-8405301ZX | 6.7 to 20.0 | 200 | 44 Terminal LCC | Gold |

PART NUMBERS - MILITARY (see next page for Commercial and Industrial Parts)
DSP320x10-32I/QA

*Note: $32010=$ TE (Thermally Enhanced LCC); $320 \mathrm{C} 10=$ NTE (Non-Thermally Enhanced LCC)

## PART NUMBERS - DESC SMD


*Note: The Case Outline Code is used for order entry only and will not be marked on device

## DIGITAL SIGNAL PROCESSORS

## NOTES:

Microchip

## CMOS Digital Signal Processor

## FEATURES

- 122ns instruction cycle
- 144 word on-chip data RAM
- ROM-less version - DSP320C10
- 1.5K word on-chip program ROM-DSP320CM10
- External memory expansion to a total of 4 K words at full speed
- 16-bit instruction/data word
- 32-bit ALU/Accumulator
- $16 \times 16$-bit multiply in 122 ns
- 0 to 15-bit barrel shifter
- Eight input and eight output channels
- 16-bit bidirectional data bus with a 65 Mbps transfer rate
- Interrupt with a full context save
- Signed two's complement fixed-point arithmetic
- CMOS technology
- Single 5 volt supply
- Four versions available:
-DSP320C10-14
-DSP320C10
-DSP320C10-25
-DSP320C10-32
14.4MHz Clock
20.5MHz Clock
25.6MHz Clock
32.8MHz Clock


## DESCRIPTION

The DSP320C10 is the first low power CMOS member of the Microchip Technology DSP320 family of digital signal processors, designed to support a wide range of high-speed or numeric-intensive applications. This device is a CMOS pin-for-pin compatible version of the industry standard DSP32010 digital signal processor.

The processor has been enhanced to make the Data RAM static with respect to the Reset. Also, the address hold time has been improved to a non-negative value.

This $16 / 32$ bit single-chip microcomputer combines the flexibility of a high-speed controller with the numerical capability of an array processor thereby offering an inexpensive alternative to multichip bit-slice processors. The DSP320 family contains MOS microcomputers capable of executing eight million instructions per second. This high throughput is the result of the comprehensive, efficient, and easily programmed instruction set and of the highly pipelined architecture. Special instructions have been incorporated to speed the execution of digital signal processing (DSP) algorithms.
The DSP320 family's unique versatility and power give the design engineer solutions to a variety of complicated applications. In addition, these microcomputers are capable of providing the multiple functions often required for a single application. For example, the DSP320 family can enable an industrial robot to synthesize and recognize speech, sense objects with radar or optical intelligence, and perform mechanical operations through digital servo loop computations.

PIN CONFIGURATION
Top View



PIN DESCRIPTIONS

| Name | I/O | Definition | Name | I/O | Definition |
| :--- | :---: | :--- | :--- | :--- | :--- |
| A11-AO/ | OUT | External address bus. I/O port address | MC/MP | IN | Memory mode select: High selects microcom- <br> Puter, low selects microprocessor mode. |
| PA2-PAO |  | multiplexed over PA2-PAO. <br> BIO | IN | External polling input for bit test and jump <br> operations. | $\overline{\text { MEN }}$ |

## ARCHITECTURE

The DSP320 family utilizes a modified Harvard architecture for speed and flexibility. In a strict Harvard architecture, program and data memory lie in two separate spaces, permitting a full overlap of the instruction fetch and execution. The DSP320 family's modification of the Harvard architecture allows transfers between program and data spaces, thereby increasing the flexibility of the device. This modification permits coefficients stored in program memory to be read into the RAM, eliminating the need for a separate coefficient ROM. It also makes available immediate instructions and subroutines based on computed values.

The DSP320C10 utilizes hardware to implement functions that other processors typically perform in software. For example, this device contains a hardware multiplier to perform a multiplication in a single 122ns cycle. There is also a hardware barrel shifter for shifting data on its way into the ALU. Finally, extra hardware has been included so that auxiliary registers, which provide indirect data RAM addresses, can be configured in an auto increment/decrement mode for single-cycle manipulation of data tables. This hardware-intensive approach gives the design engineer the type of power previously unavailable on a single chip.

## 32-bit ALU/Accumulator

The DSP320C10 contains a 32-bit ALU and accumulator that support double-precision arithmetic. The ALU operates on 16 -bit words taken from the data RAM or derived from immediate instructions. Besides the usual arithmetic instructions, the ALU can perform Boolean operations, providing the bit manipulation ability required of a high-speed controller.

## Shifters

A barrel shifter is available for left-shifting data 0 to 15 places before it is loaded into, subtracted from, or added to the accumulator. This shifter extends the high-order bit of the data word and zero-fills the low-order bits for two's complement arithmetic A second shifter left-shifts the upper half of the accumulator 0,1 , or 4 places while it is being stored in the data RAM. Both shifters are very useful for scaling and bit extraction.

## $16 \times 16$-bit Parallel Multiplier

The DSP320C10's multiplier performs a $16 \times 16$-bit, two's complement multiplication in one 122 ns instruction cycle. The 16-bit T Register temporarily stores the multiplicand; the P Register stores the 32 -bit result. Multiplier values either come from the data memory or are derived immediately from the MPYK (multiply immediate) instruction word. The fast on-chip multiplier allows the DSP320C10 to perform such fundamental operations as convolution, correlation, and filtering at a very high rate.

## Program Memory Expansion

The DSP320C10 is equipped with a 1536 -word ROM which can be mask-programmed at the factory with a customer's program. It can also execute from an additional 2560 words of off-chip program memory at full speed. This memory expansion capability is especially useful for those situations where a customer has a number of different applications that share the same subroutines. In this case, the common subroutines can be stored on-chip while the application specific code is stored off-chip.
The DSP 320C10 can operate in either of the following memory modes via the MC/MP pin:
Microcomputer Mode (MC)—Instruction addresses 01535 fetched from on-chip ROM. Those with addresses 1536-4095 fetched from off-chip memory at full speed.
Microprocessor Mode ( $\overline{\text { MP }}$ )—Full speed execution from all 4096 off-chip instruction addresses.
The ability of the DSP320C10 to execute at full speed from off-chip memory provides important benefits:

- Easier prototyping and development work than is possible with a device that can address only onchip ROM
- Purchase of a standard off-the-shelf product rather than a semi-custom mask-programmed device
- Ease of updating code
- Execution from external RAM
- Downloading of code from another microprocessor
- Use of off-chip RAM to expand data storage capability


## Input/Output

The DSP320C10's 16-bit parallel data bus can be utilized to perform I/O functions at burst rates of 65 million bits per second. Available for interfacing to peripheral devices are 128 input and 128 output bits consisting of eight 16 -bit multiplexed input ports and eight 16 -bit multiplexed output ports. In addition, a polling input for bit test and jump operations ( $\overline{\mathrm{BIO}}$ ) and an interrupt pin (INT) have been incorporated for multi-tasking.

## Interrupts and Subroutines

The DSP320C10 contains a four-level hardware stack for saving the contents of the program counter during interrupts and subroutine calls. Instructions are available for saving the DSP320C10's complete context. The instructions, PUSH stack from accumulator, and POP stack to accumulator permit a level of nesting restricted only by the amount of available RAM. The interrupts used in the DSP320C10 are maskable.

## INSTRUCTION SET

The DSP320C10's comprehensive instruction set supports both numeric-intensive operations, such as signal processing, and general purpose operations, such as high-speed control. The instruction set, explained in Tables 1 and 2, consists primarily of single-cycle singleword instructions, permitting execution rates of up to eight million instructions per second. Only infrequently used branch and I/O instructions are multicycle.
The DSP320C10 also contains a number of instructions that shift data as part of an arithmetic operation. These all execute in a single cycle and are very useful for scaling data in parallel with other operations.
Three main addressing modes are available with the DSP320C10 instruction set: direct, indirect, and immediate addressing.

## Direct Addressing

In direct addressing, seven bits of the instruction word concatenated with the data page pointer form the data memory address. This implements a paging scheme in which the first page contains 128 words and the second page contains 16 words. In a typical application, infrequently accessed variables, such as those used for servicing an interrupt, are stored on the second page. The instruction format for direct addressing is shown below.


Bit $7=0$ defines direct addressing mode. The opcode is contained in bits 15 through 8. Bits 6 through 0 contain data memory address.
The seven bits of the data memory address (DMA) field can directly address up to 128 words (1 page) of data memory. Use of the data memory page pointer is required to address the full 144 words of data memory.
Direct addressing can be used with all instructions requiring data operands except for the immediate operand instructions.

## Indirect Addressing

Indirect addressing forms the data memory from the least significant eight bits of one of two auxiliary registers, AR0 and AR1. The auxiliary register pointer (ARP) selects the current auxiliary register. The auxiliary registers can be automatically incremented or decremented in parallel with the execution of any indirect instruction to permit single-cycle manipulation of data tables. The instruction format for indirect addressing is as follows:


Bit7 = 1 defines indirect addressing mode. The opcode is contained in bits 15 through 8 . Bits 7 through 0 contain indirect addressing control bits.
Bit 3 and bit 0 control the Auxiliary Register Pointer (ARP). If bit $3=0$, then the content of bit 0 is loaded into the ARP. If bit $3=1$, then content of ARP remain unchanged. ARP $=0$ defines the contents of ARO as memory address. ARP $=1$ defines the contents of AR1 as memory address.
Bit 5 and bit 4 control the auxiliary registers. If bit $5=1$, then the ARP defines which auxiliary register is to be incremented by 1 . If bit $4=1$, then the ARP defines which auxiliary register is to be decremented by 1 . If bit 5 or bit 4 are zero, then neither auxiliary register is incremented or decremented. Bits 6, 2 and 1 are reserved and should always be programmed to zero.
Indirect addressing can be used with all instructions requiring data operands, except for the immediate operand instructions.

## Immediate Addressing

The DSP320C10 instruction set contains special "immediate" instructions. These instructions derive data from part of the instruction word rather than from the data RAM. Some very useful immediate instructions are multiply immediate (MPYK), load accumulator immediate (LACK), and load auxiliary register immediate (LARK).

## INSTRUCTION SET SUMMARY

| TABLE 1 - INSTRUCTION SYMBOLS |  |
| :--- | :--- |
| Symbol | Meaning |
| ACC | Accumulator |
| D | Data memory address field |
| I | Addressing mode bit |
| K | Immediate operand field |
| PA | 3-bit port address field |
| R | 1-bit operand field specifying auxiliary register |
| S | 4-bit left-shift code |
| X | 3-bit accumulator left-shift field |

TABLE 2 - ACCUMULATOR INSTRUCTIONS

| Mnemonic | Description | Number of Cycles Words |  | OpCode - Instruction Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 15 |  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ABS | Absolute value of accumulator | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| ADD | Add to accumulator with shift | 1 | 1 | 0 | 0 | 0 | 0 | $\longleftarrow$ | - | S |  | 1 |  |  |  |  |  |  |  |
| ADDH | Add to high-order accumulator bits | ts | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |  |  |  | D |  |  |  |
| ADDS | Add to accumulator with no sign extension | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | $\leftarrow$ |  |  | D |  |  |  |
| AND | AND with accumulator | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 |  |  |  | D |  |  |  |
| LAC | Load accumulator with shift | 1 | 1 | 0 | 0 | 1 | 0 | $\longleftarrow$ | - | S |  | 1 |  |  |  | D |  |  |  |
| LACK | Load accumulator immediate | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |  |  |  |  |  |  |  |  |
| OR | OR with accumulator | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |  |  |  | D |  |  |  |
| SACH | Store high-order accumulator bits with shift | 1 | 1 | 0 | 1 | 0 | 1 | 1 | $\stackrel{ }{ }$ | - X |  | 1 |  |  |  | D |  |  |  |
| SACL | Store low-order accumulator bits | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 |  |  |  | D |  |  |  |
| SUB | Subtract from accumulator with shift | 1 | 1 | 0 | 0 | 0 | 1 | $\leftarrow$ |  | S |  | I |  |  |  | D |  |  |  |
| SUBC | Conditional subtract (for divide) | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | , |  |  |  | D |  |  |  |
| SUBH | Subtract from high-order | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | , |  |  |  | D |  |  |  |
| SUBS | Subtract from accumulator with no sign extension | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | I |  |  |  | D |  |  |  |
| XOR | Exclusive OR with accumulator | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | , |  |  |  | D |  |  |  |
| ZAC | Zero accumulator | , | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |
| ZALH | Zero accumulator and load high-order bits | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 |  |  |  |  |  |  |  |
| ZALS | Zero accumulator and load low-order bits with no sign extension | 1 | 1 | 0 |  | 1 | 0 |  |  | 1 | 0 | 1 |  |  |  | D |  |  |  |

## INSTRUCTION SET SUMMARY (CONT.)

| TABLE 2 (CONT.) - AUXILIARY REGISTER AND DATA PAGE POINTER INSTRUCTIONS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Description | Number of Cycles Words |  | OpCode - Instruction Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | 15 |  | 413 | 312 | 211 | 110 | 09 |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| LAR | Load auxiliary register | 1 | 1 | 0 |  | 1 | 1 | 11 | 0 | 0 |  | R | 1 |  |  |  | D |  |  |  |
| LARK | Load auxiliary register immediate | 1 | 1 | 0 |  | 1 | 1 | 0 | 0 | 0 |  | R |  |  |  |  |  |  |  |  |
| LARP | Load auxiliary register pointer immediate | 1 | 1 | 0 |  | 1 | 0 | - 1 | 0 | 0 |  | 0 | 1 | 0 | 0 | 0 |  | 0 | 0 | K |
| LDP | Load data memory page pointer | 1 | 1 | 0 |  | 1 | 0 |  | 1 | 1 |  | 1 | 1 |  |  |  |  |  |  |  |
| LDPK | Load data memory page pointer immediate | 1 | 1 | 0 |  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | K |
| MAR | Modify auxiliary register and pointer | ter | 1 | 0 |  | 1 | 0 | 0 | 0 | 0 |  | 0 | 1 |  |  |  | D |  |  |  |
| SAR | Store auxiliary register | 1 | 1 | 0 | 0 | 1 | 1 | 10 | 0 | 0 | 0 | R | 1 | $\stackrel{ }{2}$ |  |  | D |  |  |  |


| TABLE 2 (CONT.) - BRANCH INSTRUCTIONS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Description | Number of Cycles Words |  | OpCode - Instruction Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | 15 | 14 | 13 | 12 |  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| B | Branch unconditionally | 2 | 2 | 1 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $1$ | 0 | $0$ | 1 | $\stackrel{0}{\operatorname{RAN}}$ | $\begin{gathered} 0 \\ \mathrm{CH} \end{gathered}$ | $\begin{gathered} 0 \\ A D D R \end{gathered}$ | $0$ | $0$ | $0$ |  | 0 |
| BANZ | Branch on auxiliary register not zero | 2 | 2 | 1 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $0$ | $1$ |  | 0 | $\begin{gathered} 0 \\ 0 \\ \text { RAN } \end{gathered}$ |  | $\begin{gathered} 0 \\ \text { ADD } \end{gathered}$ | BESS | 0 | $0$ |  | 0 |
| BGEZ | Branch if accumulator $\geq 0$ | 2 | 2 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \leftarrow \end{aligned}$ |  |  | 1 | $\begin{gathered} 0 \\ \text { RAN } \end{gathered}$ | $\begin{gathered} 0 \\ \mathrm{CH} \end{gathered}$ | $0$ | O | 0 | $0$ |  | 0 |
| BGZ | Branch if accumulator $>0$ | 2 | 2 |  | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \leftarrow \end{aligned}$ | $1$ | $0$ | 0 | $\begin{gathered} 0 \\ \text { RAN } \end{gathered}$ | $\begin{gathered} 0 \\ \mathrm{CH} \end{gathered}$ | $0$ | $0$ | 0 | $0$ |  | 0 |
| BIOZ | Branch on $\overline{\mathrm{BIO}}=0$ | 2 | 2 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & \leftarrow \end{aligned}$ |  |  | - | $\begin{array}{r} 0 \\ \text { RAN } \end{array}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{CH} \mathrm{C} \end{gathered}$ | $\begin{aligned} & 0 \\ & A D D F \end{aligned}$ | $0$ | $0$ | $0$ |  | 0 |
| BLEZ | Branch if accumulator $\leq 0$ | 2 | 2 |  | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \leftarrow \end{aligned}$ |  | $1$ | 1 | $\begin{gathered} 0 \\ \text { RAN } \end{gathered}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{CH} \end{gathered}$ | $0$ | $\begin{gathered} 0 \\ \text { RESS } \end{gathered}$ | $0$ | $0$ |  | 0 |
| BLZ | Branch if accumulator < 0 | 2 | 2 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \leftarrow \end{aligned}$ |  |  | ${ }^{0}$ | $\begin{gathered} 0 \\ \text { RAN } \end{gathered}$ | $\begin{gathered} 0 \\ \mathrm{CH} \end{gathered}$ | $\stackrel{0}{9 D D F}$ | ${ }_{\text {BESS }}^{0}$ | 0 | $0$ |  | 0 |
| BNZ | Branch if accumulator $\neq 0$ | 2 | 2 | 1 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \leftarrow \end{aligned}$ |  |  | 0 | $\begin{gathered} 0 \\ \text { RAN } \end{gathered}$ | $\begin{gathered} \mathrm{O} \\ \mathrm{CH} \end{gathered}$ | $0$ | $0$ | 0 | $0$ |  | 0 |
| BV | Branch on overflow | 2 | 2 | 1 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ |  |  |  | 1 | $\begin{gathered} 0 \\ \text { RAN } \end{gathered}$ | $\begin{gathered} 0 \\ \mathrm{CH} \end{gathered}$ | $0$ | $0$ | $0$ | $0$ |  | 0 |
| BZ | Branch if accumulator $=0$ | 2 | 2 | 1 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \leftarrow \end{aligned}$ |  |  | 1 | - | O | $0$ | RESS- | 0 | $0$ |  | 0 |
| CALA | Call subroutine from accumulator | 2 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 |
| CALL | Call subroutine immediately | 2 | 2 | 1 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | 1 |  |  |  | 0 | $\stackrel{0}{ }$ | 0 | $\stackrel{0}{0}$ | $0$ | $0$ | $0$ | $\xrightarrow{0}$ | 0 |
| RET | Return from subroutine or interrupt routine | 2 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |

INSTRUCTION SET SUMMARY (CONT.)

| Mnemonic | Description C | Number of Cycles Words |  | OpCode - Instruction Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 15 |  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| APAC | Add P register to accumulator | 1 | , | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| LT | Load T register | 1 | 1 |  | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 |  |  |  | D |  |  |  |
| LTA | LTA combines LT and APAC into one instruction | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | $\leftarrow$ |  | - | D |  |  |  |
| LTD | LTD combines LT, APAC, and DMOV into one instruction | 1 | 1 |  | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | $\stackrel{ }{2}$ |  |  | D | - |  |  |
| MPY | Multiply with T register, store product in P register | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 |  |  |  | D |  |  | $\longrightarrow$ |
| MPYK | Multiply T register with immediate operand; store product in P register | 1 | 1 |  | 0 | 0 |  |  |  |  |  |  | K |  |  |  |  |  |  |
| PAC | Load accumulator from P register | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |  | 1 | 1 | 0 |
| SPAC | Subtract $P$ register from accumulator | $1$ | 1 | 0 | 1 | 1 |  |  | 1 | 1 | 1 | 1 |  | 0 | 1 | 0 | 0 | 0 | 0 |


| TABLE 2 (CONT.) - CONTROL INSTRUCTIONS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Description | Number of Cycles Words |  | OpCode - Instruction Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | 15 | 1413 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DINT | Disable interrupt | 1 | 1 | 0 | 11 | , | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| EINT | Enable interrupt | 1 | 1 | 0 | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
| LST | Load status register | 1 | 1 | 0 | 11 | 1 | 1 | 0 | 1 | 1 | , | $\stackrel{ }{2}$ |  |  | D | - | - | $\rightarrow$ |
| NOP | No operation | 1 | 1 | 0 | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| POP | POP stack to accumulator | 2 | 1 | 0 | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | , | 0 | 1 |
| PUSH | PUSH stack from accumulator | 2 | 1 | 0 | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 |  | 0 | 0 |
| ROVM | Reset overflow mode | 1 | 1 | 0 | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 |
| SOVM | Set overflow mode | 1 | 1 | 0 | 11 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 |
| SST | Store status register | 1 | 1 | 0 | 11 | 1 | 1 | 1 | 0 | 0 | 1 |  |  |  | D |  |  |  |

TABLE 2 (CONT.) - I/O AND DATA MEMORY OPERATIONS

| Mnemonic | Description | Number of Cycles Words |  | OpCode - Instruction Register |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 15 | 14 | 13 | 12 | 11 | 10 | 0 |  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DMOV | Copy contents of data memory |  | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 0 |  | 1 | 1 | $\leftarrow$ |  |  | D |  |  |  |
| IN | Input data from port | 2 | 1 | 0 | 1 | 0 | 0 | 0 | $\leftarrow$ | PA |  | $\rightarrow$ | 1 | $\stackrel{ }{2}$ |  |  | D |  |  |  |
| OUT | Output data to port | 2 | 1 | 0 | 1 | 0 | 0 | 1 | $\leftarrow$ | -PA |  |  | 1 |  |  |  | D |  |  |  |
| TBLR | Table read from program memory to data RAM | 3 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |  | 1 | 1 | $\leftarrow$ |  |  | D |  |  | $\longrightarrow$ |
| TBLW | Table write from data RAM to program (external only) | 3 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 |  | 1 | 1 |  |  |  | D |  |  |  |

## ELECTRICAL CHARACTERISTICS

Absolute Maximum Ratings*Over specified temperature range (unless otherwisenoted)**Supply voltage, Vcc-0.3 V to 7 V
All input voltages ..... -0.3 V to 7 V
Output voltage ..... -0.3 V to 7 V
Continuous power dissipation:
DSP320C10 ( $0^{\circ}$ to $+70^{\circ} \mathrm{C}$ ) ..... 0.3W
DSP320C101 ( $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ ) ..... 0.36W
DSP320C10-25 ( $0^{\circ}$ to $+70^{\circ} \mathrm{C}$ ) ..... 0.35W
DSP320C101-25 ( $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ ) ..... 0.4 W
Air temperature range above operating device:

- Commercial ..... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
- Industrial $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
Storage Temperature Range $-55^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$Junction Temperature (TJ)$.165^{\circ} \mathrm{C}$
**Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied - operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

Data labeled "typical" is presented for design guidance only and is not guaranteed.


## DSP320C10

## PARAMETER MEASUREMENT INFORMATION

FIGURE 2 - TEST LOAD CIRCUIT


TTL Load Condition
figure 3 - AC timing Voltage reference levels
a. Inputs, TTL compatible

b. Outputs, TTL compatible


## DSP320C10

## CLOCK

The DSP320C10 can use either its internal oscillator or an external frequency source for a clock.

## INTERNAL CLOCK OPTION

The internal oscillator is enabled by connecting a crystal across X1 and X2/CLKIN (See Figure 1). The frequency of CLKOUT is one-fourth the crystal fundamental frequency.

## FIGURE 1 - INTERNAL CLOCK OPTION



The crystal should be fundamental mode, and parallel resonant, with an effective series resistance of 30 ohms, a power dissipation of 1 mW , and be specified at a load capacitance of 20 pF .

## EXTERNAL CLOCK OPTION

An external frequency source can be used by injecting the frequency directly into X2/CLKIN with X1 left unconnected.

The external frequency injected must conform to the specifications listed in the table below.

| CLOCK FREQUENCIES |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristics | Sym | Min | Nom | Max | Unit | Temperature <br> Range Conditions |
| DSP320C10 Crystal frequency | fx | 6.7 | - | 20.5 | MHz | $\mathrm{I}, \mathrm{C}$ |
| DSP320C10-14 Crystal frequency | fx | 6.7 | - | 14.4 | MHz | $\mathrm{I}, \mathrm{C}$ |
| DSP320C10-25 Crystal frequency | fx | 6.7 | - | 25.6 | MHz | $\mathrm{I}, \mathrm{C}$ |
| DSP320C10-32 Crystal frequency | fx | 6.7 | - | 32.8 | MHz | $\mathrm{I}, \mathrm{C}$ |
| C1,C2 |  | - | 10 | - | pf | $\mathrm{I}, \mathrm{C}$ |

## CLOCK (CONT.)

| CLOCK AC CHARACTERISTICS <br> Timing requirements/Switching Characteristics over Recommended Operating Conditions |  |  |  |  |  |  |  |  |  |  | $\begin{aligned} & \mathrm{TA}(\text { Commercial })=0^{\circ} \text { to } 70^{\circ} \mathrm{C} \\ & \mathrm{TA}(\text { Industrial })=-40^{\circ} \text { to } 85^{\circ} \mathrm{C} \\ & \mathrm{VCC}=5 \mathrm{~V}+10 \%, \mathrm{VSS}=0 \mathrm{~V} \end{aligned}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | DSP320C10 |  |  | DSP320C10-14 |  |  | DSP320C10-25 |  |  | DSP320C10-32 |  |  |  |  |
| Characteristics | Sym | Min | Nom | Max | Min | Nom | Max | Min | Nom | Max | Min | Nom | Max | Unit | Conditions |
| Master clk cycle time | Tc(MC) | 48.78 | - | 150 | 69.50 | - | 150 | 39 | - | 150 | 30.5 | - | 150 | ns | Note 1 |
| Rise time mast. clk in. | $\operatorname{Tr}(\mathrm{MC})$ | - | 5 | 10* | - | 5 | 10* | - | 4 | 8* | - | 3 | $6{ }^{*}$ | ns |  |
| Fall time mast. clk in. | Tf(MC) | - | 5 | 10* | - | 5 | 10* | - | 4 | $8^{*}$ | - | 3 | $6^{*}$ | ns |  |
| Pulse dur. mast. clk low, $\mathrm{Tc}(\mathrm{MC})=70 \mathrm{~ns}$ | Tw(MCL) | $14^{*}$ | 20 | - | 14* | 20 | - | 12* | 16 | - | 8* | 12 | - | ns |  |
| Pulse dur. mast clk high, $\mathrm{Tc}(\mathrm{MC})=70 \mathrm{~ns}$ | Tw(MCH) | 14* | 20 | - | 14* | 20 | - | 12* | 16 | - | 8* | 12 | - | ns |  |
| Pulse dur. mast clk | Tw(MCP) | $0.4 \mathrm{Tc}(\mathrm{C})^{*}$ | - | $0.6 \mathrm{Tc}(\mathrm{C})^{*}$ | $0.4 \mathrm{Tc}(\mathrm{C})^{*}$ | - | $0.6 \mathrm{Tc}(\mathrm{C})^{*}$ | $0.45 \mathrm{Tc}(\mathrm{C})^{*}$ | - | $0.55 \mathrm{Tc}(\mathrm{C})^{*}$ | $0.45 \mathrm{Tc}(\mathrm{C})^{*}$ | - | $0.55 \mathrm{TC}(\mathrm{C})^{*}$ | ns |  |
| CLKOUT cycle time CLKOUT rise time CLKOUT fall time | $\begin{aligned} & \mathrm{T}_{\mathrm{c}}(\mathrm{C}) \\ & \mathrm{Tr}(\mathrm{C}) \\ & \mathrm{T}_{\mathrm{f}}(\mathrm{C}) \end{aligned}$ | $195.12$ | $\begin{gathered} - \\ 10 \\ 8 \end{gathered}$ |  | $277.80$ | $\begin{gathered} - \\ 10 \\ 8 \end{gathered}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ | $156$ | $\begin{aligned} & - \\ & 10 \\ & 8 \end{aligned}$ |  | $122$ | - 4 7 | $-$ | ns ns ns | See Fig 2 |
| Pls. dur., CLKOUT low | Tw(CL) | - | 92 | - | - | 131 | - | - | 74 | - | - | 57 | - | ns |  |
| Pls.dur., CLKOUT high | Tw(CH) | - | 90 | - | - | 129 | - | - | 72 | - | - | 54 | - | ns |  |
| Delay time to CLKIN $\uparrow$ to CLKOUT $\downarrow$ (Note 2) | Td(MCC) | 10 | - | 60 | 10 | - | 60 | 10 | - | 50 | 10 | - | 50 | ns |  |
| Note: <br> (1) $\operatorname{TC}(\mathrm{C})$ is <br> (2) *These |  | the cycle values we | time <br> re de | of CLKO <br> erived fro | OUT. i.e., chara |  | (MC) (4 <br> ation dat | times CL a and are | KIN <br> not | cycle time tested or | e if an ext guarante | ternal ed. | oscillator | $r$ is $u$ | used) |

## CLOCK TIMING



* TD(MCC) and TW(MCP) are referenced to an intermediate level of 1.5 volts on the CLKIN waveform. Note: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

MEMORY AND PERIPHERAL INTERFACE TIMING

| MEMORY AND PERIPHERAL INTERFACE - AC CHARACTERISTICS <br> Over recommended operating conditions |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristics | Sym | Min | Typ | Max | Unit | Conditions |
| Delay time CLKOUT $\downarrow$ to address bus valid (see note) | Td 1 | $10^{*}$ | - | 38 | ns | See Figure 2 |
| Delay time CLKOUT $\downarrow$ to $\overline{\text { MEN }} \downarrow$ | Td2 | 1/4Tc(C) -5* | - | $1 / 4 \mathrm{Tc}_{( }(\mathrm{C})+12$ | ns |  |
| Delay time CLKOUT $\downarrow$ to $\overline{\text { MEN }} \uparrow$ | Td3 | $-8^{*}$ | - | 12 | ns |  |
| Delay time CLKOUT $\downarrow$ to $\overline{\text { DEN }} \downarrow$ | Td4 | 1/4Tc(C) -5* | - | 1/4Tc(C) +12 | ns |  |
| Delay time CLKOUT $\downarrow$ to $\overline{\mathrm{DEN}} \uparrow$ | Td5 | $-8^{*}$ | - | 12 | ns |  |
| Delay time CLKOUT $\downarrow$ to $\overline{W E} \downarrow$ | Td6 | 1/2Tc(C) -5* | - | 1/2Tc(C) +12 | ns |  |
| Delay time CLKOUT $\downarrow$ to $\overline{\mathrm{WE}} \uparrow$ | Td7 | $-8^{*}$ | - | 12 | ns |  |
| Delay time CLKOUT $\downarrow$ to data bus OUT valid | Td8 | - | - | $1 / 4 \mathrm{Tc}(\mathrm{C})+40$ | ns |  |
| Time after CLKOUT $\downarrow$ that data bus starts to be driven | Td9 | 1/4Tc(C) - $5^{*}$ | - | - | ns |  |
| Time after CLKOUT $\downarrow$ that data bus stops being driven | Td10 | - | - | $1 / 4 \mathrm{Tc}(\mathrm{C})+30^{*}$ | ns |  |
| Data bus OUT valid after CLKOUT $\downarrow$ | TV | 1/4Tc(C) - 10 | - | - | ns |  |
| Delay time $\overline{\mathrm{DEN}} \uparrow, \overline{\mathrm{MEN}} \uparrow$ and $\overline{\mathrm{WE}} \uparrow$ from $\overline{\mathrm{RS}} \downarrow$ | Td11 | - | - | $\mathrm{Tc}(\mathrm{C})+50^{*}$ | ns |  |
| Setup time data bus valid prior to CLKOUT $\downarrow$ | Tsu(D) | 38 | - | - | ns |  |
| Hold time data bus held valid after CLKOUT $\downarrow$ | Th(D) | 0 | - | - | ns |  |
| Address bus setup time prior to $\overline{\text { MEN }} \downarrow$ or $\overline{\mathrm{DEN}} \downarrow$ | Tsu (A-MD) | 1/4Tc(C) -35 | - | - | ns |  |
| Address bus hold after $\overline{\mathrm{WE}} \uparrow, \overline{\mathrm{MEN}} \uparrow$ or $\overline{\mathrm{DEN}} \uparrow$ | Th(A-WMD) | 5 | - | - | ns |  |
| Address bus setup time prior to $\overline{\mathrm{WE}} \downarrow$ | Tsu(A-WE) | 1/2Tc(C) -34 | - | - | ns |  |
| Data bus setup time prior to $\overline{\mathrm{WE}} \downarrow$ | Tsu(D-WE) | 1/4Tc(C) -32 | - | - | ns |  |
| Data bus hold after $\overline{\mathrm{WE}} \uparrow$ | $\operatorname{Th}(\mathrm{D}-\mathrm{WE})$ | $1 / 4 \mathrm{Tc}(\mathrm{C})-18$ | - | - | ns |  |
| External memory access time | Tacc | - | - | Tc(C) - 69 | ns |  |
| External memory output enable time | Toe | - | - | $3 / 4 \mathrm{Tc}(\mathrm{C})-40$ | ns |  |
| *These values were derived from characterization data and are not tested. <br> Note: 1. Address bus will be valid upon $\overline{\mathrm{WE}} \uparrow, \overline{\mathrm{DEN}} \uparrow$, or $\overline{\mathrm{MEN}} \uparrow$. <br> 2. Data may be removed from the data bus upon $\overline{\mathrm{MEN}} \uparrow$ or $\overline{\mathrm{DEN}} \uparrow$ preceding CLKOUT $\downarrow$ |  |  |  |  |  |  |

## MEMORY AND PERIPHERAL INTERFACE TIMING (CONT.)



Note: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

## INSTRUCTION TIMING DIAGRAMS (CONT.)



TBLW INSTRUCTION TIMING DIAGRAM


Legend:

1. TBLW INSTRUCTION PREFETCH
2. DUMMY PREFETCH
3. ADDRESS BUS VALID
4. NEXT INSTRUCTION PREFETCH
5. INSTRUCTION IN VALID
6. ADDRESS BUS VALID
7. INSTRUCTION IN VALID
8. ADDRESS BUS VALID
9. DATA OUT VALID
10. ADDRESS BUS VALID
11. INSTRUCTION IN VALID

Note: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

## INSTRUCTION TIMING DIAGRAMS (CONT.)



OUT INSTRUCTION TIMING DIAGRAM


Note: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

## DSP320C10

## RESET (RS) TIMING

| $\begin{array}{l}\text { RESET TIMING AC CHARACTERISTICS } \\ \text { Timing requirements over recommended operating conditions }\end{array}$ |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristics | Sym | Min | Nom | Max | Unit | Conditions |
| $\begin{array}{l}\text { Reset }(\overline{\mathrm{RS}}) \text { setup time prior to } \\ \text { CLKOUT. See notes } 1-4 .\end{array}$ | Tsu $(\mathrm{R})$ | 38 | - | - | ns |  |
| DSP320C10-32 |  |  |  |  |  |  |$)$

FIGURE 4 - RESET TIMING


## Notes:

1. $\overline{\mathrm{RS}}$ forces $\overline{\mathrm{DEN}}, \overline{\mathrm{WE}}$, and $\overline{\mathrm{MEN}}$ high and tristates data bus DO through D15. AB outputs (and program counter) are synchronously cleared to zero after the next complete CLK cycle from $\overline{\mathrm{RS}} \downarrow$.
2. $\overline{\mathrm{RS}}$ must be maintained for a minimum of five clock cycles.
3. Resumption of normal program will commence after one complete CLK cycle from $\overline{\mathrm{RS}} \uparrow$.
4. Due to the synchronizing action on $\overline{\mathrm{RS}}$, time to execute the function can vary dependent upon when $\overline{\mathrm{RS}} \uparrow$ or $\overline{\mathrm{RS}} \downarrow$ occur in the CLK cycle.
5. Diagram shown is for definition purpose only. $\overline{\mathrm{DEN}}, \overline{\mathrm{WE}}$, and $\overline{\mathrm{MEN}}$ are mutually exclusive.
6. Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.
7. During a write cycle, $\overline{\mathrm{RS}}$ may produce an invalid write address.

## INTERRUPT (INT) TIMING

| INTERRUPT TIMING AC CHARACTERISTICS <br> Timing requirements over recommended operating conditions |  |  |  |  | *These values are not tested |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristics | Sym | Min | Nom | Max | Unit | Conditions |
| Fall time $\overline{\mathrm{INT}}$ | $\mathrm{T}_{\mathbf{t} \text { (INT) }}$ | - | - | 15* | ns |  |
| Pulse duration $\overline{\mathrm{INT}}$ | Tw(INT) | Tc (C) | - | - | ns |  |
| Setup time $\overline{\text { INT }} \downarrow$ before CLKOUT $\downarrow$ | Tsu(INT) | 38 | - | - | ns |  |

## INTERRUPT TIMING DIAGRAM



Note: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

## I/O (BIO) TIMING



## I/O (BIO) TIMING DIAGRAM



Note: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

## SALES AND SUPPORT

To order or to obtain information, e.g., on pricing or delivery, please use the listed part numbers, and refer to the factory or the listed sales offices.

## PART NUMBERS

DSP320C10-32I/P


# DSP320C10 DIGITAL SIGNAL PROCESSOR SUPPORT TOOLS 

The following information relates to the support tools available for Microchip's DSP320C10 Digital Signal Processor. A brief description of each tool is provided along with the availability and prices. A part number is assigned for each product and this number should be used when ordering.

For more information, please contact your local Microchip sales office. Microchip reserves the rights to change the specifications of each system without notice.

## Systems \& Tools

## Hardware Tools:

Please contact your local sales office or factory for a list of third party support products. These include in-circuit emulators, EVM boards and other plug in modules.

Software Tools:
Product Function

C10ASM A cross assembler and linker with macro capabilities for DSP320C10. Various computer systems are supported.

C10SIM A software instruction level simulator of DSP320C10. Available on various computer systems.

Please contact your local sales office or factory for a list of third party support products. These include assemblers/linkers, filter design packages and other DSP libraries.

## C10ASM (ASSEMBLER/LINKER)

## Description

This is a cross assembler which converts the source code to object code for Microchip's DSP320C10 series of 16 -bit digital signal processors. A linker is also provided for combining separately assembled modules into one or more object modules. Multiple object code format is provided and supports formats required by all other Microchip's development systems. One of the output format is 8 bit Intel hex format. Under this format two separate files with high bytes in one and low bytes in another file are produced. This eases programming 8 bit wide EPROMs.

## Functional Features

- Absolute and Relocatable addressing.
- Conditional assembly.
- Macro capability.
- External Symbol Reference.
- Multiple Object code formats.
- Combines separately assembled modules into one or more object modules.
- External Symbol resolution.
- ROM/RAM partitioning.
- Object code libraries and Multiple Object code formats.

Minimum Host Requirements :

- MS-DOS -- 512k RAM.
- VAX/VMS.

Part Number \& Ordering Information

| - C10ASM-DS | C10 Assembler/Linker for MS-DOS systems/IBM <br> compatibles |
| :--- | :--- |
| - C10ASM-VS | C10 Assembler/Linker for DEC VAX/VMS |

## C10SIM (SIMULATOR)

## Description

This is a software simulator simulating the DSP320C10 series. The simulator accepts any object code format generated by Microchip's cross assembler, and aids in debugging and testing microcode. Algorithms and software development can be executed without waiting for silicon and other hardware. Since the simulator is totally under software control, the user has a lot more control in execution of his code through complex breakpoints, trace, single stepping, viewing/modifying. Various signals, memory locations and registers can be viewed very easily. Signals can be injected or captured from/to files by redirecting the I/O port to files, and then be analyzed by other software.

## Functional Features

- Instruction Boundary Simulation
- Three execution modes ( execute until break condition, trace and single stepping).
- Flexible breakpoints : On Instruction acquisition, error conditions, data conditions and maskable memory read/write.
- Watch/modify registers and memory locations.
- 128 instruction trace buffer (can be output to a file).
- Continuous trace mode
- Symbolic debug and symbolic disassembler.
- File associated port I/O.
- Programmable interrupts.
- Friendly user interface that can constantly display registers and memory on screen.
- Input/Output Radix can be Hex, decimal or Octal.


## Part Number \& Ordering Information

NOTES:

Microchip

## SECTION 7 QUALITY AND RELIABILITY

QA Quality Without Compromise ..... 7- 1
27CxxxEPROM Plastic Package Reliability Bulletin7- 11

Microchip
$\qquad$

Microchip

## Quality Without Compromise

## A CORPORATE COMMITMENT

Raising the quality level of Microchip's products and services is a performance alliance built with customers and suppliers.

Total quality improvement and quality awareness is powered by company-wide participation.

Meeting a customer's expectations is where quality commitment begins. The resolve to continuously improve as a supplier never ends.

## THE CHALLENGE OF COMPLEXITY

## Integrating An Ideal

Microchip's quality programs and business plan are vertically integrated and touch all levels of the company. From the top down the President and CEO actively leads and audits programs to ensure continuous improvement is a perpetual process. Quality teams work from the bottom up to improve performance at every department level. Incorporating quality improvement objectives into the business plan creates a unity of purpose and mandates that the two merge as one measurement.

## Determination To Be The Best

Through statistical management and the use of statistical tools, a framework is built for becoming a continuously improving supplier. The programs put in place are to become the foundation for success.

## PROCESS TECHNOLOGY

## EEPROM Technology

Microchip's CMOS floating gate EEPROM technology produces a non-volatile memory cell by storing or removing charge from the floating gate. Charge is transferred bidirectionally to the floating gate by FowlerNordheirn tunneling through a sub-10 nm oxide over the drain of the transistor. This technology produces a memory cell with a guaranteed endurance of $>10^{4}$ which can be erased automatically and byte written in-situ in a system, all in 1 ms .

## EPROM Technology

The CMOS EPROM technology produces a non-volatile memory cell by storing or removing charge from a selfaligned floating gate. Electrons are provided to the floating gate via hot electron injection from the drain depletion region, and are removed by radiation from a high intensity UV source. This memory cell is guaranteed to have an endurance of $>100$. Programming is done off-line using an EPROM programmer and block erasing accomplished with a high intensity UV source through the package window.

## SNOS Technology

Microchip's SNOS EEPROM technology produces a non-volatile memory cell which stores or removes charge from the nitrite/oxide interface by electron tunneling through a sub- 5 nm oxide under the nitride. This cell is guaranteed to have an endurance $>10^{4}$. Individual bytes can be written in-situ in a system at 30 ms but due to layout design constraints, a circuit can only be block erased.

## Microcontroller and Logic

Logic Products use an N -well CMOS technology. Depending on functionality and/or performance requirements, however, different variations of the CMOS process are used. These include ROM, EPROM or EEPROM and use of single or double level metallization. Two levels of polysilicon are used for EPROM, EEPROM or capacitors (in analog circuits).
Oxide spacers are used to obtain DDD (Double Diffused Drains) and titanium is used for polycide formation for low resistance poly lines. The process uses a $250 \AA$ gate-oxide thickness and $550 \AA$ Anterpoly oxide thickness. Boron and Phosphorous plugs are used for N contacts and P -contacts to prevent junction spiking.

## QUALITY

## Design For Quality And Reliability

Product reliability is designed into all Microchip processes and products. Design margins are established to guarantee every product can be produced economically, error-free and within the tolerances of the manufacturing process. Design committee members representing manufacturing, engineering, quality and product divisions ensure that exacting standards are met for each specific product.

## Documentation And Procurement Specifications

Microchip's positive documentation control program assures the correct and current document always is available at the point of use. Active documents are revision coded and serialized. Procurement specifications bear the same requirements. These positive document control procedures, which are common in the industry for military and high reliability products, are employed by Microchip, system wide.

## In Line Controls And Process Assessment

Product integrity is assured by samplings and inspection plans performed in line. This enables Microchip to control and improve product quality levels as product moves through the manufacturing operation. Microchip's acceptance sampling plans in assembly emphasize the attempt to eliminate defective product as it is discovered. Acceptance and sampling plans follow MIL-STD-883C procedures where applicable.
To determine whether a process is within normal manufacturing variation, statistical techniques are put to work at selected process steps. In-process controls are performed by operators in the wafer fabrication and assembly operations. Operators take immediate corrective action if a process step is out of its control limit. Through these in-line controls the true capability of a process is assured and data to guide continuous improvement is generated. (See Appendix A - Controls)

Material controls prevent defective piece parts from getting into the line. Microchip's assembly material control sample plan is typical of the emphasis placed on safeguards. (See Appendix B-Material Controls)

## Testing For Margin

Microchip conducts a product's initial test under stringent requirements. All quality assurance tests are run to tighter limits than customer specifications. As part of an out going quality assurance program, most products are tested at least two machine tolerances tighter than those specified by the customer. Margin testing accounts for normal tolerances of any particular test system and provides customers with the assurance that Microchip's products meet a customer's specifications.

## Quality \& Reliability

## Variation From Expectation

Microchip works to make variation from target as small as possible. The better process is the one that holds the narrowest dispersion. Presently Microchip uses electrical screens to help eliminate short term failures. The long term program of total quality improvement emphasizes continuous improvement.
Individuals in all departments are encouraged to analyze the methods employed at their positions and formulate plans to improve performance. Because a customer could receive part of every mistake, definitive programs are continuously formulated at all working levels, designed to eliminate mistakes and contain error.

## Outgoing Quality

Quality Control samples all outgoing product from Microchip final testing.

## RELIABILITY

## Process Qualification

No priority is more important than the one where processes under which Microchip products are built operate without fail. Engineers labor under strict guidelines to ensure tests of sample lots are precise and reliable. Exacting internal specifications demand every product used to qualify a process endure an accelerated life test. EPROMs, EEPROMs, and Logic Products are stressed beyond normal use limits when undergoing high temperature reverse bias, operating life, and retention bake tests.

## Package Qualification

Package qualification measures a component's ability to withstand thermal and mechanical shock, temperature cycles and moisture. Stresses applied to products exceed normal parts use. All products are stressed to high level military or industrial specifications to ensure reliability.

## Ongoing Sampling Of Key Reliability Variables

Microchip conducts accelerated mechanical tests, operating life tests and memory retention tests to explore the many ways failures might occur. Data gleaned from continuous testing is used to identify potential reliability problems and for defining action courses to improve product. Microchip's reliability knowledge is shared with customers. This data is available for use in customer's own quality and reliability improvement programs.

## Quality \& Reliability

## RELIABILITY CONCEPTS

## Definition

Reliability is the probability of a system or circuit performing its predefined function adequately under specific conditions for a given period of time. Thus, the reliability of a microcircuit is a function of both stress conditions and the time of operation.
The reliability (or probability of survival) range runs from 0 (no chance of survival) to 1 (no chance of failure). Current microelectronic circuits are manufactured and controlled to such tight specifications that reliability figures for the total operation time approaching 1 (i.e., 0.9999 ) are common. As a result, the complement of reliability, or the failure probability, is more often quoted in current literature.
The failure rate is the rate at which failures occur on units surviving to a specific number of hours of operation. Failure rates per unit circuit-hour would generally be very small. To avoid reporting such small numbers, failure rates have been defined for longer periods of circuit-hours. One thousand circuit-hours is defined as one circuit operating for one thousand hours, or 1,000 circuits operating for 1 hour, etc. The number of circuithours is the number of circuits multiplied by the number of operation hours for each circuit.

Two methods of failure rate statements are commonly used:

* Percent failures per thousand circuit-hours, (represented as ${ }^{\wedge}$ ), or
* Absolute failures per $10^{9}$ circuit-hours, or Fits.

Note that a failure rate of $0.0001 \% / 1000$ hours and 1 Fit are equivalent numbers.

## Bathtub Curve: Failure Rate Over Time

The generic representational graph of failure rate vs. time takes the shape of a bathtub curve. (Figure 1).
The early failure rate (infant mortality) period starts from initial operation (time T0) and decreases as time goes on.
Time T1 signifies the end of the infant mortality period. The next phase of the curve occurs between time $\mathrm{T}_{1}$ and T2. This long period of time is distinguished by a nearly constant and very low failure rate. After T2 is passed, the failure rate starts to increase slowly. This last phase of failure rate vs. time is known as the wear-out period.

## Temperature Dependency

In order to establish failure rates in a reasonable time, it is necessary to accelerate by higher environmental stress levels, the incidence of the failure modes encountered under normal conditions. The accelerating parameter most employed is junction temperature, although voltage and humidity, for example, are also used. Higher temperatures are capable of accelerating many common failure modes dramatically.

## Arrhenius Equation

A number of mathematical models were developed to quantify the relationship between accelerated failure rates and increased junction temperatures. The one model most commonly used is known as the Arrhenius Equation. It is as follows:

$$
A F=e^{x}, \text { Where: } \quad x=\frac{E_{A}}{K}\left[\frac{1}{T_{N}}-\frac{1}{T_{A}}\right]
$$

AF = Acceleration Factor (non-dimensional)
$\mathrm{e}=2.718281828 \ldots$...(non-dimensional constant)
$E_{A}=$ Activation energy level (electron volts)
$k=$ Boltzmann's constant $=8.6172754^{*} 10^{-5}$ (elec-tron-volts/degree Kelvin)
$T_{N}=$ Normal junction temperature (degrees Kelvin)
$\mathrm{T}_{\mathrm{A}}=$ Accelerated junction temperature (degrees Kelvin)

Thus, the time to achieve a certain probability of failure at time $\mathrm{T}_{1}$ under temperature $\mathrm{T}_{N}$ can be compressed by the amount $T_{1}$ divided by AF at the accelerated temperature $T_{A}$. Note that for true acceleration, the acceleration factor AF is independent of the probability of the fail point specified.

## FIGURE 1: BATHTUB CURVE



## Activation Energy Level

The dependent variable AF in the Arrhenius Equation is a function of several variables. TN and TA are specified for the situation under consideration. EA is a function of the particular mode of failure, and can be viewed as the minimum energy required for a particular failure to occur.
Activation energy levels in semiconductors generally are in the 0.4-1.1 electron-volt range. Each failure mode that is accelerated has its own activation energy level. Some typical examples are:

| FAILURE MECHANISM | EA(eV) |
| :--- | :---: |
| Oxide/Dielectric Defects | 0.3 |
| Chemical, Galvanic, or Electrolytic | 0.3 |
| Corrosion Silicon Defect | 0.5 |
| Electromigration | 0.5 to 0.7 |
| Unknown | 0.7 |
| Broken Bonds | 0.7 |
| Lifted Die | 0.7 |
| Surface Related Contamination | 1.0 |
| Induced Shifts/ Lifted |  |
| Bonds (Au-A1 Interface) | 1.0 |
| Charge Injection | 1.3 |
| Floating Gate Charge Loss | 0.6 |
| Hot Electron Trapping | -.06 |
| Tunnel Dielectric Breakdown | 0.13 |

A compromise value of 0.7 electron-volts is often used when there are no specific a prior facts relating to the failure modes being accelerated.
There is however, a continous reliability program at Microchip structured to validate EA values in use and to categorize new failure mechanisms.

## RELIABILITY TESTS

## Operating Life Test

The Operating Life Test is run under dynamic bias conditions where inputs are clocked like a typical application and outputs are loaded in the same way as a typical application. The test is conducted at high temperature to accelerate the failure mechanisms. The normal temperature for the test is $+125^{\circ} \mathrm{C}$ for 1,000 hours. Readouts occur at 24, 168, 500 and 1,000 hours. Early hour failures are usually associated with test escapes, manufacturing defects or otherwise marginal material. Longer term failures are typically caused by metal migration, ionic contamination, and oxide breakdowns.

## High Temperature Reverse Bias (HTRB)

Microchip employs the High Temperature Reverse Bias test on floating gate devices to accelerate any charge gain onto the floating gate due to oxide defects and to accelerate threshold shifts due to ionic contamination. The test is conducted by putting the device into a special test mode whereby 7.0 volts is applied to all poly 2 structures with all source, drain and substrate held at ground. The test is conducted at $+150^{\circ} \mathrm{C}$ and is normally conducted for 1,000 hours with readouts at $24,168,500$ and 1,000 hours.

## Retention Bake

The Retention Bake Test is performed to accelerate data loss on floating gate and SNOS devices. The test consists of unbiased baking at elevated temperature. Usually the test lasts for 1,000 hours at $+150^{\circ} \mathrm{C}$. The failure mechanism that is accelerated is charge leakage from a stored element.

## Endurance Cycling

Endurance Cycling establishes the number of times a programmable device can be programmed and erased. Normally the test is conducted at worse case programming conditions and is followed by a retention bake.

## Temperature Cycle

The Temperature Cycle test simulates systems that are subject to power up/power down sequences. The test is intended to reveal any deficiencies resulting from thermal expansion mismatch of the die/package structure. Normally the test is conducted by cycling between $-65^{\circ} \mathrm{C}$ and $+150^{\circ} \mathrm{C}$ in an air ambient. Duration for the test is normally 1,000 cycles for plastic and 100 cycles for ceramic packages. Endpoint criteria is both electrical and mechanical.

## RELIABILITY TESTS (CONT.)

## Thermal Shock

The Thermal Shock test is similar to the Temperature Cycle test except that the ambient during cycling is liquid-to-liquid which simulates rapid environment changes. The mechanisms accelerated are identical to those in the Temperature Cycle test except that the Thermal Shock test is a more accelerated test with temperatures normally $+125^{\circ} \mathrm{C}$ to $-55^{\circ} \mathrm{C}$ and the number of cycles are typically 15 .

## Autoclave

The autoclave test determines the survivability of devices in molded plastic packages to a hot, humid environment. The test exposes unbiased, plastic packaged devices to saturated steam at $121^{\circ} \mathrm{C}$ and 15 pounds per square inch (one atmosphere) gauge pressure. The 168 or more hours of testing allows moisture to penetrate to the die surface. Chemical corrosion of the die metallization may occur if ionic contaminants are present and the die surface protection is deficient or damaged. Charge leaks from floating gate devices usually happen before a corrosion mechanism develops.

## Temperature Humidity Test

The Temperature Humidity test determines the survivability of devices in molded plastic packages functioning in a humid environment. By convention, test conditions are $85^{\circ} \mathrm{C}$ and $85 \%$ relative humidity. The parts are biased to lend themselves to electrochemical corrosion. The duration of the test is usually 1,000 hours or more. The test checks the adequacy of the die surface protection and the plastic's lack of ionic impurities. The applied bias may be 5 volts on alternating pins or set up for minimum power to reduce internal heating and consequent moisture evaporation on the device. Similar to the Autoclave test, charge loss on floating gate devices is a principle failure mechanism.

## QUALIFICATION CATEGORIES

Qualification is required for new design, major changes in old design, process or material when either wafer fabrication or package assembly operations are affected. Qualification applies to the following changes:
I. New technology
II. Start-up of Fab or Assembly
III. Transfer of fab or assembly to another location
IV. Major process changes:
A. Process scaling (shrink conversion)
B. Change in vendor or material source
C. New equipment that affects reliability
V. New die configurations:
A. New structures
B. New packaging material
C. Design rule changes
D. Existing package revision (dimensional or layout)

## QUALIFICATION PROGRAMS

Qualifications guarantee new processes and technologies are properly evaluated for reliability performance.

## Reliability Monitoring

Microchip's reliability monitoring program is a comprehensive effort to measure the reliability of all process families with strict regularity. The program strives to improve performance through failure analysis and corrective action. Numerous screening procedures are used and estimates of product life and expected failure rates are provided.
Typical tests and frequency on each process family include:
A. 168 hour operating life - weekly
B. 1,000 hour operating life - annually
C. Endurance test - weekly
D. Data retention test - weekly
E. Temperature cycle - weekly
F. Temperature humidity - annually
G. Long term retention - annually
H. Mechanical tests - annually

## APPENDIX A - IN-LINE CONTROLS

| CONTROLS - PLASTIC PACKAGE ASSEMBLY |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PROCESS STEP | REJECT PARAMETER LIMITS | SAMPLE PLAN |  | IION | $\begin{aligned} & \text { MIL } \\ & \text { STD } \\ & \text { REP } \end{aligned}$ |
| Die Visual Inspection | Reject For Any Defect | 100\% |  | x | 883 C Method 2010 B |
| Wafer Saw | Report Failure Modes | 1 Slice Per Lot Visual | X |  | 883C <br> Method <br> 2010 |
| Die Attach Inspection | Machine Shut Down | 5/Shift Each Machine | x |  | 883C <br> Method <br> 2019 |
| Wire Bond Inspection | Report Failure Mode <br> Machine Shut Down | 1\% AQL <br> Each Half <br> Shift | x |  | 883C Method 2011 D 2010 |
| Post Wire Bond Visual Inspect | Reject For Any Defect | 100\% |  | X | 883C <br> Method <br> 2010 |
| Mould Press <br> Visual | Machine Shut Down | $\begin{aligned} & \text { LTPD } \\ & 15 \% \\ & \mathrm{~A}=0 \end{aligned}$ | X |  | X-Ray Monitor |
| Package Visual | Report Defects 100\% Screen For Major Defects | $\begin{aligned} & \text { LTPD } \\ & 2 \% \\ & \mathrm{~A}=0 \end{aligned}$ | X |  | N/A |
| Trim \& Form Visual | Report Defects 100\% Screen For Major Defects | $\begin{aligned} & \text { LTPD } \\ & 2 \% \\ & \mathrm{~A}=0 \end{aligned}$ | X |  | 883 C <br> Method <br> 2016 |
| External Final <br> Visual <br> Inspection <br> - Run Ticket Verification <br> - Marking Legibility <br> - Package Outline Check <br> - Solderability Monitor <br> - Package Form | Major Defects 100\% Screen | $\begin{aligned} & \text { LTPD } 2 \% \\ & \mathrm{~A}=0 \end{aligned}$ | X |  | 883 C <br> Method <br> 2009 |


| CONTROLS - CERAMIC PACKAGE ASSEMBLY |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PROCESS STEP | $\begin{aligned} & \text { REJECT } \\ & \text { PARAMETER } \end{aligned}$ | SAMPLE PLAN LIMITS |  | ION PROD | MIL <br> STD <br> REP |
| Die Visual Inspection | Reject For Any Defect | 100\% |  | X |  |
| Wafer Saw Inspection | Machine Shut Down | 1 Slice/ Lot Visual | X |  |  |
| Die Attach Inspection | Machine Shut Down | Non-destruct Each 2 hrs Destruct Each Shift | X |  |  |
| Wire Bond Inspection | Report Failure Mode Machine Shut Down | 1\% AQL Each Half Shift | X |  | 883C <br> Method <br> 2011 D <br> 2010 |
| Preseal <br> Visual Inspection | Reject For Any Defect | $\begin{aligned} & \text { LTPD } \\ & 15 \% \\ & \mathrm{~A}=0 \\ & \hline \end{aligned}$ |  | X |  |
| Package Seal Inspection | Machine Shut Down | $\begin{aligned} & \text { LTPD } \\ & 15 \% \\ & \mathrm{~A}=0 \end{aligned}$ | X |  | $\begin{aligned} & 883 C \\ & \text { Method } \\ & 1014 \end{aligned}$ |
| Fine Leak Test | Screen 100\% | LTPD <br> 5\% <br> A=0 | X |  | 883C <br> Method 1014 |
| Gross Leak Test | Screen 100\% | $\begin{aligned} & \text { LTPD } \\ & 5 \% \\ & \mathrm{~A}=0 \end{aligned}$ | X |  | 883C <br> Method 2014 |
| Lead Trim Visual | Screen 100\% | $\begin{aligned} & \text { LTPD } \\ & 2 \% \\ & \mathrm{~A}=0 \\ & \hline \end{aligned}$ | X |  | 883C Method 2016 |
| Package Mark Inspection | Machine Shut Down | $\begin{aligned} & \hline \text { LTPD } \\ & 10 \% \\ & \mathrm{~A}=1 \end{aligned}$ | X |  |  |
| Environmental Inspection | Machine <br> Shut Dow | LTPD 5\% $\mathrm{A}=0$ | X |  | 883C <br> Methods 1010C 2001E, 1014 |
| External <br> Package Visual | Screen 100\% | $\begin{aligned} & \text { LTPD } \\ & 10 \% \\ & A=1 \end{aligned}$ | X |  |  |

## APPENDIX B - MATERIAL CONTROLS

| MATERIAL CONTROLS - PLASTIC PACKAGE ASSEMBLY |  |  |  |
| :---: | :---: | :---: | :---: |
| PROCESS STEP | REJECT PARAMETER LIMITS |  | SAMPLE PLAN |
| Lead Frame Inspection | Reject For Any Failure | Visual <br> Functional | $\begin{aligned} & \text { LTPD } 2 \% \\ & \mathrm{~A}=0 \\ & \text { LTPD } 10 \% \\ & \mathrm{~A}=0 \end{aligned}$ |
| Die Mount Epoxy Inspect | Functional Test-Reject Any Failure |  | 3 Sample Runs |
| Gold Wire Inspection | Reject For Any Defect |  | $\begin{aligned} & 2 \text { Spools } \\ & \text { Per Lot } \\ & \mathrm{A}=0 \end{aligned}$ |
| Mould Compound Inspection | Storage Temp $5^{\circ} \mathrm{C}$ <br> Pellet Weight $\pm 5$ GMS <br> Functional Test Any Failure |  | 3 Sample Runs |


| MATERIAL CONTROLS - CERAMIC PACKAGE ASSEMBLY |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PROCESS STEP | REJECT PARAMETER LIMITS | SAMP | LAN |  | $\begin{aligned} & \text { MIL } \\ & \text { STD } \\ & \text { REP } \end{aligned}$ |
| Package Inspection <br> - Mechanical Visual <br> - Hermeticity <br> - Plating Thickness <br> - Bake Visual | Reject For Any Defect |  | LTPD \% <br> $10 \mathrm{~A}=0$ <br> $15 \mathrm{~A}=0$ <br> $10 \mathrm{~A}=0$ <br> $15 \mathrm{~A}=0$ | x | N/A |
| Preform Inspection | Reject For Any Defect | Visual Functional | LTPD \% $10 \mathrm{~A}=0$ $15 \mathrm{~A}=0$ | x | N/A |
| Bond Wire Inspection | Reject For Any Defect |  | 2 Spools Per Lot A=0 | x | N/A |
| Lid Inspection | Reject For <br> Any Defect | Visual Functional | LTPD \% $7 \mathrm{~A}=0$ $10 \mathrm{~A}=0$ | x | N/A |

## Plastic Package Reliability Bulletin

## AVERAGE OUTGOING QUALITY OF PLASTIC EPROMS

Microchip Technology Inc.'s organized data on outgoing quality of plastic EPROMs tracks parametric failures such

as speed, power and device leakage. Its present level has reached 200 ppm after programming, with a goal of 100 ppm.

As plastic parts have extremely high impact resistance, visual/mechanical failure rate is expected to run half the expected failure rate of ceramic parts.


## OVERVIEW

Microchip Technology Inc.'s Plastic EPROM products provide competitive leadership in quality and reliability, with demonstrated performance of less than 170 FITs (Failures in Time) operating life. The designed-in reliability of Microchip Technology Inc.'s Plastic EPROMs is supported by ongoing reliability data monitors. This document presents current data for your use - to provide you with results you can count on.

The test descriptions included in this document explain Microchip Technology Inc.'s quality and reliability system, and the EPROM product data demonstrate its results.

The customer's quality requirements are Microchip Technology Inc.'s top priority: Ongoing customer feedback and device performance monitoring drive Microchip Technology Inc.'s manufacturing and design process, leading to continuing improvements in the long-term quality and reliability of Microchip Technology Inc.'s products.

## PRODUCT SCOPE

Subject of this Product Reliability Bulletin are the Plastic Packages of Microchip Technology Inc.'s EPROM Product Family:

$$
\begin{array}{ll}
27 C 64-X X / Y Y & 64 \mathrm{~K}(8 \mathrm{Kx} 8) \mathrm{CMOS} \text { EPROM } \\
27 \mathrm{C} 128-\mathrm{XX} / \mathrm{YY} & 128 \mathrm{~K}(16 \mathrm{Kx8}) \mathrm{CMOS} \text { EPROM } \\
27 \mathrm{C} 256-\mathrm{XX} / \mathrm{Y} & 256 \mathrm{~K}(32 \mathrm{Kx8}) \mathrm{CMOS} \text { EPROM } \\
27 \mathrm{C} 512-X X / Y Y & 512 \mathrm{~K}(64 \mathrm{Kx}) \mathrm{CMOS} \text { EPROM }
\end{array}
$$

These EPROMs are available in a range of access times designated by the XX parameter: 120, 150, 170, 200 and 250 ns . Available plastic packages are identified by the YY parameter: Plastic DIP, PLCC, and SOIC.

## RELIABILITY DATA

Microchip Technology Inc.'s EPROMs in plastic were produced to offer the customer the flexibility of using the plastic device as a direct substitution for a Cerdip EPROM in one-time-programming applications. Failure Rate Predictions/Operating Life data for plastic EPROMs at $125^{\circ} \mathrm{C}$ proves to be equivalent to the data of ceramic EPROMs (refer to page 8), opening the way for package substitution for cost savings and inventory reduction.

## Plastic EPROM Reliability Bulletin

## FAILURE RATE CALCULATION

Extended field life is simulated by using high ambient temperature. In the semiconductor technology, high temperatures dramatically accelerate the mechanisms leading to component failure. Using performance results at different temperatures, an activation energy is determined using the Arrhenius equation. For each type of failure mechanism, the activation energy expresses the degree to which temperature increases the failure rate.

The activation energy values determined by Microchip Technology Inc. agree closely with those published in the literature. For complex CMOS devices in production at Microchip Technology Inc., an activation energy of 0.7 eV has been shown to be most representative of typical failures on operating life, while 0.6 eV is representative of charge gain or loss failures. By definition, failure is reached when a device no longer meets the data sheet specifications as a direct result of the reliability test environment to which it was exposed. Common failure modes for CMOS integrated circuits are identified for each test environment.

EPROM products have an early failure rate (infant mortality) of less than $0.05 \%$ and thus, a production burn-in should not be necessary. For all products shown, the early and the intermediate failure rates are combined and expressed as a single failure rate.

To establish a field failure rate, the acceleration factor is applied to the device operating hours observed at high temperature stress and extrapolated to a failure rate at $55^{\circ} \mathrm{C}$ ambient temperature in still air.

The actual failure rate experienced could be considerably less than that calculated if lower device temperatures occur in the application board, such as would be the case if a fan, a heat sink, or air flow by convection is used.

| Environment | Typical Failure Mechanism |
| :--- | :--- |
| Operating Life | Process parameter drift/shift <br> Metal electromigration <br> Internal leakage path <br> Lifted bond/ball bond chip-out <br> Temperature Cycle |
|  | Lifted bond/ball bond chip-out <br> Cracked die or surface cracks <br> Bond pad corrosion |
| Biased-Humidity/ | Internal circuit corrosion <br> Autoclave |
| High Temp. Baker-pin leakage Charge loss |  |
| High Temp. Reverse | Charge loss from EPROM cell |
| Bias | Charge gain to EPROM cell |

## DEFINITIONS

AOQ (Average Outgoing Quality): The amount of defective product in a population, usually expressed in terms of parts per million (PPM).

FIT (Failure in Time): Expresses the estimated field failure rate in number of failures per billion power-on device-hours. 100 FITS equals $0.01 \%$ fail per 1000 device-hours.

Operating Life Test: The device is dynamically exercised at a high ambient temperature (usually $125^{\circ} \mathrm{C}$ ) to quickly simulate field life. Derating from high temperature, an ambient use condition failure rate can be calculated.

Temperature Cycle: The devices are exposed to severe extremes of temperature in an alternating fashion $\left(-65^{\circ} \mathrm{C}\right.$ for 15 minutes, $150^{\circ} \mathrm{C}$ for 15 minutes per cycle). Package strength, bond quality and consistency of assembly process are stressed using this environment.

Blased-Humidity: Moisture and bias are used to accelerate corrosion-type failures in plastic packages. The conditions include $85^{\circ} \mathrm{C}$ ambient temperature with $85 \%$ relative humidity. Typical bias voltage is +5 volts and ground on alternating pins.

Autoclave (pressure cooker): Using a pressure of one atmosphere above normal pressure, plastic packaged devices are exposed to moisture at $121^{\circ} \mathrm{C}$. The pressure forces moisture permeation of the package and accelerates related failure mechanisms, if present, on the device.

Thermal Shock: Consists of extreme temperature cycling of devices from $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ by alternate immersion in liquid media.

Retention Bake: A $150^{\circ} \mathrm{C}$ Temperature stress is used to accelerate charge loss in the memory cell and measure the data retention on the EPROM.

High Temperature Reverse Bias (HTRB): A special test mode which subjects the entire EPROM array to a high voltage level and is used to measure charge gain and/or threshold shifts.

## Plastic EPROM Reliability Bulletin

## RELIABILITY CONTROL SYSTEM

A comprehensive qualification system ensures that released products are designed, processed, packaged and tested to meet both design functionality and strict reliability objectives. Once qualified, a reliability monitor system
ensures that wafer fabrication and assembly process performance is stable over time. A set of baseline specifications is maintained that states which changes require requalification. These process changes can only be
made after successful demonstration of reliability performance. This system results in reliable field performance, while enabling the smooth phase-in of improved designs and product capability.

## DESIGN AND DEVELOPMENT

Specify:

- Design objectives/specifications
- Testability goals
- Reliability requirements
- Process/packaging requirements
- Design guidelines


## Design:

- Functional models
- Logic design \& verification
- Circuit design \& verification
- Layout design \& verification
- Prototype verification
- Performance characterization

Develop (as required):

- Wafer fabrication processes
- Package/packaging technology


## QUALIFICATION

Confirm design objectives using qualification tests:

- Operating life, $125^{\circ} \mathrm{C}$ ambient
- Temp-cycle, $-65^{\circ} / 150^{\circ} \mathrm{C}$
- Thermal shock, $-65^{\circ} / 150^{\circ} \mathrm{C}$
- ESD resistance, $\pm 2000 \mathrm{~V}$
- Latch-up (CMOS devices)
- Biased-humidity, $85^{\circ} \mathrm{C} / 85 \%$
- Autoclave (pressure cooker) retention bake
- HTRB


## RELIABILITY CONTROL

Assure Outgoing Quality Level:

- Design release document
- Baseline wafer fabrication process
- Baseline assembly process
- Qualification release
- Enter device to specification system
- Wafer-level reliability controls
- Assembly reliability controls
- Early failure rate sampling
- Reliability monitoring
- Statistical process control feedback
- Audit specifications
- Analyze returned failures
- Requalify devices as needed for major changes such as ESD resistance enhancement, cost reduction/die shrink. process improvement, and new package types.


## Plastic EPROM Reliability Bulletin

## RELIABILITY DATA SUMMARY

## INTRODUCTION

This section provides a reliability summary of Microchip Technology Inc.'s plastic EPROMs. Included is plastic packaging information and reliability data obtained to date for the 27C64, 27C128, 27C256, and 27C512 EPROM plastic devices.

EPROMs have become a viable quick turn solution for providing new ROM pattern capability without the typical long turn around time associated with mask programmable ROMs. The speed capability of EPROMs has also improved, making them competitive with traditional ROM products.

With this capability, it is possible and practical for the customer to keep an inventory of blank EPROMs on hand and do custom programming on an as needed basis.

Units are also available from Microchip Technology Inc. utilizing the QTP (Quick Turn Product) approach. Microchip Technology Inc. will provide pre-programmed EPROM units to customers using the customers defined pattern. This approach eliminates the traditional delay time involved in processing a mask programmable ROM.

## PLASTIC PACKAGE CHARACTERISTICS

Plastic packaging utilized for the EPROM products uses a silver filled epoxy adhesive for die attach. Bonding technology is gold wire thermosonic bonding. The lead frame pedestal and finger tips are silver plated. The epoxy molding compound used is a Shinitsu compound KMC-140-3 which meets the safety rating requirements of UL 94 VO $1 / 8 \mathrm{in} / \mathrm{min}$. External lead finish is electroplated tin lead $90 / 10$ percent. The package code table below lists the plastic packages covered by the reliability data in this document.

As part of an on going product improvement program, Microchip Technology Inc. will apply its Quality and Reliability process in evaluating the latest developments in plastic packaging technology, and implement the highest reliability materials and assembly techniques.

## PLASTIC PACKAGE IDENTIFICATION CODES

| Package Description | Identification Code |
| :--- | :---: |
| Plastic Leadless Chip Carrier | L |
| Plastic Dual In Line $(600)$ | P |
| Plastic Dual In Line $(300)$ | SP |

## ELECTRICAL CHARACTERISTICS

Microchip Techr.ulogy inc.'s EPROMs packaged in plastic are tested to the same electrical characteristics as devices assembled in Cerdip packages. This testing covers the full commercial range of $0-70^{\circ} \mathrm{C}$. Performance characteristics are the same as for Cerdip packaging with speeds to 120ns available.

## QUALITY/RELIABILITY TESTING RESULTS

Reliability and programming tests were performed on EPROM devices in plastic packages. Data from these qualification tests are displayed throughout this document.

## PROGRAMMABILITY

Programmability is measured by sample data taken from production lots. Devices are programmed with a Diagonal FF which exercises $98 \%$ of the EPROM cell array. This rigorous patterning combined with Microchip Technology Inc.'s FAST programming algorithm greatly enhances the ability to meet specific customer applications. Large volume beta site programming results for plastic EPROMs indicate an expected yield of $98.7 \%$ using Fast Mode programming under normal production conditions. This means customer programming, using a recommended Express programming algorithm, should be higher than $99 \%$ on the smaller EPROM arrays.
PROGRAMMABILITY DATA (12 months period)

| Time <br> Period | No. of <br> Sample Units | No. of Non-Pro- <br> grammable Units | Fraction <br> Defective |
| :--- | :---: | :---: | :---: |
| 1989 | 10019 | 258 | .026 |

Note: Derated to typical customer programming, the defective fraction should be 0.009

PACKAGE CODE

| Package Code | SP | P | L | Gull Wing |
| :--- | :---: | :---: | :---: | :---: |
| Package Type | $\mathbf{3 0 0}$ Mil P Dip | $\mathbf{6 0 0}$ Mil P Dip | J Lead PLCC | $\mathbf{3 0 0}$ mil body SOIC |
| Lead Count: 24 | F | A |  | F |
| 28 |  | A | F |  |
| 32 |  | F | A |  |
| 40 |  | $F$ |  |  |
| 44 |  |  |  |  |

(A) Available - (F) Future Release Planned

# Plastic EPROM Reliability Bulletin 

## HIGH TEMPERATURE ( $125^{\circ} \mathrm{C}$ ) DYNAMIC LIFE TEST

High temperature dynamic life testing accelerates random failure modes which would occur in a users application.

Voltage bias and address signals are used to exercise the device in a manner similar to the users system.


## HIGH TEMPERATURE REVERSE BIAS ( $150^{\circ} \mathbf{C} / 7$ Volts)

Microchip Technology Inc.'s EPROMs are designed for enhanced reliability by having a special test mode which allows all gates on the array to be simultaneously placed at a high voltage stress level in reference to the rest of the circuitry. This test is used to create a high voltage stress on the memory oxide. An additional acceleration of three
times is gained from the 7 V level based on experimental data. This is calculated into the failure rates below. Failures which will be detected with this type of stress are: pin holes in the oxide, thin oxide layers, and charge gain failures.


## Plastic EPROM Reliability Bulletin

## MOISTURE RESISTANCE TESTING

Moisture resistance evaluation of Microchip Technology Inc. plasticEPROMs includes both autoclave testing $\left(121^{\circ} \mathrm{C}\right.$, $15 \mathrm{PSI})$ and temperature humidity testing $\left(85^{\circ} \mathrm{C} / 85 \%\right.$ relative humidity with bias). Moisture resistance could not be obtained by the industry standard so a layered passivation utilizing an Oxy-Nitride film to provide a moisture block while allowing unblocked UV transmission is used.

The autoclave accelerates any moisture penetration through the plastic package material or around the metal leadframe
and plastic to leadframe interface. The objective of this testing is to accelerate failure of the device as a result of any moisture contamination on the surface of the die. Failure mechanisms such as passivation defects (pinholes, cracking, lifting), corrosion of bondpads or surface metal through passivation defects, leakage and surface contamination as well as charge loss failures may be identified. The predominant failure mechanism for EPROMs is data loss.

AUTOCLAVE ( $121^{\circ} \mathbf{C} / 15 \mathrm{PSI}$ )

| Product | Failures/Sample Size |  |  |
| :--- | :---: | :---: | :---: |
|  | $\mathbf{2 4}$ Hrs | $\mathbf{9 6 ~ H r s}$ | $\mathbf{1 6 8 H r s}$ |
| $27 C 256 / \mathrm{L}$ | $0 / 723$ | $0 / 766$ | $1 / 766^{1}$ |
| 27C64/P | $1 / 767^{1}$ | $0 / 380$ | $1 / 766^{1}$ |
| $27 \mathrm{C} 128 / \mathrm{P}$ | $0 / 380$ | $1 / 444^{1}$ | $2 / 443^{1}$ |
| $27 \mathrm{C} 256 / \mathrm{P}$ | $0 / 444$ | $1 / 450^{1}$ | $3 / 449^{1}$ |
| 27C512/P | $0 / 450$ | $3 / 723^{1}$ | $9 / 720^{1}$ |
| 27Cxxx/X (discounted | $0 / 2764$ | $0 / 2763$ | $0 / 2758$ |
| for charge loss) |  |  |  |
|  |  |  | 1 - Failures due to charge loss on EPROM cell |

## HUMIDITY BIAS - $\mathbf{8 5}^{\circ} \mathbf{C} / \mathbf{8 5} \%$ RH

Temperature humidity testing is utilized to accelerate failures through electrolytic corrosion. This is accomplished by subjecting devices to a high temperature and high humidity atmosphere with bias applied to the device. The combination of moisture penetration through the plas-
tic package and interaction of the moisture with any contaminates on the surface of the device and the applied voltage to the unit, will result in electrolytic corrosion and failure of the device.


## Plastic EPROM Reliability Bulletin

## DATA RETENTION BAKE

Data storage in EPROMs is done by developing a charge on the floating gate structure in the memory cell. Charge loss in this cell structure results in loss of data. In order to detect this type of failure, devices are subjected to a $150^{\circ} \mathrm{C}$ bake. This bake accelerates charge loss in the memory cell.

This added screen for detecting infant mortality charge loss allows Microchip Technology Inc.'s plastic product to duplicate the excellent data retention characteristics of the ceramic EPROM packages.


## TEMPERATURE CYCLING ( $-65^{\circ} \mathrm{C}$ TO $+150^{\circ} \mathrm{C}$ )

This stress is used to evaluate the mechanical integrity of the plastic package and the assembly process. Temperature cycling consists of cycling the devices between $-65^{\circ} \mathrm{C}$ and $+150^{\circ} \mathrm{C}$ at the rate of 4 cycles per hour. This stress will identify failure mechanisms such as plastic package cracking, die attach problems, and wire bonds lifting.

| Product | Failures/ Sample Size |  |
| :---: | ---: | ---: |
|  | $\mathbf{1 0 0}$ Cycles | $\mathbf{5 0 0}$ Cycles |
| $27 \mathrm{C} 64 / \mathrm{L}$ | $0 / 34$ | $0 / 0$ |
| $27 \mathrm{C} 256 / \mathrm{L}$ | $0 / 102$ | $0 / 0$ |
| $27 \mathrm{C} 64 / \mathrm{P}$ | $0 / 374$ | $0 / 340$ |
| $27 \mathrm{C} 256 / \mathrm{P}$ | $0 / 68$ | $0 / 68$ |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |

THERMAL SHOCK $\left(-55^{\circ} \mathrm{C}\right.$ TO $\left.+125^{\circ} \mathrm{C}\right)$
This stress is used to evaluate the mechanical integrity of the plastic package. It consists of rapid immersion of devices into liquids of $-55^{\circ} \mathrm{C}$ and $+125^{\circ} \mathrm{C}$ respectively.

| Product | Failures/ Sample Size |
| :---: | :---: |
|  | 15 cycles |
| $27 \mathrm{C} 64 / \mathrm{P}$ | $0 / 170$ |
| $27 \mathrm{C} 256 / \mathrm{L}$ | $0 / 34$ |
| $27 \mathrm{C} 256 / \mathrm{P}$ | $0 / 68$ |

## Plastic EPROM Reliability Bulletin

## PRODUCT RELIABILITY DATA

| Reliability Test | Product | Failures/Sample Size at |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 24 Hrs | 168 Hrs | 500 Hrs | 1000 Hrs | FITs |
| $125^{\circ} \mathrm{C}$ Operating Life | 27C64 | 0/871 | 2/871 | 0/198 | 0/45 | 170 |
|  | 27C128 | 3/393 | 1/390 | 0/216 | 0/172 | 301 |
|  | 27C256 | 2/1243 | 2/1241 | 2/882 | 0/880 | 100 |
|  | 27 C 512 | 4/954 | 1/949 | 0/948 | 0/948 | 85 |
| $150^{\circ} \mathrm{C}$ HTRB | 27C64 | 1/749 | 1/748 | 2/154 | 0/0 | 84 |
|  | 27C128 | 3/225 | 0/222 | 0/45 | 0/45 | 157 |
|  | 27C256 | 1/902 | 3/901 | 1/586 | 0/585 | 27 |
|  | 27 C 512 | 2/411 | 4/409 | 2/405 | 0/284 | 77 |
| $150^{\circ} \mathrm{C}$ Retention Bake | 27C64 | 1/1074 | 0/1073 | 0/813 | 0/813 | 9 |
|  | 27 C 128 | 0/1562 | 0/1562 | 0/1562 | 0/1562 | 4 |
|  | 27C256 | 1/1670 | 2/1669 | 1/1509 | 0/1508 | 29 |
|  | 27C512 | 2/477 | 2/475 | 0/397 | 0/397 | 108 |
| Failure Modes | Operating Life: (5) Metal Migration, (10) Oxide Breakdown, (2) Poly Shorts HT Reverse Bias: (12) Oxide Breakdown, (8) Charge Gain Retention Bake: (9) Charge Loss |  |  |  |  |  |

# SECTION 8 PACKAGING 

Packaging Outlines and Dimensions<br>8- 1

Microchip

## PACKAGING

## Commercial/Industrial Outlines and Parameters

## COMMERCIAL AND INDUSTRIAL PARTS

Part Number Suffix Designations:
xxxxxxxxxx-xx x/xx xxx


## TABLE OF CONTENTS

## SECTION 1: HERMETIC

A. Ceramic Side Brazed Dual In-line Package ("D" Case Outlines)
Symbol List for Side Brazed Package Parameters ..... 8-1-1
8 -Lead, Side Brazed, 300 mil ..... 8-1-2
14-Lead, Side Brazed, 300 mil ..... 8-1-3
16-Lead, Side Brazed, 300 mil ..... 8-1-4
18-Lead Side Brazed, 300 mil ..... 8-1-5
20-Lead Side Brazed, 300 mil ..... 8-1-6
22-Lead, Side Brazed, 400 mil ..... 8-1-7
24-Lead, Side Brazed, 600 mil ..... 8-1-8
24-Lead, Side Brazed, 600 mil, Window ..... 8-1-9
28-Lead, Side Brazed, 600 mil ..... 8-1-10
28-Lead, Side Brazed, 600 mil, Window ..... 8-1-11
40-Lead, Side Brazed, 600 mil ..... 8-1-12
40-Lead, Side Brazed, 600 mil, Window ..... 8-1-13
48-Lead, Side Brazed, 600 mil ..... 8-1-14
B. Ceramic Cerdip Dual In-iine Package ("J, JW, SJ" Case Outlines)
Symbol List for Cerdip Dual In-Line Package Parameters ..... 8-1-15
8-Lead, Cerdip, 300 mil ..... 8-1-16
16 -Lead, Cerdip, 300 mil ..... 8-1-17
18 -Lead, Cerdip, 300 mil ..... 8-1-18
18-Lead, Cerdip, 300 mil, Window ..... 8-1-19
20-Lead, Cerdip, 300 mil ..... 8-1-20
22-Lead, Cerdip, 400 mil ..... 8-1-21
24-Lead, Cerdip, 300 mil ..... 8-1-22
24-Lead, Cerdip, 600 mil ..... 8-1-23
24-Lead, Cerdip, 300 mil, Window ..... 8-1-24
24-Lead, Cerdip, 600 mil, Window ..... 8-1-25
28 -Lead, Cerdip, 600 mil ..... 8-1-26
28-Lead, Cerdip, 600 mil, Window ..... 8-1-27
40-Lead, Cerdip, 600 mil ..... 8-1-28
40-Lead, Cerdip, 600 mil, Window ..... 8-1-29
C. Ceramic Flatpack
Symbol List for Ceramic Flatpack Package Parameters ..... 8-1-30
28-Lead ..... 8-1-31
D. Ceramic Leadless Chip Carrier (Surface Mount Package, "K" Case Outlines)
Symbol List for Ceramic Leadless Chip Carrier Package Parameters ..... 8-1-32
28-Lead (Square) ..... 8-1-33
28-Lead, Window (Square) ..... 8-1-34
32-Lead (Rectangle) ..... 8-1-35
32-Lead, FRIT (Rectangle) ..... 8-1-36
32-Lead, Window (Rectangle) ..... 8-1-37
32-Lead, FRIT Window (Rectangle) ..... 8-1-38
44-Lead (Square) ..... 8-1-39

## TABLE OF CONTENTS (Cont'd)

## SECTION 2: PLASTIC

A. Plastic Dual In-Line Package ("P, SP" Case Outlines)
Symbol List for Plastic Dual In-Line Package Parameters ..... 8-2-1
8 -Lead, 300 mil ..... 8-2-2
14-Lead, 300 mil ..... 8-2-3
16-Lead, 300 mil ..... 8-2-4
18 -Lead, 300 mil ..... 8-2-5
20-Lead, 300 mil ..... 8-2-6
22-Lead, 400 mil ..... 8-2-7
24-Lead, 300 mil ..... 8-2-8
24-Lead, 600 mil ..... 8-2-9
28-Lead, 600 mil ..... 8-2-10
40-Lead, 600 mil ..... 8-2-11
48-Lead, 600 mil ..... 8-2-12
B. Plastic Leaded Chip Carrier (Surface Mount, "L" Case Outlines)
Symbol List for Plastic Leaded Chip Carrier Package Parameters ..... 8-2-13
20-Lead (Square) ..... 8-2-14
28-Lead (Square) ..... 8-2-15
32-Lead (Retangle) ..... 8-2-16
44-Lead (Square) ..... 8-2-17
C. Plastic Small Outline (SOIC) (Surface Mount, "SN, SM, SO" Case Outlines)
Symbol List for Plastic Small Outline Package Parameters ..... 8-2-18
8 -Lead, 150 mil (Body) ..... 8-2-19
8 -Lead, 200 mil (Body) ..... 8-2-20
14-Lead, 150 mil (Body) ..... 8-2-21
14-Lead, 300 mil (Body) ..... 8-2-22
16-Lead, 150 mil (Body) ..... 8-2-23
16-Lead, 300 mil (Body) ..... 8-2-24
18-Lead, 300 mil (Body) ..... 8-2-25
20-Lead, 300 mil (Body) ..... 8-2-26
24-Lead, 300 mil (Body) ..... 8-2-27
28-Lead, 300 mil (Body) ..... 8-2-28

## Packaging Diagrams and Parameters

## Ceramic Side Brazed Dual In-line Family

| Symbol List for Ceramic Side Brazed Dual In-line Package Parameters |  |
| :---: | :--- |
| Symbol | Description of Parameters |
| $\alpha$ | Angular spacing between min and max lead positions measured at the guage plane |
| A | Distance between seating plane to highest point of body (lid) |
| $\mathrm{A}_{1}$ | Distance between seating plane and base plane |
| $\mathrm{A}_{2}$ | Distance from base plane to highest point of body (lid) |
| $\mathrm{A}_{3}$ | Base body thickness |
| B | Width of terminal leads |
| $\mathrm{B}_{1}$ | Width of terminal lead shoulder which locate seating plane (standoff geometry optional) |
| C | Thickness of terminal leads |
| D | Largest overall package parameter of length |
| $\mathrm{D}_{1}$ | Body length parameter - end lead center to end lead center |
| E | Largest overall package width parameter outside of lead |
| $\mathrm{E}_{1}$ | Body width parameters not including leads |
| eA | Linear spacing of true minimum lead position center line to center line |
| eB | Linear spacing between true lead position outside of lead to outside of lead |
| e1 | Linear spacing between center lines of body standoffs (terminal leads) |
| L | Distance from seating plane to end of lead |
| N | Total number of potentially useable lead positions |
| S | Distance from true position center line of No. 1 lead to the extremity of the body |
| S1 | Distance from other end lead edge positions to the extremity of the body |

## Notes:

1. Controlling parameter: inches.
2. Parameter "e," ("e") is non-cumulative.
3. Seating plane (standoff) is defined by board hole size.
4. Parameter " $\mathrm{B}_{1}$ " is nominal.

## Packaging Diagrams and Parameters

## Package Type: 8-Lead Ceramic Side Brazed Dual In-line (. 300 mil )



| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.302 | 3.937 |  | 0.130 | 0.155 |  |
| A1 | 0.635 | 1.143 |  | 0.025 | 0.045 |  |
| $\mathrm{A}_{2}$ | 2.032 | 2.794 |  | 0.080 | 0.110 |  |
| A3 | 1.778 | 2.413 |  | 0.070 | 0.095 |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |
| $\mathrm{B}_{1}$ | 1.3716 | 1.3716 | Typical | 0.054 | 0.054 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 13.0048 | 13.4112 |  | 0.512 | 0.528 |  |
| $\mathrm{D}_{1}$ | 7.4168 | 7.8232 | Reference | 0.292 | 0.308 | Reference |
| E | 7.5692 | 8.2296 |  | 0.298 | 0.324 |  |
| E1 | 7.112 | 7.620 |  | 0.280 | 0.300 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| eA | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| eB | 7.620 | 9.652 |  | 0.300 | 0.380 |  |
| L | 3.302 | 3.810 |  | 0.130 | . 150 |  |
| N | 8 | 8 |  | 8 | 8 |  |
| S | 2.540 | 3.048 |  | 0.100 | 0.120 |  |
| S1 | 0.127 | - |  | . 005 | - |  |

## Packaging Diagrams and Parameters

Package Type: 14-Lead Ceramic Side Brazed Dual In-line (. 300 mil)


| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| A1 | 0.635 | 1.143 |  | 0.025 | 0.045 |  |
| A2 | 2.032 | 2.794 |  | 0.080 | 0.110 |  |
| А3 | 1.778 | 2.413 |  | 0.070 | 0.095 |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| C | 0.2032 | 0.3048 | Typical | 0.008 | 0.012 | Typical |
| D | 18.796 | 19.2278 |  | 0.740 | 0.757 |  |
| D1 | 15.0368 | 15.4432 | Reference | 0.592 | 0.608 | Reference |
| E | 7.620 | 8.382 |  | 0.300 | 0.330 |  |
| E1 | 7.0612 | 7.5692 |  | 0.278 | 0.298 |  |
| el | 2.3622 | 2.7432 | Typical | 0.093 | 0.108 | Typical |
| ea | 7.366 | 7.874 | Reference | 0.290 | 0.310 | Reference |
| eB | 7.620 | 9.652 |  | 0.300 | 0.380 |  |
| L | 3.175 | 4.191 |  | 0.125 | 0.165 |  |
| N | 14 | 14 |  | 14 | 14 |  |
| S | - | 2.4892 |  | - | 0.098 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

## Packaging Diagrams and Parameters

## Package Type: 16-Lead Ceramic Side Brazed Dual In-line (. 300 mil)



| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| A1 | 0.635 | 1.143 |  | 0.025 | 0.045 |  |
| A2 | 2.032 | 2.794 |  | 0.080 | 0.110 |  |
| A3 | 1.778 | 2.413 |  | 0.070 | 0.095 |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |
| B1 | 1.3716 | 1.3716 | Typical | 0.054 | 0.054 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 19.812 | 20.574 |  | 0.780 | 0.810 |  |
| D1 | 17.653 | 17.907 | Reference | 0.695 | 0.705 | Reference |
| E | 7.620 | 8.382 |  | 0.300 | 0.330 |  |
| E1 | 7.1628 | 7.4676 |  | 0.282 | 0.294 |  |
| e1 | 2.413 | 2.667 | Typical | 0.095 | 0.105 | Typical |
| ea | 7.366 | 7.874 | Reference | 0.290 | 0.310 | Reference |
| eB | 7.620 | 9.652 |  | 0.300 | 0.380 |  |
| L | 3.175 | 4.191 |  | 0.125 | 0.165 |  |
| N | 16 | 16 |  | 16 | 16 |  |
| S | - | 2.032 |  | - | 0.080 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

## Packaging Diagrams and Parameters

## Package Type: 18-Lead Ceramic Side Brazed Dual In-line (. 300 mil)



| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| A1 | 0.635 | 1.143 |  | 0.025 | 0.045 |  |
| A2 | 2.032 | 2.794 |  | 0.080 | 0.110 |  |
| А3 | 1.778 | 2.413 |  | 0.070 | 0.095 |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |
| B1 | 1.3716 | 1.3716 | Typical | 0.054 | 0.054 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 22.352 | 23.114 |  | 0.880 | 0.910 |  |
| D1 | 20.193 | 20.447 | Reference | 0.795 | 0.805 | Reference |
| E | 7.620 | 8.382 |  | 0.300 | 0.330 |  |
| E1 | 7.0612 | 7.5692 |  | 0.278 | 0.298 |  |
| e1 | 2.413 | 2.667 | Typical | 0.095 | 0.105 | Typical |
| ea | 7.366 | 7.874 | Reference | 0.290 | 0.310 | Reference |
| ев | 7.620 | 9.652 |  | 0.300 | 0.380 |  |
| L | 3.175 | 4.191 |  | 0.125 | 0.165 |  |
| N | 18 | 18 |  | 18 | 18 |  |
| S | - | 2.4892 |  | - | 0.098 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

Microchip

## Packaging Diagrams and Parameters

Package Type: 20-Lead Ceramic Side Brazed Dual In-line ( 300 mil )


| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 0.508 |  | - | 0.200 |  |
| A1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |
| A2 | - | - |  | - | - |  |
| A3 | 3.81 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.355 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.27 | 1.27 | Typical | 0.050 | 0.050 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 23.876 | 24.892 |  | 0.940 | 0.980 |  |
| D1 | 22.86 | 22.86 | Reference | 0.900 | 0.900 | Reference |
| E | 7.62 | 8.382 |  | 0.300 | 0.330 |  |
| E1 | 5.588 | 7.874 |  | 0.220 | 0.310 |  |
| e1 | 2.54 | 2.54 | Typical | 0.100 | 0.100 | Typical |
| eA | 7.62 | 7.62 | Reference | 0.300 | 0.300 | Reference |
| eB | 7.62 | 10.16 |  | 0.300 | 0.400 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 20 | 20 |  | 20 | 20 |  |
| S | 0.508 | 1.397 |  | 0.020 | 0.055 |  |
| S1 | 0.381 | 1.270 |  | 0.015 | 0.050 |  |

## Packaging Diagrams and Parameters

Package Type: 22-Lead Ceramic Side Brazed Dual In-line (. 400 mil)


| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 2.667 | 4.064 |  | 0.105 | 0.160 |  |
| A 1 | 0.7112 | 1.2192 |  | 0.028 | 0.048 |  |
| A2 | 2.032 | 3.302 |  | 0.080 | 0.130 |  |
| A3 | 1.778 | 2.921 |  | 0.070 | 0.115 |  |
| B | 0.4318 | 0.5842 |  | 0.017 | 0.023 |  |
| B1 | 1.016 | 1.016 | Typical | 0.040 | 0.040 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 27.1526 | 27.8638 |  | 1.069 | 1.091 |  |
| D1 | 25.2968 | 25.6032 | Reference | 0.992 | 1.008 | Reference |
| E | 10.160 | 10.922 |  | 0.400 | 0.430 |  |
| E1 | 9.7282 | 9.9822 |  | 0.383 | 0.393 |  |
| e1 | 2.3368 | 2.7432 | Typical | 0.092 | 0.108 | Typical |
| eA | 9.906 | 10.414 | Reference | 0.390 | 0.410 | Reference |
| ев | 10.160 | 12.192 |  | 0.400 | 0.480 |  |
| L | 3.175 | 4.191 |  | 0.125 | 0.165 |  |
| N | 22 | 22 |  | 22 | 22 |  |
| S | - | 2.032 |  | - | 0.080 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

Microchip

## Packaging Diagrams and Parameters

## Package Type: 24-Lead Ceramic Side Brazed Dual In-line (. 600 mil)



| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.048 | 4.445 |  | 0.120 | 0.175 |  |
| A1 $^{\circ}$ | 1.016 | 1.524 |  | 0.040 | 0.060 |  |
| A2 | 2.032 | 2.921 |  | 0.080 | 0.115 |  |
| A3 | 1.778 | 2.540 |  | 0.070 | 0.100 |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 30.1752 | 30.7848 |  | 1.188 | 1.212 |  |
| D1 | 27.7368 | 28.1432 | Reference | 1.092 | 1.108 | Reference |
| E | 14.986 | 16.002 |  | 0.590 | 0.630 |  |
| E1 | 14.7828 | 14.9352 |  | 0.582 | 0.588 |  |
| e1 | 2.3368 | 2.7432 | Typical | 0.092 | 0.108 | Typical |
| eA | 14.986 | 15.748 | Reference | 0.590 | 0.620 | Reference |
| eB | 14.986 | 16.256 |  | 0.590 | 0.640 |  |
| L | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| N | 24 | 24 |  | 24 | 24 |  |
| S | - | 2.540 |  | - | 0.100 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

## Packaging Diagrams and Parameters

Package Type: 24-Lead Ceramic Side Brazed Dual In-line with Window (. 600 mil )


| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.048 | 4.445 |  | 0.120 | 0.175 |  |
| A1 | 1.016 | 1.524 |  | 0.040 | 0.060 |  |
| A2 | 2.032 | 2.921 |  | 0.080 | 0.115 |  |
| А3 | 1.778 | 2.540 |  | 0.070 | 0.100 |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 30.1752 | 30.7848 |  | 1.188 | 1.212 |  |
| D1 | 27.7368 | 28.1432 | Reference | 1.092 | 1.108 | Reference |
| E | 14.986 | 16.002 |  | 0.590 | 0.630 |  |
| E1 | 14.7828 | 14.9352 |  | 0.582 | 0.588 |  |
| e1 | 2.3368 | 2.7432 | Typical | 0.092 | 0.108 | Typical |
| ea | 14.986 | 15.748 | Reference | 0.590 | 0.620 | Reference |
| eB | 14.986 | 16.256 |  | 0.590 | 0.640 |  |
| L | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| N | 24 | 24 |  | 24 | 24 |  |
| S | - | 2.540 |  | - | 0.100 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

Microchip

## Packaging Diagrams and Parameters

Package Type: 28-Lead Ceramic Side Brazed Dual In-line (. 600 mil )


| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.048 | 4.064 |  | 0.120 | 0.160 |  |
| A1 | 1.016 | 1.524 |  | 0.040 | 0.060 |  |
| A2 | 2.032 | 2.921 |  | 0.080 | 0.115 |  |
| А3 | 1.778 | 2.540 |  | 0.070 | 0.100 |  |
| B | 0.4572 | 0.508 |  | 0.018 | 0.020 |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 35.2044 | 35.9156 |  | 1.386 | 1.414 |  |
| D1 | 32.8168 | 33.2232 | Reference | 1.292 | 1.308 | Reference |
| E | 14.986 | 16.002 |  | 0.590 | 0.630 |  |
| E1 | 14.7828 | 15.1892 |  | 0.582 | 0.598 |  |
| e1 | 2.4892 | 2.5908 | Typical | 0.098 | 0.102 | Typical |
| eA | 14.986 | 15.494 | Reference | 0.590 | 0.610 | Reference |
| eB | 14.986 | 16.256 |  | 0.590 | 0.640 |  |
| L | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| N | 28 | 28 |  | 28 | 28 |  |
| S | - | 2.540 |  | - | 0.100 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

## Packaging Diagrams and Parameters

## Package Type: 28-Lead Ceramic Side Brazed Dual In-line with Window (. 600 mil )



| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.048 | 4.064 |  | 0.120 | 0.160 |  |
| A1 | 1.016 | 1.524 |  | 0.040 | 0.060 |  |
| A2 | 2.032 | 2.921 |  | 0.080 | 0.115 |  |
| A3 | 1.778 | 2.540 |  | 0.070 | 0.100 |  |
| B | 0.4572 | 0.508 |  | 0.018 | 0.020 |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 35.2044 | 35.9156 |  | 1.386 | 1.414 |  |
| D1 | 32.8168 | 33.2232 | Reference | 1.292 | 1.308 | Reference |
| E | 14.986 | 16.002 |  | 0.590 | 0.630 |  |
| E1 | 14.7828 | 15.1892 |  | 0.582 | 0.598 |  |
| $\mathrm{e}_{1}$ | 2.4892 | 2.5908 | Typical | 0.098 | 0.102 | Typical |
| eA | 14.986 | 15.494 | Reference | 0.590 | 0.610 | Reference |
| eB | 14.986 | 16.256 |  | 0.590 | 0.640 |  |
| L | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| N | 28 | 28 |  | 28 | 28 |  |
| S | - | 2.540 |  | - | 0.100 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

Microchip

## Packaging Diagrams and Parameters

Package Type: 40-Lead Ceramic Side Brazed Dual In-line (. 600 mil )


| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | 3.048 | 4.445 |  | 0.120 | 0.175 |  |  |
| A1 $^{2}$ | 1.016 | 1.524 |  | 0.040 | 0.060 |  |  |
| A2 | 2.032 | 2.921 |  | 0.080 | 0.115 |  |  |
| A3 | 1.829 | 2.235 |  | .072 | .088 |  |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |  |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |  |
| D | 50.546 | 51.308 |  | 1.990 | 2.020 |  |  |
| D1 | 48.056 | 48.463 | Reference | 1.892 | 1.908 | Reference |  |
| E | 15.240 | 16.256 |  | 0.600 | 0.640 |  |  |
| E1 | 14.478 | 15.748 |  | 0.570 | 0.620 |  |  |
| e1 | 2.3368 | 2.7432 | Typical | 0.092 | 0.108 | Typical |  |
| eA | 15.240 | 15.240 | Reference | 0.600 | 0.600 | Reference |  |
| eB | 14.986 | 16.256 |  | 0.590 | 0.640 |  |  |
| L | 3.302 | 4.064 |  | 0.130 | 0.160 |  |  |
| N | 40 | 40 |  | 40 | 40 |  |  |
| S | - | 2.4892 |  | - | 0.098 |  |  |
| S1 | 0.127 | - |  | 0.005 | - |  |  |

## Packaging Diagrams and Parameters

Package Type: 40-Lead Ceramic Side Brazed Dual In-line with Window (. 600 mil )


| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.048 | 4.445 |  | 0.120 | 0.175 |  |
| A1 | 1.016 | 1.524 |  | 0.040 | 0.060 |  |
| A2 | 2.032 | 2.921 |  | 0.080 | 0.115 |  |
| А3 | 1.829 | 2.235 |  | . 072 | . 088 |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 50.546 | 51.308 |  | 1.990 | 2.020 |  |
| D1 | 48.056 | 48.463 | Reference | 1.892 | 1.908 | Reference |
| E | 15.240 | 16.256 |  | 0.600 | 0.640 |  |
| E1 | 14.478 | 15.748 |  | 0.570 | 0.620 |  |
| e1 | 2.3368 | 2.7432 | Typical | 0.092 | 0.108 | Typical |
| ea | 15.240 | 15.240 | Reference | 0.600 | 0.600 | Reference |
| eB | 14.986 | 16.256 |  | 0.590 | 0.640 |  |
| L | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| N | 40 | 40 |  | 40 | 40 |  |
| S | - | 2.4892 |  | - | 0.098 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

Microchip

## Packaging Diagrams and Parameters

Package Type: 48-Lead Ceramic Side Brazed Dual In-line (. 600 mil)


Area


| Package Group: Ceramic Side Brazed Dual In-line (CER) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 3.048 | 4.445 |  | 0.120 | 0.175 |  |
| A1 | 1.016 | 1.524 |  | 0.040 | 0.060 |  |
| A2 | 2.032 | 2.921 |  | 0.080 | 0.115 |  |
| А3 | 1.829 | 2.235 |  | 0.072 | 0.088 |  |
| B | 0.4064 | 0.508 |  | 0.016 | 0.020 |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| C | 0.2286 | 0.3048 | Typical | 0.009 | 0.012 | Typical |
| D | 60.3504 | 61.5696 |  | 2.376 | 2.424 |  |
| D1 | 58.2168 | 58.6232 | Reference | 2.292 | 2.308 | Reference |
| E | 15.240 | 16.256 |  | 0.600 | 0.640 |  |
| E1 | 14.478 | 15.748 |  | 0.570 | 0.620 |  |
| e1 | 2.3368 | 2.7432 | Typical | 0.092 | 0.108 | Typical |
| eA | 15.240 | 15.290 | Reference | 0.600 | 0.600 | Reference |
| eB | 14.986 | 16.256 |  | 0.590 | 0.640 |  |
| L | 3.302 | 4.064 |  | 0.130 | 0.160 |  |
| N | 48 | 48 |  | 48 | 48 |  |
| S | - | 2.4892 |  | - | 0.100 |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

## Packaging Diagrams and Parameters

## Ceramic Cerdip Dual In-line Family

| Symbol List for Ceramic Cerdip Dual In-line Package Parameters |  |
| :---: | :---: |
| Symbol | Description of Parameters |
| $\alpha$ | Angular spacing between min and max lead positions measured at the guage plane |
| A | Distance between seating plane to highest point of body (lid) |
| A1 | Distance between seating plane and base plane |
| A2 | Distance from base plane to highest point of body (lid) |
| А3 | Base body thickness |
| B | Width of terminal leads |
| B1 | Width of terminal lead shoulder which locate seating plane (standoff geometry optional) |
| C | Thickness of terminal leads |
| D | Largest overall package parameter of length |
| D1 | Body length parameter - end lead center to end lead center |
| E | Largest overall package width parameter outside of lead |
| E1 | Body width parameters not including leads |
| ea | Linear spacing of true minimum lead position center line to center line |
| eB | Linear spacing between true lead position outside of lead to outside of lead |
| $\mathrm{e}_{1}$ | Linear spacing between center lines of body standoffs (terminal leads) |
| L | Distance from seating plane to end of lead |
| N | Total number of potentially useable lead positions |
| S | Distance from true position center line of No. 1 lead to the extremity of the body |
| S1 | Distance from other end lead edge positions to the extremity of the body |

Notes:

1. Controlling parameter: inches.
2. Parameter " $e_{1}$ " ("e") is non-cumulative.
3. Seating plane (standoff) is defined by board hole size.
4. Parameter " $\mathrm{B}_{1}$ " is nominal.

## Packaging Diagrams and Parameters

## Package Type: 8-Lead Cerdip Dual In-line (. 300 mil)



| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.080 |  | - | 0.200 |  |
| A1 | 0.381 | 1.524 |  | 0.015 | 0.060 |  |
| A2 | - | - | Ref. A3 | - | - | Ref. A3 |
| A3 | 3.810 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 9.398 | 10.287 |  | 0.370 | 0.405 |  |
| D1 | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| E | 7.620 | 8.255 |  | 0.300 | 0.325 |  |
| E1 | 5.588 | 7.874 |  | 0.220 | 0.310 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| ea | 7.366 | 8.128 | Referemce | 0.290 | 0.320 | Reference |
| eB | 7.620 | 10.160 |  | 0.300 | 0.400 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 8 | 8 |  | 8 | 8 |  |
| S | 5.08 | 1.397 |  | 0.020 | 0.055 |  |
| S1 | 0.381 | 1.270 |  | 0.015 | 0.050 |  |

## Packaging Diagrams and Parameters

## Package Type: 16-Lead Ceramic Cerdip Dual In-line (. 300 mil)



| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 4.191 | 5.080 |  | 0.165 | 0.200 |  |
| A1 | 0.381 | 1.524 |  | 0.015 | 0.060 |  |
| A2 | - | - | Ref. A3 | - | - | Ref. A3 |
| Аз | 3.810 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 19.050 | 20.320 |  | 0.750 | 0.800 |  |
| D1 | 17.780 | 17.780 | Reference | 0.700 | 0.700 | Reference |
| E | 7.493 | 8.255 |  | 0.295 | 0.325 |  |
| E1 | 5.588 | 7.874 |  | 0.220 | 0.310 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| eA | 7.366 | 8.128 | Reference | 0.290 | 0.320 | Reference |
| eB | 7.62 | 10.160 |  | 0.300 | 0.400 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 16 | 16 |  | 16 | 16 |  |
| S | 5.08 | 1.397 |  | 0.020 | 0.055 |  |
| S1 | 0.381 | 1.270 |  | 0.015 | 0.050 |  |

## Packaging Diagrams and Parameters

## Package Type: 18-Lead Ceramic Cerdip Dual In-line (. 300 mil )



| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.080 |  | - | 0.200 |  |
| A1 | 0.381 | 1.524 |  | 0.015 | 0.070 |  |
| A2 | - | - | Ref. A3 | - | - | Ref. A3 |
| А3 | 3.180 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 22.352 | 23.622 |  | 0.880 | 0.930 |  |
| D1 | 20.320 | 20.320 | Reference | 0.800 | 0.800 | Reference |
| E | 7.620 | 8.382 |  | 0.300 | 0.330 |  |
| E1 | 5.588 | 7.874 |  | 0.220 | 0.310 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| eA | 7.366 | 8.128 | Reference | 0.290 | 0.320 | Reference |
| eB | 7.62 | 10.160 |  | 0.300 | 0.400 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 18 | 18 |  | 18 | 18 |  |
| S | 5.08 | 1.397 |  | 0.020 | 0.055 |  |
| S1 | 0.381 | 1.270 |  | 0.015 | 0.050 |  |

## Packaging Diagrams and Parameters

Package Type: 18-Lead Cerdip Dual In-line with Window (. 300 mil)


| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.080 |  | - | 0.200 |  |
| A1 | 0.381 | 1.524 |  | 0.015 | 0.070 |  |
| A2 | 3.810 | 4.699 |  | 0.150 | 0.185 |  |
| А3 | 3.180 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 22.352 | 23.622 |  | 0.880 | 0.930 |  |
| D1 | 20.320 | 20.320 | Reference | 0.800 | 0.800 | Reference |
| E | 7.620 | 8.382 |  | 0.300 | 0.330 |  |
| E1 | 5.588 | 7.874 |  | 0.220 | 0.310 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| eA | 7.366 | 8.128 | Reference | 0.290 | 0.320 | Reference |
| ев | 7.62 | 10.160 |  | 0.300 | 0.400 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 18 | 18 |  | 18 | 18 |  |
| S | 5.08 | 1.397 |  | 0.020 | 0.055 |  |
| S1 | 0.381 | 1.270 |  | 0.015 | 0.050 |  |

Microchip

## Packaging Diagrams and Parameters

## Package Type: 20-Lead Ceramic Dual In-line ( .300 mil)



Area


| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | . 508 |  | - | 0.200 |  |
| A1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |
| A2 | - | - | Ref. A3 | - | - | Ref. A3 |
| A3 | 3.81 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.355 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.27 typ | 1.27 typ | Typical | 0.050 typ | 0.050 typ | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 23.876 | 24.892 |  | 0.940 | 0.980 |  |
| D1 | 22.86 | 22.86 | Reference | 0.900 | 0.900 | Reference |
| E | 7.62 | 8.382 |  | 0.300 | 0.330 |  |
| E1 | 5.588 | 7.874 |  | 0.220 | 0.310 |  |
| e1 | 2.54 | 2.54 | Typical | 0.100 | 0.100 | Typical |
| ea | 7.62 | 7.62 | Reference | 0.300 | 0.300 | Reference |
| eB | 7.62 | 10.16 |  | 0.300 | 0.400 |  |
| L | 3.175 | 3.81 |  | 0.125 | 0.150 |  |
| N | 20 | 20 |  | 20 | 20 |  |
| S | 0.508 | 1.397 |  | 0.020 | 0.055 |  |
| S1 | 0.381 | 1.27 |  | 0.015 | 0.050 |  |

## Packaging Diagrams and Parameters

## Package Type: 22-Lead Ceramic Cerdip Dual In-line (. 400 mil )



| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.715 |  | - | 0.225 |  |
| A1 | 0.381 | 1.524 |  | 0.015 | 0.070 |  |
| A2 | - | - | Ref. A3 | - | - | Ref. A3 |
| А3 | 3.180 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 26.670 | 27.940 |  | 1.050 | 1.100 |  |
| D1 | 25.400 | 25.400 | Reference | 1.000 | 1.000 | Reference |
| E | 10.160 | 10.922 |  | 0.400 | 0.430 |  |
| E1 | 8.890 | 10.414 |  | 0.350 | 0.410 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| ea | 9.906 | 10.668 | Reference | 0.390 | 0.420 | Reference |
| eB | 10.160 | 12.700 |  | 0.400 | 0.500 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 18 | 18 |  | 22 | 22 |  |
| S | - | 1.270 |  | - | 0.050 |  |
| S1 | 0.127 | 1.270 |  | 0.005 | 0.050 |  |

Microchip

## Packaging Diagrams and Parameters

## Package Type: 24-Lead Ceramic Cerdip Dual In-line (. 300 mil )



| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | - | 5.715 |  | - | 0.225 |  |  |
| A1 $^{\circ}$ | 0.381 | 1.905 |  | 0.015 | 0.075 |  |  |
| A2 $^{2}$ | - | - | Ref. A3 | - | - | Ref. A3 |  |
| A3 $^{2}$ | 3.810 | 4.445 |  | 0.150 | 0.175 |  |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |  |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 31.115 | 32.385 |  | 1.225 | 1.275 |  |  |
| D1 | 27.940 | 27.940 | Reference | 1.100 | 1.100 | Reference |  |
| E | 7.620 | 8.382 |  | 0.300 | 0.330 |  |  |
| E1 | 5.588 | 7.894 |  | 0.220 | 0.310 |  |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |  |
| eA | 7.366 | 8.128 | Reference | 0.290 | 0.320 | Reference |  |
| eB | 7.62 | 11.43 |  | 0.300 | 0.450 |  |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |  |
| N | 24 | 24 |  | 24 | 24 |  |  |
| S | 1.016 | 2.286 |  | 0.040 | 0.090 |  |  |
| S1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |  |

## Packaging Diagrams and Parameters

Package Type: 24-Lead Ceramic Cerdip Dual In-line with Window (. 300 mil)


| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Mores | Min | Max |  |
|  | Min | Max | Notes | Notes |  |  |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | - | 5.715 |  | - | 0.225 |  |  |
| A1 | 0.381 | 1.905 |  | 0.015 | 0.075 |  |  |
| A2 | 3.810 | 4.699 |  | 0.150 | 0.185 |  |  |
| A3 | 3.810 | 4.445 |  | 0.150 | 0.175 |  |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |  |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 31.115 | 32.385 |  | 1.225 | 1.275 |  |  |
| D1 | 27.940 | 27.940 | Reference | 1.100 | 1.100 | Reference |  |
| E | 7.62 | 8.382 |  | 0.300 | 0.330 |  |  |
| E1 | 5.588 | 7.874 |  | 0.220 | 0.310 |  |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |  |
| eA | 7.366 | 8.128 | Reference | 0.290 | 0.320 | Reference |  |
| eB | 7.62 | 11.43 |  | 0.300 | 0.450 |  |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |  |
| N | 24 | 24 |  | 24 | 24 |  |  |
| S | 1.016 | 2.286 |  | 0.040 | 0.090 |  |  |
| S1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |  |

## Packaging Diagrams and Parameters

Package Type: 24-Lead Ceramic Cerdip Dual In-line (. 600 mil )


| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.715 |  | - | 0.225 |  |
| A1 | 0.381 | 1.524 |  | 0.015 | 0.075 |  |
| A2 | - | - | Ref. A3 | - | - | Ref. A3 |
| A3 | 3.810 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 31.115 | 32.385 |  | 1.225 | 1.275 |  |
| D1 | 27.940 | 27.940 | Reference | 1.100 | 1.100 | Reference |
| E | 15.240 | 15.875 |  | 0.600 | 0.625 |  |
| E1 | 12.954 | 15.240 |  | 0.510 | 0.600 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| eA | 14.986 | 15.748 | Reference | 0.590 | 0.620 | Reference |
| eB | 15.240 | 18.034 |  | 0.600 | 0.710 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 24 | 24 |  | 24 | 24 |  |
| S | 1.016 | 2.286 |  | 0.040 | 0.090 |  |
| S1 | 0.127 | 1.778 |  | 0.015 | 0.070 |  |

## Packaging Diagrams and Parameters

## Package Type: 24-Lead Ceramic Cerdip Dual In-line with Window (. 600 mil )



| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0{ }^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.715 |  | - | 0.225 |  |
| A1 | 0.381 | 1.524 |  | 0.015 | 0.075 |  |
| A2 | 3.810 | 4.699 |  | 0.150 | 0.185 |  |
| A3 | 3.810 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 31.115 | 32.385 |  | 1.225 | 1.275 |  |
| D1 | 27.940 | 27.940 | Reference | 1.100 | 1.100 | Reference |
| E | 15.240 | 15.875 |  | 0.600 | 0.625 |  |
| E1 | 12.954 | 15.240 |  | 0.510 | 0.600 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| eA | 14.986 | 15.748 | Reference | 0.590 | 0.620 | Reference |
| eB | 15.240 | 18.034 |  | 0.600 | 0.710 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 24 | 24 |  | 24 | 24 |  |
| S | 1.016 | 2.286 |  | 0.040 | 0.090 |  |
| S1 | 0.127 | 1.778 |  | 0.015 | 0.070 |  |

## Packaging Diagrams and Parameters

Package Type: 28-Lead Ceramic Cerdip Dual In-line (. 600 mil )


| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | - | 5.461 |  | - | 0.215 |  |  |
| A1 $^{2}$ | 0.381 | 1.524 |  | 0.015 | 0.060 |  |  |
| A2 | - | - | Ref. A3 | - | - | Ref. A3 |  |
| A3 | 3.810 | 4.445 |  | 0.150 | 0.175 |  |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |  |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 36.195 | 36.195 |  | 1.425 | 1.475 |  |  |
| D1 | 33.020 | 33.020 | Reference | 1.300 | 1.300 | Reference |  |
| E | 15.240 | 15875 |  | 0.600 | 0.625 |  |  |
| E1 | 12.954 | 15.240 |  | 0.510 | 0.600 |  |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |  |
| eA | 14.986 | 8.128 | Reference | 0.590 | 0.620 | Reference |  |
| eB | 15.240 | 18.034 |  | 0.600 | 0.710 |  |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |  |
| N | 28 | 28 |  | 28 | 28 |  |  |
| S | 1.016 | 2.286 |  | 0.040 | 0.090 |  |  |
| S1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |  |

## Packaging Diagrams and Parameters

Package Type: 28-Lead Ceramic Cerdip Dual In-line with Window (. 600 mil)


| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.461 |  | - | 0.215 |  |
| A1 | 0.381 | 1.524 |  | 0.015 | 0.060 |  |
| A2 | 3.810 | 4.699 |  | 0.150 | 0.185 |  |
| А3 | 3.810 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 36.195 | 36.195 |  | 1.425 | 1.475 |  |
| D1 | 33.020 | 33.020 | Reference | 1.300 | 1.300 | Reference |
| E | 15.240 | 15875 |  | 0.600 | 0.625 |  |
| E1 | 12.954 | 15.240 |  | 0.510 | 0.600 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| eA | 14.986 | 8.128 | Reference | 0.590 | 0.620 | Reference |
| eB | 15.240 | 18.034 |  | 0.600 | 0.710 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 28 | 28 |  | 28 | 28 |  |
| S | 1.016 | 2.286 |  | 0.040 | 0.090 |  |
| S1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |

Microchip

## Packaging Diagrams and Parameters

## Package Type: 40-Lead Ceramic Cerdip Dual In-line (. 600 mil)



| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 4.318 | 5.715 |  | 0.170 | 0.225 |  |
| A1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |
| A2 | - | - | Ref. A3 | - | - | Ref. A3 |
| А3 | 3.810 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 51.435 | 52.705 |  | 2.025 | 2.075 |  |
| D1 | 48.260 | 48.260 | Reference | 1.900 | 1.900 | Reference |
| E | 15.240 | 15875 |  | 0.600 | 0.625 |  |
| E1 | 12.954 | 15.240 |  | 0.510 | 0.600 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| eA | 14.986 | 16.002 | Reference | 0.590 | 0.630 | Reference |
| eB | 15.240 | 18.034 |  | 0.600 | 0.710 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 40 | 40 |  | 40 | 40 |  |
| S | 1.016 | 2.286 |  | 0.040 | 0.090 |  |
| S1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |

## Packaging Diagrams and Parameters

## Package Type: 40-Lead Ceramic Cerdip Dual In-line with Window (. 600 mil )



| Package Group: Ceramic Cerdip Dual In-line (CDP) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | 4.318 | 5.715 |  | 0.170 | 0.225 |  |
| A1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |
| A2 | 3.810 | 4.699 | Ref. A3 | 0.150 | 0.185 | Ref. A3 |
| A3 | 3.810 | 4.445 |  | 0.150 | 0.175 |  |
| B | 0.356 | 0.584 |  | 0.014 | 0.023 |  |
| B1 | 1.270 | 1.651 | Typical | 0.050 | 0.065 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 51.435 | 52.705 |  | 2.025 | 2.075 |  |
| D1 | 48.260 | 48.260 | Reference | 1.900 | 1.900 | Reference |
| E | 15.240 | 15875 |  | 0.600 | 0.625 |  |
| E1 | 12.954 | 15.240 |  | 0.510 | 0.600 |  |
| e1 | 2.540 | 2.540 | Typical | 0.100 | 0.100 | Typical |
| ea | 14.986 | 16.002 | Reference | 0.590 | 0.630 | Reference |
| eB | 15.240 | 18.034 |  | 0.600 | 0.710 |  |
| L | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| N | 40 | 40 |  | 40 | 40 |  |
| S | 1.016 | 2.286 |  | 0.040 | 0.090 |  |
| S1 | 0.381 | 1.778 |  | 0.015 | 0.070 |  |

## Packaging Diagrams and Dimensions

## Ceramic Flatpack Family

| Symbol List for Ceramic Flatpack Package Parameters |  |
| :---: | :--- |
| Symbol | Description of Parameters |
| A | Distance between seating plane to highest point of body (lid) |
| B | Width of terminal leads |
| C | Thickness of terminal leads |
| D | Largest overall package parameter of length |
| $\mathrm{D}_{1}$ | Body length parameter - end lead center to end lead center |
| E | Largest overall package width parameter outside of lead |
| E2, E3 | Body width parameters not including leads |
| e | Linear spacing between center lines of body standoffs (terminal leads) |
| H | Other package width parameter |
| L | Distance from package body to end of lead |
| N | Total number of potentially useable lead positions |
| Q | Distance between seating plane and lead |
| S | Distance from true position center line of No. 1 lead to the extremity of the body |
| S1 | Distance from other end lead edge positions to the extremity of the body |

## Notes:

1. Controlling parameter: inches.
2. Parameter "e1" ("e") is non-cumulative.
3. Seating plane (standoff) is defined by board hole size.
4. Parameters " B " and " C " are nominal.

## Packaging Diagrams and Dimensions

## Package Type: 28-Lead Ceramic Flatpack



| Package Group: Ceramic Flatpack (CFPK) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| A | 2.286 | 3.302 |  | 0.090 | 0.130 |  |
| B | 0.381 | 0.4826 |  | 0.015 | 0.019 | Typical |
| C | 0.0762 | 0.1524 |  | 0.003 | 0.006 | Typical |
| D | 17.780 | 18.796 |  | 0.700 | 0.740 |  |
| D1 | 16.307 | 16.713 |  | 0.642 | 0.658 | Reference |
| E | 9.652 | 10.668 |  | 0.380 | 0.420 |  |
| E2 | 9.756 | - |  | 0.180 | - |  |
| E3 | 0.762 | - |  | 0.030 | - |  |
| e | 1.270 | 1.270 |  | 0.050 | 0.050 | Typical |
| H | 22.352 | 29.464 |  | 0.880 | 1.160 |  |
| L | 6.350 | 9.398 |  | 0.250 | 0.370 |  |
| N | 28 | 28 |  | 28 | 28 |  |
| Q | 0.660 | 1.143 |  | 0.026 | 0.045 |  |
| S | 0.889 | 1.016 |  | 0.035 | 0.040 |  |
| S1 | 0.254 | 0.381 |  | 0.010 | 0.015 |  |

## Packaging Diagrams and Parameters

## Ceramic Leadless Chip Carrier Family

| Symbol List for Ceramic Leadless Chip Carrier Package Parameters |  |
| :---: | :--- |
| Symbol |  |
| A | Thickness of base body |
| $A_{1}$ | Total package height |
| $A_{2}$ | Distance from base body to highest point of body (lid) |
| B | Width of terminal lead pin |
| D | Largest overall package dimension of length |
| $D_{1}, E_{1}$ | Body length dimension - end lead center to end lead center |
| E | Largest overall package dimension of width |
| e | Linear spacing |
| e1 | Linear spacing between edges of true lead positions (of corner terminal lead pads) <br> lead corner to lead corner |
| h | Depth of major index feature |
| L | Width of minor index feature |
| $N$ | Distance from package edge to end of effective pad |

Notes:

1. Controlling dimension: inches.
2. Dimension " $e_{1}$ ("e") is non-cumulative.
3. Seating plane (standoff) is defined by PC board hole size.
4. Dimension " B " is nominal.
5. Corner configuration optional.

Microchip

## Packaging Diagrams and Parameters

Package Type: 28-Lead Ceramic Leadless Chip Carrier


| Package Group: Ceramic Leadless Chip Carrier (LCC) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| A | 1.397 | 2.159 |  | 0.055 | 0.085 |  |
| A1 $^{2}$ | 1.651 | 2.540 |  | 0.065 | 0.100 |  |
| A2 | 0.254 | 0.381 |  | 0.010 | 0.015 |  |
| B | 0.5588 | 0.7112 | Typical | 0.022 | 0.028 | Typical |
| D | 11.2268 | 11.684 |  | 0.442 | 0.460 |  |
| D1 $^{2}$ | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| E | 11.2268 | 11.684 |  | 0.442 | 0.460 |  |
| E1 | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| e1 | 0.38 | - | Typical | 0.015 | - | Typical |
| h | 1.02 | 1.02 | Reference | 0.040 | 0.040 | Reference |
| j | 0.51 | 0.51 | Reference | 0.020 | 0.020 | Reference |
| L | 1.143 | 1.397 | Typical | 0.045 | 0.055 | Typical |
| N | 28 | 28 |  | 28 | 28 |  |

Microchip

## Packaging Diagrams and Parameters

## Package Type: 28-Lead Ceramic Leadless Chip Carrier with Window



| Package Group: Ceramic Leadless Chip Carrier (LCC) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| A | 1.397 | 2.159 |  | 0.055 | 0.085 |  |
| A1 | 2.286 | 3.302 |  | 0.090 | 0.100 |  |
| A2 | 0.889 | 1.143 |  | 0.035 | 0.045 |  |
| B | 0.5588 | 0.7112 | Typical | 0.022 | 0.028 | Typical |
| D | 11.2268 | 11.684 |  | 0.442 | 0.460 |  |
| D1 | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| E | 11.2268 | 11.684 |  | 0.442 | 0.460 |  |
| E1 | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| e1 | 0.38 | - | Typical | 0.015 | - | Typical |
| h | 1.02 | 1.02 | Reference | 0.040 | 0.040 | Reference |
| j | 0.51 | 0.51 | Reference | 0.020 | 0.020 | Reference |
| L | 1.143 | 1.397 | Typical | 0.045 | 0.055 | Typical |
| N | 28 | 28 |  | 28 | 28 |  |

## Packaging Diagrams and Parameters

Package Type: 32-Lead Ceramic Leadless Chip Carrier


| Package Group: Ceramic Leadless Chip Carrier (LCC) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| A | 1.397 | 2.159 |  | 0.055 | 0.085 |  |
| A1 $^{2}$ | 2.54 | 3.048 |  | 0.100 | 0.120 |  |
| A2 | 0.254 | 0.381 |  | 0.010 | 0.015 |  |
| B | 0.635 | 0.7112 | Typical | 0.025 | 0.026 | Typical |
| D | 13.716 | 14.224 |  | 0.540 | 0.560 |  |
| $\mathrm{D}_{1}$ | 9.98 | 10.34 | Reference | 0.393 | 0.407 | Reference |
| E | 11.2268 | 11.684 |  | 0.442 | 0.458 |  |
| E1 | 7.442 | 7.80 | Reference | 0.293 | 0.307 | Reference |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| e1 | 0.38 | - | Typical | 0.015 | - | Typical |
| h | 1.02 | 1.02 | Reference | 0.040 | 0.040 | Reference |
| j | 0.51 | 0.51 | Reference | 0.020 | 0.020 | Reference |
| L | 1.143 | 1.397 | Typical | 0.045 | 0.055 | Typical |
| N | 32 | 32 |  | 32 | 32 |  |

Microchip

## Packaging Diagrams and Parameters

## Package Type: 32-Lead Ceramic Leadless Chip Carrier - FRIT



| Package Group: Ceramic Leadless Chip Carrier (LCC) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| A | 1.397 | 2.159 |  | 0.055 | 0.085 |  |
| $\mathrm{~A}_{1}$ | 2.286 | 3.302 |  | 0.090 | 0.130 |  |
| $\mathrm{~A}_{2}$ | 0.635 | 1.143 |  | 0.025 | 0.045 |  |
| B | 0.5588 | 0.7112 | Typical | 0.022 | 0.028 | Typical |
| D | 13.716 | 14.224 |  | 0.540 | 0.560 |  |
| $\mathrm{D}_{1}$ | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| E | 11.2268 | 11.6332 |  | 0.442 | 0.458 |  |
| $\mathrm{E}_{1}$ | 10.160 | 10.160 | Reference | 0.400 | 0.400 | Reference |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| e1 | 0.38 | - | Typical | 0.015 | - | Typical |
| h | 1.02 | 1.02 | Reference | 0.040 | 0.040 | Reference |
| j | 0.51 | 0.51 | Reference | 0.020 | 0.020 | Reference |
| L | 1.143 | 1.397 | Typical | 0.045 | 0.055 | Typical |
| N | 32 | 32 |  | 32 | 32 |  |

## Packaging Diagrams and Parameters

Package Type: 32-Lead Ceramic Leadless Chip Carrier with Window


| Package Group: Ceramic Leadless Chip Carrier (LCC) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| A | 1.397 | 2.159 |  | 0.055 | 0.085 |  |
| A1 | 2.286 | 3.302 |  | 0.090 | 0.130 |  |
| A2 | 0.889 | 1.143 |  | 0.035 | 0.045 |  |
| B | 0.5588 | 0.7112 | Typical | 0.022 | 0.028 | Typical |
| D | 13.716 | 14.224 |  | 0.540 | 0.560 |  |
| D1 $^{2}$ | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| E | 11.2268 | 11.6332 |  | 0.442 | 0.458 |  |
| E1 | 10.160 | 10.160 | Reference | 0.400 | 0.400 | Reference |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| e1 | 0.38 | - | Typical | 0.015 | - | Typical |
| h | 1.02 | 1.02 | Reference | 0.040 | 0.040 | Reference |
| j | 1.02 | 1.02 | Reference | 0.020 | 0.020 | Reference |
| L | 1.143 | 1.397 | Typical | 0.045 | 0.055 | Typical |
| N | 32 | 32 |  | 32 | 32 |  |

## Packaging Diagrams and Parameters

## Package Type: 32-Lead Ceramic Leadless Chip Carrier with FRIT Window



| Package Group: Ceramic Leadless Chip Carrier (LCC) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| A | 1.397 | 2.159 |  | 0.055 | 0.085 |  |
| A1 $_{1}$ | 2.286 | 3.302 |  | 0.090 | 0.130 |  |
| A2 | 0.889 | 1.143 |  | 0.035 | 0.045 |  |
| B | 0.5588 | 0.7112 | Typical | 0.022 | 0.028 | Typical |
| D | 13.716 | 14.224 |  | 0.540 | 0.560 |  |
| D1 $_{1}$ | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| E | 11.2268 | 11.6332 |  | 0.442 | 0.458 |  |
| E1 | 10.160 | 10.160 | Reference | 0.400 | 0.400 | Reference |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| e1 | 0.38 | - | Typical | 0.015 | - | Typical |
| h | 1.02 | 1.02 | Reference | 0.040 | 0.040 | Reference |
| j | 0.51 | 0.51 | Reference | 0.020 | 0.020 | Reference |
| L | 1.143 | 1.397 | Typical | 0.045 | 0.055 | Typical |
| N | 32 | 32 |  | 32 | 32 |  |

Microchip

## Packaging Diagrams and Parameters

Package Type: 44-Lead Ceramic Leadless Chip Carrier


| Package Group: Ceramic Leadless Chip Carrier (LCC) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| A | 1.37 | 2.082 |  | 0.054 | 0.082 |  |
| A1 | 1.778 | 3.048 |  | 0.070 | 0.120 |  |
| A2 | 0.254 | 1.143 |  | 0.010 | 0.045 |  |
| B | 0.584 | 0.7112 | Typical | 0.023 | 0.028 | Typical |
| D | 16.256 | 16.8148 |  | 0.640 | 0.662 |  |
| D1 | 12.700 | 12.700 | Reference | 0.500 | 0.500 | Reference |
| E | 16.256 | 16.8148 |  | 0.640 | 0.662 |  |
| E1 | 12.700 | 12.700 | Reference | 0.500 | 0.500 | Reference |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| e1 | 0.38 | - | Typical | 0.015 | - | Typical |
| h | 1.02 | 1.02 | Reference | 0.040 | 0.040 | Reference |
| j | 0.51 | 0.51 | Reference | 0.020 | 0.020 | Reference |
| L | 1.143 | 1.397 | Typical | 0.045 | 0.055 | Typical |
| N | 44 | 44 |  | 44 | 44 |  |

Microchip

## Packaging Diagrams and Parameters

## Packaging Diagrams and Dimensions

## Plastic Dual In-line Family

| Symbol List for Plastic Dual In-line Package Parameters |  |
| :---: | :--- |
| Symbol | Description of Parameters |
| $\alpha$ | Angular spacing between min and max lead positions measured at the guage plane |
| A | Distance between seating plane to highest point of body |
| $\mathrm{A} 1^{2}$ | Distance between seating plane and base plane |
| A 2 | Base body thickness |
| B | Width of terminal leads |
| $\mathrm{B}_{1}$ | Width of terminal lead shoulder which locate seating plane (standoff geometry optional) |
| C | Thickness of terminal leads |
| D | Largest overall package parameter of length |
| $\mathrm{D}_{1}$ | Body length parameter - end lead center to end lead center |
| E | Largest overall package width parameter outside of lead |
| $\mathrm{E}_{1}$ | Body width parameters not including leads |
| eA | Linear spacing of true minimum lead position center line to center line |
| eB | Linear spacing between true lead position outside of lead to outside of lead |
| e1 | Linear spacing between center lines of body standoffs (terminal leads) |
| L | Distance from seating plane to end of lead |
| N | Total number of potentially useable lead positions |
| S | Distance from true position center line of No. 1 lead to the extremity of the body |
| S1 | Distance from other end lead edge positions to the extremity of the body |

## Notes:

1. Controlling parameter: inches.
2. Parameter " $e_{1}$ (" $e$ ") is non-cumulative.
3. Seating plane (standoff) is defined by board hole size.
4. Parameter " $B_{1}$ " is nominal.
5. Details of pin No. 1 identifier are optional.

## Packaging Diagrams and Dimensions

## Package Type: 8-Lead Plastic Dual In-line (. 300 mil)



| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Motes | Min | Max |  |
|  | Min | Max | Noter | Notes |  |  |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | - | 4.064 |  | - | 0.160 |  |  |
| A1 $^{2}$ | 0.381 | - |  | 0.015 | - |  |  |
| A2 | 3.048 | 3.810 |  | 0.120 | 0.150 |  |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |  |
| B1 | 1.524 | 1.524 | Typical | 0.060 | 0.060 | Typical |  |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 9.144 | 10.922 |  | 0.360 | 0.430 |  |  |
| D1 | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |  |
| E | 7.620 | 8.255 |  | 0.300 | 0.325 |  |  |
| E1 | 6.096 | 7.112 |  | 0.240 | 0.280 |  |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |  |
| eA | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |  |
| eB | 7.874 | 9.906 |  | 0.310 | 0.390 |  |  |
| L | 3.048 | 3.556 |  | 0.120 | 0.140 |  |  |
| N | 8 | 8 |  | 8 | 8 |  |  |
| S | 0.889 | - |  | 0.035 | - |  |  |
| S1 | 0.127 | - |  | 0.005 | - |  |  |

## Packaging Diagrams and Dimensions

## Package Type: 14-Lead Plastic Dual In-line (. 300 mil)



| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | - | 4.064 |  | - | 0.160 |  |  |
| A1 $^{2}$ | 0.381 | - |  | 0.015 | - |  |  |
| A2 | 3.048 | 3.810 |  | 0.120 | 0.150 |  |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |  |
| B1 | 1.524 | 1.524 | Typical | 0.060 | 0.060 | Typical |  |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 18.415 | 19.431 |  | 0.725 | 0.765 |  |  |
| D1 | 15.240 | 15.240 | Reference | 0.600 | 0.600 | Reference |  |
| E | 7.620 | 8.255 |  | 0.300 | 0.325 |  |  |
| E1 | 6.096 | 7.112 |  | 0.240 | 0.280 |  |  |
| e1 | 2.4892 | 2.591 | Typical | 0.098 | 0.102 | Typical |  |
| eA | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |  |
| eB | 7.874 | 9.906 |  | 0.310 | 0.390 |  |  |
| L | 3.048 | 3.556 |  | 0.120 | 0.140 |  |  |
| N | 14 | 14 |  | 14 | 14 |  |  |
| S | 0.889 | - |  | 0.035 | - |  |  |
| S1 | 0.127 | - |  | 0.005 | - |  |  |

Microchip

## Packaging Diagrams and Dimensions

Package Type: 16-Lead Plastic Dual In-line (. 300 mil )


| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | - | 4.064 |  | - | 0.160 |  |  |
| A1 $^{\circ}$ | 0.381 | - |  | 0.015 | - |  |  |
| A2 $_{2}$ | 3.048 | 3.810 |  | 0.120 | 0.150 |  |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |  |
| B1 $_{1}$ | 1.524 | 1.524 | Typical | 0.060 | 0.060 | Typical |  |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 18.923 | 19.939 |  | 0.745 | 0.785 |  |  |
| D1 | 17.780 | 17.780 | Reference | 0.700 | 0.700 | Reference |  |
| E | 7.620 | 8.255 |  | 0.300 | 0.325 |  |  |
| E1 | 6.096 | 7.112 |  | 0.240 | 0.280 |  |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |  |
| eA | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |  |
| eB | 7.874 | 9.906 |  | 0.310 | 0.390 |  |  |
| L | 3.0480 | 3.556 |  | 0.120 | 0.140 |  |  |
| N | 16 | 16 |  |  | 16 | 16 |  |
| S | 0.889 | - |  | 0.035 | - |  |  |
| S1 | 0.127 | - |  | 0.005 | - |  |  |

Microchip

## Packaging Diagrams and Dimensions

Package Type: 18-Lead Plastic Dual In-line (. 300 mil)


| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | - | 4.064 |  | - | 0.160 |  |  |
| A1 $^{2}$ | 0.381 | - |  | 0.015 | - |  |  |
| A2 | 3.048 | 3.810 |  | 0.120 | 0.150 |  |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |  |
| B1 $_{1}$ | 1.524 | 1.524 | Typical | 0.060 | 0.060 | Typical |  |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 22.479 | 23.495 |  | 0.885 | 0.925 |  |  |
| D1 | 20.320 | 20.32 | Reference | 0.800 | 0.800 | Reference |  |
| E | 7.620 | 8.255 |  | 0.300 | 0.325 |  |  |
| E1 | 6.096 | 7.112 |  | 0.240 | 0.280 |  |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |  |
| eA | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |  |
| eB | 7.874 | 9.906 |  | 0.310 | 0.390 |  |  |
| L | 3.048 | 3.556 |  | 0.120 | 0.140 |  |  |
| N | 18 | 18 |  | 18 | 18 |  |  |
| S | 0.889 | - |  | 0.035 | - |  |  |
| S1 | 0.127 | - |  | 0.005 | - |  |  |

## Packaging Diagrams and Dimensions

## Package Type: 20-Lead Plastic Dual In-line (. 300 mil )



Area


| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 4.064 |  | - | 0.160 |  |
| A1 $^{2}$ | 0.381 | - |  | 0.015 | - |  |
| A2 | 3.048 | 3.810 |  | 0.120 | 0.150 |  |
| B | 0.355 | 0.558 |  | 0.014 | 0.022 |  |
| B1 | 1.524 | 1.524 | Typical | 0.060 | 0.060 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 24.892 | 26.924 |  | 0.980 | 1.060 |  |
| D1 | 22.86 | 22.86 | Reference | 0.900 | 0.900 | Reference |
| E | 7.620 | 8.255 |  | 0.300 | 0.325 |  |
| E1 | 6.096 | 7.112 |  | 0.240 | 0.280 |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |
| eA | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| eB | 7.874 | 9.906 |  | 0.310 | 0.390 |  |
| L | 3.048 | 3.556 |  | 0.120 | 0.140 |  |
| N | 20 | 20 |  | 20 | 20 |  |
| S | 0.889 | - |  |  | 0.035 | - |
| S1 | 0.127 | - |  | 0.005 | - |  |

## Packaging Diagrams and Dimensions

Package Type: 22-Lead Plastic Dual In-line (. 400 mil)


Area


| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | . 180 |  | - | . 180 |  |
| A1 | 0.381 | - |  | 0.015 | - |  |
| A2 | 3.175 | 3.810 |  | 0.125 | 0.150 |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |
| B1 | 1.524 | 1.524 | Typical | 0.060 | 0.060 | Typical |
| C | 0.203 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 26.670 | 28.448 |  | 1.050 | 1.120 |  |
| D1 | 25.400 | 25.400 | Reference | 1.000 | 1.000 | Reference |
| E | 9.906 | 10.795 |  | 0.390 | 0.425 |  |
| E1 | 8.382 | 9.398 |  | 0.330 | 0.370 |  |
| $\mathrm{e}_{1}$ | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |
| ea | 10.160 | 10.160 | Reference | 0.400 | 0.400 | Reference |
| ев | 10.160 | 12.192 |  | 0.400 | 0.480 |  |
| L | 3.048 | 3.556 |  | 0.120 | 0.140 |  |
| N | 22 | 22 |  | 22 | 22 |  |
| S | 0.889 | - |  | 0.035 | - |  |
| S1 | 0.127 | - |  | 0.005 | - |  |

## Packaging Diagrams and Dimensions

## Package Type: 24-Lead Plastic Dual In-line (. 600 mil )



| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| A | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A1 | 0.508 | - |  | - | 0.200 |  |  |
| A2 | 3.175 | 4.064 |  | 0.020 | - |  |  |
| B | 0.356 | 0.559 |  | 0.125 | 0.160 |  |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |  |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 30.353 | 32.385 |  | 1.195 | 1.275 |  |  |
| D1 | 27.940 | 27.940 | Reference | 1.100 | 1.100 | Reference |  |
| E | 15.240 | 15.875 |  | 0.600 | 0.625 |  |  |
| E1 | 12.827 | 14.224 |  | 0.505 | 0.560 |  |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |  |
| eA | 15.240 | 15.240 | Reference | 0.600 | 0.600 | Reference |  |
| eB | 15.494 | 17.272 |  | 0.610 | 0.680 |  |  |
| L | 3.048 | 3.556 |  |  | 0.120 | 0.140 |  |
| N | 24 | 24 |  | 24 | 24 |  |  |
| S | 0.889 | - |  |  | 0.035 | - |  |
| S1 | 0.127 | - |  |  |  |  |  |

Microchip

## Packaging Diagrams and Dimensions

## Package Type: 24-Lead Plastic Dual In-line (. 300 mil)



| Package Group: Plastic Dual In-line Package (PLA) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Millimeters |  |  | Inches |  |  |
| Symbol | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 4.064 |  | - | 0.160 |  |
| A1 | 0.381 | - |  | 0.015 | - |  |
| A2 | 3.048 | 3.810 |  | 0.120 | 0.150 |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |
| B1 | 1.524 | 1.524 | Typical | 0.060 | 0.060 | Typical |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 31.242 | 32.258 |  | 1.230 | 1.270 |  |
| D1 | 27.940 | 27.940 | Reference | 1.100 | 1.100 | Reference |
| E | 7.620 | 8.255 |  | 0.300 | 0.325 |  |
| E1 | 6.096 | 7.112 |  | 0.240 | 0.280 |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |
| eA | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| eB | 7.874 | 9.906 |  | 0.310 | 0.390 |  |
| L | 3.048 | 3.556 |  | 0.120 | 0.140 |  |
| N | 24 | 24 |  | 24 | 24 |  |
| S | 0.889 | - |  | 0.035 | - |  |
| S1 | 0.381 | - |  | 0.015 | - |  |

## Packaging Diagrams and Dimensions

## Package Type: 28-Lead Dual In-line Plastic (. 600 mil)



| Package Group: Plastic Dual-In-Line (PLA) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.080 |  | - | 0.200 |  |
| A1 | 0.508 | - |  | 0.020 | - |  |
| A2 | 3.175 | 4.064 |  | 0.125 | 0.160 |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |
| B1 | 1.270 | 1.778 | Typical | 0.050 | 0.070 | Typical |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 35.560 | 37.084 |  | 1.400 | 1.460 |  |
| D1 | 33.020 | 33.020 | Reference | 1.300 | 1.300 | Reference |
| E | 15.240 | 15.875 |  | 0.600 | 0.625 |  |
| E1 | 12.827 | 13.970 |  | 0.505 | 0.550 |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |
| eA | 15.240 | 15.240 | Reference | 0.600 | 0.600 | Reference |
| eB | 15.240 | 17.272 |  | 0.600 | 0.680 |  |
| L | 2.921 | 3.683 |  | 0.115 | 0.145 |  |
| N | 28 | 28 |  | 28 | 28 |  |
| S | 0.889 | - |  | 0.035 | - |  |
| S1 | 0.508 | - |  | 0.020 | - |  |

## Packaging Diagrams and Dimensions

Package Type: 40-Lead Plastic Dual In-line (. 600 mil )


| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |  |
| A | - | 5.080 |  | - | 0.200 |  |  |
| A1 | 0.381 | - |  | 0.015 | - |  |  |
| A2 | 3.175 | 4.064 |  | 0.125 | 0.160 |  |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |  |
| B1 | 1.270 | 1.778 | Typical | 0.050 | 0.070 | Typical |  |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |  |
| D | 51.181 | 52.197 |  | 2.015 | 2.055 |  |  |
| D1 | 48.260 | 48.260 | Reference | 1.900 | 1.900 | Reference |  |
| E | 15.240 | 15.875 |  | 0.600 | 0.625 |  |  |
| E1 | 13.462 | 13.970 |  | 0.530 | 0.550 |  |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |  |
| eA | 15.240 | 15.240 | Reference | 0.600 | 0.600 | Reference |  |
| eB | 15.240 | 17.272 |  | 0.600 | 0.680 |  |  |
| L | 2.921 | 3.683 |  | 0.115 | 0.145 |  |  |
| N | 40 | 40 |  | 40 | 40 |  |  |
| S | 1.270 | - |  | 0.050 | - |  |  |
| S1 | 0.508 | - |  | 0.020 | - |  |  |

## Packaging Diagrams and Dimensions

## Package Type: 48-Lead Plastic Dual In-line (. 600 mil)



| Package Group: Plastic Dual In-line (PLA) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $10^{\circ}$ |  | $0^{\circ}$ | $10^{\circ}$ |  |
| A | - | 5.080 |  | - | 0.200 |  |
| A1 | 0.381 | - |  | 0.015 | - |  |
| A2 | 3.175 | 4.064 |  | 0.125 | 0.160 |  |
| B | 0.356 | 0.559 |  | 0.014 | 0.022 |  |
| B1 | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| C | 0.2032 | 0.381 | Typical | 0.008 | 0.015 | Typical |
| D | 61.468 | 62.230 |  | 2.420 | 2.450 |  |
| D1 | 58.420 | 58.420 | Reference | 2.300 | 2.300 | Reference |
| E | 15.240 | 15.875 |  | 0.600 | 0.625 |  |
| E1 | 13.716 | 14.224 |  | 0.540 | 0.560 |  |
| e1 | 2.489 | 2.591 | Typical | 0.098 | 0.102 | Typical |
| ea | 15.240 | 15.240 | Reference | 0.600 | 0.600 | Reference |
| eB | 15.240 | 17.272 |  | 0.600 | 0.680 |  |
| L | 2.921 | 3.683 |  | 0.115 | 0.145 |  |
| N | 48 | 48 |  | 48 | 48 |  |
| S | 1.270 | - |  | 0.050 | - |  |
| S1 | 0.508 | - |  | 0.020 | - |  |

## Packaging Diagrams and Parameters

## Plastic Leaded Chip Carrier Family

| Symbol List for Plastic Leaded Chip Carrier Package Parameters |  |
| :---: | :--- |
| Symbol | Description of Parameters |
| A | Distance from seating plane to highest point of body |
| $\mathrm{A}_{1}$ | Distance from lead shoulder to seating plane |
| CP | Seating plane coplanarity |
| $\mathrm{D} / \mathrm{E}$ | Outside dimension |
| $\mathrm{D}_{1} / \mathrm{E}_{1}$ | Plastic body dimension |
| $\mathrm{D}_{2} / \mathrm{E}_{2}$ | Footprint |
| $\mathrm{D}_{3} / \mathrm{E}_{3}$ | Footprint |
| LT | Lead thickness |
| N | Total number of potentially useable lead positions |
| Nd | Total number of leads on short side (rectangular) |
| Ne | Total number of leads on long side (rectangular) |

## Notes:

1 All dimensions and tolerances conform to ANSI Y14.5M-1982.
 line and coincident with top of lead. Where lead exits plastic body.

Datum D-E and F-G to be determined where center leads exit plastic body at datum plane-H].

To be determined at seating plane -C .
Transition is optional.
Plastic body details between leads are optional.
Dimensions D1 and E1 do not include mold protrusion. Allowable mold protrusion is .254 $\mathrm{mm} / .010 \mathrm{in}$. per side. Dimensions D and E include mold mismatch and are determined at parting line.

Square: Details of pin 1 identifier are optional but must be located within one of the two zones indicated.
Rectangle: Details of pin 1 identifier are optional but must be located within zone indicated. If the number of terminals on a side is odd, terminal 1 is the center terminal.

Location to datums $-\mathrm{A}-$ and -B -to be determined at plane -H .
10
All dimensions and tolerances include lead trim offset and lead finish.
11
These two dimensions determine maximum angle of the lead for certain socket applications. If unit is intended to be socketed, it is advisable to review these dimensions with the socket supplier.

Controlling dimension: inches.
Sum of dam bar protrusions to be 0.17 (.007) max per lead.
$\gamma$
Feature is not required, but is optional at manufacturer's discretion.

## Packaging Diagrams and Parameters

## Package Type: 20-Lead Plastic Leaded Chip Carrier (Square)



| Package Group: Plastic Leaded Chip Carrier (PLCC) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| A | 4.191 | 4.572 |  | 0.165 | 0.180 |  |  |
| A1 $_{1}$ | 2.413 | 2.921 |  | 0.095 | 0.115 |  |  |
| D | 9.779 | 10.033 |  | 0.385 | 0.395 |  |  |
| D1 $_{1}$ | 8.890 | 9.042 |  | 0.350 | 0.356 |  |  |
| D2 $_{2}$ | 7.493 | 8.255 |  | 0.295 | 0.325 |  |  |
| D3 $_{3}$ | 5.080 | 5.080 | Reference | 0.200 | 0.200 | Reference |  |
| E | 9.779 | 10.033 |  | 0.385 | 0.395 |  |  |
| E1 $_{1}$ | 8.890 | 9.042 |  | 0.350 | 0.356 |  |  |
| E2 | 7.493 | 8.255 |  | 0.295 | 0.325 |  |  |
| E3 | 5.080 | 5.080 | Reference | 0.200 | 0.200 | Reference |  |
| N | 20 | 20 |  | 20 | 20 |  |  |
| CP | - | 0.1016 |  | - | 0.004 |  |  |
| LT | 0.203 | 0.381 |  | 0.008 | 0.015 |  |  |

## Packaging Diagrams and Parameters

## Package Type: 28-Lead Plastic Leaded Chip Carrier (Square)



| Package Group: Plastic Leaded Chip Carrier (PLCC) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| A | 4.191 | 4.572 |  | 0.165 | 0.180 |  |
| A1 $^{2}$ | 2.413 | 2.921 |  | 0.095 | 0.115 |  |
| D | 12.319 | 12.573 |  | 0.485 | 0.495 |  |
| D1 $_{1}$ | 11.430 | 11.582 |  | 0.450 | 0.456 |  |
| D2 $_{2}$ | 10.414 | 10.922 |  | 0.410 | 0.430 |  |
| D3 $_{3}$ | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| E | 12.319 | 12.573 |  | 0.485 | 0.495 |  |
| E1 | 11.430 | 11.582 |  | 0.450 | 0.456 |  |
| E2 | 10.414 | 10.922 |  | 0.410 | 0.430 |  |
| E3 | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |
| N | 28 | 28 |  | 28 | 28 |  |
| CP | - | 0.1016 |  | - | 0.004 |  |
| LT | 0.203 | 0.381 |  |  | 0.008 | 0.015 |
|  |  |  |  |  |  |  |

Microchip

## Packaging Diagrams and Parameters

## Package Type: 32-Lead Plastic Leaded Chip Carrier (Rectangle)



| Package Group: Plastic Leaded Chip Carrier (PLCC) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| A | 3.048 | 3.556 |  | 0.120 | 0.140 |  |  |
| A1 | 1.905 | 2.413 |  | 0.075 | 0.095 |  |  |
| D | 12.319 | 12.573 |  | 0.485 | 0.495 |  |  |
| D1 | 11.35 | 11.506 |  | 0.447 | 0.453 |  |  |
| D2 | 4.826 | 5.334 |  | 0.190 | 0.210 |  |  |
| D3 | 7.620 | 7.620 | Reference | 0.300 | 0.300 | Reference |  |
| E | 14.859 | 15.113 |  | 0.585 | 0.595 |  |  |
| E1 | 13.893 | 14.046 |  | 0.547 | 0.553 |  |  |
| E2 | 6.096 | 6.858 |  | 0.240 | 0.270 |  |  |
| E3 | 10.160 | 10.160 | Reference | 0.400 | 0.400 | Reference |  |
| N | 32 | 32 |  | 32 | 32 |  |  |
| Nd | 7 | 7 |  | 7 | 7 |  |  |
| Ne | 9 | 9 |  | 9 | 9 |  |  |
| CP | - | 0.1016 |  |  |  | 0.004 |  |
| LT | 0.203 | 0.381 |  |  | 0.008 | 0.015 |  |

## Packaging Diagrams and Parameters

Package Type: 44-Lead Plastic Leaded Chip Carrier (Square)


| Package Group: Plastic Leaded Chip Carrier (PLCC) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
| A | 4.191 | 4.572 |  | 0.165 | 0.180 |  |  |
| A1 $^{2}$ | 2.413 | 2.921 |  | 0.095 | 0.115 |  |  |
| D | 17.399 | 17.653 |  | 0.685 | 0.695 |  |  |
| D1 $_{1}$ | 16.510 | 16.662 |  | 0.650 | 0.656 |  |  |
| D2 $_{2}$ | 15.494 | 16.002 |  | 0.610 | 0.630 |  |  |
| D3 $_{3}$ | 12.700 | 12.700 | Reference | 0.500 | 0.500 | Reference |  |
| E | 17.399 | 17.653 |  | 0.685 | 0.695 |  |  |
| E1 $_{1}$ | 16.510 | 16.662 |  | 0.650 | 0.656 |  |  |
| E $2^{\text {E }} 3$ | 15.494 | 16.002 |  | 0.610 | 0.630 |  |  |
| N | 12.700 | 12.700 | Reference | 0.500 | 0.500 | Reference |  |
| CP | - | 44 |  | 44 | 44 |  |  |
| LT | 0.203 | 0.381 |  | - | 0.004 |  |  |

## Packaging Diagrams and Parameters

## Plastic Small Outline Family

| Symbol List for Small Outline Package Parameters |  |
| :---: | :--- |
| Symbol | Description of Parameters |
| $\alpha$ | Angular spaciing between min and max lead positions measured at the guage plane |
| A | Distance between seating plane to highest point of body |
| A1 | Distance between seating plane and base plane |
| B | Width of terminals |
| C | Thickness of terminals |
| D | Largest overall package parameter of length |
| E | Largest overall package width parameter not including leads |
| e | Linear spacing of true minimum lead position center line to center line |
| H | Largest overall package dimension of width |
| L | Length of terminal for soldering to a substrate |
| N | Total number of potentially useable lead postions |
| CP | Seating plane coplanarity |

## Notes:

1. Controlling parameter: inches.
2. All packages are gull wing lead form.
3. "D" and "E" are reference datums and do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .15 mm (. 0086 inches).
4. The chamfer on the body is optional. If it is not present, a visual index feature must be located within the crosshatched area to indicate pin 1 position.
5. Terminal numbers are shown for reference.

Microchip

## Packaging Diagrams and Parameters

Package Type: 8-Lead Plastic Surface Mount (SOIC - Narrow, 150 mil Body)


| Package Group: Plastic SOIC (SN) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |
| A | 1.3716 | 1.7272 |  | 0.054 | 0.068 |  |
| A1 | 0.1016 | 0.2489 |  | 0.004 | 0.0098 |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |
| C | 0.1905 | 0.2489 |  | 0.0075 | 0.0098 |  |
| D | 4.8006 | 4.9784 |  | 0.189 | 0.196 |  |
| E | 3.810 | 3.9878 |  | 0.150 | 0.157 |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| H | 5.8166 | 6.1976 |  | 0.229 | 0.244 |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |
| L | 0.508 | 1.016 |  | 0.020 | 0.040 |  |
| N | 8 | 8 |  | 8 | 8 |  |
| CP | - | 0.1016 |  | - | 0.004 |  |

## Packaging Diagrams and Parameters

## Package Type: 8-Lead Plastic Surface Mount (SOIC - Medium, 200 mil Body)



| Package Group: Plastic SOIC (SM) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
|  | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |  |
| A | 1.778 | 2.032 |  | 0.070 | 0.080 |  |  |
| A1 | 0.1016 | 0.2489 |  | 0.004 | 0.0098 |  |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |  |
| C | 0.1905 | 0.2489 |  | 0.0075 | 0.0098 |  |  |
| D | 5.08 | 5.334 |  | 0.200 | 0.210 |  |  |
| E | 5.156 | 5.410 |  | 0.203 | 0.213 |  |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |  |
| H | 7.62 | 8.382 |  | 0.300 | 0.330 |  |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |  |
| L | 0.508 | 1.016 |  | 0.020 | 0.040 |  |  |
| N | 14 | 14 |  | 14 | 14 |  |  |
| CP | - | 0.1016 |  | - | 0.004 |  |  |

## Packaging Diagrams and Parameters

Package Type: 14-Lead Plastic Surface Mount (SOIC - Narrow, 150 mil Body)


| Package Group: Plastic SOIC (SN) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
|  | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |  |
| A | 1.3716 | 1.7272 |  | 0.054 | 0.068 |  |  |
| A1 | 0.1016 | 0.2489 |  | 0.004 | 0.0098 |  |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |  |
| C | 0.1905 | 0.2489 |  | 0.0075 | 0.0098 |  |  |
| D | 5.08 | 5.334 |  | 0.387 | 0.393 |  |  |
| E | 3.810 | 3.9878 |  | 0.150 | 0.157 |  |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |  |
| H | 5.8166 | 6.1976 |  | 0.229 | 0.244 |  |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |  |
| L | 0.4064 | 1.143 |  | 0.016 | 0.045 |  |  |
| N | 14 | 14 |  | 16 | 16 |  |  |
| CP | - | 0.1016 |  | - | 0.004 |  |  |

## Packaging Diagrams and Parameters

## Package Type: 14-Lead Plastic Surface Mount (SOIC - Wide. 300 mil Body)



| Package Group: Plastic SOIC (SO) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
|  | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |  |
| A | 2.3622 | 2.6416 |  | 0.093 | 0.104 |  |  |
| A $^{\circ}$ | 0.1016 | 0.2997 |  | 0.004 | 0.0118 |  |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |  |
| C | 0.2413 | 0.3175 |  | 0.0095 | 0.0125 |  |  |
| D | 0.8763 | 9.271 |  | 0.345 | 0.365 |  |  |
| E | 7.4168 | 7.5946 |  | 0.292 | 0.299 |  |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |  |
| H | 10.0076 | 10.6426 |  | 0.394 | 0.419 |  |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |  |
| L | 0.4064 | 1.143 |  | 0.016 | 0.045 |  |  |
| N | 14 | 14 |  | 14 | 14 |  |  |
| Cp | - | 0.1016 |  | - | 0.004 |  |  |

## Packaging Diagrams and Parameters

Package Type: 16-Lead Plastic Surface Mount (SOIC - Narrow, 150 mil Body)


| Package Group: Plastic SOIC (SN) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
|  | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |  |
| A | 1.3716 | 1.7272 |  | 0.054 | 0.068 |  |  |
| A1 | 0.1016 | 0.2489 |  | 0.004 | 0.0098 |  |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |  |
| C | 0.1905 | 0.2489 |  | 0.0075 | 0.0098 |  |  |
| D | 5.08 | 5.334 |  | 0.387 | 0.393 |  |  |
| E | 3.810 | 3.9878 |  | 0.150 | 0.157 |  |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |  |
| H | 5.8166 | 6.1976 |  | 0.229 | 0.244 |  |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |  |
| L | 0.4064 | 1.143 |  | 0.016 | 0.045 |  |  |
| N | 14 | 14 |  | 16 | 16 |  |  |
| CP | - | 0.1016 |  | - | 0.004 |  |  |

Microchip

## Packaging Diagrams and Parameters

Package Type: 16-Lead Plastic Surface Mount (SOIC - Wide, 300 mil Body)


| Package Group: Plastic SOIC (SO) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
|  | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |  |
| A | 2.3622 | 2.6416 |  | 0.093 | 0.104 |  |  |
| A1 | 0.1016 | 0.2997 |  | 0.004 | 0.0118 |  |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |  |
| C | 0.2413 | 0.3175 |  | 0.0095 | 0.0125 |  |  |
| D | 10.1092 | 10.4902 |  | 0.398 | 0.413 |  |  |
| E | 7.4168 | 7.5946 |  | 0.292 | 0.299 |  |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |  |
| H | 10.0076 | 10.6426 |  | 0.394 | 0.419 |  |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |  |
| L | 0.4064 | 1.143 |  | 0.016 | 0.045 |  |  |
| N | 16 | 16 |  | 16 | 16 |  |  |
| CP | - | 0.1016 |  | - | 0.004 |  |  |

Microchip

## Packaging Diagrams and Parameters

Package Type: 18-Lead Plastic Surface Mount (SOIC - Wide, 300 mil Body)


| Package Group: Plastic SOIC (SO) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
|  | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |
| A | 2.3622 | 2.6416 |  | 0.093 | 0.104 |  |
| A | 0.1016 | 0.2997 |  | 0.004 | 0.0118 |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |
| C | 0.2413 | 0.3175 |  | 0.0095 | 0.0125 |  |
| D | 11.3538 | 11.7348 |  | 0.447 | 0.462 |  |
| E | 7.4168 | 7.5946 |  | 0.292 | 0.299 |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| H | 10.0076 | 10.6426 |  | 0.394 | 0.419 |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |
| L | 0.4064 | 1.143 |  | 0.016 | 0.045 |  |
| N | 18 | 18 |  | 18 | 18 |  |
| CP | - | 0.1016 |  | - | 0.004 |  |

Microchip

## Packaging Diagrams and Parameters

Package Type: 20-Lead Plastic Surface Mount (SOIC - Wide, 300 mil Body)


| Package Group: Plastic SOIC (SO) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |  |
|  | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |  |
| A | 2.3622 | 2.6416 |  | 0.093 | 0.104 |  |  |
| A1 | 0.1016 | 0.2997 |  | 0.004 | 0.0118 |  |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |  |
| C | 0.2413 | 0.3175 |  | 0.0095 | 0.0125 |  |  |
| D | 12.5984 | 13.0048 |  | 0.496 | 0.512 |  |  |
| E | 7.4168 | 7.5946 |  | 0.292 | 0.299 |  |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |  |
| H | 10.0076 | 10.6426 |  | 0.394 | 0.419 |  |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |  |
| L | 0.4064 | 1.143 |  | 0.016 | 0.045 |  |  |
| N | 20 | 20 |  | 20 | 20 |  |  |
| CP | - | 0.1016 |  | - | 0.004 |  |  |

## Packaging Diagrams and Parameters

## Package Type: 24-Lead Plastic Surface Mount (SOIC - Wide, 300 mil Body)



| Package Group: Plastic SOIC (SO) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Millimeters |  |  | Inches |  |  |
|  | Min | Max | Notes | Min | Max | Notes |
| $\alpha$ | $0^{\circ}$ | $8^{\circ}$ |  | $0^{\circ}$ | $8^{\circ}$ |  |
| A | 2.3622 | 2.6416 |  | 0.093 | 0.104 |  |
| A1 | 0.1016 | 0.2997 |  | 0.004 | 0.0118 |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |
| C | 0.2413 | 0.3175 |  | 0.0095 | 0.0125 |  |
| D | 15.2146 | 15.5956 |  | 0.599 | 0.614 |  |
| E | 7.4168 | 7.5946 |  | 0.292 | 0.299 |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| H | 10.0076 | 10.6426 |  | 0.394 | 0.419 |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |
| L | 0.4064 | 1.143 |  | 0.016 | 0.045 |  |
| N | 24 | 24 |  | 24 | 24 |  |
| CP | - | 0.1016 |  | - | 0.004 |  |

## Packaging Diagrams and Parameters

Package Type: 28-Lead Plastic Surface Mount (SOIC - Wide, 300 mil Body)


| Package Group: Plastic SOIC (SO) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Min | Max | Notes | Min | Max | Notes |
|  | Millimeters |  |  | $0^{\circ}$ | $8^{\circ}$ |  |
|  | $0^{\circ}$ | $8^{\circ}$ |  | 0.093 | 0.104 |  |
| A1 | 0.3622 | 2.6416 |  | 0.004 | 0.0118 |  |
| B | 0.3556 | 0.4826 |  | 0.014 | 0.019 |  |
| C | 0.2413 | 0.3175 |  | 0.0095 | 0.0125 |  |
| D | 17.7038 | 18.0848 |  | 0.697 | 0.712 |  |
| E | 7.4168 | 7.5946 |  | 0.292 | 0.299 |  |
| e | 1.270 | 1.270 | Typical | 0.050 | 0.050 | Typical |
| H | 10.0076 | 10.6426 |  | 0.394 | 0.419 |  |
| h | 0.381 | 0.762 |  | 0.015 | 0.030 |  |
| L | 0.4064 | 1.143 |  | 0.016 | 0.045 |  |
| N | 28 | 28 |  | 28 | 28 |  |
| CP | - | 0.1016 |  |  |  | 0.004 |

## APPENDIX <br> OFFICE LOCATIONS

Factory Representatives ..... A- 1
Distributors ..... A- 5
Field Offices ..... A- 12

Microchip

## CANADA

## British Columbia

Enerlec Sales, Ltd. 3671 Viking Way \#7
Richmond, B.C. V6V 1W1
Tel: 6042730882
Fax: 6042730884

## Ontario

Dynasty Components, Inc. 6295 Northam Drive, Unit 1 Missisauga, Ont. L4V 1W8
Tel: 4166725977
Fax: 4166726252
Dynasty Components, Inc.
174 Colonnade Road - Unit 21
Nepean, Ontario K2E 7J5
Tel: 6137230725
Fax: 6137238820

## Quebec

Dynasty Components, Inc. 1870 Blvd. des Sources, \# 304
Pointe Claire, P.Q. H9R 5N4
Tel: 5146940275
Fax: 5146946826

## SOUTH AMERICA

## Brazil

Hitech Commercial \& Industrial Av. Eng. Luiz Carlos Berrini 801 Conj. 111/121-CEP: 04571 Brooklin, Sao Paulo
Tel: 0115319355
Fax: 0112402650
Telex: 1153288

## USA

## Alabama

Electramark, Inc. 4950 Corporate Dr., Suite 130L Huntsville, AL 35805
Tel: 2058304400
Fax: 2058304406

## Arizona

Western High Tech Marketing, Inc.
9414 E. San Salvador
Scottsdale, AZ 85258
Tel: 6028602702
Fax: 6028602712

## Arkansas

Comptech Sales, Inc.
9810 E. 42nd Street, Suite 219
Tulsa, OK 74146
Tel: 9186227744
Fax: 9186600340

## California

QuadRep Southern
28720 Roadside Dr. - Suite 227
Agoura, CA 91301
Tel: 8185970222
Fax: 8185971116
QuadRep Southern
4 Jenner Street, Suite 120
Irvine, CA 92718
Tel: 7147274222
Fax: 7147274033
QuadRep Southern 7585 Ronson Road, Suite 100
San Diego, CA 92111
Tel: 6195608330
Fax: 6195609156
QuadRep, Inc. 2713 North First Street San Jose, CA 95134
Tel: 4084323300
Fax: 4084323428

## Colorado

Western Region Marketing 9176 Marshall Place
Westminster, CO 80030
Tel: 3034288088
Fax: 3034268585

## Connecticut

VISTAssociates, Inc.
2505 Main Street
Stratford, CT 06497
Tel: 2033755456
Fax: 2033756907

## Delaware

Tritek Sales
21 E. Euclid Avenue
Haddonfield, NJ 08033
Tel: 6094291551
Fax: 6094294915

## District of Columbia

Parogem, Inc.
3201 Harness Creek Road
Annapolis, MD 21403
Tel: 3012691898
Fax: 3019748170

## Florida

Electramark, Inc.
401 Whooping Loop, Suite 1565
Altamonte Springs, FL 32701
Tel: 4078300844
Fax: 4078300847

Electramark, Inc.
1700 N Dixie Hwy - Suite 126
Boca Raton, FL 33432
Tel: 4073921763
Fax: 4073927188
Electramark, Inc. 6105E Memorial Hwy
Tampa, FL 33615
Tel: 8138897775
Fax: 8138897772

## Georgia

Electramark, Inc. 6030H Unity Drive Norcross, GA 30071
Tel: 4044467915
Fax: 4042636389

## Idaho

QR/Crown, Inc.
1111 South Orchard, Suite 112
Boise, ID 83702
Tel: 2083449588
Fax: 2083449550

## Illinois

Janus Incorporated 650 E. Devon Ave. Itasca, IL 60143
Tel: 7082509650
Fax: 7082508761
SPS Associates, Ltd.
3301 Rider Trail South
Earth City, MO 63045
Tel: 3142910520
Fax: 3142917138

## Indiana

Electro Reps, Inc. 407 Airport North Office Park Fort Wayne, IN 46825
Tel: 2194898205
Fax: 2194842897
Electro Reps, Inc. 7240 Shadeland Station \#275 Indianapolis, IN 46256
Tel: 3178427202
Fax: 3178410230

## lowa

SPS Associates, Ltd.
119-19th Street, Suite 102
West Des Moines, IA 50265
Tel: 5152250607
Fax: 5152258713
Telex: TWX:910 380

## Kansas

SPS Associates, Ltd.
300 A. Clairborne
Olathe, KS 66062
Tel: 9137644460
Fax: 9137646161
SPS Associates, Ltd.
501 Lancaster Dr.
Wichita, KS 67230
Tel: 3167334415
Fax: 3167335218

## Minnesota

Comprehensive Technical Sales, Inc.
6525 City West Parkway
Eden Prairie, MN 55344
Tel: 6129417181
Fax: 6129414322
Mississippi
Electramark, Inc.
4950 Corporate Dr., Suite 130L
Huntsville, AL 35805
Tel: 2058304400
Fax: 2058304406

## Missouri

SPS Associates, Ltd.
3301 Rider Trail South
Earth City, MO 63045
Tel: 3142910520
Fax: 3142917138

## Montana

QR/Crown, Inc.
1111 South Orchard, Suite 112
Boise, ID 83702
Tel: 2083449588
Fax: 2083449550

## Nebraska

SPS Associates, Ltd. 21930 Locust Street Panama, NE 68419
Tel: 4027882536
Fax: 4027882537

## Nevada

QuadRep, Inc. 2713 North First Street
San Jose, CA 95134
Tel: 4084323300
Fax: 4084323428
Western High Tech Marketing, Inc.
9414 E. San Salvador
Scottsdale, AZ 85258
Tel: 6028602702
Fax: 6028602712

## New Hampshire

VISTAssociates, Inc.
237 Cedar Hill Street
Marlborough, MA 01752
Tel: 5084819277
Fax: 5084601869
Telex: 710-380-0466

## New Jersey

Technical Marketing Group 175-3C Fairfield Ave.
W. Caldwell, NJ 07006

Tel: 2012263300
Fax: 2012269518
Tritek Sales
21 E. Euclid Avenue
Haddonfield, NJ 08033
Tel: 6094291551
Fax: 6094294915

## New Mexico

Western High Tech Marketing
4205 Montgomery, NE
Albuquerque, NM 87109
Tel: 5058842256
Fax: 5058842258

## New York

Apex Associates, Inc. 1210 Jefferson Rd.
Rochester, NY 14623
Tel: 7162727040
Fax: 7162727756
Technical Marketing Group
20 Broad Hollow Rd., \#3001
Melville, NY 11747
Tel: 5163518833
Fax: 5163518667
Technical Marketing Group
175-3C Fairfield Ave.
W. Caldwell, NJ 07006

Tel: 2012263300
Fax: 2012269518

## North Carolina

Zucker Associates
4070 Barrett Drive
Raleigh, NC 27609
Tel: 9197828433
Fax: 9197828476

## North Dakota

Comp. Technical Sales, Inc.
6525 City West Parkway
Eden Prairie, MN 55344
Tel: 6129417181
Fax: 6129414322

## Ohio

JMK Electronics
7921 Euclid Rd., Suite B
Cincinnati, OH 45243
Tel: 5132713860
Fax: 5132716321

JMK Electronics
124B Woolery Lane
Dayton, OH 45415
Tel: 5138988834
Fax: 5138988863
JMK Electronics
7050 Engle Road, Suite 100
Middleburg Heights, OH 44130
Tel: 2162341202
Fax: 2162341912

## Oklahoma

Comptech Sales, Inc. 9810 E. 42nd Street, Suite 219
Tulsa, OK 74146
Tel: 9186227744
Fax: 9186600340

## Oregon

QR/Crown, Inc.
17020 SW Upper Boones
Ferry Road, Suite 202
Portland, OR 97224
Tel: 5036208320
Fax: 5036394023

## Pennsylvania

Tritek Sales
21 E. Euclid Avenue
Haddonfield, NJ 08033
Tel: 6094291551
Fax: 6094294915
JMK Electronics
7921 Euclid Rd., Suite B
Cincinnati, OH 45243
Tel: 5132713860
Fax: 5132716321

## Rhode Island

VISTAssociates, Inc.
237 Cedar Hill Street
Marlborough, MA 01752
Tel: 5084819277
Fax: 5084601869
Telex: 710-380-0466

## South Carolina

Zucker Associates 4070 Barrett Drive
Raleigh, NC 27609
Tel: 9197828433
Fax: 9197828476

## South Dakota

Comp. Technical Sales, Inc. 6525 City West Parkway
Eden Prairie, MN 55344
Tel: 6129417181
Fax: 6129414322

## Tennessee

Electramark, Inc.
4950 Corporate Dr., Suite 130L
Huntsville, AL 35805
Tel: 2058304400
Fax: 2058304406
Zucker Associates
4070 Barrett Drive
Raleigh, NC 27609
Tel: 9197828433
Fax: 9197828476

## Texas

Comptech Sales, Inc.
11130 Jollyville Rd., Suite 200
Austin, TX 78759
Tel: 5123430300
Fax: 5123452530
Comptech Sales, Inc.
802 E Harrison - Suite 19
Harlingen, TX 78523
Tel: 5124287503
Fax: 5124280242
Comptech Sales, Inc.
15415 Katy Fwy., Suite 102
Houston, TX 77094
Tel: 7134920005
Fax: 7134926116
Comptech Sales, Inc.
2401 Gateway Dr., Suite 114
lrving, TX 75063
Tel: 2147511181
Fax: 2145508113
Western High Tech Marketing, Inc.
4205 Montgomery NE
Albuquerque, NM 87109
Tel: 5058842256
Fax: 5058842258

## Utah

Western Region Marketing 3539 S Main - Suite 210
Salt Lake City, UT 84115
Tel: 8012689768
Fax: 8012689773

## Vermont

VISTAssociates, Inc.
237 Cedar Hill Street
Marlborough, MA 01752
Tel: 5084819277
Fax: 5084601869
Telex: 710-380-0466

## Virginia

Parogem, Inc.
3201 Harness Creek Road
Annapolis, MD 21403
Tel: 3012691898
Fax: 3019748170

## Washington

QR/Crown, Inc.
375 118th Ave., Suite 110
Bellevue, WA 98005
Tel: 2064535100
Fax: 2066468775

## West Virginia

JMK Electronics
124B Woolery Lane
Dayton, OH 45415
Tel: 5138988834
Fax: 5138988863

## Wisconsin

Janus, Inc.
W239 N 1690 Busse Road
Waukesha, WI 53188
Tel: 4145427575
Fax: 4145427634

## Wyoming

Western Region Marketing 9176 Marshall Place
Westminster, CO 80030
Tel: 3034288088
Fax: 3034268585

## AFRICA

South Africa
Pace Electronic Components (PTY) LTD.
Cnr. Van Acht \& Gewel Streets
P.O. Box 7014

Isando 1600/Transvaal
Tel: 11974 1211/6
Fax: 119741271
Telex: 4-29023
ASIA

## Japan

Marubeni Hytech Corporation Marubeni Hytech Bldg. 4-20-22, Koishikawa
Bunkyo-Ku, Tokyo 112,
Tel: 813 817-4921
Fax: 813 817-4880

## Korea

Daeho Corporation 1004, Keo Yang Building 51-8 Soosong Dong Chongro-Ku,Seoul,
Tel: 822 739-8543
Fax: 822 739-6040

## CANADA

## Alberta

ITT Multicomponents
3015-5th Ave. N.E. - Suite 210
Calgary, Alberta, T2A 6T8
Tel: 403 273-2780
Fax: 403 273-7458

Future Electronics
3833-29th Street N.E.
Calgary, Alta. T1Y 6B5
Tel: 403 250-5550
Fax: 403 291-7054
ITT Multicomponents 9840-47th Avenue - Suite 3
Edmonton, Alta. T6E 5P3
Tel: 403 436-9555
Fax: 403 438-4983
Future Electronics
5312 Calgary Trail
Edmonton, Alta. T6H 4J8
Tel: 403 438-2858
Fax: 403 434-0812

## British Columbia

ITT Multicomponents 3455 Gardner Court Burnaby, B.C., V5G 4J7
Tel: 604 291-8866
Fax: 604 291-1227
Future Electronics 1695 Boundary Road Vancouver, B.C., V5K 4X7
Tel: 604 294-1166
Fax: 604 294-1206

## Manitoba

Future Electronics 106 King Edward Winnipeg, Man. R3H ON8 Tel: 204 786-7711

ITT Multicomponents 1313 Border Street - Suite 35 Winnipeg, Manitoba, R3H 0M4
Tel: 204 697-2300
Fax: 204 697-2293

## Ontario

ITT Multicomponents
300 N. Rivermede Road
Concord, Ont. L4K $2 Z 4$
Tel: 416 736-1144
Fax: 416 736-4831
Future Electronics
82 St. Regis
Downs View, Ont. M3J 1S6
Tel: 416 638-4771
Fax: 416 638-2936
ITT Multicomponents
39 Robertson Rd.
\#506, Bell Mews
Nepean, Ont. K2H 8R2
Tel: 613 596-6980
Fax: 613 596-6987
Future Electronics
1050 Baxter Road
Ottawa, Ont. K2C 3P2
Tel: 613 820-8313
Fax: 613 820-3271

## Quebec

Future Electronics
237 Hymus Boulevard
Pointe Claire, P.Q. H9R 5C7
Tel: 514 694-7710
Fax: 514 695-3707
Future Electronics
1990 Charest Blvd. West - \#190
St. Foy, P.Q. G1N 4 K8
Tel: 418 682-8092
Fax: 418 682-8303
ITT Multicomponents 5713 Chemin St. Francois
Ville St. Laurent, P.Q. H4S 1W9
Tel: 514 335-7697
Fax: 514 335-9330
Saskatchewan
ITT Multicomponents
3521 - 8th St. East, \#209
Saskatoon, Sask. S7H OW5
Tel: 306 373-7138
Fax: 306 373-7390

## EUROPE

## Austria

Bacher El. Geraete GmbH
Rotenmuehlgasse 26
A-1120 Wien
Tel: 0222813564
Fax: 0222834276

## Belgium

Velleman N.V.
Legen Heirweg Industrieterrein 27
B-9751 Gavere
Tel: 091843611
Fax: 091844362 Telex: 11668

## Denmark

Nordisk Elektronik AS
Transformervej 17
DK-2730 Herlev
Tel: 02842000

## England

Polar Electronics PLC
Cherrycourt Way
Leighton Buzzard
Bedfordshire LU7 8YY
Tel: 0525377093
V.S.I. Electronics Ltd.

Roydonbury Ind. Park
Horsecroft Road
Harlow, Essex CM19 5BY
Tel: 027929666
Campbell Collins Ltd.
162 High Street
Stevenage
Hertfordshire
Tel: 0438369466

Future Electronics Ltd.
Petersfield Avenue
Slough, Berkshire, SL2 5EA
Finland
Komdel Oy
Meteorinkatu 3
SF-02211 Espoo
Tel: 0885011

## France

Ericsson
1 parc Club Ariane
Rue Helene Boucher
78284 Guyancourt
Tel: 30640900
Fax: 30641146

## France (cont.)

P.E.P.

6 Rue Ambroise Croizat
ZI des Glaises
91122 Palaiseau Cedex
Tel: 64470031
Fax: 64470084

## Mecodis

Parc d'Activites
3 Allee des Erables
94042 Creteil Cedex
Tel: 43994400
Fax: 43999828

## Germany

Metronik GmbH
Leonhardsweg 2
8025 Unterhaching
Tel: 089611080
Fax: 089611468
Semitron W. Roeck GmbH Im Gut 1
D-7891 Kuessaberg 6
Tel: 077427011
Fax: 077426901
Electronic 2000 Vertriebs AG
Stahlgruberring 12
D-8000 Muenchen 82
Tel: 089 42001-0
Fax: 08942001210

## Ireland

Eltech Agencies, Itd.
Lehanaghmore
Farmers Cross, Cork

## Israel

Elina Ltd.
3, Hametzuda Street
Azur 58001, Holon
Tel: 3559 0275/6
Fax: 35590270

## Italy

Deutsche ITT/Intesi
Viale Milanofiori, E/5
20090 Assago Milano
Tel: 282470215
Fax: 282470278
Eurelettronica Srl
Viale E. Fermi 8
20094 Assago Milano
Tel: 24880022
Fax: 24880275

## Italy (cont.)

Kevin
Via del Gradenigo, 3
20148 Milano
Tel: 248706300
Fax: 248706500

## Netherlands

Semicon B.V.
P.O. Box 258, Gulberg 33

NL-5670 AG Nuenen
Tel: 040837075
Fax: 040832300

## Norway

Morgenstierne \& Co. A/S
Konghellengaten $3 / 5$
N-0569 Oslo 5
Tel: 02356110

## Portugal

Digicontrole
Dpt. Comercial
Ave. Eng. Arantes E Oliveira 52d
1900 Lisboa
Tel: 11805730
Fax: 11890373

## Spain

Sagitron
Corazon de Maria 80/82
28402 Madrid
Tel: 14169261
Fax: 14158652

## Sweden

Bexab Technology AB
Kemistvaegen 10
Box 523, KAJC
Tel: S-18325 Taeby
Fax: 087328980

## Switzerland

Omni Ray AG
Industriestrasse 31
CH-8305 Dietlikon
018352111
Tel: 018335081

## Turkey

Electro
Sanayiva Ticaret Koll. Sti.
Ahmet Rasim Sok. No. 16
Hasanpasa, Kadikoy, Istanbul
Tel: 013372245
Fax: 013368814

## USA

## Alabama

Future Electronics
4950 Corporate Dr. - Suite 145
Huntsville, AL 35081
Tel: 205 830-2322
Fax: 205 830-6664

Hall-Mark Electronics
4900 Bradford Drive
Huntsville, AL 35805
Tel: 205 837-8700
Fax: 205 830-2565
Reptron Electronics
4950 Corporate Dr. - Suite 105C
Huntsville, AL 35805
Tel: 205 722-9500
Fax: 205 722-9565

## Arizona

Future Electronics
4636 E. University Dr. - Suite 245
Phoenix, AZ 85034
Tel: 602 968-7140
Fax: 602 968-0334
Hall-Mark Electronics
4637 South 36th Place
Phoenix, AZ 85040
Tel: 602 437-1200
Fax: 602 437-2348

## California

Future Electronics
9301 Oakdale Ave. - Suite 210
Chatsworth, CA 91311
Tel: 818 772-6240
Fax: 818 772-6247
Hall-Mark Electronics
9420 Topanago Canyon Blvd.
Chatsworth, CA 91311
Tel: 818 773-4500
Fax: 818 773-4555
Bell Microproducts, Inc.
18350 Mt. Langley - Suite 207
Fountain Valley, CA 92708
Tel: 714 963-0667
Fax: 714 968-3195
Future Electronics
1692 Browning Ave.
Irvine, CA 92714
Tel: 714 250-4141
Fax: 714 250-4185
Falcon Electronics
2301 Dupont Drive - Suite 160
Irvine, CA 92715
Tel: 714 757-1955
Fax: 714 757-1890
Hall-Mark Electronics
1 Maunchly
Irvine, CA 92718
Tel: 714 727-6000
Fax: 714 727-6066
Bell Microproducts, Inc.
550 Sycamore Drive
Milpitas, CA 95035
Tel: 408 434-1150
Fax: 408 434-0778

## California (cont.)

Hall-Mark Electronics 580 Menlo Drive - Suite 2
Rocklin, CA 95677
Tel: 916 624-9781
Fax: 916 961-0922
Future Electronics
3940 Ruffin Road \#E
San Diego, CA 92123
Tel: 619 278-5020
Fax: 619 576-8564

Hall-Mark Electronics 3878 Ruffin Road San Diego, CA 92123
Tel: 619 268-1201
Fax: 619 268-0209
Hall-Mark Electronics
2105 Lundy Avenue
San Jose, CA 95131
Tel: 408 432-0900

Future Electronics
575 River Oaks Parkway
San Jose, CA 95134
Tel: 408 434-1122

## Colorado

Future Electronics
9030 Yukon Street - Suite 2700
Broomfield, CO 80021
Tel: 303 421-0123
Hall-Mark Electronics
12503 E. Euclid Drive - Suite 20
Englewood, CO 80111
Tel: 303 790-1662
Fax: 303 790-4991

## Connecticut

Future Electronics 24 Stoney Hill Road
Bethel, CT 06801
Tel: 203 743-9594
Fax: 203 798-9745
Hall-Mark Electronics
615 West Johnson Ave. - Bldg. 3
Cheshire, CT 06410
Tel: 203 271-2844
Falcon Electronics
5 Higgins Drive
Milford, CT 06460
Tel: 203 878-5272
Fax: 203 877-2010

## Florida

Future Electronics
380 S. Northlake Blvd. - Suite 1048
Altamonte Springs, FL 32701
Tel: 407 767-8414
Fax: 407 834-9318
Vantage Components, Inc. 1110 Douglas Ave. - Suite 2050
Altamonte Springs, FL 32714
Tel: 407 682-1199
Fax: 407 682-1286
Hall-Mark Electronics
489 E. Semoran Blvd. - Suite 145
Casselberry, FL 32707
Tel: 407 830-5855
Fax: 407 767-5002

## Florida (cont.)

Future Electronics 4900 M Creekside Drive
Clearwater, FL 34620
Tel: 813 578-2770
Fax: 813 576-7600
Vantage Components, Inc.
1761 W. Hillsborough Ave. - \#318
Deerfield Beach, FL 33441
Tel: 305 429-1001
Fax: 305 481-3586
Reptron Electronics
3320 N.W. 53rd St. - Suite 206
Ft. Lauderdale, FL 33309
Tel: 305 735-1112
Fax: 305 735-1121

Hall-Mark Electronics
10491-72nd St. North
Largo, FL 34647
Tel: 813 541-7440
Fax: 813 544-4394
Hall-Mark Electronics
3161 S.W. 15th Street
McNabb Road
Pompano Beach, FL 33069
Tel: 305 971-9280
Fax: 305 971-9339
Reptron Electronics
14401 McCormick Drive
Tampa, FL 33626
Tel: 813 855-4656
Fax: 813 855-7660
Falcon Electronics
1265 S. Semoran Blvd. - Suite 1203
Winter Park, FL 32792
Tel: 407 671-3739
Fax: 407 679-3255

## Georgia

Future Electronics
3000 Northwoods Pkwy. - \#295
Norcross, GA 30071
Tel: 404 441-7676
Fax: 404 441-7580
Hall-Mark Electronics
3425 Corporate Way - Suite A
Duluth, GA 30136
Tel: 404 623-4400
Fax: 404 476-8806

## Georgia (cont.)

Reptron Electronics
3040 Business Park Dr. - Suite H
Norcross, GA 30071
Tel: 404 446-1300
Fax: 404 446-2991

## llinois

Advent Electronics
7110-16 N. Lyndon Street
Rosemont, IL 60018
Tel: 708 297-6200
Fax: 708 297-6650
Future Electronics
1000 East State Parkway - Suite B
Schaumburg, IL 60195
Tel: 708 882-1255
Reptron Electronics
1000 East State Pkwy - Suite K
Schaumburg, IL 60195
Tel: 708 882-1700
Fax: 708 882-8904
Hall-Mark Electronics
210 Mittel Drive
Wood Dale, IL 60191
Tel: 708 860-3800
Indiana
CAM/RPC
1329 W. 96th St. - Suite 10
Indianapolis, IN 46260
Tel: 317 578-1111
Fax: 317 578-3338
Advent Electronics
8446 Moller Road
Indianapolis, IN 46268
Tel: 317 872-4910
Fax: 317 872-9987
Hall-Mark Electronics
4275 West 96th Street
Indianapolis, IN 46268
Tel: 317 872-8875
Fax: 317 876-7165

## lowa

Advent Electronics 682-58th Ave. Court S.W. Cedar Rapids, IA 52404
Tel: 319 363-0221
Fax: 319 363-4514

## Kansas

Hall-Mark Electronics 10809 Lakeview Drive Lenexa, KS 66215
Tel: 913 888-4747
Fax: 913 888-0523

## Maryland

Falcon Electronics 1520 Caton Research Ctr. \#Q Baltimore, MD 21227
Tel: 301 247-5800
Fax: 301 247-5893
Vantage Components, Inc. 6925 R. Oakland Mills Road Columbia, MD 21045
Tel: 301 720-5100
Fax: 301 381-2172
Future Electronics
7165 Columbia Gateway Dr. \#G
Columbia, MD 21046
Tel: 301 995-1222
Fax: 301 290-0328

Hall-Mark Electronics 10240 Old Columbia Road
Columbia, MD 21046
Tel: 301 988-9800
Fax: 301 381-2036

## Massachussetts

Vantage Components, Inc.
200 Bullfinch Drive
Andover, MA 01810
Tel: 508 687-3900
Fax: 508 687-4116
Hall-Mark Electronics
6 Cook St. - Pinehurst Park
Billerica, MA 01821
Tel: 617 935-9777
Fax: 617 667-4129
Falcon Electronics
500 Franklin Village Dr. \#302
Franklin, MA 02038
Tel: 508 520-0323
Fax: 508 528-2626
Future Electronics
133 Flanders Road
Westborough, MA 01581
Tel: 508 366-2400
Fax: 508 366-1195

Bell Microproducts, Inc.
16 Upton Drive
Wilmington, MA 01887
Tel: 508 658-0222
Fax: 508 694-9987

## Michigan

Advent Electronics
24713 Crestview Court
Farmington Hills, MI 48333
Tel: 313 477-1650
Fax: 313 477-2630

CAM/RPC
32468 Schoolcraft Road
Livonia, MI 48150
Tel: 313 427-4800
Fax: 313 427-4820
Future Electronics
35200 Schoolcraft Road - \#106
Livonia, MI 48150
Tel: 313 261-5270
Fax: 313 261-8125

## Michigan (cont.)

Hall-Mark Electronics 38027 Schoolcraft Road Livonia, MI 48150
Tel: 313 462-1205
Fax: 313 462-1830
Reptron Electronics 34403 Glendale Road Livonia, MI 48150
Tel: 313 525-2700
Fax: 313 525-3209

## Minnesota

Future Electronics
10025 Valley View Road - \#196
Eden Prairie, MN 55344
Tel: 612 944-2200
Fax: 612 944-2520

Hall-Mark Electronics
10300 Valley View Road - \#101
Eden Prairie, MN 55344
Tel: 612 941-2600
Fax: 612 941-5778
Reptron Electronics
5959 Baker Road - Suite 405
Minnetonka, MN 55344
Tel: 612 938-0000
Fax: 612 938-3995

## Missouri

Hall-Mark Electronics 3783 Rider Trail South
Earth City, MO 63045
Tel: 314 291-5350
Fax: 314 291-0362
Future Electronics
1067 N. Mason Road - Suite 15
St. Louis, MO 63141
Tel: 314 469-6805
Fax: 314 469-7226

## New Jersey

Vantage Components, Inc.
23 Sebago Street
Clifton, NJ 07013
Tel: 201 777-4100
Fax: 201 777-6194
Future Electronics
122 Fairfield Road
Fairfield, NJ 07006
Tel: 201 227-4346
Fax: 201 227-5305
Future Electronics
520 Fellowship Road
Mt. Laurel, NJ 08054
Tel: 609 778-7600
Fax: 609 778-4621
Hall-Mark Electronics
11000 Midlantic Drive - Suite 5
Mt. Laurel, NJ 08054
Tel: 609 235-1900
Fax: 609 235-3381
Future Electronics
1259 Route 46 East
Parsippany, NJ 07054
Tel: 201 299-0400
Fax: 201 299-1377
Hall-Mark Electronics
200 Lanidex Plaza - 2nd Floor
Parsippany, NJ 07054
Tel: 201 575-4415
Fax: 201 525-4475

## New York

Hall-Mark Electronics
6605 Pittsford Palmyra Rd. \#E-8
Fairport, NY 14450
Tel: 716 425-3300
Fax: 716 425-7195
Falcon Electronics
1383-18 Veterans Memorial Hwy.
Hauppauge, NY 11788
Tel: 516 724-0980
Fax: 516 724-0993
Future Electronics
801 Motor Parkway
Hauppauge, NY 11788
Tel: 516 234-4000
Fax: 516 234-6183
Future Electronics
7453 Morgan Road
Liverpool, NY 13090
Tel: 315 451-2371
Fax: 315 451-7258
CAM/RPC
2975 Brighton Henrietta
Town Line Road
Rochester, NY 14623
Tel: 716 427-9999
Fax: 716 427-7559
Future Electronics
333 Metro Park
Rochester, NY 14623
Tel: 716 272-1120
Fax: 716 272-7182
Hall-Mark Electronics 3075 Veterans Memorial Hwy.
Ronkonkoma, NY 11779
Tel: 516 737-0600
Fax: 516 737-0838
Vantage Components, Inc.
1056 West Jericho Turnpike
Smithtown, NY 11787
Tel: 516 543-2000
Fax: 516 543-2030

## North Carolina

Future Electronics 1515 Mockingbird Lanie
Chariotte, NC 28209
Tel: 704 529-5500
Fax: 704 527-2222
Hall-Mark Electronics
5234 Green's Dairy Road
Raleigh, NC 27604
Tel: 919 872-0712
Fax: 919 878-8729
Future Electronics
1304 Paddock Dr. - Suite F100
Raleigh, NC 27609
Tel: 919 790-7111
Fax: 919 790-9022
Reptron Electronics
5954-A Six Forks Road
Raleigh, NC 27609
Tel: 919 870-5189
Fax: 919 870-5210

## Ohio

CAM/RPC
749 Miner Road
Cleveland, OH 44143
Tel: 800 283-5588
Fax: 216 461-4329
CAM/RPC
15 Bishop Drive - Suite 104
Columbus, OH 43081
Tel: 614 888-7777
Fax: 614 895-1550
CAM/RPC
7973-B Washington Woods Drive
Dayton, OH 45459
Tel: 513 898-1111
Fax: 513 433-6792
Hall-Mark Electronics
5821 Harper Road
Solon, OH 44139
Tel: 216 349-4632
Fax: 216 248-4803
Reptron Electronics
30640 Bainbridge Road
Solon, OH 44139
Tel: 216 349-1415
Fax: 216 349-1634

Ohio (cont)
Hall-Mark Electronics
400 E. Wilson Bridge Rd. - \#S
Worthington, OH 43085
Tel: 614 888-3313
Fax: 614 888-0767
Reptron Electronics
404 E. Wilson Bridge Rd. \#A
Worthington, OH 43085
Tel: 614 436-6675
Fax: 614 436-4285

## Oklahoma

Hall-Mark Electronics
5411 S. 125th E. Ave. - Suite 305
Tulsa, OK 74146
Tel: 918 251-1108
Fax: 918 254-6207

## Oregon

Future Electronics 15236 N.W. Greenbrier Pkwy. Beaverton, OR 97006
Tel: 503 645-9454
Fax: 503 645-1559

## Pennsylvania

CAM/RPC
620 Alpha Drive
Pittsburgh, PA 15238
Tel: 800 245-2519
Fax: 412 963-6210

## Texas

Hall-Mark Electronics
12211 Technology Blvd.
Austin, TX 78727
Tel: 512 258-8848
Fax: 512 258-3777
Hall-Mark Electronics
11420 Pagemill Road
Dallas, TX 75243
Tel: 214 553-4300
Fax: 214 553-4395
Hall-Mark Electronics
8000 Westglen
Houston, TX 77063
Tel: 713 781-6100
Fax: 713 953-8420
Future Electronics
11271 Richmond Ave. - Suite 106
Houston, TX 77082
Tel: 713 556-8696
Fax: 713 589-7069

Future Electronics
1850 N. Greenville Ave. - Suite 146
Richardson, TX 75081
Tel: 214 437-2437
Fax: 214 669-2347

## Utah

Future Electronics
2250 S. Redwood Road
Salt Lake City, UT 84119
Tel: 801 972-8489
Fax: 801 972-3602

## Washington

Falcon Electronics
19231-36th ave. West
Lynnwood, WA 98036
Tel: 206 774-3005
Future Electronics
4038-148th Ave. N.E.
Redmond, WA 98052
Tel: 206 881-8199
Fax: 206 881-5232
Hall-Mark Electronics 250 N.W. 39th - Suite 4 Seattle, WA 98107
Tel: 206 547-0415

## Wisconsin

Hall-Mark Electronics
16255 W. Lincoln Ave.
New Berlin, WI 53151
Tel: 414 797-7844
Fax: 414 797-9259

## ASIA

## ASIAN HEADQUARTERS

## Hong Kong

Arizona Microchip Technology Ltd. 75, Mody Road, Tsimshatsui East Rm 1103, Tower 1, So.Seas Ctr. Kowloon
Tel: 3116103
Fax: 3115125
Telex: 44611

## Japan

Microchip Technology Inc.
4F Madre Matsuda Bldg.
4-13, Kioi-Cho,
Chiyoda-Ku, Tokyo 102
Tel: 32348774
Fax: 32348549

## Korea

Microchip Technology Inc. c/o Daeho Corp. 1004 Keo Yang Bldg.
51-8 Soosong Dong
Chongro-Ku, Seoul
Tel: 27209800
Fax: 27396040
Telex: 26880

## Singapore

Arizona Microchip Technology Ltd.
Singapore Representative Office
10 Anson Road, \#14-02
International Plaza
Singapore 0207
Tel: 2224962
Fax: 2224939

## Taiwan

Microchip Technology Taiwan Liaison Office 5F, 41 Ming Chuan Road
Hsin-Tien, Taipei
Tel: 29113431
Fax: 29146234

## EUROPE

## EUROPEAN HEADQUARTERS

## England

Arizona Microchip Technology Unit 3, Meadow Bank, Furlong Road
Bourne End, Bucks SL8 5AJ
Tel: 0628850303
Fax: 0628850178

## France

Arizona Microchip Technology
2, Rue du Buisson aux Fraises F-91300 Massy
Tel: 169309090
Fax: 169309079

## Germany

Arizona Microchip Technology
Alte Landstr. 12-14
D-8012 Ottobrunn
Tel: 0896096072
Fax: 0896091997
Telex: 524518

## USA

## California

Microchip Technology Inc.
1411 W. 190th Street, Suite 230
Gardena, CA 90248
Tel: 2133231888
Fax: 2133231424
Microchip Technology Inc.
2107 North First Street, \#410
San Jose, CA 95131
Tel: 4084367950
Fax: 4084367955

## Georgia

Microchip Technology Inc. 2860 Johnson Ferry Rd. N.E., \#250B
Marietta, GA 30062
Tel: 4046426933
Fax: 4046426890

## Illinois

Microchip Technology Inc. 800 East Diehl Road, Suite 175
Naperville, IL 60563
Tel: 7085050022
Fax: 7085050065

## Massachusetts

Microchip Technology Inc.
Five The Mountain Road, Suite 120
Framingham, MA 01701
Tel: 5088203334
Fax: 5088720923

## New York

Microchip Technology Inc.
300 Wheeler Road., Suite 206
Hauppage, NY 11788
Tel: 5162321930
Fax: 5162321935

## Texas

Microchip Technology Inc. 17480 N Dallas Pkwy., Suite 114
Dallas, TX 75287
Tel: 2147330391
Fax: 2142504631

# Microchip 

[^16]Microchip Technology Inc. 2355 W Chandler Blvd. Chandler, AZ 85224-6199
Tel:602 9637373 FAX:602 3453390


[^0]:    * All EEPROMs 4K and greater utilize a 1.2 micron CMOS process.

[^1]:    ** See 27C64 Military Data sheet DS60011

[^2]:    * Code subject to change.

[^3]:    ** See 27C128 Military Data sheet DS60012

[^4]:    * Code subject to change.

[^5]:    ** See 27C256 Military Data sheet DS60013

[^6]:    * Code subject to change.

[^7]:    **See 27C512 Military Data Sheet DS60014

[^8]:    ** See 27HC64 Military Data sheet DS60006

[^9]:    **See 27HC256 Military Data Sheet DS60009A

[^10]:    ** See 27HC1616 Military Data sheet DS60038

[^11]:    * Code subject to change.

[^12]:    * DIP Packages

[^13]:    $\dagger$ Typical data is at $T A=25^{\circ} \mathrm{C}, \mathrm{VDD}=5.0 \mathrm{~V}$.

[^14]:    **Typical values are at $+25^{\circ} \mathrm{C}$ and nominal voltages.
    Note 1: The active pull-up during an output operation will achieve a logic 1 of 2.4 volts in a time of typically 1 microsecond. However, from 2.4 volts to the high level of 3.5 volts the available pull up current will reduce significantly and further edge transition will be highly dependent upon load capacitance.

[^15]:    * Assume the direction of the I/O port has already been determined via a write to the Enable register (R7A).

[^16]:    Microchip Technology Inc. $\cdot 2355$ W. Chandler Blvd. • Chandler, AZ 85224-6199•(602) 963-7373• Printed in USA © 9005

