## Microcontroller <br> Databook

## A Corporate Dedication to

 Quality and ReliabilityNational Semiconductor is an industry leader in the manufacture of high quality, high reliability integrated circuits. We have been the leading proponent of driving down IC defects and extending product lifetimes. From raw material through product design, manufacturing and shipping, our quality and reliability is second to none.
We are proud of our success . . . it sets a standard for others to achieve. Yet, our quest for perfection is ongoing so that you, our customer, can continue to rely on National Semiconductor Corporation to produce high quality products for your design systems.


Charles E. Sporck
President, Chief Executive Officer
National Semiconductor Corporation

## Wir fühlen uns zu Qualität und Zuverlässigkeit verpflichtet

National Semiconductor Corporation ist führend bei der Herstellung von integrierten Schaltungen hoher Qualität und hoher Zuverlässigkeit. National Semiconductor war schon immer Vorreiter, wenn es galt, die Zahl von IC Ausfällen zu verringern und die Lebensdauern von Produkten zu verbessern. Vom Rohmaterial über Entwurf und Herstellung bis zur Auslieferung, die Qualität und die Zuverlässigkeit der Produkte von National Semiconductor sind unübertroffen.
Wir sind stolz auf unseren Erfolg, der Standards setzt, die für andere erstrebenswert sind. Auch ihre Ansprüche steigen ständig. Sie als unser Kunde können sich auch weiterhin auf National Semiconductor verlassen.

## La Qualité et La Fiabilité: <br> Une Vocation Commune Chez National Semiconductor Corporation

National Semiconductor Corporation est un des leaders industriels qui fabrique des circuits intégrés d'une très grande qualité et d'une fiabilité exceptionelle. National a été le premier à vouloir faire chuter le nombre de circuits intégrés défectueux et a augmenter la durée de vie des produits. Depuis les matières premières, en passant par la conception du produit sa fabrication et son expédition, partout la qualité et la fiabilité chez National sont sans équivalents.
Nous sommes fiers de notre succès et le standard ainsi défini devrait devenir l'objectif à atteindre par les autres sociétés. Et nous continuons à vouloir faire progresser notre recherche de la perfection; il en résulte que vous, qui êtes notre client, pouvez toujours faire confiance à National Semiconductor Corporation, en produisànt des systèmes d'une très grande qualité standard.

## Un Impegno Societario di Qualità e Affidabilità

National Semiconductor Corporation è un'industria al vertice nella costruzione di circuiti integrati di altà qualità ed affidabilità. National è stata il principale promotore per l'abbattimento della difettosità dei circuiti integrati e per l'allungamento della vita dei prodotti. Dal materiale grezzo attraverso tutte le fasi di progettazione, costruzione e spedizione, la qualità e affidabilità National non è seconda a nessuno.
Noi siamo orgogliosi del nostro successo che fissa per gli altri un traguardo da raggiungere. Il nostro desiderio di perfezione è d'altra parte illimitato e pertanto tu, nostro cliente, puoi continuare ad affidarti a National Semiconductor Corporation per la produzione dei tuoi sistemi con elevati livelli di qualità.


Charles E. Sporck
President, Chief Executive Officer
National Semiconductor Corporation

## MICROCONTROLLER DATABOOK

COP400 Family COP800 Family

COPS Peripherals
COPS Peripherals

COPS Applications
COPS Applications
HPC Family
Display/Terminal ManagementProcessor (TMP)
Microcontroller Development Tools
Appendices/Physical Dimensions

## Appendices/Physical Dimensions

## TRADEMARKS

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

| Abuseable ${ }^{\text {TM }}$ | DPVMTM | MSTTM | SPIRETM |
| :---: | :---: | :---: | :---: |
| Anadig'M | ELSTARTM | Naked-87M | STARTM |
| ANS-R-TRANTM | E-Z-LINKTM | National ${ }^{\text {® }}$ | Starlink ${ }^{\text {TM }}$ |
| APPSTM | GENIXTM | NAX 800tm | STARPLEXTM |
| Auto-Chem DeflasherTM | GNXTM | Nitride Plustm | STARPLEX IITM |
| BI-FETTM | HEX 3000 ${ }^{\text {TM }}$ | Nitride Plus Oxide ${ }^{\text {TM }}$ | SuperChiptm |
| BI-FET IITM | HPCTM | NMLTM | SYS32TM |
| BI-LINETM | INFOCHEXTM | NOBUSTM | TAPE-PAKTM |
| BIPLANTM | Integral ISETM | NSC800тм | TDSTM |
| BLCTM | Intelisplay ${ }^{\text {TM }}$ | NSX-16TM | TeleGateTM |
| BLXTM | ISETM | NS-XC-16TM | The National Anthem ${ }^{\text {® }}$ |
| Brite-LiteTM | ISE/06TM | NURAM ${ }^{\text {TM }}$ | TimerChekTM |
| BTLTM | ISE/08TM | OXISSTM | TLCTM |
| CIM ${ }^{\text {™ }}$ | ISE/16TM | Perfect Watch ${ }^{\text {TM }}$ | Trapezoidal ${ }^{\text {TM }}$ |
| CIMBUSTM | ISE32TM | PharmanChekTM | TRI-CODETM |
| Clock $\sim$ Chek ${ }^{\text {TM }}$ | LMCMOSTM | PLANTM | TRI-POLYTM |
| COMBOTM | Macrobus ${ }^{\text {TM }}$ | Polycraftim | TRI-SAFETM |
| COMBO ${ }^{\text {TM }}$ | Macrocomponent ${ }^{\text {TM }}$ | POSitalkerTM | TRI-STATE ${ }^{\text {® }}$ |
| COMBO IITM | Meat $\llcorner$ ChekTM | QUAD3000TM | TURBOTRANSCEIVERTM |
| COPSTM microcontrollers | Microbus ${ }^{\text {TM }}$ data bus | RATtM | VIPTM |
| DATACHECKER ${ }^{\text {® }}$ | (adjective) | RTX16TM | VR32Tm |
| DENSPAKTM | MICRO-DACTM | ScriptrChekTM | XMOSTM |
| DIBTM | $\mu$ talkerTM | SCXTM | XPUTM |
| Digitalker ${ }^{\text {® }}$ | MicrotalkerTM | Shelf-ChekTM | Z STARTM |
| DISCERNTM | MICROWIRETM | SERIES/800TM | 883B/RETSTM |
| DISTILLTM | MICROWIRE/PLUSTM | Series 32000 ${ }^{\text {® }}$ | 883S/RETSTM |
| DNRTM | MOLETM |  |  |

## LIFE SUPPORT POLICY

NATIONAL'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT OF NATIONAL SEMICONDUCTOR CORPORATION. As used herein:

1. Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
2. A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.

National Semiconductor Corporation 2900 Semiconductor Drive, P.O. Box 58090, Santa Clara, California 95052-8090 (408) 721-5000 TWX (910) 339-9240

National does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied, and National reserves the right, at any time without notice, to change said circuitry or specifications.

## Microcontrollers for Today and Tomorrow

## ANSWERING CUSTOMER NEEDS:

In todays applications, system designers are using more and more microcontrollers to lower system cost while providing more functions and reducing system size. By using advanced technologies and designs, National's families of microcontrollers offer a complete range of performance and features from the lowest cost to the highest performance in the industry. Now a microcontroller can be chosen that is "just right for the application."
These microcontrollers have become the standard in a multitude of products from many companies in many different industries. Designers can now choose from a wide range of devices to match the performance and cost objective of a particular product. Since all the latest products are designed to fit in National's standard cell program they can be customized for a specific application.

## THE FAMILY APPROACH:

National offers families of products that satisfy a wide variety of application needs. The COPS Family of devices provide the most flexible, cost effective system solution in applications requiring timing, counting or control functions. This family offers products that sell for under $50 \phi$ in volume and provide a very high cost/performance efficiency. The COPS Family includes over sixty different microcontrollers. They are all compatible so if you design one into a system, you can easily migrate to others in the family.
National's COPS Family is being expanded with the COP800 Family. The COP800 Family offers an excellent cost/performance efficiency. The family is designed with the core/modularity concept to make it easy to add additional family members. The chip has been designed to make it easy to add peripheral functions: such as EERAM, PLL's, A/D's, display drivers, etc.
National's 8050 Family includes the 8048,8049 , and 8050 . The 8050 U provides MICROWIRE PLUS for serial communication. In addition National offers the Display/Terminal Management Processor (TMP) which make designing a display controller easy.
Because future designs require more processing power, National's High Performance Controller (HPC) Family provides high performance. Utilizing microCMOS advanced low power technology, HPC is designed for code efficiency and is capable of greater than 240 ns register instruction cycle time. Designed utilizing the core/modularity concept on board peripheral functions can easily be added-A/D's, UARTS, HDLC controller, Timers/counters and gate array to name a few.
microCMOS MICROCONTROLLERS:
National's advanced microCMOS technology combines NMOS speeds and bipolar ruggedness with the inherent benefits of CMOS. This gives a definite edge in performance:

- Wide performance range
- Power saving operation
- Extended temperature range

These families of microcontrollers enables the design of reliable, high performance CMOS systems at a competitive cost.
SUPPORT FROM DEVELOPMENT TO PRODUCTION:
The MOLE (Microcontroller on Line Emulator) development system makes for easy program development and software debugging. The MOLE was developed with the microcontroller design engineer in mind. This low cost and powerful development system consists of three components-a Brain Board, a Personality Board and a personal computer.
In addition to the development systems there are Piggyback and ROMless Microcontrollers for low volume production. You can market test your product, add features and have the flexibility of tailoring the program to meet the needs of your market place.

## QUALITY AND RELIABILITY:

Being second to none in quality and reliability is a corporate objective at National. It has led to reduced I.C. defects and extended product lifetimes. With a committment from Nationals top management and the implementation of a company-wide Quality Program National's quality continues towards the goal of Zero Defects.
In addition to quality, National has invested heavily in reliability. Two programs provide for product dependability: Reliability Fast Reaction Program and Long-term Reliability Audit Program.
Reliability performance at National has improved due to procedures such as:

- Designed to Withstand High Temperature Testing
- Electro Static Discharge (ESD) Voltages
- Copper Frames

National's investment in producing quality products has earned many awards from customers for outstanding quality achievements. Nationals's goal is to provide consistent levels of quality and service that are second to none.

## CONTINUED INNOVATIONS:

National's heavy investment in R\&D will continue to provide the most effective microcontrollers for your designs.
National is committed to stay in the forefront with innovations in cost effective microcontrollers; and by providing/developing the latest in High Peformance Controllers; and supported by a wide variety of development aids: MOLE, Piggyback devices, ROMless.
National works with you from initial development through production, for optimal cost performance solutions to your design needs. National offers Field Application Engineers along with Factory Application Engineers to provide both hardware and software design support. In addition there are workshops with hands on training, and Dial-a-helper to help with code development and debug to enable you to quickly get to market with the most competitive product available.

## Table of Contents

Section 1 COP400 Family COPS ..... 1-3
ROM'd Devices
COP210C/COP211C Single-Chip CMOS Microcontrollers ..... 1-6
COP224C/COP225C/COP226C/COP244C/COP245C Single-Chip 1k and 2k CMOS Microcontrollers ..... 1-18
COP410C/COP411C/COP310C/COP311C Single-Chip CMOS Microcontrollers ..... 1-34
COP410L/COP411L/COP310L/COP311L Single-Chip N-Channel Microcontrollers ..... 1-49
COP413L/COP313L Single Chip Microcontrollers ..... 1-67
COP413C/COP413CH/COP313C/COP313CH Single-Chip CMOS Microcontrollers ..... 1-80
COP414L/COP314L/COP214L Single-Chip N-Channel Microcontroller ..... 1-94
COP417C/COP418C/COP317C/COP318C/COP217C/COP218C Single-Chip CMOS Microcontrollers ..... 1-110
COP420/COP421/COP422 and COP320/COP321/COP322 Single-Chip N-Channel Microcontrollers ..... 1-111
COP420L/COP421L/COP422L/COP320L/COP321L/COP322L Single-Chip N -Channel Microcontrollers ..... 1-133
COP420H/COP421H/COP422H/COP320H/COP321H/COP322H/COP220H/ COP221H/COP222H Single-Chip Microcontrollers ..... 1-159
COP420P/COP444CP/COP444LP Piggyback EEPROM Microcontrollers ..... 1-181
COP424C/COP425C/COP426C/COP324C/COP325C/COP326C/ and COP444C/ COP445C/COP344C/COP345C Single-Chip 1k and 2k CMOS Microcontrollers ..... 1-182
COP427C/COP428C/COP429C/COP327C/COP328C/COP329C/COP227C/COP228C/COP229C/COP447C/COP448C/COP449C/COP347C/COP348C/COP349C Single-Chip 1k and 2k CMOS Microcontrollers1-201
COP440/COP441/COP442/COP340/COP341/COP342 Single-Chip N-Channel Microcontrollers ..... 1-224
COP444L/COP445L/COP344L/COP345L Single-Chip N-Channel Microcontrollers ..... 1-247
ROMless Devices
COP401L ROMless N-Channel Microcontroller ..... 1-270
COP401L-X13/COP401L-R13 ROMless N-Channel Microcontroller ..... 1-284
COP402/COP402M ROMless N-Channel Microcontrollers ..... 1-297
COP404 ROMless N-Channel Microcontroller ..... 1-315
COP404C ROMless CMOS Microcontrollers ..... 1-322
COP404LSN-5 ROMless N-Channel Microcontrollers ..... 1-339
Section 2 COP800 Family
COP800C ..... 2-3
COP820C/COP821C/COP822C Single-Chip microCMOS Microcontroller ..... 2-4
COP840C 2k Single-Chip 8-Bit Low Cost Microcontroller ..... 2-20
COP8620C 1k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Data Memory ..... 2-21
COP8640C 2k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Data Memory ..... 2-22
COP8720C 1k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Program and Data Memory ..... 2-23
COP8740C 2 k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Program and Data Memory ..... 2-24
Section 3 COPS Peripherals
COP431/COP432/COP434/COP438/ADC0831/ADC0832/ADC0834/ADC0838 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
COP452L/COP352L Frequency Generator and Counter ..... 3-27
COP470/COP370 V.F. Display Driver ..... 3-57

## Table of Contents

Section 3 COPS Peripherals (Continued) COP472-3 Liquid Crystal Display Controller . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-64
COP494/NMC9306 256-Bit Serial Electrically Erasable Programmable Memory ....... 3-71
COP495/NMC9345 1024-Bit Serial Electrically Erasable
Programmable Memory (5V Only) 3-76
COP498/COP398 Low Power CMOS RAM and Timer (RAT) COP499/COP399 Low Power CMOS Memory ..... 3-81
DS8906 AM/FM Digital Phase-Locked Loop Synthesizer ..... 3-93
DS8907 AM/FM Digital Phase-Locked Loop Frequency Synthesizer ..... 3-100
DS8908 AM/FM Digital Phase-Locked Loop Frequency Synthesizer ..... 3-106
DS8911/DS8912 AM/FM/TV Sound Up-Conversion Frequency Synthesizers ..... 3-114
MM5450/MM5451 LED Display Drivers ..... 3-123
MM5452/MM5453 Liquid Crystal Display Drivers ..... 3-129
MM5483 Liquid Crystal Display Driver ..... 3-136
MM5484 16-Segment LED Display Driver ..... 3-139
MM5486 LED Display Driver ..... 3-142
MM58201 Multiplexed LCD Driver ..... 3-147
MM58248 High Voltage Display Driver. ..... 3-153
MM58241 High Voltage Display Driver ..... 3-158
MM58242 High Voltage Display Driver ..... 3-163
MM58342 High Voltage Display Driver ..... 3-168
MM58348 High Voltage Display Driver ..... 3-173
MM58341 High Voltage Display Driver ..... 3-178
AN-440 New CMOS Vacuum Fluorescent Drivers Enable Three Chip System to
Provide Intelligent Control of Dot Matrix VF Display ..... 3-183
NMC27C32B 32,768-Bit ( $4095 \times 8$ ) UV Erasable CMOS PROM ..... 3-193
NMC27C64 65,536-Bit (8k x 8) UV Erasable CMOS PROM ..... 3-201
NMC27C256 262,144-Bit (32k x 8) UV Erasable CMOS PROM ..... 3-209
NMC27C512 524,288-Bit (64k x 8) UV Erasable CMOS PROM ..... 3-218
NMC27C1024 1,048,576-Bit (64k x 16) UV Erasable CMOS PROM ..... 3-226
DM54LS373/DM74LS373, DM54LS374/DM74LS374 TRI-STATE Octal D-Type
Transparent Latches and Edge-Triggered Flip-Flops ..... 3-234
MM54HC373/MM74HC373 TRI-STATE Octal D-Type Latch ..... 3-239
MM57409 Super Number Cruncher ..... 3-242
Section 4 COPS Applications
COP Brief 2 Easy Logarithms for COP400 ..... 4-3
COP Brief 4 L-Bus Considerations ..... 4-14
COP Brief 5 Software and Opcode Differences in the COP444L Instruction Set ..... 4-15
COP Brief 6 RAM Keep-Alive ..... 4-16
COP420-QRX/N Preprogrammed Single-Chip Microcontroller for Musical Organ ..... 4-17
COP Note 1 Analog to Digital Conversion Techniques with COPS Family Microcontrollers ..... 4-19
COP Note 4 The COP444L Evaluation Device 444L-EVAL ..... 4-51
COP Note 5 Oscillator Characteristics of COPS Microcontrollers ..... 4-56
COP Note 6 Triac Control Using the COP400 Microcontroller Family ..... 4-73
COP Note 7 Testing of COPS Chips ..... 4-81
AB-3 Current Consumption in NMOS COPS Controllers ..... 4-90
AB-4 Further Information on Testing of COPS Microcontrollers ..... 4-92
AB-6 COPS Interrupts ..... 4-94
AB-15 Protecting Data in the NMC9306/COP494 and NMC9346/COP495 Serial EEPROMS ..... 4-95
AB-28 COPS Peripheral Chips ..... 4-97

## Table of Contents (continuen)

Section 4 COPS Applications (Continued) AN-326 A Users Guide to COPS Oscillator Operation ..... 4-99
AN-329 Implementing an 8-bit Buffer in COPS ..... 4-103
AN-338 Designing with the NMC9306/COP494 a Versatile Simple to Use E2PROM ..... 4-107
AN-400 A Study of the Crystal Oscillator for CMOS-COPS ..... 4-114
AN-401 Selecting Input/Output Options on COPS Microcontrollers ..... 4-118
AN-452 MICROWIRE Serial Interface ..... 4-128
AN-453 COPS Based Automobile Instrument Cluster ..... 4-139
AN-454 Automotive Multiplex Wiring ..... 4-144
AN-455 The COPS Programming Manual ..... 4-148
Section 5 HPC FamilyHPC Introduction5-3
HPC16040/HPC26040/HPC36040/HPC46040/HPC16030/HPC36030/HPC46030 High Performance Microcontroller ..... 5-4
HPC16083/HPC26083/HPC36083/HPC46083/HPC16073/HPC36073/HPC46073 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC16400/HPC36400/HPC46400 Telecom Microcontroller ..... 5-30
HPC16740/HPC36740/HPC46740/HPC16730/HPC36730/HPC46730 High Performance Microcontroller with Gate Array ..... 5-50
HPC16900 Port Expansion and Recreation Logic ..... 5-51
Section 6 NS8050 Family6-3
INS8048/INS8049/INS8048L/INS8049L/INS8048I/INS8049I/NS8050U/NS8040U/NS87P50U/NS8050UL/NS8050UI/NS87P50 Microcomputer/
Microprocessor Family ..... 6-4
INS8243 Input/Output Expander ..... 6-25
AB-17 Using E2PROMS with ROMless Single-Chip Microcontrollers ..... 6-32
AN-345 Internal ROM Verification for the 48-Series Microcontrollers ..... 6-34
AN-358 NS8050U MICROWIRE/PLUS Interface ..... 6-37
Section 7 Display/Terminal Management Processor (TMP)TMP7-3
NS405/NS32405 Series Display Terminal Management Processor (TMP) ..... 7-4
AB-14 Throughput Considerations in NS405 System Planning ..... 7-43
AB-16 NS405-Series TMP External Interrupt Processing ..... 7-44
AN-354 TMP Row and Attribute Table Lookup Operation ..... 7-46
AN-355 TMP-Dynamic RAM Interfacing ..... 7-53
AN-367 TMP External Character Generation ..... 7-58
AN-369 NS405 TMP Logic Analyzer ..... 7-61
AN-374 Building an Inexpensive but Powerful Color Terminal ..... 7-68
AN-399 TMP Extended Program Memory ..... 7-73
Section 8 Microcontroller Development Tools
8-3
Mole8-4
Section 9 Appendices/Physical Dimensions
PCC Packaging ..... 9-3
Technical Manuals ..... 9-7
Physical Dimensions ..... 9-8
Data Bookshelf
Sales and Distribution Offices

## Alpha-Numeric Index

AB-3 Current Consumption in NMOS COPS Controllers ..... 4-90
AB-4 Further Information on Testing of COPS Microcontrollers ..... 4-92
AB-6 COPS Interrupts ..... 4-94
AB-14 Throughput Considerations in NS405 System Planning ..... 7-43
AB-15 Protecting Data in the NMC9306/COP494 and NMC9346/COP495 Serial EEPROMS ..... 4-95
AB-16 NS405-Series TMP External Interrupt Processing ..... 7-44
AB-17 Using E2PROMS with ROMless Single-Chip Microcontroller ..... 6-32
AB-28 COPS Peripheral Chips ..... 4-97
AN-326 A Users Guide to COPS Oscillator Operation ..... 4-99
AN-329 Implementing an 8-bit Buffer in COPS ..... 4-103
AN-338 Designing with the NMC9306/COP494 a Versatile Simple to Use E2PROM ..... 4-107
AN-345 Internal ROM Verification for the 48-Series Microcontrollers ..... 6-34
AN-354 TMP Row and Attribute Table Lookup Operation ..... 7-46
AN-355 TMP-Dynamic RAM Interfacing ..... 7-53
AN-358 NS8050U MICROWIRE/PLUS Interface ..... 6-37
AN-367 TMP External Character Generation ..... 7-58
AN-369 NS405 TMP Logic Analyzer ..... 7-61
AN-374 Building an Inexpensive But Powerful Color Terminal ..... 7-68
AN-399 TMP Extended Program Memory ..... 7-73
AN-400 A Study of the Crystal Oscillator for CMOS-COPS ..... 4-114
AN-401 Selecting Input/Output Options on COPS Microcontrollers ..... 4-118
AN-440 New CMOS Vacuum Fluorescent Drivers Enable Three Chip System to Provide Intelligent Control of Dot Matrix VF Display ..... 3-183
AN-452 MICROWIRE Serial Interface ..... 4-128
AN-453 COPS Based Automobile Instrument Cluster ..... 4-139
AN-454 Automotive Multiplex Wiring ..... 4-144
AN-455 The COPS Programming Manual ..... 4-148
AN-456 Microcontroller Development Tools ..... 8-4
COP Brief 2 Easy Logarithms for COP400 ..... 4-3
COP Brief 4 L-Bus Considerations ..... 4-14
COP Brief 5 Software and Opcode Differences in the COP444L Instruction Set ..... 4-15
COP Brief 6 RAM Keep-Alive ..... 4-16
COP Note 1 Analog to Digital Conversion Techniques with COPS Family Microcontrollers ..... 4-19
COP Note 4 The COP444L Evaluation Device 444L-EVAL ..... 4-51
COP Note 5 Oscillator Characteristics of COPS Microcontrollers ..... 4-56
COP Note 6 Triac Control Using the COP400 Microcontroller Family ..... 4-73
COP Note 7 Testing of COPS Chips ..... 4-81
ADC0831 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
ADC0832 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
ADC0834 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
ADC0838 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
COP210C Single-Chip CMOS Microcontrollers ..... 1-6
COP211C Single-Chip CMOS Microcontrollers ..... 1-6
COP214L Single-Chip N-Channel Microcontroller ..... $1-94$
COP217C Single-Chip CMOS Microcontrollers ..... 1-110
COP218C Single-Chip CMOS Microcontrollers ..... 1-110
COP220H Single-Chip Microcontrollers ..... 1-159
COP221H Single-Chip Microcontrollers ..... 1-159
COP222H Single-Chip Microcontrollers ..... 1-159
COP224C Single-Chip 1k and 2k CMOS Microcontrollers ..... $1-18$
COP225C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-18

## Alpha-Numeric Index (Coninued)

COP226C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-18
COP227C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-201
COP228C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-201
COP229C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-201
COP244C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-18
COP245C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-18
COP310C Single-Chip CMOS Microcontrollers ..... 1-34
COP310L Single-Chip N-Channel Microcontrollers ..... 1-49
COP311C Single-Chip CMOS Microcontrollers ..... 1-34
COP311L Single-Chip N-Channel Microcontrollers ..... 1-49
COP313C Single-Chip CMOS Microcontrollers ..... 1-80
COP313CH Single-Chip CMOS Microcontrollers ..... 1-80
COP313L Single Chip Microcontrollers ..... 1-67
COP314L Single-Chip N-Channel Microcontroller ..... 1-94
COP317C Single-Chip CMOS Microcontrollers ..... 1-110
COP318C Single-Chip CMOS Microcontrollers ..... 1-110
COP320 Single-Chip N-Channel Microcontrollers ..... 1-111
COP320H Single-Chip Microcontroller ..... 1-159
COP320L Single-Chip N-Channel Microcontrollers ..... 1-133
COP321 Single-Chip N-Channel Microcontrollers ..... 1-111
COP321H Single-Chip Microcontroller ..... 1-159
COP321L Single-Chip N-Channel Microcontrollers ..... 1-133
COP322 Single-Chip N-Channel Microcontrollers ..... 1-111
COP322H Single-Chip Microcontroller ..... 1-159
COP322L Single-Chip N-Channel Microcontrollers ..... 1-133
COP324C Single-Chip 1 k and 2 k CMOS Microcontrollers ..... 1-182
COP325C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-182
COP326C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-182
COP327C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-201
COP328C Single-Chip 1k and 2k CMOS Microcontrollers ..... 1-201
COP329C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-201
COP340 Single-Chip N-Channel Microcontrollers ..... 1-224
COP341 Single-Chip N-Channel Microcontrollers ..... 1-224
COP342 Single-Chip N-Channel Microcontrollers ..... 1-224
COP344C Single-Chip 1k and 2k CMOS Microcontrollers ..... 1-182
COP344L Single-Chip N-Channel Microcontrollers ..... 1-247
COP345C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-182
COP345L Single-Chip N-Channel Microcontrollers ..... 1-247
COP347C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-201
COP343C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-201
COP349C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-201
COP352L Frequency Generator and Counter ..... 3-27
COP370 V.F. Display Driver ..... 3-57
COP398 Low Power CMOS RAM and Timer (RAT) ..... 3-81
COP399 Low Power CMOS Memory ..... 3-81
COP401L ROMless N-Channel Microcontroller ..... 1-270
COP401L-R13 ROMless N-Channel Microcontroller ..... 1-284
COP401L-X13 ROMless N -Channel Microcontroller ..... 1-284
COP402 ROMIess N -Channel Microcontrollers ..... 1-297
COP402M ROMless N-Channel Microcontrollers ..... 1-297
COP404 ROMless N -Channel Microcontroller ..... 1-315
COP404C ROMIess CMOS Microcontrollers ..... 1-322
Alpha-Numeric Index (Continued)
COP404LSN-5 ROMless N-Channel Microcontrollers ..... 1-339
COP410C Single-Chip CMOS Microcontrollers ..... 1-34
COP410L Single-Chip N-Channel Microcontrollers ..... 1-49
COP411C Single-Chip CMOS Microcontrollers ..... 1-34
COP411L Single-Chip N-Channel Microcontrollers ..... 1-49
COP413C Single-Chip CMOS Microcontrollers ..... 1-80
COP413CH Single-Chip CMOS Microcontrollers ..... $1-80$
COP413L Single Chip Microcontrollers ..... 1-67
COP414L Single-Chip N-Channel Microcontroller ..... 1-94
COP417C Single-Chip CMOS Microcontrollers ..... 1-110
COP418C Single-Chip CMOS Microcontrollers ..... 1-110
COP420 Single-Chip N-Channel Microcontrollers ..... 1-111
COP420H Single-Chip Microcontroller ..... 1-159
COP420L Single-Chip N-Channel Microcontrollers ..... 1-133
COP420P Piggyback EEPROM Microcontrollers ..... 1-181
COP420-QRX/N Preprogrammed Single-Chip Microcontroller for Musical Organ ..... 4-17
COP421 Single-Chip N-Channel Microcontrollers ..... 1-111
COP421H Single-Chip Microcontroller ..... 1-159
COP421L Single-Chip N-Channel Microcontrollers ..... 1-133
COP422 Single-Chip N-Channel Microcontrollers ..... 1-111
COP422H Single-Chip Microcontroller ..... 1-159
COP422L Single-Chip N-Channel Microcontrollers ..... 1-133
COP424C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-182
COP425C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-182
COP426C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-182
COP427C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-201
COP428C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-201
COP429C Single-Chip 1k and 2k CMOS Microcontrollers ..... 1-201
COP431 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
COP432 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
COP434 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
COP438 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
COP440 Single-Chip N-Channel Microcontrollers ..... 1-224
COP441 Single-Chip N-Channel Microcontrollers ..... 1-224
COP442 Single-Chip N-Channel Microcontrollers ..... 1-224
COP444C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-182
COP444CP Piggyback EEPROM Microcontrollers ..... 1-181
COP444L Single-Chip N-Channel Microcontrollers ..... 1-247
COP444LP Piggyback EEPROM Microcontrollers ..... 1-181
COP445C Single-Chip 1k and 2 k CMOS Microcontrollers ..... 1-182
COP445L Single-Chip N-Channel Microcontrollers ..... 1-247
COP447C Single-Chip 1k and 2k CMOS Microcontrollers ..... 1-201
COP448C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-201
COP449C Single-Chip 1k and $2 k$ CMOS Microcontrollers ..... 1-201
COP452L Frequency Generator and Counter ..... 3-27
COP470 V.F. Display Driver ..... 3-57
COP472-3 Liquid Crystal Display Controller ..... 3-64
COP494 256-Bit Serial Electrically Erasable Programmable Memory ..... 3-71
COP495 1024-Bit Serial Electrically Erasable Programmable Memory (5V Only) ..... 3-76
COP498 Low Power CMOS RAM and Timer (RAT) ..... 3-81
COP499 Low Power CMOS Memory ..... 3-81
Alpha-Numeric Index (Continued)
COP820C Single Chip MicroCMOS Microcontrollers ..... 2-4
COP821C Single Chip MicroCMOS Microcontrollers ..... 2-4
COP822C Single Chip MicroCMOS Microcontrollers ..... 2-4
COP840C 2k Single-Chip 8-Bit Low Cost Microcontroller ..... 2-20
COP8620C 1k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Data Memory ..... 2-21
COP8640C 2 k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Data Memory ..... 2-22
COP8720C 1k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Program and Data Memory ..... 2-23
COP8740C 2k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Program and Data Memory ..... 2-24
DM54LS373 TRI-STATE Octal D-Type Transparent Latches and Edge-Triggered Flip-Flops ..... 3-234
DM54LS374 TRI-STATE Octal D-Type Transparent Latches and Edge-Triggered Flip-Flops ..... 3-234
DM74LS373 TRI-STATE Octal D-Type Transparent Latches and Edge-Triggered Flip-Flops ..... 3-234
DM74LS374 TRI-STATE Octal D-Type Transparent Latches and Edge-Triggered Flip-Flops ..... 3-234
DS8906 AM/FM Digital Phase-Locked Loop Synthesizer ..... 3-93
DS8907 AM/FM Digital Phase-Locked Loop Frequency Synthesizer ..... 3-100
DS8908 AM/FM Digital Phase-Locked Loop Frequency Synthesizer ..... 3-106
DS8911 AM/FM/TV Sound Up-Conversion Frequency Synthesizers ..... 3-114
DS8912 AM/FM/TV Sound Up-Conversion Frequency Synthesizers ..... 3-114
HPC16030 High Performance Microcontrollers ..... 5-4
HPC16040 High Performance Microcontroller ..... 5-4
HPC16073 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC16083 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC16400 Telecom Microcontroller ..... 5-30
HPC16730 High Performance Microcontroller with Gate Array ..... 5-50
HPC16740 High Performance Microcontroller with Gate Array ..... 5-50
HPC16900 Port Expansion and Recreation Logic ..... 5-51
HPC26040 High Performance Microcontrollers ..... 5-4
HPC26083 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC36030 High Performance Microcontrollers ..... 5-4
HPC36040 High Performance Microcontrollers ..... 5-4
HPC36073 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC36083 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC36400 Telecom Microcontroller ..... 5-30
HPC36730 High Performance Microcontroller with Gate Array ..... 5-50
HPC36740 High Performance Microcontroller with Gate Array ..... 5-50
HPC46030 High Performance Microcontrollers ..... 5-4
HPC46040 High Performance Microcontroliers ..... 5-4
HPC46073 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC46083 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC46400 Telecom Microcontroller ..... 5-30
HPC46730 High Performance Microcontroller with Gate Array ..... 5-50
HPC46740 High Performance Microcontroller with Gate Array ..... 5-50
INS8048 Microcomputer/Microprocessor Family ..... 6-4
INS8048I Microcomputer/Microprocessor Family ..... 6-4
INS8048L Microcomputer/Microprocessor Family ..... 6-4
INS8049 Microcomputer/Microprocessor Family ..... 6-4
INS80491 Microcomputer/Microprocessor Family ..... 6-4
INS8049L Microcomputer/Microprocessor Family ..... 6-4
INS8243 Input/Output Expander ..... 6-25
MM5450 LED Display Drivers ..... 3-123
MM5451 LED Display Drivers ..... 3-123
Alpha-Numeric Index ${ }_{\text {(coninuoo }}$
MM5452 Liquid Crystal Display Drivers ..... 3-129
MM5453 Liquid Crystal Display Drivers ..... 3-129
MM5483 Liquid Crystal Display Driver ..... 3-136
MM5484 16-Segment LED Display Driver ..... 3-139
MM5486 LED Display Driver ..... 3-142
MM54HC373 TRI-STATE Octal D-Type Latch ..... 3-239
MM57409 Super Number Cruncher ..... 3-242
MM58201 Multiplexed LCD Driver ..... 3-147
MM58241 High Voltage Display Driver ..... 3-158
MM58242 High Voltage Display Driver ..... 3-163
MM58248 High Voltage Display Driver ..... 3-153
MM58341 High Voltage Display Driver ..... 3-178
MM58342 High Voltage Display Driver ..... 3-168
MM58348 High Voltage Display Driver ..... 3-173
MM74HC373 TRI-STATE Octal D-Type Latch ..... 3-239
NMC27C32B 32,768-Bit ( $4095 \times 8$ ) UV Erasable CMOS PROM ..... 3-193
NMC27C64 65,536-Bit ( $8 \mathrm{k} \times 8$ ) UV Erasable CMOS PROM ..... 3-201
NMC27C256 262,144-Bit (32k x 8) UV Erasable CMOS PROM ..... 3-209
NMC27C512 524,288-Bit (64k x 8) UV Erasable CMOS PROM ..... 3-218
NMC27C1024 1,048,576-Bit (64k x 16) UV Erasable CMOS PROM ..... 3-226
NMC9306 256-Bit Serial Electrically Erasable Programmable Memory ..... 3-71
NMC9345 1024-Bit Serial Electrically Erasable Programmable Memory (5V Only) ..... 3-76
NS405 Series Display Terminal Management Processor (TMP) ..... 7-4
NS32405 Series Display Terminal Management Processor (TMP) ..... 7-4
NS8040U Microcomputer/Microprocessor Family ..... 6-4
NS8050U Microcomputer/Microprocessor Family ..... 6-4
NS8050UI Microcomputer/Microprocessor Family ..... 6-4
NS8050UL Microcomputer/Microprocessor Family ..... 6-4
NS87P50 Microcomputer/Microprocessor Family ..... 6-4
NS87P50U Microcomputer/Microprocessor Family ..... 6-4

Section 1
COP400 Family

## Section 1 Contents

COPS ..... $1-3$
ROM'd Devices
COP210C/COP211C Single-Chip CMOS Microcontrollers ..... $1-6$
COP224C/COP225C/COP226C/COP244C/COP245C Single-Chip 1k and 2k CMOS
Microcontrollers ..... 1-18
COP410C/COP411C/COP310C/COP311C Single-Chip CMOS Microcontrollers ..... 1-34
COP410L/COP411L/COP310L/COP311L Single-Chip N-Channel Microcontrollers ..... 1-49
COP413L/COP313L Single Chip Microcontrollers ..... 1-67
COP413C/COP413CH/COP313C/COP313CH Single-Chip CMOS Microcontrollers ..... 1-80
COP414L/COP314L/COP214L Single-Chip N-Channel Microcontroller ..... 1-94
COP417C/COP418C/COP317C/COP318C/COP217C/COP218C Single-Chip CMOS Microcontrollers ..... 1-110
COP420/COP421/COP422/COP320/COP321/COP322 Single-Chip N-Channel Microcontrollers ..... 1-111
COP420L/COP421L/COP422L/COP320L/COP321L/COP322L Single-Chip N-Channel Microcontrollers ..... 1-133
COP420H/COP421H/COP422H/COP320H/COP321H/COP322H/COP22OH/COP221H/ COP222H Single-Chip Microcontrollers ..... 1-159
COP420P/COP444CP/COP444LP Piggyback EEPROM Microcontrollers ..... 1-181
COP424C/COP425C/COP426C/COP324C/COP325C/COP326C/ and COP444C/ COP445C/COP344C/COP345C Single-Chip 1k and 2k CMOS Microcontrollers ..... 1-182
COP427C/COP428C/COP429C/COP327C/COP328C/COP329C/COP227C/COP228C/ COP229C/COP447C/COP448C/COP449C/COP347C/COP348C/COP349C Single-Chip 1 k and 2 k CMOS Microcontrollers ..... 1-201
COP440/COP441/COP442/COP340/COP341/COP342 Single-Chip N-Channel Microcontrollers ..... 1-224
COP444L/COP445L/COP344L/COP345L Single-Chip N-Channel Microcontrollers ..... 1-247
ROMless Devices
COP401L ROMless N-Channel Microcontroller ..... 1-270
COP401L-X13/COP401L-R13 ROMIess N-Channel Microcontroller ..... 1-284
COP402/COP402M ROMless N-Channel Microcontrollers ..... 1-297
COP404 ROMless N-Channel Microcontroller ..... 1-315
COP404C ROMless CMOS Microcontrollers ..... 1-322
COP404LSN-5 ROMless N-Channel Microcontrollers ..... 1-339

## COPS ${ }^{\text {TM }}$

The COPS family of microcontrollers provides a flexible, cost-effective system solution in applications requiring timing, counting or other control functions. COPS can be used to replace discrete logic in high-volume consumer products and low-volume industrial products allowing you to add features, miniaturize and reduce component count.
$\bullet 0.5 \mathrm{k}$ ROM and $32 \times 4$ RAM to 2 k ROM and $160 \times 4$ RAM

- ROM-efficient instruction set
- 2-16 $\mu \mathrm{s}$ instruction cycle time plus HALT
- Common pin-out
- Wide temperature ranges: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- MICROWIRETM serial communication
- Low-cost MOLETM development system

COPS wide acceptance comes from innovative products. National has built on this established family with continued and enhanced devices.

- The first under-a-dollar microcontroller led to a broader range of automotive and consumer applications.
- The first high-speed, low-power CMOS microcontrollers with 0.5 k ROM provides design flexibility at low cost.
- The first microcontroller implementing MICROWIRE/PLUSTM allowing two-way communication across only three lines.
- The first under $\$ .50$ microcontroller providing excellent cost/performance benefits for applications impossible before.

National's microCMOS controllers offer a definite edge in performance. These advanced microcontrollers combine NMOS speed and bipolar ruggedness with the inherent benefits of CMOS. All the benefits of microCMOS are found in the high performance microcontroller family which now boasts more than 22 compatible device types.
As system designs become more complex, and as low power becomes more important in meeting design objectives, greater performance is required from microcontrollers. The COPS family provides the system solution.

COPS Family of Microcontrollers
$\stackrel{\rightharpoonup}{\mathbf{S}}$

| Commercial Temp Version $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | Industrial Temp Version $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | Military Temp Version $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | Technology | Description |  | Features |  |  |  |  |  |  |  |  | Development Tools |  | Data <br> Sheet <br> Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Mem <br> ROM (Bytes) | nory <br> RAM <br> (Digits) | $\begin{array}{\|l\|} \hline 1 / 0 \\ \text { Pins } \\ \hline \end{array}$ | Serial <br> I/O | Interrupt | Stack | Time <br> Base <br> Counter | Micro Bus | Typ. 5V <br> Operat. <br> Power | Max <br> Standby at 3.3 V | Size (Pins) | ROMless Device | Piggyback |  |
| COP413L | COP313L |  | NMOS Low Power | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 15 mW | 7.5 mW | 20 | $\begin{aligned} & \text { COP401L-X13/ } \\ & \text { R13 } \end{aligned}$ |  | 1-67 |
| COP414L | COP314L |  | NMOS Low Power | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 15 mW | 7.5 mW | 20 | COP401LN |  | 1-94 |
| COP410L | COP310L |  | NMOS Low Power | 0.5k | 32 | 19 | Yes | No | 2 Level | No | No | 15 mW | 7.5 mW | 20 | COP401LN |  | 1-49 |
| COP411L | COP311L |  | NMOS Low Power | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 15 mW | 7.5 mW | 20 | COP401LN |  | 1-49 |
| COP413C | COP313C |  | CMOS Low Power | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 1 mW | 0.1 mW | 20 | COP404CN | COP444CP | 1-80 |
| COP413CH | COP313CH |  | CMOS Hi Speed | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 1 mW | 0.1 mW | 20 | COP404CN | COP444CP | $1-80$ |
| COP410C | COP310C | COP210C (Note 1) | CMOS Hi Speed | 0.5k | 32 | 19 | Yes | No | 2 Leve! | No | No | 1 mW | 0.1 mW | 24 | COP404CN | COP444CP | 1-34 |
| COP411C | COP311C | COP211C (Note 1) | CMOS Hi Speed | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 1 mW | 0.1 mW | 20 | COP404CN | COP444CP | 1-34 |
| COP420 | COP320 |  | NMOS Hi Speed | 1.0k | 64 | 23 | Yes | 1 Source | 3 Level | Yes | Yes | 100 mW | N/A mW | 28 | COP402N | COP420P | 1-111 |
| COP421 | COP321 |  | NMOS Hi Speed | 1.0k | 64 | 19 | Yes | No | 3 Level | Yes | No | 100 mW | N/A mW | 24 | COP402N | COP420P | 1-111 |
| COP422 | COP322 |  | NMOS Hi Speed | 1.0k | 64 | 16 | Yes | No | 3 Level | Yes | No | 100 mW | N/A mW | 20 | COP402N | COP420P | 1-111 |
| COP424C | COP324C | COP224C (Note 2) | CMOS Hi Speed | 1.0k | 64 | 23 | Yes | 1 Source | 3 Level | Yes | Yes | 1 mW | 0.1 mW | 28 | COP404CN | COP444CP | 1-182 |
| COP425C | COP325C | COP225C ( ( l 2 2) | CMOS Hi Speed | 1.0k | 64 | 19 | Yes | No | 3 Level | Yes | No | 1 mW | 0.1 mW | 24 | COP404CN | COP444CP | 1-182 |
| COP426C | COP326C | COP226C (Note 2) | CMOS Hi Speed | 1.0k | 64 | 16 | Yes | No | 3 Level | Yes | No | 1 mW | 0.1 mW | 20 | COP404CN | COP444CP | 1-182 |
| COP420L | COP320L |  | NMOS Low Power | 1.0k | 64 | 23 | Yes | 1 Source | 3 Level | Yes | Yes | 45 mW | 9.9 mW | 28 | COP404LSN-5 | COP444LP | 1.133 |
| COP421L | COP321L |  | NMOS Low Power | 1.0k | 64 | 19 | Yes | No | 3 Level | Yes | No | 45 mW | 9.9 mW | 24 | COP404LSN-5 | COP444LP | 1-133 |
| COP422L | COP322L |  | NMOS Low Power | 1.0k | 64 | 16 | Yes | No | 3 Level | Yes | No | 45 mW | 9.9 mW | 20 | COP404LSN-5 | COP444LP | 1-133 |
| COP420H | COP320H |  | NMOS Low Power | 1.0k | 64 | 23 | Yes | 1 Source | 3 Level | Yes | Yes | 40 mW | 9.9 mW | 28 | COP404LSN-5 | COP444LP | 1-159 |
| COP421H | COP321H |  | NMOS Low Power | 1.0k | 64 | 19 | Yes | No | 3 Level | Yes | No | 40 mW | 9.9 mW | 24 | COP404LSN-5 | COP444LP | 1-159 |
| COP422H | COP322H |  | NMOS Low Power | 1.0k | 64 | 16 | Yes | No | 3 Level | Yes | No | 30 mW | 9.9 mW | 20 | COP404LSN-5 | COP444LP | 1-159 |
| COP440 | COP340 |  | NMOS Hi Speed | 2.0 k | 160 | 35 | Yes | 4 Sources | 4 Level | Yes | Yes | 205 mW | 9.9 mW | 40 | COP404N | COP440R | 1-224 |
| COP441 | COP341 |  | NMOS Hi Speed | 2.0k | 160 | 23 | Yes | 4 Sources | 4 Level | Yes | Yes | 205 mW | 9.9 mW | 28 | COP404N | COP440R | 1-224 |
| COP442 | COP342 |  | NMOS Hi Speed | 2.0k | 160 | 19 | Yes | 2 Sources | 4 Level | Yes | No | 205 mW | 9.9 mW | 24 | COP404N | COP440R | 1-224 |
| COP444C | COP344C | COP244C (Note 2) | CMOS Hi Speed | 2.0k | 128 | 23 | Yes | 1 Source | 3 Level | Yes | Yes | 1 mW | 0.1 mW | 28 | COP404CN | COP444CP | 1-182 |
| COP445C | COP345C | COP245C (Note 2) | CMOS Hi Speed | 2.0k | 128 | 19 | Yes | No | 3 Level | Yes | No | 1 mW | 0.1 mW | 24 | COP404CN | COP444CP | 1-182 |
| COP444L | COP344L |  | NMOS Low Power | 2.0k | 128 | 23 | Yes | 1 Source | 3 Level | Yes | No | 65 mW | 9.9 mW | 28 | COP404LSN-5 | COP444LP | 1-247 |
| COP445L | COP345L |  | NMOS Low Power | 2.0k | 128 | 19 | Yes | No | 3 Level | Yes | No | 65 mW | 9.9 mW | 24 | COP404LSN-5 | COP444LP | 1.247 |

Note 1: Datasheet found on page 1-6.
Note 2: Datasheet found on page 1-18.

| COPS Family Development Tools |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Technology | Description |  | Features |  |  |  |  |  |  |  |  | Supplementary Description | Data <br> Sheet <br> Page |
| Temp Version |  | Memory |  | 1/0 |  | Interrupt | Stack | Time <br> Base <br> Counter | Micro Bus | Typ. 5V Operat. Power | Max <br> Standby <br> at 3.3V | $\begin{aligned} & \text { Size } \\ & \text { (Pins) } \end{aligned}$ |  |  |
| $0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}$ |  | ROM (Bytes) | RAM (Digits) | $\begin{aligned} & \text { I/O } \\ & \text { Pins } \end{aligned}$ | Serial I/O |  |  |  |  |  |  |  |  |  |
| ROMless |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| COP401L-X13 | NMOS Low Power | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 100 mW | 7.5 mW | 40 | Has XTAL Oscillator Option | 1-284 |
| COP401L-R13 | NMOS Low Power | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 100 mW | 7.5 mW | 40 | Has RC Oscillator Option | 1-284 |
| COP401L | NMOS Low Power | 0.5k | 32 | 16 | Yes | No | 2 Level | No | No | 100 mW | 7.5 mW | 40 | ROMless Version of COP410L | 1-270 |
| COP402 | NMOS Hi Speed | 1.0k | 63 | 20 | Yes | 1 Source | 3 Level | Yes | No | 50 mW | N/A mW | 40 | Has Interrupt, No Microbus | 1-297 |
| COP402M | NMOS Hi Speed | 1.0k | 63 | 16 | Yes | No | 3 Level | Yes | Yes | 125 mW | N/A mW | 40 | No Interrupt, Has Microbus | 1-297 |
| COP404LSN-5 | NMOS Low Power | 1.0k | 128 | 20 | Yes | 1 Source | 3 Level | Yes | No | 125 mW | N/A mW | 40 | W/Push-Pull Mem Interface | 1-339 |
| COP404 | NMOS Hi Speed | 2.0k | 160 | 23 | Yes | 4 Source | 4 Level | Yes | Yes | 35 mW | 15 mW | 48 | ROMless Version of COP440 | 1-315 |
| COP404C | CMOS Hi Speed | 2.0k | 128 | 23 | Yes | 1 Source | 3 Level | Yes | Yes | 1 mW | 0.1 mW | 48 | CMOS ROMless Device | 1-322 |
| Piggyback |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| COP420P | NMOS Hi Speed | 1.0k | 64 | 23 | Yes | 3 Sources | 3 Level | Yes | No | 50 mW | N/A mW | 28 | Includes: CPU, RAM, I/O | 1-181 |
| COP444LP | NMOS Low Power | 2.0k | 128 | 23 | Yes | 3 Sources | 3 Level | Yes | No | 125 mW | N/A mW | 28 | and EPROM Socket | 1-181 |
| COP444CP | CMOS Hi Speed | 2.0k | 128 | 23 | Yes | 1 Source | 1 Level | Yes | Yes | 1 mW | 1 mW | 28 | Will Accept Standard EPROM | 1-181 |

National
Semiconductor Corporation

## COP210C/COP211C Single-Chip CMOS Microcontrollers

## General Description

The COP210C and COP211C fully static, single-chip CMOS microcontrollers are members of the COPSTM family, fabricated using double-poly, silicon-gate CMOS technology. These controller-oriented processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture, and I/O scheme designed to facilitate keyboard input, display output, and BCD data manipulation. The COP211C is identical to the COP210C but with $16 \mathrm{I} / \mathrm{O}$ lines instead of 20 . They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized control-ler-oriented processor at a low end-product cost.
The COP404C should be used for exact emulation.

## Features

■ Lowest power dissipation (500 $\mu \mathrm{W}$ typical)

- Low cost
- Power-saving HALT mode with Continue function
- Powerful instruction set
- $512 \times 8$ ROM, $32 \times 4$ RAM
- 20 I/O lines (COP210C)
- Two-level subroutine stack

■ DC to $4.4 \mu$ s instruction time

- Single supply operation ( 4.5 V to 5.5 V )
- General purpose and TRI-STATE® outputs
- Internal binary counter register with MICROWIRETM compatible serial I/O
- LSTTL/CMOS compatible in and out
- Software/hardware compatible with other members of the COP400 family
- Military temperature $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ devices


## Block Diagram



TL/DD/8444-1
FIGURE 1. COP210C

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Maximum Allowable Voltage

$$
V_{C C}=6 V
$$

Voltage at Any Pin
Total Allowable Source Current
Total Allowable Sink Current
Maximum Allowable Power Consumption 150 mW

| Operating Temperature Range | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, 10 sec. ) | $300^{\circ} \mathrm{C}$ |

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage |  | 4.5 | 5.5 | V |
| Supply Current (Note 1) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{t}_{\mathrm{C}}=\mathrm{Min} \\ & \left(\mathrm{t}_{\mathrm{C}} \text { is instruction cycle time }\right) \end{aligned}$ |  | 4000 | $\mu \mathrm{A}$ |
| Power Supply Ripple (Notes 3, 4) | Peak to Peak |  | 0.25 | V |
| HALT Mode Current (Note 2) | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~F}_{\text {IN }}=0 \mathrm{kHz}$ |  | 120 | $\mu \mathrm{A}$ |
| Input Voltage Levels <br> RESET, CKI <br> Logic High <br> Logic Low <br> All Other Inputs <br> Logic High <br> Logic Low |  | $\begin{aligned} & 0.9 \mathrm{~V}_{\mathrm{CC}} \\ & 0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \\ & \hline \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Hi-Z Input Leakage |  | -10 | +10 | $\mu \mathrm{A}$ |
| Input Capacitance (Note 4) |  |  | 7 | pF |
| Output Voltage Levels LSTTL Operation Logic High Logic Low CMOS Operation Logic High Logic Low | Standard Outputs (except CKO) $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=400 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.2$ | $\begin{aligned} & 0.6 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Allowable Sink/Source Current per Pin (Note 5) |  |  | 5 | mA |
| CKO Current Levels (As Clock Out)  <br> Sink $\div 4$ <br>  $\div 8$ <br> Source $\div 16$ <br>  $\div 4$ <br>  $\div 8$ <br>  $\div 16$ | $\begin{aligned} & \mathrm{CKI}=\mathrm{V}_{\text {CC }}, \mathrm{V}_{\text {OUT }}=\mathrm{V}_{\mathrm{CC}} \\ & \mathrm{CKI}=\mathrm{OV}, \mathrm{~V}_{\text {OUT }}=\mathrm{OV} \end{aligned}$ | $\begin{gathered} 0.2 \\ 0.4 \\ 0.8 \\ -0.2 \\ -0.4 \\ -0.8 \end{gathered}$ |  | mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Allowable Loading on CKO (as HALT I/O pin) |  |  | 50 | pF |
| Current Needed to Override HALT (Note 6) <br> To Continue To Halt | $\begin{aligned} & V_{I N}=0.2 \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{IN}}=0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |  | $\begin{aligned} & 2.0 \\ & 3.0 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| TRI-STATE or Open Drain Leakage Current |  | -10 | +10 | $\mu \mathrm{A}$ |

Note 1: Supply Current is measured after running for 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled up to VcC with $5 k$ resistors. See current drain equation.
Note 2: The HALT mode will stop CKI from oscillating in the RC and crystal configurations. Test conditions: all inputs tied to VCC. L lines in TRI-STATE mode and tied to ground, all other outputs low and tied to ground.
Note 3: Voltage change must be less than 0.25 V in a 1 ms period.
Note 4: This parameter is only sampled and not $100 \%$ tested. Variation due to the device included.
Note 5: SO Output sink current must be limited to keep $V_{O L}$ less than $0.2 \mathrm{~V}_{\mathrm{CC}}$.
Note 6: When forcing HALT, current is only needed for a short time (approximatey 200 ns ) to flip the HALT flip-flop.

AC Electrical Characteristics $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Unlts |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time ( $\mathrm{t}_{\mathrm{c}}$ ) |  | 4.4 | DC | $\mu \mathrm{s}$ |
| Operating CKI $\div 4$ mode <br> Frequency $\div 8$ mode <br>  $\div 16$ mode |  | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ | $\begin{aligned} & 0.9 \\ & 1.8 \\ & 3.6 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{MHz} \\ & \mathrm{MHz} \\ & \mathrm{MHz} \end{aligned}$ |
| Instruction Cycle Time RC Oscillator (Note 4) | $\begin{aligned} & R=30 \mathrm{k} \pm 5 \% \\ & \mathrm{C}=82 \mathrm{pF} \pm 5 \% \quad(\div 4 \text { Mode }) \end{aligned}$ | 6 | 18 | $\mu \mathrm{S}$ |
| Inputs (See Figure 3) tsETUP (Note 4) <br> $t_{\text {HOLD }}$ | $\left.\begin{array}{l} \text { G Inputs } \\ \text { SI Input } \\ \text { All Others } \end{array}\right\} \quad V_{C C} \geq 4.5 \mathrm{~V}$ | $\begin{gathered} \mathrm{tc} / 4+0.8 \\ 0.33 \\ 1.9 \\ 0.40 \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Output Propagation Delay tPD1 t ${ }^{\text {PDO }}$ | $V_{\text {OUT }}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=5 \mathrm{k}$ |  | 1.4 | $\mu \mathrm{S}$ |

## Connection Diagrams



TL/DD/8444-2
Order Number COP211C-XXX/D, See NS Package D20A

Order Number COP211C-XXX/N, See NS Package N20A

## Pin Descriptions

| Pin | Description | Pin | Description |
| :---: | :---: | :---: | :---: |
| $\mathrm{L}_{7}-\mathrm{L}_{0}$ | 8-bit bidirectional I/O port with TRI-STATE | SK | Logic-controlled clock |
| $\mathrm{G}_{3}-\mathrm{G}_{0}$ | 4-bit bidirectional I/O port |  | (or general purpose output) |
|  | ( $\mathrm{G}_{2}-\mathrm{G}_{0}$ for 20-pin package) | CKI | System oscillator input |
| $\mathrm{D}_{3}-\mathrm{D}_{0}$ | 4-bit general purpose output port ( $D_{1}-D_{0}$ for 20-pin package) | CKO | Crystal oscillator output, or HALT mode I/O port (24-pin package only) |
| SI | Serial input (or counter input) | RESET | System reset input |
| SO | Serial output (or general purpose output) | $V_{C C}$ <br> GND | System power supply System Ground |

FIGURE 2


Order Number COP210C-XXX/D, See NS Package D24C

Order Number COP210C-XXX/N, See NS Package N24A

TL/DD/8444-3

## Functional Description

A block diagram of the COP210C is given in Figure 1．Data paths are illustrated in simplified form to depict how the vari－ ous logic elements communicate with each other in imple－ menting the instruction set of the device．Positive logic is used．When a bit is set，it is a logic＂ 1 ＂；when a bit is reset，it is a logic＂ 0 ＂．

## PROGRAM MEMORY

Program memory consists of a 512－byte ROM．As can be seen by an examination of the COP210C／211C instruction set，these words may be program instructions，program data，or ROM addressing data．Because of the special char－ acteristics associated with the JP，JSRP，JID，and LQID in－ structions，ROM must often be thought of as being orga－ nized into 8 pages of 64 words（bytes）each．

## ROM ADDRESSING

ROM addressing is accomplished by a 9 －bit PC register．Its binary value selects one of the 5128 －bit words contained in ROM．A new address is loaded into the PC register during each instruction cycle．Unless the instruction is a transfer of control instruction，the PC register is loaded with the next sequential 9－bit binary count value．Two levels of subroutine nesting are implemented by two 9 －bit subroutine save regis－ ters，SA and SB．
ROM instruction words are fetched，decoded，and executed by the instruction decode，control and skip logic circuitry．

## DATA MEMORY

Data Memory consists of a 128－bit RAM，organized as four data registers of $8 \times 4$－bit digits．RAM addressing is imple－ mented by a 6 －bit B register whose upper two bits $(\mathrm{Br})$ se－ lects one of four data registers and lower three bits of the 4－ bit Bd select one of eight 4 －bit digits in the selected data register．While the 4 －bit cortents of the selected RAM digit （M）are usually loaded into or from，or exchanged with，the A register（accumulator），they may also be loaded into the $Q$ latches or loaded from the L ports．RAM addressing may also be performed directly by the XAD 3， 15 instruction．The Bd register also serves as a source register for 4－bit data sent directly to the D outputs．
The most significant bit of Bd is not used to select a RAM digit．Hence，each physical digit of RAM may be selected by two different values of Bd as shown in Figure 4．The skip condition for XIS and XDS instructions will be true if Bd changes between 0 to 15，but not between 7 and 8 （see Table III）．

## INTERNAL LOGIC

The internal logic of the COP210C／211C is designed to en－ sure fully static operation of the device．
The 4－bit A register（accumulator）is the source and destina－ tion register for most I／O，arithmetic，logic and data memory access operations．It can also be used to load the Bd por－ tion of the B register，to load four bits of the 8 －bit Q latch data and to perform data exchanges with the SIO register．
The 4－bit adder performs the arithmetic and logic functions of the COP210C／211C，storing its results in A．It also out－ puts the carry information to a 1 －bit carry register，most of－ ten employed to indicate arithmetic overflow．The C register， in conjunction with the XAS instruction and the EN register， also serves to control the SK output．C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time．（See XAS instruction and EN register description below．）


FIGURE 4．RAM Digit Address to Physical RAM Digit Mapping
The G register contents are outputs to four general purpose bidirectional I／O ports．
The Q register is an internal，latched， 8 －bit register，used to hold data loaded from RAM and $A$ ，as well as 8 －bit data from ROM．Its contents are output to the LI／O ports when the L drivers are enabled under program control．（See LEI instruc－ tion．）
The eight L drivers，when enabled，output the contents of latched Q data to the L I／O ports．Also，the contents of $L$ may be read directly into $A$ and RAM．
The SIO register functions as a 4－bit serial－in／serial－out shift register or as a binary counter，depending upon the con－ tents of the EN register．（See EN register description below．）Its contents can be exchanged with $A$ ，allowing it to input or output a continuous serial data stream．With SIO functioning as a serial－in／serial－out shift register and SK as a sync clock，the COP210C／211C is MICROWIRE compatible．
The D register provides four general purpose outputs and is used as the destination register for the 4－bit contents of Bd． The XAS instruction copies C into the SKL latch．In the counter mode，SK is the output of SKL；in the shift register mode，SK is a sync clock，inhibited when SKL is a logic＂ 0 ＂． The EN register is an internal 4－bit register loaded under program control by the LEI instruction．The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register（EN3－ENO）．
1．The least significant bit of the enable register，ENO，se－ lects the SIO register as either a 4－bit shift register or as a 4－bit binary counter．With ENO set，SIO is an asynchro－ nous binary counter，decrementing its value by one upon each low－going pulse（＂ 1 ＂to＂ 0 ＂）occurring on the SI input．Each pulse must be at least two instruction cycles wide．SK outputs the value of SKL．The SO output is equal to the value of EN3．With ENO reset，SIO is a serial shift register，shifting left each instruction cycle time．The data present at SI is shifted into the least significant bit of SIO．SO can be enabled to output the most significant bit of SIO each instruction cycle time．（See 4，below．）The SK output becomes a logic－controlled clock．

Functional Description (Continued)
TABLE I. Enable Register Modes - Blts ENO and EN3

| ENO | EN3 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift | 0 | If SKL $=1, \mathrm{SK}=$ clock |
|  |  |  | Register |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 0 | 1 | Shift Register | Input to Shift | Serial | If $S K L=1, S K=$ clock |
|  |  |  | Register | out | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 1 | 0 | Binary Counter | Input to Counter | 0 | SK = SKL |
| 1 | 1 | Binary Counter | Input to Counter | 1 | SK $=$ SKL |

2. EN1 is not used, it has no effect on the COP210C/211C.
3. With EN2 set, the L drivers are enabled to output the data in $Q$ to the LI/O ports. Resetting EN2 disables the L drivers, placing the LI/O ports in a high impedance input state.
4. EN3, in conjunction with ENO, affects the SO output. With ENO set (binary counter option selected), SO will output the value loaded into EN3. With ENO reset (serial shift register option selected), setting EN3 enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting EN3 with the serial shift register option selected, disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with $A$ via an XAS instruction but SO remains reset to " 0 ".

## INITIALIZATION

The internal reset logic will initialize the device upon powerup if the power supply rise time is less than 1 ms and if the operating frequency at CKI is greater than 32 kHz , otherwise the external RC network shown in Figure 5 must be connected to the RESET pin. The RESET pin is configured as a Schmitt trigger input. If not used, it should be connected to $V_{\text {Cc. }}$. Initialization will occur whenever a logic " 0 " is applied to the $\overline{\text { RESET input, providing it stays low for at }}$ least three instruction cycle times.
When $\mathrm{V}_{\mathrm{CC}}$ power is applied, the internal reset logic will keep the chip in initialization mode for up to 2500 instruction cycles. If the CKI clock is running at a low frequency, this could take a long time, therefore, the internal logic should be disabled by a mask option with initialization controlled solely by RESET pin.
Note: If CKI clock is less than 32 kHz , the internal reset logic (Option $25=1$ ) must be disabled and the external RC network must be present.
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N$, and $G$ registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA (clear A register).


TL/DD/8444-6
RC $>5 \times$ Power Supply Rise Time and RC $>100 \times$ CKI Period
FIGURE 5. Power-Up Clear Circuit

## COP211C

If the COP210C is bonded as a 20-pin package, it becomes the COP211C, illustrated in Figure 2, COP210C/211C Connection Diagrams. Note that the COP211C does not contain D2, D3, G3, or CKO. Use of this option, of course, precludes use of D2, D3, G3, and CKO options. All other options are available for the COP211C.

## HALT MODE

The COP210C/211C is a fully static circuit; therefore, the user may stop the system oscillator at any time to halt the chip. The chip also may be halted by the HALT instruction or by forcing CKO high when it is used as a HALT I/O port. Once in the HALT mode, the internal circuitry does not receive any clock signal, and is therefore frozen in the exact state it was in when halted. All information is retained until continuing. The HALT mode is the minimum power dissipation state.
The HALT mode has slight differences depending upon the type of oscillator used.
a. 1-pin oscillator-RC or external

The HALT mode may be entered into by either program control (HALT instruction) or by forcing CKO to a logic "1" state.
The circuit may be awakened by one of two different methods:

1) Continue function. By forcing CKO to a logic " 0 ", the system clock is re-enabled and the circuit continues to operate from the point where it was stopped.
2) Restart. Forcing the RESET pin to a logic " 0 " will restart the chip regardless of HALT or CKO (see initialization).
b. 2-pin oscillator-crystal

The HALT mode may be entered into by program control (HALT instruction) which forces CKO to a logic " 1 " state. The circuit can be awakened only by the RESET function.


## CKO PIN OPTIONS

In a crystal-controlled oscillator system, CKO is used as an output to the crystal network. CKO will be forced high during the execution of a HALT instruction, thus inhibiting the crystal network. If a 1-pin oscillator system is chosen (RC or

## Functional Description（Continued）

external），CKO will be selected as HALT and is an I／O flip－ flop which is an indicator of the HALT status．An external signal can override this pin to start and stop the chip．By forcing a high level to CKO，the chip will stop as soon as CKI is high and the CKO output will go high to keep the chip stopped．By forcing a low level to CKO，the chip will contin－ ue and CKO output will go low．
All features associated with the CKO I／O pin are available with the 24 －pin package only．

## OSCILLATOR OPTIONS

There are three options available that define the use of CKI and CKO．
a．Crystal－Controlled Oscillator．CKI and CKO are connect－ ed to an external crystal．The instruction cycle time equals the crystal frequency divided by 16 （optionally by 8 or 4）．
b．External Oscillator．CKI is configured as LSTTL－compati－ ble input accepting an external clock signal．The external frequency is divided by 16 （optionally by 8 or 4）to give the instruction cycle time．CKO is the HALT I／O port．
c．RC－Controlled Oscillator．CKI is configured as a single pin RC－controlled Schmitt trigger oscillator．The instruction cycle equals the oscillation frequency divided by 4．CKO is the HALT I／O port．
The RC oscillator is not recommended in systems that re－ quire accurate timing or low current．The RC oscillator draws more current than an external oscillator（typically an additional $100 \mu \mathrm{~A}$ at 5 V ）．However，when the part halts，it stops with CKI high and the halt current is at the minimum．

COP210C／COP211C Instruction Set
Table II is a symbol table providing internal architecture，in－ struction operand and operational symbols used in the in－ struction set table．
Table III provides the mnemonic，operand，machine code， data flow，skip conditions and description associated with each instruction in the COP210C／211C instruction set．


| Crystal or Resonator |  |  |  |  | RC－Controller Oscillator |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Crystal |  | Component Values |  |  |  |  | Cycle |
| Value | R1 | R2 | C1pF | C2pF | R | C | Time |
| 32 kHz | 220k | 20M | 30 | 5－36 | 47k | 100 pF | 17－25 $\mu \mathrm{s}$ |
| 455 kHz | 5k | 10M | 80 | 40 | 30k | 82 pF | 6－18 $\mu \mathrm{s}$ |
| 3.58 MHz | 1k | 1 M | 30 | 6－36 | Note 50 p | $\begin{aligned} & k \leq R \leq 1 \\ & C \leq 150 p \end{aligned}$ |  |

TABLE II．COP210C／211C Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4－bit Accumulator |
| B | 6－bit RAM Address Register |
| Br | Upper 2 bits of B（register address） |
| Bd | Lower 4 bits of B（digit address） |
| C | 1－bit Carry Register |
| D | 4－bit Data Output Port |
| EN | 4－bit Enable Register |
| G | 4－bit Register to latch data for G I／O Port |
| L | 8－bit TRI－STATE I／O Port |
| M | 4－bit contents of RAM Memory pointed to by B |
|  | Register |
| PC | 9－bit ROM Address Register（program counter） |
| Q | 8－bit Register to latch data for L I／O Port |
| SA | 9－bit Subroutine Save Register A |
| SB | 9－bit Subroutine Save Register B |
| SIO | 4－bit Shift Register and Counter |
| SK | Logic－Controlled Clock Output |

Symbol Definition

## INSTRUCTION OPERAND SYMBOLS

d 4－bit Operand Field， $0-15$ binary（RAM Digit Select）
r 2－bit Operand Field，0－3 binary（RAM Register Select）
a 9－bit Operand Field，0－511 binary（ROM Address）
y 4－bit Operand Field， $0-15$ binary（Immediate Data）
RAM（s）Contents of RAM location addressed by s
ROM（t）Contents of ROM location addressed by $t$
OPERATIONAL SYMBOLS
$+\quad$ Plus
－Minus
$\rightarrow \quad$ Replaces
$\longleftrightarrow \quad$ Is exchanged with
$=\quad$ Is equal to
$\bar{A} \quad$ The one＇s complement of $A$
$\oplus \quad$ Exclusive－OR
：Range of values

| Instruction Set (Continued) TABLE III. COP210C/211C Instruction Set |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Operand | $\begin{aligned} & \text { Hex } \\ & \text { Code } \end{aligned}$ | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 00110000 | $\begin{aligned} & \mathrm{A}+\mathrm{C}+\mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \text { Carry } \rightarrow \mathrm{C} \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 0011 0001 | $A+\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A}$ | None | Add RAM to A |
| AISC | y | $5-$ | $0101{ }^{\text {y }}$ y | $A+y \rightarrow A$ | Carry | Add immediate, Skip on Carry ( $y \neq 0$ ) |
| CLRA |  | 00 | 1000010000 | $0 \rightarrow A$ | None | Clear A |
| COMP |  | 40 | 1010010000 | $\bar{A} \rightarrow A$ | None | One's complement of A to A |
| NOP |  | 44 | 010010100 | None | None | No Operation |
| RC |  | 32 | 0011 0010 | " 0 " $\rightarrow$ C | None | Reset C |
| SC |  | 22 | -001010010 | "1" $\rightarrow$ c | None | Set C |
| XOR |  | 02 | $\underline{0000 \mid 0010}$ | $A \oplus \operatorname{RAM}(\mathrm{~B}) \rightarrow \mathrm{A}$ | None | Exclusive-OR RAM with A |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | 1111\|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 2) |
| JMP |  | $6-$ | $\underset{\mathrm{a}_{\text {a }: 0}}{\|0110\| 000\left\|\mathrm{a}_{8}\right\|}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  |  | $a \rightarrow P C_{6: 0}$ $a \rightarrow P C_{5: 0}$ | None | Jump within Page (Note 1) |
| JSRP | a | - | 10\| $\mathrm{a}_{5: 0}$ | $\left\lvert\, \begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}\right.$ | None | Jump to Subroutine Page <br> (Note 2) |
| JSR | a | $6-$ | $\frac{\|0110\| 100\left\|a_{8}\right\|}{\mathrm{a}_{7: 0}}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | 0100\|1000 | $S B \rightarrow S A \rightarrow P C$ | None | Return from Subroutine |
| RETSK |  | 49 | 0100 1001 | $S B \rightarrow S A \rightarrow P C$ | Always Skip on Return | Return from Subroutine then Skip |
| HALT |  | $\begin{aligned} & 33 \\ & 38 \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0011 \mid & 0011 \mid \\ \hline 0011 & 1000 \\ \hline \end{array}$ |  | None | Halt processor |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonlc | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Descriptlon |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 | 0011\|0011 | $A \rightarrow Q_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C | 0011\|1100 | $\operatorname{RAM}(B) \xrightarrow{\rightarrow} Q_{3: 0}$ |  |  |
| CQMA |  | 33 | 0011\|0011 | $\mathrm{Q}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Copy Q to RAM, A |
|  |  | 2 C | \|0010|1100 | $\mathrm{Q}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| LD | r | -5 | $\underline{00\|r\| 0101 \mid}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A Exclusive-OR Br with r |
| LQID |  | BF | [1011 1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SA} \rightarrow \mathrm{SB} \end{aligned}$ | None | Load Q Indirect |
| RMB | 0 | 4 C | -0100\|1100 | $0 \rightarrow$ RAM $(\mathrm{B})_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | 0100\|0101 | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{1}$ |  |  |
|  | 2 | 42 | \|0100|0010 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 43 | $0100 \mid 0011$ | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |
| SMB | 0 | 4D | 0100\|1101 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Set RAM Bit |
|  | 1 | 47 | 0100\|0111 | $1 \rightarrow \mathrm{RAM}(\mathrm{B})_{1}$ |  |  |
|  | 2 | 46 | 0100\|0110 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 4B | $0100 \mid 1011$ | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |
| STII | $y$ | $7-$ | \|0111 ${ }^{\text {y }}$ | $\begin{aligned} & y \rightarrow R A M(B) \\ & B d+1 \rightarrow B d \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | r | -6 | $\underline{00\|r\| 0110}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with $A$, Exclusive-OR Br with r |
| XAD | 3,15 | 23 $B F$ |  | $\operatorname{RAM}(3,15) \longleftrightarrow A$ | None | Exchange A with RAM $(3,15)$ |
| XDS | r | -7 | $\underline{00\|r\| 0111}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with A and Decrement Bd Exclusive-OR Br with r |
| XIS | r | -4 | $\underline{00 \mid r 10100]}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \longrightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with A and Increment Bd Exclusive-OR Br with r |
| REGISTER REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAB |  | 50 | 1010110000 | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| CBA |  | 4E | 0100\|1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI |  |  | $\frac{\|00\| r\|(d-1)\|}{(d=0,9: 15)}$ | $r, d \rightarrow B$ | Skip until not a LBI | Load B Immediate with r,d |
| LEI | $y$ | 33 | $0011 \mid 0011$ | $y \rightarrow E N$ | None | Load EN Immediate |
|  |  | 6- | $\underline{0110} \mathrm{y}$ y |  |  |  |

TABLE III. COP210C/211C Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  | 20 | 0010\|0000 |  | $C=" 1 "$ | Skip if C is True |
| SKE |  | 21 | 0010\|0001 |  | $A=R A M(B)$ | Skip if A Equals RAM |
| SKGZ |  | 33 21 | 0011 <br> 0010 <br> 00011 |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
| SKGBZ |  | 33 | 0011\|0011 | 1st byte |  | Skip if G Bit is Zero |
|  | 0 | 01 | 0000 0001 |  | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 0001 00011 | 2nd byte | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 | 2nd byte | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 001010011 | J | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 000010001 |  | $\operatorname{RAM}(\mathrm{B})_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | $00010^{0001}$ |  | $\operatorname{RAM}(\mathrm{B})_{1}=0$ |  |
|  | 2 | 03 | 0000 10011 |  | $\operatorname{RAM}(\mathrm{B})_{2}=0$ |  |
|  | 3 | 13 | 0001 0011 |  | $\operatorname{RAM}(\mathrm{B})_{3}=0$ |  |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 10011 0011 | $G \rightarrow A$ | None | Input G Ports to A |
|  |  | 2A |  |  |  |  |
| INL |  | 33 | 00110011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2E | 0010 1110 | $L_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | 0011 ${ }^{\text {20011 }}$ | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E |  |  |  |  |
| OMG |  | 33 | 0011 0011 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{G}$ | None | Output RAM to G Ports |
|  |  | 3A | 0011 1010 |  |  |  |
| XAS |  | 4F | [0100\|1111] | A | None | Exchange A with SIO |

Note 1: The JP instruction allows a jump, while in subroutine pages 2 or 3 , to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 2: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP210C/211C programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO ) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register). If SIO is selected as a shift register, an XAS instruction must be performed once every four instruction cycle times to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by $A$ and $M$. It loads the lower eight bits of the

ROM address register PC with the contents of ROM addressed by the 9 -bit word, $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{8}$ is not affected by this instruction.

Note: JID uses two instruction cycles if executed, one if skipped.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 9 -bit word $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}$. LQID can be used for table look-up or code conversion such as BCD to 7 -segment. The LQID instruction "pushes" the stack (PC + $1 \rightarrow$ SA $\rightarrow \mathrm{SB}$ ) and replaces the least significant eight bits of the PC as follows: $A \rightarrow \mathrm{PC}_{7: 4}$, $R A M(B) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" (SB $\rightarrow$ SA $\rightarrow$ PC ), restoring the saved value of the PC to continue sequential program execution. Since LQID pushes SA $\rightarrow$ SB, the previous contents of SB are lost.
Note: LQID uses two instruction cycles if executed, one if skipped.

## Description of Selected Instructions（Continued）

## INSTRUCTION SET NOTES

a．The first word of a COP210C／211C program（ROM ad－ dress 0 ）must be a CLRA（Clear A）instruction．
b．Although skipped instructions are not executed，one in－ struction cycle time is devoted to skipping each byte of the skipped instruction．Thus all program paths take the same number of cycle times whether instructions are skipped or executed（except JID and LQID）．
c．The ROM is organized into eight pages of 64 words each． The program counter is a 9 －bit binary counter，and will count through page boundaries．If a JP，JSRP，JID，or LQID instruction is located in the last word of a page，the instruction operates as if it were in the next page．For example：A JP located in the last word of a page will jump to a location in the next page．Also，a LQID or JID located in the last word in page 3 or 7 will access data in the next group of four pages．

## POWER DISSIPATION

The lowest power drain is when the clock is stopped．As the frequency increases so does current．Current is also low－ er at lower operating voltages．Therefore，to minimize pow－ er consumption，the user should run at the lowest speed and voltage that his application will allow．The user should take care that all pins swing to full supply levels to ensure that outputs are not loaded down and that inputs are not at some intermediate level which may draw current．Any input with a slow rise or fall time will draw additional current．A crystal－or resonator－generated clock will draw additional current．An RC oscillator will draw even more current since the input is a slow rising signal．

If using an external squarewave oscillator，the following equation can be used to calculate the COP210C current drain．

$$
\begin{aligned}
& \mathrm{Ic}=\mathrm{Iq}+(\mathrm{V} \times 35 \times \mathrm{Fi})+(\mathrm{V} \times 2195 \times \mathrm{Fi} / \mathrm{Dv}) \\
& \text { where } \mathrm{Ic}=\text { chip current drain in microamps } \\
& \mathrm{Iq}=\text { quiescent leakage current (from curve) } \\
& \mathrm{Fi}=\mathrm{CKI} \text { frequency in megahertz } \\
& \mathrm{V}=\text { chip } \mathrm{V}_{\mathrm{CC}} \text { in volts } \\
& \mathrm{Dv}=\text { divide by option selected }
\end{aligned}
$$

For example，at $5 \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}$ and 400 kHz （divide by 4），

$$
\mathrm{I}=10+(5 \times 35 \times 0.4)+(5 \times 2195 \times 0.4 / 4)
$$

$$
\mathrm{lc}=10+50+1097.5=1157.5 \mu \mathrm{~A}
$$

## I／O OPTIONS

COP210C／211C outputs have the following optional config－ urations，illustrated in Figure 7：
a．Standard．A CMOS push－pull buffer with an N－channel device to ground in conjunction with a P－channel device to $V_{C C}$ ，compatible with CMOS and LSTTL．
b．Open Drain．An N－channel device to ground only，allow－ ing external pull－up as required by the user＇s application．
c．Standard TRI－STATE L Output．A CMOS output buffer similar to（a）which may be disabled by program control．
d．Open－Drain TRI－STATE L Output．This has the N－channel device to ground only．
The SI and $\overline{\operatorname{RESET}}$ inputs are $\mathrm{Hi}-\mathrm{Z}$ inputs（Figure 7e）．
When using either the $G$ or $L I / O$ ports as inputs，an exter－ nal pull－up device is necessary．

a．Standard Push－Pull Output

b．Open Drain Output

c．Standard TRI－STATE
＂L＂Output

d．Open Drain TRI－STATE ＂L＂Output

e．Hi－Z Input

TL／DD／8444－9

FIGURE 7．I／O Configurations

All output drivers uses one or two common devices num－ bered 1 to 2 ．Minimum and maximum current（lout and $V_{\text {OUT }}$ ）curves are given in Figure 8 for each of these devices
to allow the designer to effectively use these I／O configura－ tions．

## Typical Performance Characteristics





FIGURE 8

## Option List

The COP210C/211C mask-programmable options are assigned numbers which correspond with the COP210C pins. The following is a list of COP210C options. When specifying a COP211 chip, options 20, 21, and 22 must be set to 0 . The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
Option 1: $\quad 0=$ Ground Pin. No options available.
Option 2: CKO I/O Port Determined by Option 3. $=0$ no option (a. is crystal oscillator output for two pin oscillator $b$. is HALT I/O for one pin oscillator)
Option 3: CKI Input.
$=0$ : Crystal-controlled oscillator input ( $\div 4$ ).
$=1$ : Single-pin RC-controlled oscillator $(\div 4)$.
$=2$ : External oscillator input $(\div 4)$.
$=3:$ Crystal oscillator input $(\div 8)$.
$=4$ : External oscillator input ( $\div 8$ ).
$=5$ : Crystal oscillator input $(\div 16)$.
$=6$ : External oscillator input ( $\div 16$ ).
Option 4: RESET Input = 1: Hi-Z input. No option available.
Option 5: $L_{7}$ Driver
$=0$ : Standard TRI-STATE push-pull output.
= 2: Open-drain TRI-STATE output.
Option 6: $\mathrm{L}_{6}$ Driver. (Same as Option 5.)
Option 7: $\quad L_{5}$ Driver. (Same as Option 5.)
Option 8: $L_{4}$ Driver. (Same as Option 5.)
Option 9: $\quad V_{C C}$ Pin $=0$ no option.

Option 10: $\mathrm{L}_{3}$ Driver. (Same as Option 5.)
Option 11: $\mathrm{L}_{2}$ Driver. (Same as Option 5.)
Option 12: $\mathrm{L}_{1}$ Driver. (Same as Option 5.)
Option 13: Lo Driver. (Same as Option 5.)
Option 14: SI Input.
No option available.
$=1$ : Hi-Z input.
Option 15: SO Output.
$=0$ : Standard push-pull output.
= 2: Open-drain output.
Option 16: SK Driver. (Same as Option 15.)
Option 17: $\mathrm{G}_{0}$ I/O Port. (Same as Option 15.)
Option 18: $\mathrm{G}_{1}$ I/O Port. (Same as Option 15.)
Option 19: $\mathrm{G}_{2}$ I/O Port. (Same as Option 15.)
Option 20: $\mathrm{G}_{3}$ I/O Port. (Same as Option 15.)
Option 21: $\mathrm{D}_{3}$ Output. (Same as Option 15.)
Option 22: $\mathrm{D}_{2}$ Output. (Same as Option 15.)
Option 23: $\mathrm{D}_{1}$ Output. (Same as Option 15.)
Option 24: $\mathrm{D}_{0}$ Output. (Same as Option 15.)
Option 25: Internal Initialization Logic.
$=0$ : Normal operation.
= 1: No internal initialization logic.
Option 26: No option available.
Option 27: COP Bonding
$=0:$ COP210C (24-pin device).
= 1: COP211C (20-pin device). See Note.
$=2:$ COP210C and COP211C. See Note.
Note: If option $27=1$ or 2 then option 20 must $=0$.

## Option Table

Please fill out a photocopy of the Option Table and send along with your EPROM.

Option Table

| Option 1 Value $=$ | 0 | is: Ground Pin |
| :---: | :---: | :---: |
| Option 2 Value $=$ | 0 | is: CKO Pin |
| Option 3 Value $=$ |  | is: CKI Input |
| Option 4 Value $=$ | 1 | is: $\overline{\text { RESET }}$ Input |
| Option 5 Value $=$ |  | is: $L_{7}$ Driver |
| Option 6 Value $=$ |  | is: $L_{6}$ Driver |
| Option 7 Value $=$ |  | is: $L_{5}$ Driver |
| Option 8 Value $=$ |  | is: $L_{4}$ Driver |
| Option 9 Value = | 0 | is: $\mathrm{V}_{C C}$ Pin |
| Option 10 Value = |  | is: $L_{3}$ Driver |
| Option 11 Value $=$ |  | is: $L_{2}$ Driver |
| Option 12 Value $=$ |  | is: $L_{1}$ Driver |
| Option 13 Value $=$ |  | is: $L_{0}$ Driver |
| Option 14 Value = | 1 | is: SI Input |



## COP224C/COP225C/COP226C/COP244C/COP245C Single-Chip 1k and 2 k CMOS Microcontrollers

## General Description

The COP224C, COP225C, COP226C, COP244C and COP245C fully static, Single-Chip CMOS Microcontrollers are members of the COPSTM family, fabricated using dou-ble-poly, silicon gate microCMOS technology. These Controller Oriented Processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture and I/O scheme designed to facilitate keyboard input, display output and BCD data manipulation. The COP224C and COP244C are 28 pin chips. The COP225C and COP245C are 24-pin versions (4 inputs removed) and COP226C is 20-pin version with $15 \mathrm{I} / \mathrm{O}$ lines. Standard test procedures and reliable high-density techniques provide the medium to large volume customers with a customized microcontroller at a low end-product cost. These microcontrollers are appropriate choices in many demanding control environments especially those with human interface.

## Features

- Lowest power dissipation ( $600 \mu \mathrm{~W}$ typical)
- Fully static (can turn off the clock)
- Power saving IDLE state and HALT mode
- $4.4 \mu \mathrm{~s}$ instruction time
- $2 k \times 8$ ROM, $128 \times 4$ RAM (COP244C/COP245C)

■ 1k x 8 ROM, $64 \times 4$ RAM (COP224C/COP225C/ COP226C)

- 23 I/O lines (COP244C and COP224C)
- True vectored interrupt, plus restart
- Three-level subroutine stack
- Single supply operation ( 4.5 V to 5.5 V )
- Programmable read/write 8 -bit timer/event counter
- Internal binary counter register with MICROWIRETM serial I/O capability
- General purpose and TRI-STATE® outputs
- LSTTL/CMOS output compatible
- Software/hardware compatible with COP400 family
m Military temperature $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ operation

Block Diagram


FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Supply Voltage ( $V_{C C}$ )
6 V
Voltage at any Pin
Total Allowable Source Current
Total Allowable Sink Current
-0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$

Total Allowable Power Dissipation
25 mA
25 mA

DC Electrical Characteristics
150 mW

Operating Temperature Range $\quad-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Storage Temperature Range $\quad-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temperature
(soldering, 10 seconds)
$300^{\circ} \mathrm{C}$
Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. $D C$ and $A C$ electrical specifications are not ensured when operating the device at absolute maximum ratings.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage Power Supply Ripple (Note 5) | Peak to Peak | 4.5 | $\begin{gathered} 5.5 \\ 0.25 V_{C C} \\ \hline \end{gathered}$ | $\begin{aligned} & v \\ & v \end{aligned}$ |
| Supply Current (Note 1) | $V_{C C}=5.0 \mathrm{~V}, \mathrm{tc}=4.4 \mu \mathrm{~s}$ <br> ( tc is instruction cycle time) |  | 5000 | $\mu \mathrm{A}$ |
| HALT Mode Current (Note 2) | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~F}_{\mathrm{IN}}=0 \mathrm{kHz}$ |  | 120 | $\mu \mathrm{A}$ |
| Input Voltage Levels <br> RESET, CKI, $D_{0}$ (clock input) <br> Logic High <br> Logic Low <br> All Other Inputs <br> Logic High <br> Logic Low |  | $0.9 \mathrm{~V}_{\mathrm{CC}}$ $0.7 \mathrm{~V}_{\mathrm{CC}}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Hi-Z Input Leakage |  | -10 | +10 | $\mu \mathrm{A}$ |
| Input Capacitance (Note 4) |  |  | 7 | pF |
| Output Voltage Levels (except CKO) <br> LSTTL Operation <br> Logic High <br> Logic Low <br> CMOS Operation <br> Logic High <br> Logic Low | Standard Outputs $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=400 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.2$ | $\begin{aligned} & 0.6 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & V \\ & v \\ & v \\ & v \end{aligned}$ |
| CKO Current Levels (As Clock Out) | $\mathrm{CKI}=\mathrm{V}_{\mathrm{CC}}, \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ $\mathrm{CKI}=O \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=0 \mathrm{~V}$ | $\begin{aligned} & 0.2 \\ & 0.4 \\ & 0.8 \\ & 0.2 \\ & 0.4 \\ & 0.8 \end{aligned}$ |  | mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Allowable Sink/Source Current per Pin (Note 6) |  |  | 5 | mA |
| Allowable Loading on CKO (as HALT) |  |  | 50 | pF |
| Current Needed to Over-Ride HALT <br> (Note 3) <br> To Continue <br> To Halt | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.2 \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{IN}}=0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |  | $\begin{aligned} & 2.0 \\ & 3.0 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ |
| TRI-STATE or Open Drain Leakage Current |  | -10 | $+10$ | $\mu \mathrm{A}$ |

AC Electrical Characteristics $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C},+4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq+5.5 \mathrm{~V}$ unless otherwise specified.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time (tc) |  | 4.4 | DC | $\mu \mathrm{S}$ |
| $\left.\begin{array}{ll}\text { Operating CKI } & \div 4 \text { mode } \\ \text { Frequency } & \div 8 \text { mode } \\ & \div 16 \text { mode }\end{array}\right\}$ |  | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ | $\begin{aligned} & 0.9 \\ & 1.8 \\ & 3.6 \\ & \hline \end{aligned}$ | MHz <br> MHz <br> MHz |
| Duty Cycle (Note 4) | $\mathrm{f}_{1}=3.6 \mathrm{MHz}$ | 40 | 60 | \% |
| Rise Time (Note 4) | $\mathrm{f}_{1}=3.6 \mathrm{MHz}$ External Clock |  | 60 | ns |
| Fall Time (Note 4) | $\mathrm{f}_{1}=3.6 \mathrm{MHz}$ External Clock |  | 40 | ns |
| Instruction Cycle Time RC Oscillator (Note 4) | $\begin{aligned} & \mathrm{R}=30 \mathrm{k} \pm 5 \% \\ & \mathrm{C}=82 \mathrm{pF} \pm 5 \%(\div 4 \text { Mode }) \end{aligned}$ | 6 | 18 | $\mu \mathrm{S}$ |
| Inputs: (See Figure 3) (Note 4) ${ }^{\mathrm{t}}$ SETUP $t_{\text {HOLD }}$ | G Inputs SI Input All Others | $\begin{gathered} \mathrm{tc} / 4+0.8 \\ 0.33 \\ 1.9 \\ 0.4 \\ \hline \end{gathered}$ |  | $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{s}$ <br> $\mu \mathrm{s}$ |
| Output Propagation Delay tpD1 $\mathrm{t}_{\text {PDO }}$ | $\mathrm{V}_{\text {OUT }}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=5 \mathrm{k}$ |  | 1.4 | $\mu \mathrm{S}$ |

Note 1: Supply current is measured after running for 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled up to $V_{C C}$ with $5 k$ resistors. See current drain equation on page 13.
Note 2: The HALT mode will stop CKI from oscillating in the RC and crystal configurations. Test conditions: all inputs tied to $\mathrm{V}_{\mathrm{CC}}$, L lines in TRI-STATE mode and tied to ground, all outputs low and tied to ground.
Note 3: When forcing HALT, current is only needed for a short time (approx. 200 ns ) to flip the HALT flip-flop.
Note 4: This parameter is not tested but guaranteed by design. Variation due to the device included.
Note 5: Voltage change must be less than 0.25 volts in a 1 ms period.
Note 6: SO output sink current must be limited to keep $V_{O L}$ less than $0.2 \mathrm{~V}_{\mathrm{CC}}$ when part is running in order to prevent entering test mode.

## Connection Diagrams



| Dual-In-L | ine Package | Pln | Description |
| :---: | :---: | :---: | :---: |
| GND - 1 | $28-00$ | L7-L0 | 8-bit bidirectional port with TRI-STATE |
| $\begin{aligned} & \mathrm{ck} 0 \_{ }_{\mathrm{ck} 1}^{2} \end{aligned}$ | $\begin{array}{l\|l} 27 \\ 26 & 01 \\ { }_{26} \end{array}$ | G3-G0 | 4-bit bidirectional |
| RESET | $25-03$ | D3-D0 | 4-bit output port |
| ${ }_{17} 17$ - ${ }^{5}$ | $\begin{array}{l\|l} 24 & \text { —" }_{63} \\ 23 \end{array}$ | IN3-INO | 4-bit input port <br> (28 pin package only) |
| $0^{7}$ |  | SI | Serial input or counter input |
|  |  | So | Serial or general purpose output |
| $\mathrm{vcc}^{13}-11$ 12 | $\begin{array}{l\|l} 18 & \text { sk } \\ 17 & { }^{2} \text { so } \end{array}$ | SK | Logic controlled clock output |
| ${ }^{13}$ | $16-51$ | CKI | Chip oscillator input |
| 14 | $15 \text { - } 10$ | CKO | Oscillator output, HALT I/O port or general purpose input |
|  | op Vlew | RESET | Reset input |
|  | TL/DD/ | $V_{C C}$ | Most positive power supply |
|  |  | GND | Ground |

FIGURE 2

## Order Number COP226C-XXX/D, COP226C-XXX/N See NS Package D20A or N20A

Order Number COP225C-XXX/D,
COP225C-XXX/N,
or COP245C-XXX/D,
COP245C-XXX/N
See NS Package D24C or N24A

## Order Number COP224C-XXX/D, COP224C-XXX/N, or COP244C-XXX/D, COP244C-XXX/N See NS Package D28C or N28B

## Functional Description

The internal architecture is shown in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 ", when a bit is reset, it is a logic " 0 ".

## Caution:

The output options available on the COP224C/225C/226C and COP244C/245C are not the same as those available on the COP324C/325C/326C, COP344C/345C, COP424C/ 425C/426C and COP444C/445C. Options not available on the COP224C/225C/226C and COP244C/245C are: Option 2 value 2; Option 4 value 0; Option 5 value 1; Option 9 value 0; Option 17 value 1; Option 30, Dual Clock, all values; Option 32, MicrobusTM, all values; Option 33 values 2, 4, and 6; Option 34 all values; and Option 35 all values.

## PROGRAM MEMORY

Program Memory consists of ROM, 1024 bytes for the COP224C/225C/226C and 2048 bytes for the COP244C/ 245C. These bytes of ROM may be program instructions, constants or ROM addressing data.
ROM addressing is accomplished by an 11-bit PC register which selects one of the 8-bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 11-bit binary count value.
Three levels of subroutine nesting are implemented by a three level deep stack. Each subroutine call or interrupt pushes the next PC address into the stack. Each return pops the stack back into the PC register.

## DATA MEMORY

Data memory consists of a 512-bit RAM for the COP244C/ 245 C , organized as 8 data registers of $16 \times 4$-bit digits.

RAM addressing is implemented by a 7 -bit B register whose upper 3 bits ( Br ) select 1 of 8 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. Data memory consists of a 256 -bit RAM for the COP224C/ $225 \mathrm{C} / 226 \mathrm{C}$, organized as 4 data registers of $16 \times 4$-bits digits. The $B$ register is 6 bits long. Upper 2 bits ( Br ) select 1 of 4 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4-bit contents of the selected RAM digit (M) are usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the $Q$ latches or $T$ counter or loaded from the L ports. RAM addressing may also be performed directly by the LDD and XAD instructions based upon the immediate operand field of these instructions.
The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The processor contains its own 4-bit A register (accumulator) which is the source and destination register for most I/O, arithmetic, logic, and data memory access operations. It can also be used to load the Br and Bd portions of the B register, to load and input 4 bits of the 8 -bit $Q$ latch or T counter, to input 4 bits of LI/O ports data, to input 4-bit G, or IN ports, and to perform data exchanges with the SIO register. A 4-bit adder performs the arithmetic and logic functions, storing the results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register in conjunction with the XAS instruction and the EN register, also serves to control the SK output.
The 8 -bit T counter is a binary up counter which can be loaded to and from M and A using CAMT and CTMA instructions. This counter may be operated in two modes depending on a mask-programmable option: as a timer or as an external event counter. When the T counter overflows, an

## Functional Description (Continued)

overflow flag will be set (see SKT and IT instructions below). The $T$ counter is cleared on reset. A functional block diagram of the timer/counter is illustrated in Figure 7.
Four general-purpose inputs, IN3-INO, are provided.
The D register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd. The G register contents are outputs to a 4-bit general-purpose bidirectional I/O port.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are outputted to the L I/O ports when the $L$ drivers are enabled under program control.
The 8 L drivers, when enabled, output the contents of latched Q data to the LI/O port. Also, the contents of L may be read directly into $A$ and $M$.
The SIO register functions as a 4-bit serial-in/serial-out shift register for MICROWIRE I/O and COPS peripherals, or as a binary counter (depending on the contents of the EN register). Its contents can be exchanged with $A$.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the clock.
EN is an internal 4-bit register loaded by the LEl instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register:
0 . The least significant bit of the enable register, ENO, selects the SIO register as either a 4-bit shift register or a 4-bit binary counter. With ENO set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output equals the value of EN3. With ENO reset, SIO is a serial shift register left shifting 1 bit each instruction cycle time. The data present at SI goes into the least significant bit of

SIO. SO can be enabled to output the most significant bit of SIO each cycle time. The SK outputs SKL ANDed with the instruction cycle clock.

1. With EN1 set, interrupt is enabled. Immediately following an interrupt, EN1 is reset to disable further interrupts.
2. With EN2 set, the L drivers are enabled to output the data in $Q$ to the L I/O port. Resetting EN2 disables the $L$ drivers, placing the LI/O port in a high-impedance input state.
3. EN3, in conjunction with ENO, affects the SO output. With ENO set (binary counter option selected) SO will output the value loaded into EN3. With ENO reset (serial shift register option selected), setting EN3 enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting EN3 with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains set to " 0 ".

## INTERRUPT

The following features are associated with interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once recognized as explained below, pushes the next sequential program counter address (PC+1) onto the stack. Any previous contents at the bottom of the stack are lost. The program counter is set to hex address OFF (the last word of page 3) and EN1 is reset.
b. An interrupt will be recognized only on the following conditions:

1. EN1 has been set.
2. A low-going pulse (" 1 " to " 0 ") at least two instruction cycles wide has occurred on the $\mathrm{IN}_{1}$ input.
3. A currently executing instruction has been completed.


FIGURE 3. Input/Output Timing Diagrams (divide by 8 mode)
TABLE I. Enable Register Modes - Bits EN0 and EN3

| ENO | EN3 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=\text { clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Shift Register | Input to Shift Register | Serial out | $\begin{aligned} & \text { If } S K L=1, S K=\text { clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Binary Counter | Input to Counter | 0 | SK $=$ SKL |
| 1 | 1 | Binary Counter | Input to Counter | 1 | SK $=$ SKL |

## Functional Description (Continued)

4. All successive transfer of control instructions and successive LBls have been completed (e.g. if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed).
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example, if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at hex address OFF. At the end of the interrupt routine, a RET instruction is executed to pop the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines should not be nested within the interrupt service routine, since their popping of the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The instruction at hex address OFF must be a NOP.
e. An LEI instruction may be put immediately before the RET instruction to re-enable interrupts.

## INITIALIZATION

The internal reset logic will initialize the device upon powerup if the power supply rise time is less than 1 ms and if the operating frequency at CKI is greater than 32 kHz , otherwise the external RC network shown in Figure 4 must be connected to the $\overline{\text { RESET }}$ pin (the conditions in Figure 4 must be met). The $\overline{\text { RESET }}$ pin is configured as a Schmitt trigger input. If not used, it should be connected to $\mathrm{V}_{\mathrm{CC}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, providing it stays low for at least three instruction cycle times.
Note: If CKI clock is less than 32 kHz , the internal reset logic (option \# $29=1$ ) MUST be disabled and the external RC circuit must be used.


FIGURE 4. Power-Up Circuit

Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the A, B, C, D, EN, IL, T and G registers are cleared. The SKL latch is set, thus enabling SK as a clock output. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA (clear A register).

## TIMER

There are two modes selected by mask option:
a. Time-base counter. In this mode, the instruction cycle frequency generated from CKI passes through a 2-bit divide-by- 4 prescaler. The output of this prescaler increments the 8 -bit T counter thus providing a 10 -bit timer. The prescaler is cleared during execution of a CAMT instruction and on reset.
For example, using a 3.58 MHz crystal with a divide-by-16 option, the instruction cycle frequency of 223.70 kHz increments the 10 -bit timer every $4.47 \mu \mathrm{~s}$. By presetting the counter and detecting overflow, accurate timeouts between $17.88 \mu \mathrm{~s}$ ( 4 counts) and 4.577 ms ( 1024 counts) are possible. Longer timeouts can be achieved by accumulating, under software control, multiple overflows.
b. External event counter. In this mode, a low-going pulse ("1" to " 0 ") at least 2 instruction cycles wide on the IN2 input will increment the 8 -bit $T$ counter.
Note: The IT instruction is not allowed in this mode.


Crystal or Resonator

| Crystal <br> Value | Component Values |  |  |  |
| :--- | ---: | :---: | :---: | :---: |
|  | $\mathbf{R 1}$ | R2 | C1(pF) | C2(pF) |
| 32 kHz | 220 k | 20 M | 30 | $6-36$ |
| 455 kHz | 5 k | 10 M | 80 | 40 |
| 2.096 MHz | 2 k | 1 M | 30 | $6-36$ |
| 3.6 MHz | 1 k | 1 M | 30 | $6-36$ |

RC Controlled Oscillator

| $\mathbf{R}$ | C | Cycle <br> Time | V CC |
| :---: | :---: | :---: | :---: |
| 30 k | 82 pF | $6-18 \mu \mathrm{~s}$ | 24.5 V |

Note: $15 \mathrm{k} \leq \mathrm{R} \leq 150 \mathrm{k}$
$50 \mathrm{pF} \leq \mathrm{C} \leq 150 \mathrm{pF}$
FIGURE 5. Oscillator Component Values

## Functional Description (Continued)

## HALT MODE

The COP244C/245C/224C/225C/226C is a FULLY STATIC circuit; therefore, the user may stop the system oscillator at any time to halt the chip. The chip may also be halted by the HALT instruction or by forcing CKO high when it is mask-programmed as a HALT I/O port. Once in the HALT mode, the internal circuitry does not receive any clock signal and is therefore frozen in the exact state it was in when halted. All information is retained until continuing. The chip may be awakened by one of two different methods:

- Continue function: by forcing CKO low, if it mask-programmed as a HALT I/O port, the system clock is re-enabled and the circuit continues to operate from the point where it was stopped.
- Restart: by forcing the RESET pin low (see Initialization).
The HALT mode is the minimum power dissipation state.


## CKO PIN OPTIONS

a. Two-pin oscillator-(Crystal). See Figure 6a.

In a crystal controlled oscillator system, CKO is used as an output to the crystal network. The HALT mode may be entered by program control (HALT instruction) which forces CKO high, thus inhibiting the crystal network. The circuit can be awakened only by forcing the RESET pin to a logic " 0 " (restart).
b. One-pin oscillator-(RC or external). See Figure $6 b$.

If a one-pin oscillator system is chosen, two options are available for CKO:

- CKO can be selected as the HALT I/O port. In that case, it is an I/O flip-flop which is an indicator of the HALT status. An external signal can over-ride this pin to start and stop the chip. By forcing a high level to CKO, the chip will stop as soon as CKI is high and CKO output will stay high to keep the chip stopped if
the external driver returns to high impedance state. By forcing a low level to CKO, the chip will continue and CKO will stay low.
- As another option, CKO can be a general purpose input, read into bit 2 of $A$ (accumulator) upon execution of an INIL instruction.


## OSCILLATOR OPTIONS

There are three basic clock oscillator configurations available as shown by Figure 5.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency optionally divided by 4,8 or 16.
b. External Oscillator. The external frequency is optionally divided by 4,8 or 16 to give the instruction cycle time. CKO is the HALT I/O port or a general purpose input.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is the HALT I/O port or a general purpose input.
Figure 7 shows the clock and timer diagram.

## COP245C AND COP225C 24-PIN PACKAGE OPTION

If the COP244C/224C is bonded in a 24-pin package, it becomes the COP245C/225C, illustrated in Figure 2, Connection diagrams. Note that the COP245C/225C does not contain the four general purpose IN inputs (IN3-INO). Use of this option precludes, of course, use of the IN options, interrupt feature, external event counter feature.
Note: If user selects the 24 -pin package, options 9, 10, 19 and 20 must be selected as a " 2 ". See option list.

## COP226C 20-PIN PACKAGE OPTION

If the COP225C is bonded as 20 -pin device it becomes the COP226C. Note that the COP226C contains all the COP225C pins except $D_{0}, D_{1}, G_{0}$, and $G_{1}$.

## Block Diagram (Continued)



TL/DD/8422-8
FIGURE 6a. Halt Mode-Two-Pin Oscillator

Block Diagrams (Continued)

FIGURE 6b. Halt Mode-One-Pin Oscillator


TL/DD/8422-10
FIGURE 7. Clock and Timer

## Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operation symbols used in the instruction set table.

TABLE II. Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| Internal Architecture Symbols |  |
| A | 4-bit accumulator |
| B | 7-bit RAM address register (6-bit for COP224C) |
| Br | Upper 3 bits of B (register address) |
|  | (2-bit for COP224C) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit carry register |
| D | 4-bit data output port |
| EN | 4-bit enable register |
| G | 4-bit general purpose I/O port |
| IL | two 1-bit (INO and IN3) latches |
| IN | 4-bit input port |
| L | 8-bit TRI-STATE I/O port |
| M | 4-bit contents of RAM addressed by B |
| PC | 11-bit ROM address program counter |
| Q | 8-bit latch for L port |
| SA,SB,SC | 11-bit 3-level subroutine stack |
| SIO | 4-bit shift register and counter |
| SK | Logic-controlled clock output |
| SKL | 1-bit latch for SK output |
| T | 8-bit timer |

Table III provides the mnemonic, operand, machine code data flow, skip conditions and description of each instruction.

| Instruction Operand Symbols |  |
| :--- | :--- |
| d | 4-bit operand field, $0-15$ binary (RAM digit select) |
| r | 3(2)-bit operand field, $0-7(3)$ binary <br> (RAM register select) |
| a | 11-bit operand field, $0-2047$ (1023) |
| y | 4-bit operand field, $0-15$ (immediate data) |
| RAM $(\mathrm{x})$ | RAM addressed by variable x |
| ROM $(\mathrm{x})$ | ROM addressed by variable x |


| Operational Symbols |  |
| :--- | :--- |
| + | Plus |
| - | Minus |
| $\rightarrow$ | Replaces |
| $\longleftrightarrow$ | Is exchanged with |
| $=$ | Is equal to |
| $\bar{A}$ | One's complement of A |
| $\oplus$ | Exclusive-or |
| $:$ | Range of values |

TABLE III. COP244C/245C Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 0011\|0000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 001110001 | $A+\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A}$ | None | Add RAM to A |
| ADT |  | 4A | \|0100|1010| | $A+10_{10} \rightarrow A$ | None | Add Ten to A |
| AISC | y | $5-$ | 0101 ${ }^{\text {y }}$ | $A+y \rightarrow A$ | Carry | Add Immediate. Skip on Carry ( $y \neq 0$ ) |
| CASC |  | 10 | 1000110000 | $\begin{aligned} & \bar{A}+R A M(B)+C \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Complement and Add with Carry, Skip on Carry |
| CLRA |  | 00 | 1000010000 | $0 \rightarrow A$ | None | Clear A |
| COMP |  | 40 | -010010000 | $\bar{A} \rightarrow A$ | None | Ones complement of $A$ to $A$ |
| NOP |  | 44 | -010010100 | None | None | No Operation |
| RC |  | 32 | -001110010 | "0" $\rightarrow$ C | None | Reset $C$ |
| SC |  | 22 | -0010/0010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | -0000\|0010 | $A \oplus \operatorname{RAM}(B) \rightarrow A$ | None | Exclusive-OR RAM with A |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE III. COP244C/245C Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| TRANSFER CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111 | $\mathrm{ROM}\left(\mathrm{PC}_{10: 8} \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{PC}_{7: 0}$ | None | Jump Indirect (Notes 1, 3) |
| JMP | a | $\begin{aligned} & 6- \\ & -- \end{aligned}$ | $\frac{0110\|0\| a_{10: 8} \mid}{a_{7: 0} \mid}$ | $\mathrm{a} \rightarrow \mathrm{PC}$ | None | Jump |
| JP | a |  |  | $\mathrm{a} \rightarrow \mathrm{PC}_{6: 0}$ $\mathrm{a} \rightarrow \mathrm{PC}_{5: 0}$ | None | Jump within Page (Note 4) |
| JSRP | a | -- |  | $\begin{aligned} & P C+1 \rightarrow S A \rightarrow S B \rightarrow S C \\ & 00010 \rightarrow P_{10: 6} \\ & a \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR | a | $\begin{aligned} & 6- \\ & -- \end{aligned}$ | $\frac{0110\|1\| a_{10: 8} \mid}{a_{7: 0}}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | 10100\|1000 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 10100\|1001| | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| HALT |  | 33 | 0011100111 |  | None | HALT Processor |
|  |  | 38 | -00111000 |  |  |  |
| IT |  | 33 | 001110011 |  |  | IDLE till Timer |
|  |  | 39 | -0011 1001\| |  | None | Overflows then Continues |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMT |  | 33 | -0011\|0011 | $\mathrm{A} \rightarrow \mathrm{T}_{7: 4}$ |  |  |
|  |  | 3 F | -0011\|1111 | RAM $(B) \rightarrow \mathrm{T}_{3: 0}$ | None | Copy A, RAM to T |
| CTMA |  | 33 | 0011 0011 | $\mathrm{T}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ |  |  |
|  |  | 2 F | \|0010|1111 | $\mathrm{T}_{3: 0} \rightarrow \mathrm{~A}$ | None | Copy $T$ to RAM, A |
| CAMQ |  | 33 | 0011 00011. | $\mathrm{A} \rightarrow \mathrm{Q}_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C | 00111100 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{Q}_{3: 0}$ |  |  |
| CQMA |  | 33 | $\underline{0011100111}$ | $\mathrm{Q}_{7: 4} \rightarrow \operatorname{RAM}(\mathrm{~B})$ | None | Copy Q to RAM, A |
|  |  | 2 C | 0010\|1100 | $\mathrm{Q}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| LD | $r$ | $-5$ | $\frac{100\|r\| 0101 \mid}{(r=0: 3)}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A, Exclusive-OR Br with r |
| LDD | r,d | $23$ | $\left.\begin{array}{\|l\|l\|l\|} \hline 0010 & 0011 \\ \hline 0 & \hline 0 & r \end{array} \right\rvert\, d \begin{gathered} \\ \hline \end{gathered}$ | $\mathrm{RAM}(\mathrm{r}, \mathrm{d}) \rightarrow \mathrm{A}$ | None | Load A with RAM pointed to directly by $r$, $d$ |
| LQID |  | BF | \|1011 [1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{10}: 8, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SB} \rightarrow \mathrm{SC} \end{aligned}$ | None | Load Q Indirect (Note 3) |
| RMB | 0 | 4C | 10100\|1100 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | -0100\|0101 | $0 \rightarrow R A M(B)_{1}$ |  |  |
|  | 2 | 42 | -0100\|0010 | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{2}$ |  |  |
|  | 3 | 43 | 0100/0011 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |
| SMB | 0 | 4D | 10100\|1101 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Set RAM Bit |
|  | 1 | 47 | 010010111 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1}$ |  |  |
|  | 2 | 46 | 010010110 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 4B | $0100 \mid 1011$ | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |

Instruction Set (Continued)
TABLE III. COP244C/245C Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MEMORY REFERENCE INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| STII | $y$ | $7-$ | 10111 ${ }^{\text {y }}$ | $\begin{aligned} & \mathrm{y} \rightarrow \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \end{aligned}$ | None | Store Memory Immediate 1 and Increment Bd |
| x | r | $-6$ | $\begin{array}{l\|l\|l\|l\|} \hline 00\|r\| 0110 \mid \\ \hline(r=0: 3) \end{array}$ | $\begin{aligned} & \operatorname{RAM}(B) \longleftrightarrow A \\ & \operatorname{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with $r$ |
| XAD | r,d | 23 | $\begin{array}{\|l\|l\|} \hline 0010 & 0011 \\ \hline 1\|r\| l \\ \hline 1 & \mathrm{r} \\ \hline \end{array}$ | $R A M(r, d) \longleftrightarrow A$ | None | Exchange A with RAM Pointed to Directly by r,d |
| XDS | r | $-7$ | $\underbrace{00\|r\| 0111 \mid}_{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd <br> decrements past 0 | Exchange RAM with $A$ and Decrement Bd. Exclusive-OR Br with r |
| XIS | r | $-4$ | $\begin{aligned} & 00\|r\| 0100 \mid \\ & \hline(r=0: 3) \end{aligned}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd <br> increments past 15 | Exchange RAM with $A$ and Increment Bd , Exclusive-OR Br with r |
| REGISTER REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAB |  | 50 | 10101/0000 | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| CBA |  | 4E | (0100\|1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d | $33$ | $100\|r\|(d-1) \mid$ <br> $(r=0: 3:$ <br> $d=0,9: 15)$ <br> $o r$ <br> $0011\|0011\|$ <br> $1\|r\| d \mid$ <br> (any $r, ~ a n y d)$ | $r, d \rightarrow B$ | Skip until not a LBI | Load B Immediate with r,d (Note 6) |
| LEI | $y$ | 33 $6-$ | $0011 \mid 0011$ <br> $0110 y^{\prime} \mathrm{y}$ | $y \rightarrow E N$ | None | Load EN Immediate (Note 7) |
| XABR |  | 12 | [0001 0010 | $A \longleftrightarrow \mathrm{Br}$ | None | Exchange A with Br (Note 8) |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  | 20 | 001010000 |  | $C=" 1 "$ | Skip if C is True |
| SKE |  | 21 | 001010001 |  | $A=\operatorname{RAM}(\mathrm{B})$ | Skip if A Equals RAM |
| SKGZ |  | $\begin{aligned} & 33 \\ & 21 \end{aligned}$ | $\begin{array}{\|r\|} \hline 0011 \mid 0011 \\ \hline 0010\|0001\| \\ \hline \end{array}$ |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
| SKGBZ |  | 33 | 001110011 | 1st byte |  | Skip if G Bit is Zero |
|  | 0 | 01 | 000010001) |  | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 00010001] |  | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011| | 2nd byte | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 0001 00011 ] |  | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 0000\|00011 |  | $\operatorname{RAM}(\mathrm{B})_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | 0001 0001 |  | $\operatorname{RAM}(\mathrm{B})_{1}=0$ |  |
|  | 2 | 03 | 000000011 |  | $\operatorname{RAM}(\mathrm{B})_{2}=0$ |  |
|  | 3 | 13 | 0001 0011 |  | $\operatorname{RAM}(B)_{3}=0$ |  |
| SKT |  | 41 | 10100/0001 |  | A time-base counter carry has occurred since last test | Skip on Timer (Note 3) |

## Instruction Set (Continued)

TABLE III. COP244C/245C Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine <br> Language Code (BInary) | Data Flow | Skip Condltions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 00011\|0011] | $\mathrm{G} \rightarrow \mathrm{A}$ | None | Input G Ports to A |
|  |  | 2 A | 10010\|1010 |  |  |  |
| ININ |  | 33 | 1001110011 | $\underline{N} \rightarrow$ A | None | Input IN Inputs to $A$ (Note 2) |
|  |  | 28 | 0010\|1000 |  |  |  |
| INIL |  | 33 | 2001110011 | $\mathrm{IL}_{3}, \mathrm{CKO},{ }^{\prime} \mathrm{O}{ }^{\prime}, \mathrm{IL}_{0} \rightarrow \mathrm{~A}$ | None | Input IL Latches to A (Note 3) |
|  |  | 29 | 0010\|1001 |  |  |  |
| INL |  | 33 | 0011\|0011] | $\mathrm{L}_{7: 4} \rightarrow$ RAM $(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2 E | 0010 1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | 001110011 | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E | 00111110 |  |  |  |
| OGI | $y$ | 33 | 00110011 | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | 5- | 0101 y |  |  |  |
| OMG |  | 33 | 001110011 | $\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{G}$ | None | Output RAM to G Ports |
|  |  | 3A | 001111010 |  |  |  |
| XAS |  | 4F | 0100[1111 | A ${ }_{\text {SIO, }} \rightarrow$ SKL | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit A register.
Note 2: The ININ instruction is not available on the 24-pin packages since these devices do not contain the IN inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while i' Jubroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3. The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 5: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ " data minus 1 , e.g., to load the lower four bits of $\mathrm{B}(\mathrm{Bd})$ with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal $15\left(1111_{2}\right)$.
Note 7: Machine code for operand field y for LEl instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)
Note 8: For 2 K ROM devices, $A \longleftrightarrow \mathrm{Br}(0 \longrightarrow \mathrm{~A} 3)$. For 1 K ROM devices, $A \longleftrightarrow \mathrm{Br}(0,0 \rightarrow \mathrm{~A} 3, \mathrm{~A} 2)$.

## Description of Selected Instructions

## XAS INSTRUCTION

XAS (Exchange A with SIO) copies $C$ to the SKL latch and exchanges the accumulator with the 4 -bit contents of the SIO register. The contents of SIO will contain serial-in/seri-al-out shift register or binary counter data, depending on the value of the EN register. If SIO is selected as a shift register, an XAS instruction can be performed once every 4 instruction cycles to effect a continuous data stream.

## LQID INSTRUCTION

LQID (Load $Q$ Indirect) loads the 8 -bit $Q$ register with the contents of ROM pointed to by the 11-bit word PC10:PC8,A,M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC $+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC}$ ) and replaces the least significant 8 bits of the PC as follows: $A \rightarrow P C 7: 4, R A M(B) \rightarrow P C 3: 0$, leaving PC10, PC9 and PC8 unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" ( $S C \rightarrow S B \rightarrow S A \rightarrow P C$ ), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost.
Note: LQID uses 2 instruction cycles if executed, one if skipped.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by $A$ and $M$. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 11-bit word, PC10:8,A,M. PC10,PC9 and PC8 are not affected by JID.
Note: JID uses 2 instruction cycles if executed, one if skipped.

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of the T counter overflow latch (see internal logic, above), executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction allow the processor to generate its own time-base for real-time processing, rather than relying on an external input signal.
Note: If the most significant bit of the T counter is a 1 when a CAMT instruction loads the counter, the overflow flag will be set. The following sample of codes should be used when loading the counter:
CAMT ; load T counter
SKT ; skip if overflow flag is set and reset it
NOP

## IT INSTRUCTION

The IT (idle till timer) instruction halts the processor and puts it in an idle state until the time-base counter overflows. This idle state reduces current drain since all logic (except the oscillator and time base counter) is stopped. IT instruction is not allowed if the T counter is mask-programmed as an external event counter (option \#31=1).

## INIL INSTRUCTION

INIL (Input IL Latches to A) inputs 2 latches, IL3 and ILO, CKO and 0 into A. The IL3 and ILO latches are set if a lowgoing pulse (" 1 " to " 0 ") has occurred on the IN3 and INO inputs since the last INIL instruction, provided the input
pulse stays low for at least two instruction cycles. Execution of an INIL inputs IL3 and ILO into A3 and A0 respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the IN3 and INO lines. If CKO is mask programmed as a general purpose input, an INIL will input the state of CKO into A2. If CKO has not been so programmed, a " 1 " will be placed in A2. AO is input into A1. IL latches are cleared on reset. IL latches are not available on the COP245C/225C, and COP226C.

## INSTRUCTION SET NOTES

a. The first word of a program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, they are still fetched from the program memory. Thus program paths take the same number of cycles whether instructions are skipped or executed except for JID, and LQID.
c. The ROM is organized into pages of 64 words each. The Program Counter is a 11 -bit binary counter, and will count through page boundaries. If a JP, JSRP, JID, or LQID is the last word of a page, it operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a JID or LQID located in the last word of every fourth page (i.e. hex address 0FF, 1FF, 2FF, 3FF, 4FF, etc.) will access data in the next group of four pages.
Note: The COP224C/225C/226C needs only 10 bits to address its ROM. Therefore, the eleventh bit ( P 10 ) is ignored.

## Power Dissipation

The lowest power drain is when the clock is stopped. As the frequency increases so does current. Current is also lower at lower operating voltages. Therefore, the user should run at the lowest speed and voltage that his application will allow. The user should take care that all pins swing to full supply levels to insure that outputs are not loaded down and that inputs are not at some intermediate level which may draw current. Any input with a slow rise or fall time will draw additional current. A crystal or resonator generated clock input will draw additional current. For example, a 500 kHz crystal input will typically draw $100 \mu \mathrm{~A}$ more than a squarewave input. An R/C oscillator will draw even more current since the input is a slow rising signal.
If using an external squarewave oscillator, the following equation can be used to calculate operating current drain.

$$
\begin{aligned}
& I_{C O}=I_{Q}+V \times 70 \times \mathrm{Fi}+\mathrm{V} \times 2400 \times \mathrm{Fi} / \mathrm{Dv} \text { where: } \\
& I_{C O}=\text { chip operating current drain in microamps } \\
& I_{Q}=\text { quiescent leakage current (from curve) } \\
& \mathrm{Fi}=\mathrm{CKI} \text { frequency in MegaHertz } \\
& \mathrm{V}=\mathrm{chip} \mathrm{~V}_{\mathrm{CC}} \text { in volts } \\
& \mathrm{DV}=\text { divide by option selected }
\end{aligned}
$$

For example at 5 volts $V_{C C}$ and 400 kHz (divide by 4)

$$
\begin{aligned}
& I_{C O}=120+5 \times 70 \times 0.4+5 \times 2400 \times 0.4 / 4 \\
& I_{C O}=120+140=800 \mu \mathrm{~A}
\end{aligned}
$$

## Power Dissipation (Continued)

If an IT instruction is executed, the chip goes into the IDLE mode until the timer overflows. In IDLE mode, the current drain can be calculated from the following equation:

$$
I c i=I_{Q}+V \times 70 \times F i
$$

For example, at 5 volts $V_{C C}$ and 400 kHz

$$
\mathrm{Ici}=120+5 \times 70 \times 0.4=260 \mu \mathrm{~A}
$$

The total average current will then be the weighted average of the operating current and the idle current:

$$
I t a=I_{C O} \times \frac{T o}{T o+T i}+I c i \times \frac{T i}{T o+T i}
$$

where:
Ita $=$ total average current
$I_{C O}=$ operating current
$\mathrm{lci}=$ idle current
To $=$ operating time
$\mathrm{Ti}=\mathrm{idle}$ time

## I/O OPTIONS

Outputs have the following optional configurations, illustrated in Figure 8:
a. Standard - A CMOS push-pull buffer with an N -channel device to ground in conjunction with a P-channel device to $V_{C C}$, compatible with CMOS and LSTTL.
b. Open Drain - An N-channel device to ground only, allowing external pull-up as required by the user's application.
c. Standard TRI-STATE L Output - A CMOS output buffer similar to a. which may be disabled by program control.
d. Open-Drain TRI-STATE L Output - This has the N-channel device to ground only.

All inputs have the following option:
e. $\mathrm{Hi}-\mathrm{Z}$ input which must be driven by the users logic.

All output drivers use two common devices numbered 1 to 2. Minimum and maximum current (lout and $\mathrm{V}_{\text {OUT }}$ ) curves are given in Figure 9 for each of these devices to allow the designer to effectively use these I/O configurations.

a. Standard Push-Pull Output

b. Open-Drain Output

c. Standard TRI-STATE "L" Output

d. Open Drain TRI-STATE "L" Output

e. Hi-Z Input

FIGURE 8. Input/Output Configurations

## Power Dissipation (Continued)




FIGURE 9. Input/Output Characteristics

## Option List

The COP244C/245C/224C/225C/COP226C mask-programmable options are assigned numbers which correspond with the COP244C/224C pins.
The following is a list of options. The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
Caution:
The output options available on the COP224C/225C/226C and COP244C/245C are not the same as those available on the COP324C/325C/326C, COP344C/345C, COP424C/ $425 \mathrm{C} / 426 \mathrm{C}$ and COP $444 \mathrm{C} / 445 \mathrm{C}$. Options not available on the COP224C/225C/226C and COP244C/245C are: Option 2 value 2; Option 4 value 0; Option 5 value 1; Option 9 value 0; Option 17 value 1; Option 30, Dual Clock, all values; Option 32, Microbus, all values; Option 33 values 2 4, and 6; Option 34 all values; and Option 35 all values.

PLEASE FILL OUT THE OPTION TABLE on the next page. Photocopy the option data and send it in with your disk or EPROM.
Option 1=0: Ground Pin - no options available
Option 2: CKO Pin
=0: clock generator output to crystal/resonator
= 1: HALT I/O port
$=3$ : general purpose input, high-Z
Option 3: CKI input
$=0$ : Crystal controlled oscillator input divide by 4
$=1$ : Crystal controlled oscillator input divide by 8
=2: Crystal controlled oscillator input divide by 16
=4: Single-pin RC controlled oscillator (divide by 4)
=5: External oscillator input divide by 4
=6: External oscillator input divide by 8
=7: External oscillator input divide by 16

Option 4: $\overline{R E S E T}$ input
$=1$ : $\mathrm{Hi}-\mathrm{Z}$ input
Option 5: L7 Driver
$=0$ : Standard TRI-STATE push-pull output
=2: Open-drain TRI-STATE output
Option 6: L6 Driver - (same as option 5)
Option 7: L5 Driver - (same as option 5)
Option 8: L4 Driver - (same as option 5)
Option 9: IN1 input
$=1$ : Hi-Z input, mandatory for 28 Pin Package
=2: Mandatory for 20 and 24 Pin Packages
Option 10: IN2 input - (same as option 9)
Option 11=0: VCC Pin - no option available
Option 12: L3 Driver - (same as option 5)
Option 13: L2 Driver - (same as option 5)
Option 14: L1 Driver - (same as option 5)
Option 15: L0 Driver - (same as option 5)
Option 16: SI input - (same as option 4)
Option 17: SO Driver
$=0$ : Standard push-pull output
$=2$ : Open-drain output
Option 18: SK Driver - (same as option 17)
Option 19: INO Input - (same as option 9)
Option 20: IN3 Input - (same as option 9)
Option 21: GO I/O Port - (same as option 17)
Option 22: G1 I/O Port - (same as option 17)
Option 23: G2 I/O Port - (same as option 17)
Option 24: G3 I/O Port - (same as option 17)
Option 25: D3 Output - (same as option 17)
Option 26: D2 Output - (same as option 17)
Option 27: D1 Output - (same as option 17)

Option List (Continued)
Option 28: DO Output - (same as option 17)
Option 29: Internal Initialization Logic
$=0$ : Normal operation
$=1$ : No internal initialization logic
Option $30=0$ : No Option Available
Option 31: Timer
$=0$ : Time-base counter
=1: External event counter
Option 32=0: No Option Available

Option 33: COP bonding. See note.
( 1 k and 2 k Microcontroller)
$=0$ : 28-pin package
=1: 24-pin package
(1k Microcontroller only)
=3: 20-pin package
=5: 24- and 20-pin package
Note:-If opt. \#33=0 then opt. \#9, 10, 19, and 20 must $=1$.
If opt. \#33=1 then opt. \#9, 10, 19 and 20 must $=2$, and option \#31 must $=0$.
If opt. \#33 $=3$ or 5 then opt. \#9, 10, 19, 20 must $=2$ and opt. \#21, 22, 31 must $=0$.

Option $34=0$ : No Option Available
Option $35=0$ : No Option Available

## Option Table

The following option information is to be sent to National along with the EPROM.

OPTION DATA

| OPTION | 1 VALUE = | 0 | IS: GROUND PIN |
| :---: | :---: | :---: | :---: |
| OPTION | 2 VALUE $=$ |  | IS: CKO PIN |
| OPTION | 3 VALUE $=$ |  | IS: CKI INPUT |
| OPTION | 4 VALUE $=$ | 1 | IS: $\overline{R E S E T}$ INPUT |
| OPTION | 5 VALUE $=$ |  | IS: L7 DRIVER |
| OPTION | 6 VALUE $=$ |  | IS: L6 DRIVER |
| OPTION | 7 VALUE $=$ |  | IS: L5 DRIVER |
| OPTION | 8 VALUE $=$ |  | IS: L4 DRIVER |
| OPTION | 9 VALUE $=$ |  | IS: IN1 INPUT |
| OPTION | 10 VALUE $=$ |  | IS: IN2 INPUT |
| OPTION | 11 VALUE = | 0 | IS: VCC PIN |
| OPTION | 12 VALUE = |  | IS: L3 DRIVER |
| OPTION | 13 VALUE = |  | IS: L2 DRIVER |
| OPTION | 14 VALUE $=$ |  | IS: L1 DRIVER |
| OPTION | 15 VALUE $=$ |  | IS: LO DRIVER |
| OPTION | 16 VALUE $=$ | 1 | IS: SI INPUT |
| OPTION | 17 VALUE $=$ |  | IS: SO DRIVER |
| OPTION | 18 VALUE = |  | IS: SK DRIVER |


| OPTION 19 VALUE $=$ |  | IS: INO INPUT IS: IN3 INPUT |
| :---: | :---: | :---: |
| OPTION 20 VALUE = |  |  |
| OPTION 21 VALUE = |  | IS: GO I/O PORT |
| OPTION 22 VALUE = |  | IS: G1 I/O PORT |
| OPTION 23 VALUE $=$ |  | IS: G2 I/O PORT |
| OPTION 24 VALUE = |  | IS: G3 I/O PORT |
| OPTION 25 VALUE = |  | IS: D3 OUTPUT |
| OPTION 26 VALUE = |  | IS: D2 OUTPUT |
| OPTION 27 VALUE = |  | IS: D1 OUTPUT |
| OPTION 28 VALUE = |  | IS: DO OUTPUT |
| OPTION 29 VALUE = |  | IS: INT INIT LOGIC |
| OPTION 30 VALUE $=$ | 0 | IS: N/A |
| OPTION 31 VALUE = |  | IS: TIMER |
| OPTION $32 \mathrm{VALUE}=$ | 0 | IS: N/A |
| OPTION 33 VALUE $=$ |  | IS: COP BONDING |
| OPTION 34 VALUE = | 0 | IS: N/A |
| OPTION 35 VALUE = | 0 | IS: N/A |



## COP410C/COP411C/COP310C/COP311C Single-Chip CMOS Microcontrollers

## General Description

The COP410C, COP411C, COP310C, and COP311C fully static, single-chip CMOS microcontrollers are members of the COPSTM family, fabricated using double-poly, silicongate CMOS technology. These controller-oriented processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture, and I/O scheme designed to facilitate keyboard input, display output, and BCD data manipulation. The COP411C is identical to the COP410C but with 16 I/O lines instead of 20 . They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized controller-oriented processor at a low endproduct cost.
The COP310C/COP311C is the extended temperature range version of the COP410C/COP411C.
The COP404C should be used for exact emulation.

## Features

■ Lowest power dissipation ( $40 \mu \mathrm{~W}$ typical)

- Low cost
- Power-saving HALT Mode with Continue function
- Powerful instruction set
- $512 \times 8$ ROM, $32 \times 4$ RAM
- 20 I/O lines (COP410C)
- Two-level subroutine stack
- DC to $4 \mu \mathrm{~s}$ instruction time

■ Single supply operation ( 2.4 V to 5.5 V )
■ General purpose and TRI-STATE ${ }^{(1)}$ outputs

- Internal binary counter register with MICROWIRETM compatible serial I/O
- LSTTL/CMOS compatible in and out
- Software/hardware compatible with other members of the COP400 family
■ Extended temperature ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ) devices available
■ The military temperature range devices $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ ) are specified on COP210C/211C data sheet


## Block Diagram



TL/DD/5015-
FIGURE 1. COP410C

## COP410C/COP411C

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in thls datasheet. Refer to the assoclated reliability electrical test specifications document.
Supply Voltage
Voltage at Any Pin
Total Allowable Source Current
Total Allowable Sink Current

Operating Temperature Range
Storage Temperature Range Lead Temperature (Soldering, 10 sec.)
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage |  | 2.4 | 5.5 | V |
| Power Supply Ripple ${ }^{5}$ |  |  | $0.1 \mathrm{~V}_{\mathrm{CC}}$ | V |
| Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=125 \mu \mathrm{~s} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=16 \mu \mathrm{~s} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=4 \mu \mathrm{~s} \\ & \left(\mathrm{t}_{\mathrm{c}}\right. \text { is instruction cycle time) } \end{aligned}$ |  | $\begin{gathered} 80 \\ 500 \\ 2000 \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| HALT Mode Current ${ }^{2}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~F}_{\mathrm{IN}}=0 \mathrm{kHz} \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~F}_{\mathrm{IN}}=0 \mathrm{kHz} \end{aligned}$ |  | $\begin{gathered} 20 \\ 7 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ |
| Input Voltage Levels RESET, CKI Logic High Logic Low All Other Inputs Logic High Logic Low |  | $\begin{aligned} & 0.9 \mathrm{~V}_{\mathrm{CC}} \\ & 0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & V \\ & v \\ & v \\ & v \end{aligned}$ |
| Hi-Z Input Leakage |  | -1 | +1 | $\mu \mathrm{A}$ |
| Input Capacitance |  |  | 7 | pF |
| Output Voltage Levels LSTTL Operation Logic High Logic Low CMOS Operation Logic High Logic Low | Standard Outputs <br> $V_{C C}=5.0 \mathrm{~V} \pm 10 \%$ <br> $\mathrm{I}_{\mathrm{OH}}=-25 \mu \mathrm{~A}$ <br> $\mathrm{lOL}=400 \mu \mathrm{~A}$ $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $2.7$ $V_{C C}-0.2$ | $\begin{aligned} & 0.4 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & V \\ & v \\ & v \\ & v \end{aligned}$ |
| Output Current Levels ${ }^{4}$ <br> (Except CKO) <br> Sink <br> Source (Standard <br> Option) <br> Source (Low Current Option) | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V}, V_{\text {OUT }}=V_{C C} \\ & V_{C C}=2.4 \mathrm{~V}, V_{\text {OUT }}=V_{C C} \\ & V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V} \\ & V_{C C}=2.4 \mathrm{~V}, V_{\text {OUT }}=0 \mathrm{~V} \\ & V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{Cl} \end{aligned}$ | $\begin{gathered} 1.2 \\ 0.2 \\ -0.5 \\ -0.1 \\ -30 \\ -6 \\ \hline \end{gathered}$ | $\begin{gathered} -330 \\ -80 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| CKO Current Levels  <br> (As Clock Out)  <br> Sink $\div 4$ <br>  $\div 8$ <br> Source $\div 16$ <br>  $\div 4$ <br>  $\div 8$ <br>  $\div 16$ | $V_{C C}=4.5 \mathrm{~V}, \mathrm{CKI}=V_{C C}, V_{O U T}=V_{C C}$ $V_{C C}=4.5 \mathrm{~V}, \mathrm{CKI}=0 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V}$ | $\begin{gathered} 0.3 \\ 0.6 \\ 1.2 \\ -0.3 \\ -0.6 \\ -1.2 \end{gathered}$ |  | mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Allowable Sink/Source Current Per Pin ${ }^{4}$ |  |  | 5 | mA |

COP410C/COP411C
DC Electrical Characteristics (Continued)

| Parameter | Conditions | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| Allowable Loading on CKO <br> (as HALT I/O pin) |  |  |  |  |
| Current Needed to |  |  |  |  |
| Override HALT <br> To Continue |  |  | 00 |  |
| To Halt | $V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{I N}=0.2 \mathrm{~V}_{\mathrm{CC}}$ |  | mA |  |
| TRI-STATE or Open Drain |  | $V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{I N}=0.7 \mathrm{~V}_{\mathrm{CC}}$ |  | 1.6 |
| Leakage Current |  | -2 | mA |  |

Note 1: Supply current is measured after running for 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled up to $V_{C C}$ with 5 k resistors. See current drain equation on page 13.
Note 2: The Halt mode will stop CKI from oscillating in the RC and crystal configurations.
Note 3: When forcing HALT, current is only needed for a short time (approximately 200 ns ) to flip the HALT flip-flop.
Note 4: SO output sink current must be limited to keep $V_{O L}$ less than $0.2 \mathrm{~V}_{\mathrm{CC}}$ when part is running in order to prevent entering test mode.
Note 5: Voltage change must be less than 0.5 V in a 1 ms period.
Note 6: This parameter is only sampled and not $100 \%$ tested.
Note 7: Variation due to the device included.

COP410C/COP411C
AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time ( $\mathrm{t}_{\mathrm{c}}$ ) | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>V_{C C} \geq 2.4 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 4 \\ 16 \end{gathered}$ | $\begin{aligned} & D C \\ & D C \end{aligned}$ | $\begin{gathered} \mu \mathrm{S} \\ \mu \mathrm{~s} \end{gathered}$ |
| Operating CKI $\div 4$ mode <br> Frequency $\div 8$ mode <br>  $\div 16$ mode <br>  $\div 4$ mode <br>  $\div 8$ mode <br>  $\div 16$ mode | $\left\{\begin{array}{l} v_{C C} \geq 4.5 \mathrm{~V} \\ 4.5 \mathrm{~V}>\mathrm{v}_{\mathrm{CC}} \geq 2.4 \mathrm{~V} \end{array}\right.$ | DC <br> DC <br> DC <br> DC <br> DC <br> DC | $\begin{aligned} & 1.0 \\ & 2.0 \\ & 4.0 \\ & 250 \\ & 500 \\ & 1.0 \\ & \hline \end{aligned}$ | MHz <br> MHz <br> MHz <br> kHz <br> kHz <br> MHz |
| Instruction Cycle Time RC Oscillator ${ }^{7}$ | $\begin{aligned} & R=30 k \pm 5 \%, V_{C C}=5 V \\ & C=82 \mathrm{pF} \pm 5 \%(\div 4 \text { Mode }) \end{aligned}$ | 8 | 16 | $\mu \mathrm{S}$ |
| Duty Cycle ${ }^{6}$ | $\mathrm{f}_{\mathrm{l}}=4 \mathrm{MHz}$ | 40 | 60 | \% |
| Rise Time ${ }^{6}$ | $\mathrm{f}_{\mathrm{I}}=4 \mathrm{MHz}$ External Clock |  | 60 | ns |
| Fall Time ${ }^{6}$ | $\mathrm{f}_{\mathrm{I}}=4 \mathrm{MHz}$ External Clock |  | 40 | ns |
| Inputs (See Figure 3) ${ }^{\text {tseTUP }}$ <br> $t_{\text {HOLD }}$ | $\left.\begin{array}{l} \text { G Inputs } \\ \text { SI Input } \\ \text { All Others } \end{array}\right\} V_{C C} \geq 4.5 \mathrm{~V}$ | $\begin{gathered} \mathrm{tc} / 4+0.7 \\ 0.3 \\ 1.7 \\ 0.25 \\ 1.0 \\ \hline \end{gathered}$ |  | $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{s}$ |
| Output Propagation Delay tpD1 $^{\text {, }}$ PDD tpD1 $^{\text {t }}$ PD0 | $\begin{aligned} & V_{O U T}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=5 \mathrm{k} \\ & \mathrm{~V}_{\mathrm{CC}} \leq 4.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}} \leq 2.4 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 1.0 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~S} \\ & \hline \end{aligned}$ |

## COP310C/COP311C

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contalned in thls datasheet. Refer to the associated reliability electrical test specifications document.
Supply Voltage 6 V
Voltage at Any Pin
Total Allowable Source Current
-0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$
25 mA
25 mA

## COP310C/COP311C

DC Electrical Characteristics
(Continued)

| Parameter | Conditions | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| Allowable Loading on CKO <br> (as HALT I/O pin) |  |  |  |  |
| Current Needed to |  |  |  |  |
| Override HALT3 <br> To Continue <br> To Halt | $V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{I N}=0.2 \mathrm{~V}_{\mathrm{CC}}$ |  | 0.8 | mA |
| TRI-STATE or Open Drain |  |  | 2.0 | mA |
| Leakage Current |  | -4 |  |  |

Note 1: Supply current is measured after running for 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled up to $V_{C C}$ with $5 k$ resistors. See current drain equation on page 13.
Note 2: The Halt mode will stop CKI from oscillating in the RC and crystal configurations.
Note 3: When forcing HALT, current is only needed for a short time (approximately 200 ns ) to flip the HALT flip-flop.
Note 4: SO output sink current must be limited to keep $V_{O L}$ less than $0.2 \mathrm{~V}_{\mathrm{CC}}$ when part is running in order to prevent entering test mode.
Note 5: Voltage change must be less than 0.5 V in a 1 ms period.
Note 6: This parameter is only sampled and not $100 \%$ tested.
Note 7: Variation due to the device included.

## COP310C/COP311C

AC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time ( $\mathrm{t}_{\mathrm{c}}$ ) | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 3.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 4 \\ 16 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Operating CKI $\div 4$ mode <br> Frequency $\div 8$ mode <br>  $\div 16$ mode <br>  $\div 4$ mode <br>  $\div 8$ mode <br>  $\div 16$ mode | $\left\{\begin{array}{l} v_{\mathrm{CC}} \geq 4.5 \mathrm{~V} \\ 4.5 \mathrm{~V}>\mathrm{v}_{\mathrm{CC}} \geq 3.0 \mathrm{~V} \end{array}\right.$ | DC <br> DC <br> DC <br> DC <br> DC <br> DC | $\begin{array}{r} 1.0 \\ 2.0 \\ 4.0 \\ 250 \\ 500 \\ 1.0 \\ \hline \end{array}$ | MHz <br> MHz <br> MHz <br> kHz <br> kHz <br> MHz |
| Instruction Cycle Time RC Oscillator ${ }^{7}$ | $\begin{aligned} & R=30 \mathrm{k} \pm 5 \%, V_{C C}=5 \mathrm{~V} \\ & \mathrm{C}=82 \mathrm{pF} \pm 5 \%(\div 4 \text { Mode }) \end{aligned}$ | 8 | 16 | $\mu \mathrm{S}$ |
| Duty Cycle ${ }^{6}$ | $\mathrm{f}_{\mathrm{l}}=4 \mathrm{MHz}$ | 40 | 60 | \% |
| Rise Time ${ }^{6}$ | $\mathrm{f}_{1}=4 \mathrm{MHz}$ External Clock |  | 60 | ns |
| Fall Time ${ }^{6}$ | $\mathrm{f}_{\mathrm{I}}=4 \mathrm{MHz}$ External Clock |  | 40 | ns |
| Inputs (See Figure 3) tsetup <br> $t_{\text {HOLD }}$ | $\begin{aligned} & \text { G Inputs } \\ & \text { SI Input } \\ & \text { All Others } \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & V_{C C} \geq 3.0 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{tc} / 4+0.7 \\ 0.3 \\ 1.7 \\ 0.25 \\ 1.0 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Output Propagation Delay <br> tpD1 t $_{\text {PDD }}$ tpD1, tpD0 | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=5 \mathrm{k} \\ & \mathrm{~V}_{\mathrm{CC}} \leq 4.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}} \leq 3.0 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 1.0 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \end{aligned}$ |

## Connection Diagrams



Order Number COP311C-XXX/D, COP411C-XXX/D, COP311C-XXX/N or COP411C-XXX/N, COP311C-XXX/N or COP411C-XXX/N
See NS Package Number D20A, M20B or N20A


TL/DD/5015-3
Top View

Order Number COP310C-XXX/D, COP410C-XXX/D, COP310C-XXX/M or COP410C-XXX/M, COP310C-XXX/N or COP410C-XXX/N See NS Package Number D24C, M24B or N24A
FIGURE 2

## Pin Descriptions

| Pin | Description | Pin | Description |
| :--- | :--- | :--- | :--- |
| $L_{7}-L_{0}$ | 8-bit bidirectional I/O port with TRI-STATE | SK | Logic-controlled clock |
| $G_{3}-G_{0}$ | 4-bit bidirectional I/O port |  | (or general purpose output) |
|  | $\left(G_{2}-G_{0}\right.$ for 20-pin package) | CKI | System oscillator input |
| $D_{3}-D_{0}$ | 4-bit general purpose output port | CKO | Crystal oscillator output, or HALT mode |
|  | ( $D_{1}-D_{0}$ for 20-pin package) |  | I/O port (24-pin package only) |
| SI | Serial input (or counter input) | RESET | System reset input |
| SO | Serial output (or general purpose output) | VCC | System power supply |
|  |  | GND | System Ground |

## Timing Diagram



FIGURE 3. Input/Output (Divide-by-8 Mode)

## Functional Description

To ease reading of this description, only COP410C and/or COP411C are referenced; however, all such references apply equally to COP310C and/or COP311C, respectively.
A block diagram of the COP410C is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 "; when a bit is reset, it is a logic " 0 ".

## PROGRAM MEMORY

Program memory consists of a 512-byte ROM. As can be seen by an examination of the COP410C/411C instruction set, these words may be program instructions, program data, or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID, and LQID instructions, ROM must often be thought of as being organized into 8 pages of 64 words (bytes) each.

## ROM ADDRESSING

ROM addressing is accomplished by a 9 -bit PC register. Its binary value selects one of the 5128 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 9-bit binary count value. Two levels of subroutine nesting are implemented by two 9-bit subroutine save registers, SA and SB.
ROM instruction words are fetched, decoded, and executed by the instruction decode, control and skip logic circuitry.

## DATA MEMORY

Data Memory consists of a 128-bit RAM, organized as four data registers of $8 \times 4$-bit digits. RAM addressing is implemented by a 6-bit $B$ register whose upper two bits ( Br ) selects one of four data registers and lower three bits of the 4bit Bd select one of eight 4-bit digits in the selected data register. While the 4-bit contents of the selected RAM digit $(M)$ are usually loaded into or from, or exchanged with, the $A$ register (accumulator), they may also be loaded into the $Q$ latches or loaded from the L ports. RAM addressing may also be performed directly by the XAD 3, 15 instruction. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.
The most significant bit of Bd is not used to select a RAM digit. Hence, each physical digit of RAM may be selected by two different values of Bd as shown in Figure 4. The skip condition for XIS and XDS instructions will be true if Bd changes between 0 to 15, but not between 7 and 8 (see Table III).

## INTERNAL LOGIC

The internal logic of the COP410C/411C is designed to ensure fully static operation of the device.
The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Bd portion of the $B$ register, to load four bits of the 8 -bit $Q$ latch data and to perform data exchanges with the SIO register.
The 4-bit adder performs the arithmetic and logic functions of the COP410C/411C, storing its results in A. It also outputs the carry information to a 1-bit carry register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description below.)
The G register contents are outputs to four general purpose bidirectional I/O ports.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded from RAM and A, as well as 8 -bit data from ROM. Its contents are output to the L I/O ports when the $L$ drivers are enabled under program control. (See LEl instruction.)
The eight $L$ drivers, when enabled, output the contents of latched Q data to the L I/O ports. Also, the contents of L may be read directly into $A$ and RAM.


TL/DD/5015-5
FIGURE 4. RAM Digit Address to Physical RAM Digit Mapping

## Functional Description (Continued)

The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter, depending upon the contents of the EN register. (See EN register description below.) Its contents can be exchanged with $A$, allowing it to input or output a continuous serial data stream. With SIO functioning as a serial-in/serial-out shift register and SK as a sync clock, the COP410C/411C is MICROWIRE compatible.
The D register provides four general purpose outputs and is used as the destination register for the 4-bit contents of Bd. The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK is a sync clock, inhibited when SKL is a logic " 0 ". The EN register is an internal 4-bit register loaded under program control by the LEl instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register (EN3-ENO).

1. The least significant bit of the enable register, ENO, selects the SIO register as either a 4-bit shift register or as a 4-bit binary counter. With ENO set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of EN3. With ENO reset, SIO is a serial shift register, shifting left each instruction cycle time. The data present at SI is shifted into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each instruction cycle time. (See 4, below.) The SK output becomes a logic-controlled clock.
2. EN 1 is not used, it has no effect on the COP410C/411C.
3. With EN2 set, the $L$ drivers are enabled to output the data in $Q$ to the $L$ I/O ports. Resetting EN2 disables the $L$ drivers, placing the LI/O ports in a high impedance input state.
4. EN3, in conjunction with ENO, affects the SO output. With ENO set (binary counter option selected), SO will output the value loaded into EN3. With ENO reset (serial shift register option selected), setting EN3 enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting EN3 with the serial shift register option selected, disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ".

## INITIALIZATION

The internal reset logic will initialize the device upon powerup if the power supply rise time is less than 1 ms and if the operating frequency at CKI is greater than 32 kHz , otherwise the external RC network shown in Figure 5 must be connected to the $\overline{\text { RESET }}$ pin. The $\overline{\text { RESET }}$ pin is configured as a Schmitt trigger input. If not used, it should be connected to $V_{\text {cc }}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, providing it stays low for at least three instruction cycle times.
When $\mathrm{V}_{\mathrm{CC}}$ power is applied, the internal reset logic will keep the chip in initialization mode for up to 2500 instruction cycles. If the CKI clock is running at a low frequency, this could take a long time, therefore, the internal logic should be disabled by a mask option with initialization controlled solely by $\overline{\operatorname{RESET}}$ pin.
Note: If CKI clock is less than 32 kHz , the internal reset logic (Option $25=1$ ) must be disabled and the external RC network must be present.
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N$, and $G$ registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA (clear A register).


TL/DD/5015-6

$$
\text { RC }>5 \times \text { Power Supply Rise Time }
$$ and $\mathrm{RC}>100 \times$ CKI Period

## FIGURE 5. Power-Up Clear Circuit

## COP411C

If the COP410C is bonded as a 20-pin package, it becomes the COP411C, illustrated in Figure 2, COP410C/411C Connection Diagrams. Note that the COP411C does not contain D2, D3, G3, or CKO. Use of this option, of course, precludes use of D2, D3, G3, and CKO options. All other options are available for the COP411C.

TABLE I. Enable Register Modes - Bits ENO and EN3

| ENO | EN3 | SIO | SI | SO | SK |
| :---: | :---: | :--- | :--- | :---: | :--- |
| 0 | 0 | Shift Register | Input to Shift | 0 | If $S K L=1$, SK $=$ clock |
|  |  |  | Register |  | If $S K L=0, S K=0$ |
| 0 | 1 | Shift Register | Input to Shift | Serial | If $S K L=1, S K=$ clock |
|  |  |  | Register | out | If $S K L=0, S K=0$ |
| 1 | 0 | Binary Counter | Input to Counter | 0 | $S K=S K L$ |
| 1 | 1 | Binary Counter | Input to Counter | 1 | $S K=S K L$ |

## Functional Description (Continued)

## HALT MODE

The COP410C/411C is a fully static circuit; therefore, the user may stop the system oscillator at any time to halt the chip. The chip also may be halted by the HALT instruction or by forcing CKO high when it is used as a HALT I/O port. Once in the HALT mode, the internal circuitry does not receive any clock signal, and is therefore frozen in the exact state it was in when halted. All information is retained until continuing. The HALT mode is the minimum power dissipation state.
The HALT mode has slight differences depending upon the type of oscillator used.
a. 1-pin oscillator-RC or external

The HALT mode may be entered into by either program control (HALT instruction) or by forcing CKO to a logic "1" state.
The circuit may be awakened by one of two different methods:

1) Continue function. By forcing CKO to a logic " 0 ", the system clock is re-enabled and the circuit continues to operate from the point where it was stopped.
2) Restart. Forcing the RESET pin to a logic " 0 " will restart the chip regardless of HALT or CKO (see initialization).
b. 2-pin oscillator-crystal

The HALT mode may be entered into by program control (HALT instruction) which forces CKO to a logic " 1 " state. The circuit can be awakened only by the RESET function.


## CKO Pin Options

In a crystal-controlled oscillator system, CKO is used as an output to the crystal network. CKO will be forced high during the execution of a HALT instruction, thus inhibiting the crystal network. If a 1-pin oscillator system is chosen (RC or external), CKO will be selected as HALT and is an I/O
flip-flop which is an indicator of the HALT status. An external signal can override this pin to start and stop the chip. By forcing a high level to CKO, the chip will stop as soon as CKI is high and the CKO output will go high to keep the chip stopped. By forcing a low level to CKO, the chip will continue and CKO output will go low.
All features associated with the CKO I/O pin are available with the 24 -pin package only.

## OSCILLATOR OPTIONS

There are three options available that define the use of CKI and CKO.
a. Crystal-Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency divided by 16 (optionally by 8 or 4).
b. External Oscillator. CKI is configured as LSTTL-compatible input accepting an external clock signal. The external frequency is divided by 16 (optionally by 8 or 4 ) to give the instruction cycle time. CKO is the HALT I/O port.
c. RC-Controlled Oscillator. CKI is configured as a single pin RC-controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is the HALT I/O port.
The RC oscillator is not recommended in systems that require accurate timing or low current. The RC oscillator draws more current than an external oscillator (typically an additional $100 \mu \mathrm{~A}$ at 5 V ). However, when the part halts, it stops with CKI high and the halt current is at the minimum.


FIGURE 6. COP410C Oscillator

| Crystal or Resonator |  |  |  |  | RC-Controlled Oscillator |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Crystal | Component Value |  |  |  | Cycle |  |  |  |
| Value | R1 | R2 | C1 pF | C2 pF | R | C | Time | $\mathrm{V}_{\text {CC }}$ |
| 32 kHz | 220k | 20M | 30 | 5-36 | 15k | 82 pF | 4-9 $\mu \mathrm{s}$ | 24.5 V |
| 455 kHz | 5k | 10M | 80 | 40 | 30k | 82 pF | 8-16 $\mu \mathrm{s}$ | 24.5 V |
| 2.096 MHz | 2k | 1M | 30 | 6-36 | 47k | 100 pF | $16-32 \mu \mathrm{~s}$ | 2.4 to 4.5 |
| 4.0 MHz | 1k | 1M | 30 | 6-36 | Note: $15 \mathrm{k} \leq \mathrm{R} \leq 150 \mathrm{k}$, $50 \mathrm{pf} \leq \mathrm{C} \leq 150 \mathrm{pF}$ |  |  |  |

## COP410C/COP411C Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table III provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with each instruction in the COP410C/411C instruction set.

TABLE II. COP410C/411C Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| PC | 9-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| SA | 9-bit Subroutine Save Register A |
| SB | 9-bit Subroutine Save Register B |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |


| Symbol | Definition |
| :---: | :---: |
| INSTRUCTION OPERAND SYMBOLS |  |
| d | 4-bit Operand Field, 0-15 binary (RAM Digit Select) |
| r | 2-bit Operand Field, 0-3 binary (RAM Register Select) |
| a | 9-bit Operand Field, 0-511 binary (ROM Address) |
| y | 4-bit Operand Field, 0-15 binary (Immediate Data) |
| RAM(s) | Contents of RAM location addressed by s |
| ROM(t) | Contents of ROM location addressed by t |

OPERATIONAL SYMBOLS
$+\quad$ Plus

- Minus
$\rightarrow \quad$ Replaces
$\longleftrightarrow \quad$ Is exchanged with
$=\quad$ Is equal to
$\bar{A} \quad$ The one's complement of $A$
$\oplus$ Exclusive-OR
: Range of values

TABLE III. COP410C/411C Instruction Set

| Mnemonic | OperandHex <br> Code | Machine <br> Language Code <br> (Binary) |  | Data Flow | Skip Conditions |
| :---: | :---: | :---: | :---: | :--- | :--- |

Instruction Set (Continued)
TABLE III. COP410C/411C Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | 1111 1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 2) |
| JMP | a | $6-$ | $\begin{gathered} 0110\|000\| \mathrm{a}_{8} \mid \\ \mathrm{a}_{7}: 0 \\ \hline \end{gathered}$ | $a \rightarrow P C$ | None | Jump |
| JP | a | - | $\begin{aligned} & \left.\frac{\|1\|}{} a_{6: 0} \right\rvert\, \\ & \text { (pages } 2,3 \text { only) } \\ & \frac{11 \mid \quad a_{5: 0}}{} \\ & \text { (all other pages) } \end{aligned}$ | $\begin{aligned} & a \rightarrow P C_{6: 0} \\ & a \rightarrow P C_{5: 0} \end{aligned}$ | None | Jump within Page (Note 1) |
| JSRP | a | - | 10\| $\mathrm{a}_{5: 0}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 2) |
| JSR | a | $6-$ | $\frac{\|0110\| 100\left\|\mathrm{a}_{8}\right\|}{\mathrm{a}_{7: 0}}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | 0100 1000 | $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 0100\|10011 | $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| HALT |  | $\begin{aligned} & 33 \\ & 38 \end{aligned}$ | 0011 0011 <br> 0011 1000 |  | None | Halt processor |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | $\begin{aligned} & 33 \\ & 3 \mathrm{C} \end{aligned}$ | 0011 0011 <br> 0011 1100 | $\begin{aligned} & \mathrm{A} \rightarrow \mathrm{Q}_{7: 4} \\ & \mathrm{RAM}(\mathrm{~B}) \xrightarrow{\rightarrow} Q_{3: 0} \end{aligned}$ | None | Copy A, RAM to Q |
| CQMA |  | $\begin{aligned} & 33 \\ & 2 \mathrm{C} \end{aligned}$ | 0011 0011 <br> 0010 1100 | $\begin{aligned} & Q_{7: 4} \rightarrow R A M(B) \\ & Q_{3: 0} \rightarrow A \end{aligned}$ | None | Copy Q to RAM, A |
| LD | r | -5 | 00\|r|0101 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A Exclusive-OR Br with r |
| LQID |  | BF | 1011/1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SA} \rightarrow \mathrm{SB} \end{aligned}$ | None | Load Q Indirect |
| RMB | 0 1 2 3 | $\begin{aligned} & 4 C \\ & 45 \\ & 42 \\ & 43 \end{aligned}$ | 0100 1100 <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{aligned} & 0 \rightarrow \text { RAM }(B)_{0} \\ & 0 \rightarrow \text { RAM }(B)_{1} \\ & 0 \rightarrow R A M(B)_{2} \\ & 0 \rightarrow \text { RAM }(B)_{3} \end{aligned}$ | None | Reset RAM Bit |
| SMB | 0 1 2 3 | $\begin{aligned} & 4 D \\ & 47 \\ & 46 \\ & 4 B \end{aligned}$ | 0100 1101 <br> 0100 0111 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} 1 & \rightarrow \text { RAM }(B)_{0} \\ 1 & \rightarrow \text { RAM }(B)_{1} \\ 1 & \rightarrow \text { RAM }(B)_{2} \\ 1 & \rightarrow \text { RAM }(B)_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | y | 7- | 0111. y | $\begin{aligned} & \mathrm{y} \rightarrow \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | r | -6 | 00\|r|0110| | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with $\mathbf{r}$ |
| XAD | 3,15 | 23 $B F$ |  | $\operatorname{RAM}(3,15) \longleftrightarrow \mathrm{A}$ | None | Exchange A with RAM $(3,15)$ |

Instruction Set (Continued)
TABLE III. COP410C/411C Instruction Set (Continued)

| Mnemonic Operand | Hex <br> Code | Machine <br> Language Code <br> (Binary) | Data Flow | Skip Conditions | Description |
| :--- | :--- | :--- | :--- | :--- | :--- |
| MEMORY REFERENCE INSTRUCTIONS (Continued) |  |  |  |  |  |



Note 1: The JP instruction allows a jump, while in subroutine pages 2 or 3 , to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 2: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.

## Description of Selected

## Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP410C/411C programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register). If SIO is selected as a shift register, an XAS instruction must be performed once every four instruction cycle times to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M . It loads the lower eight bits of the ROM address register PC with the contents of ROM addressed by the 9 -bit word, $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{8}$ is not affected by this instruction.
Note: JID uses two instruction cycles if executed, one if skipped.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 9 -bit word $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}$. LQID can be used for table look-up or code conversion such as BCD to 7 -segment. The LQID instruction "pushes" the stack (PC $+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB}$ ) and replaces the least significant eight bits of the PC as follows: $\mathrm{A} \rightarrow \mathrm{PC}_{7: 4}$, RAM $(B) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the Q latches. Next, the stack is "popped" (SB $\rightarrow$ SA $\rightarrow$ PC ), restoring the saved value of the PC to continue sequential program execution. Since LQID pushes SA $\rightarrow$ $S B$, the previous contents of $S B$ are lost.
Note: LQID uses two instruction cycles if executed, one if skipped.

## INSTRUCTION SET NOTES

a. The first word of a COP410C/411C program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths take the same number of cycle times whether instructions are skipped or executed (except JID and LQID).
c. The ROM is organized into eight pages of 64 words each. The program counter is a 9 -bit binary counter, and will count through page boundaries. If a JP, JSRP, JID, or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: A JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word in page 3 or 7 will access data in the next group of four pages.

## POWER DISSIPATION

The lowest power drain is when the clock is stopped. As the frequency increases so does current. Current is also lower at lower operating voltages. Therefore, to minimize power consumption, the user should run at the lowest speed and voltage that his application will allow. The user should take care that all pins swing to full supply levels to ensure that outputs are not loaded down and that inputs are not at some intermediate level which may draw current. Any input with a slow rise or fall time will draw additional current. A crystal- or resonator-generated clock will draw additional current. An RC oscillator will draw even more current since the input is a slow rising signal.
If using an external squarewave oscillator, the following equation can be used to calculate the COP410C current drain.

$$
\begin{gathered}
\text { Ic }=\mathrm{Iq}+(\mathrm{V} \times 20 \times \mathrm{Fi})+(\mathrm{V} \times 1280 \times \mathrm{FI} / \mathrm{Dv}) \\
\text { where } \mathrm{Ic}=\text { chip current drain in microamps } \\
\mathrm{Iq}=\text { quiescent leakage current (from curve) } \\
\mathrm{FI}=\mathrm{CKI} \text { frequency in megahertz } \\
\mathrm{V}=\text { chip } \mathrm{V}_{\mathrm{CC}} \text { in volts } \\
\mathrm{Dv}=\text { divide by option selected }
\end{gathered}
$$

For example, at $5 \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}$ and 400 kHz (divide by 4),

$$
\begin{aligned}
& \text { Ic }=10+(5 \times 20 \times 0.4)+(5 \times 1280 \times 0.4 / 4) \\
& \text { lc }=10+40+640=690 \mu \mathrm{~A}
\end{aligned}
$$

## I/O OPTIONS

COP410C/411C outputs have the following optional configurations, illustrated in Figure 7:
a. Standard. A CMOS push-pull buffer with an N-channel device to ground in conjunction with a P-channel device to $\mathrm{V}_{\mathrm{CC}}$, compatible with CMOS and LSTTL.
b. Low Current. This is the same configuration as (a) above except that the sourcing current is much less.
c. Open Drain. An N-channel device to ground only, allowing external pull-up as required by the user's application.
d. Standard TRI-STATE L Output. A CMOS output buffer similar to (a) which may be disabled by program control.
e. Low-Current TRI-STATE L Output. This is the same as (d) above except that the sourcing current is much less.
f. Open-Drain TRI-STATE L Output. This has the N-channel device to ground only.
The SI and $\overline{\text { RESET }}$ inputs are $\mathrm{Hi}-\mathrm{Z}$ inputs (Figure 7 g ).
When using either the G or LI/O ports as inputs, a pull-up device is necessary. This can be an external device or the following alternative is available: Select the low-current output option. Now, by setting the output registers to a logic " 1 " level, the P-channel devices will act as the pull-up load. Note that when using the $L$ ports in this fashion, the $Q$ registers must be set to a logic " 1 " level and the $L$ drivers must be enabled by an LEl instruction.

Functional Description (Continued)

a. Standard Push-Pull Output

b. Low Current Push-Pull Output

c. Open Drain Output

d. Standard TRI-STATE "L" Output

e. Low Current TRI-STATE "L"' Output

g. Hi-Z Input

FIGURE 7. I/O Configurations

Typical Performance Characteristics




TL/DD/5015-10
FIGURE 8

All output drivers uses one or more of three common devices numbered 1 to 3 . Minimum and maximum current (IOUT and $V_{\text {OUT }}$ ) curves are given in Figure 8 for each of these devices to allow the designer to effectively use these I/O configurations.

## Option List

The COP410C/411C mask-programmable options are assigned numbers which correspond with the COP410C pins. The following is a list of COP410C options. When specifying a COP411 chip, options 20, 21, and 22 must be set to 0 . The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
Option 1: $\quad 0=$ Ground Pin. No options available.
Option 2: CKO I/O Port Determined by Option 3.
Option 3: CKI Input.
$=0$ : Crystal-controlled oscillator input ( $\div 4$ ).
$=1$ : Single-pin RC-controlled oscillator $(\div 4)$.
$=2$ : External oscillator input $(\div 4)$.
$=3$. Crystai oscillator input $(\div 8)$.
$=4$ : External oscillator input $(\div 8)$.
$=5$ : Crystal oscillator input $(\div 16)$.
$=6$ : External oscillator input $(\div 16)$.
Option 4: $\overline{\text { RESET }}$ Input $=1: \mathrm{Hi}-\mathrm{Z}$ input. No option available.
Option 5: L.7 Driver
$=0$ : Standard TRI-STATE push-pull output.
$=1$ : Low-current TRI-STATE push-pull output.
= 2: Open-drain TRI-STATE output.
Option 6: $\quad L_{6}$ Driver. (Same as Option 5.)
Option 7: $\quad \mathrm{L}_{5}$ Driver. (Same as Option 5.)

Option 8: $\quad L_{4}$ Driver. (Same as Option 5.)
Option 9: $\quad V_{C C}$ Pin $=0$ no option.
Option 10: L3 Driver. (Same as Option 5.)
Option 11: $\mathrm{L}_{2}$ Driver. (Same as Option 5.)
Option 12: $L_{1}$ Driver. (Same as Option 5.)
Option 13: $L_{0}$ Driver. (Same as Option 5.)
Option 14: SI Input.
No option available.
= 1: Hi-Z input.
Option 15: SO Output.
$=0$ : Standard push-pull output.
= 1: Low-current push-pull output.
$=2$ : Open-drain output.
Option 16: SK Driver. (Same as Option 15.)
Option 17: $\mathrm{G}_{0}$ I/O Port. (Same as Option 15.)
Option 18: $\mathrm{G}_{1}$ l/O Port. (Same as Option 15.)
Option 19: $\mathrm{G}_{2}$ l/O Port. (Same as Option 15.)
Option 20: $\mathrm{G}_{3}$ I/O Port. (Same as Option 15.)
Option 21: $\mathrm{D}_{3}$ Output. (Same as Option 15.)
Option 22: $\mathrm{D}_{2}$ Output. (Same as Option 15.)
Option 23: $\mathrm{D}_{1}$ Output. (Same as Option 15.)
Option 24: $\mathrm{D}_{0}$ Output. (Same as Option 15.)
Option 25: Internal Initialization Logic.
$=0$ : Normal operation.
$=1$ : No internal initialization logic.
Option 26: No option available.
Option 27: COP Bonding
= 0: COP410C (24-pin device).
$=1:$ COP411C (20-pin device). See note.
$=2:$ COP410C and COP411C. See note.
Note: If opt. \#27 = 1 or 2 then opt $\# 20$ must $=0$.

## Option Table

Please fill out a photocopy of the option table and send it along with your EPROM.

## Option Table

| Option 1 Value = | 0 | is: Ground Pin |
| :---: | :---: | :---: |
| Option 2 Value $=$ | 0 | is: CKO Pin |
| Option 3 Value = |  | is: CKI Input |
| Option 4 Value $=$ | 1 | is: $\overline{\text { RESET }}$ Input |
| Option 5 Value $=$ |  | is: $L_{7}$ Driver |
| Option 6 Value $=$ |  | is: $L_{6}$ Driver |
| Option 7 Value = |  | is: $L_{5}$ Driver |
| Option 8 Value $=$ |  | is: $L_{4}$ Driver |
| Option 9 Value | 0 | is: $\mathrm{V}_{\mathrm{Cc}}$ Pin |
| Option 10 Value $=$ |  | is: $L_{3}$ Driver |
| Option 11 Value $=$ |  | is: $L_{2}$ Driver |
| Option 12 Value $=$ |  | is: $L_{1}$ Driver |
| Option 13 Value $=$ |  | is: $L_{0}$ Driver |
| Option 14 Value $=$ | 1 | is: SI Input |


| Option 15 Value |  | is: SO Output |
| :---: | :---: | :---: |
| Option 16 Value $=$ |  |  |
| Option 17 Value = |  | is: $\mathrm{G}_{0}$ I/O Port |
| Option 18 Value $=$ |  | is: $\mathrm{G}_{1}$ I/O Port |
| Option 19 Value $=$ |  | is: $\mathrm{G}_{2}$ I/O Port |
| Option 20 Value $=$ |  | is: $G_{3} 1 / O$ Port |
| Option 21 Value = |  | is: $D_{3}$ Output |
| Option 22 Value = |  | is: $D_{2}$ Output |
| Option 23 Value = |  | is: $D_{1}$ Output |
| Option 24 Value = |  | is: $D_{0}$ Output |
| Option 25 Value $=$ |  | is: Internal |
|  |  | Initialization |
| Option 26 Value $=$ | 0 | is: $\mathrm{N} / \mathrm{A}$ |
| Option 27 Value $=$ |  | P |

## COP410L/COP411L/COP310L/COP311L Single-Chip N-Channel Microcontrollers

## General Description

The COP410L and COP411L Single-Chip N-Channel Microcontrollers are members of the COPSTM family, fabricated using N-channel, silicon gate MOS technology. These Controller Oriented Processors are complete microcomputers containing all system timing, internal logic, ROM, RAM and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture and I/O scheme designed to facilitate keyboard input, display output and BCD data manipulation. The COP411L is identical to the COP410L, but with 16 I/O lines instead of 19. They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized Controller Oriented Processor at a low end-product cost.
The COP310L and COP311L are exact functional equivalents but extended temperature versions of COP410L and COP411L respectively.

Features

- Low cost
- Powerful instruction set
- $512 \times 8$ ROM, $32 \times 4$ RAM
- 19 I/O lines (COP410L)

■ Two-level subroutine stack

- $16 \mu$ s instruction time

■ Single supply operation ( $4.5 \mathrm{~V}-6.3 \mathrm{~V}$ )

- Low current drain ( 6 mA max)
- Internal binary counter register with MICROWIRETM serial I/O capability
- General purpose and TRI-STATE® outputs
- LSTTL/CMOS compatible in and out
- Direct drive of LED digit and segment lines
- Software/hardware compatible with other members of COP400 family
- Extended temperature range device
- COP310L/COP311L ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
- Wider supply range ( $4.5 \mathrm{~V}-9.5 \mathrm{~V}$ ) optionally available

Block Diagram


## COP410L/COP411L

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated rellability electrical test speclfications document.
Voltage at Any Pin Relative to GND
Ambient Operating Temperature
Ambient Storage Temperature
Lead Temperature
(Soldering, 10 seconds) $300^{\circ} \mathrm{C}$

Power Dissipation COP410L
0.75 W at $25^{\circ} \mathrm{C}$ 0.4 W at $70^{\circ} \mathrm{C}$

COP411L
0.65 W at $25^{\circ} \mathrm{C}$ 0.3 W at $70^{\circ} \mathrm{C}$

Total Source Current 120 mA Total Sink Current 100 mA
Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted


Note 1: $\mathrm{V}_{\mathrm{CC}}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: SO output " 0 " level must be less than 0.8 V for normal operation.
Note 3: TRI-STATE* and LED configurations are excluded.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ uniess otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels |  |  |  |  |
| Output Sink Current |  |  |  |  |
| SO and SK Outputs (loL) | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 1.8 |  | mA |
|  | $\mathrm{V}_{\text {CC }}=6.3 \mathrm{~V}, \mathrm{~V}_{\text {OL }}=0.4 \mathrm{~V}$ | 1.2 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.9 |  | mA |
| $L_{0}-L_{7}$ Outputs, $G_{0}-G_{3}$ and | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
| LSTTL $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs ( $\mathrm{l}_{\mathrm{L}}$ ) | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
| $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with High | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 15 |  | mA |
| Current Options (loL) | $\mathrm{V}_{\text {CC }}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 11 |  | mA |
|  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OL }}=1.0 \mathrm{~V}$ | 7.5 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 30 |  | mA |
| High Current Options (loL) | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 22 |  | mA |
|  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OL }}=1.0 \mathrm{~V}$ | 15 |  | mA |
| CKI (Single-Pin RC Oscillator) | $V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{H}}=3.5 \mathrm{~V}$ | 2 |  | mA |
| CKO | $\mathrm{V}_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OL }}=0.4 \mathrm{~V}$ | 0.2 |  | mA |
| Output Source Current |  |  |  |  |
| Standard Configuration, | $V_{\text {CC }}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -140 | -800 | $\mu \mathrm{A}$ |
| All Outputs (lor) | $\mathrm{V}_{\text {CC }}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -75 | -480 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -30 | -250 | $\mu \mathrm{A}$ |
| Push-Pull Configuration | $V_{C C}=9.5 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=4.75 \mathrm{~V}$ | -1.4 |  | mA |
| SO and SK Outputs ( $\mathrm{IOH}^{(1)}$ | $V_{\text {CC }}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ | -1.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V}$ | -1.2 |  | mA |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -1.5 | -18 | mA |
| Outputs, Low Current Driver Option (loH) | $\mathrm{V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -1.5 | -13 | mA |
| LED Configuration |  |  |  |  |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High Current | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ $\mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -3.0 -3.0 | $\begin{aligned} & -35 \\ & -25 \end{aligned}$ | $\mathrm{mA}$ |
| Driver Option ( IOH ) | $\mathrm{VCC}=6.0 \mathrm{~V}, \mathrm{VOH}=2.0 \mathrm{~V}$ | -3.0 | -25 | mA |
| TRI-STATE Configuration, | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ | -0.75 |  | mA |
| Lo-L7 Outputs, Low | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.2 \mathrm{~V}$ | -0.8 |  | mA |
| Current Driver Option ( $\mathrm{l}^{\mathrm{OH}}$ ) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}$ | -0.9 |  | mA |
| TRI-STATE Configuration, | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ | -1.5 |  | mA |
| $\mathrm{L}_{0} \mathrm{~L}_{7}$ Outputs, High | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.2 \mathrm{~V}$ | -1.6 |  | mA |
| Current Driver Option ( $\mathrm{l}^{\mathrm{OH}}$ ) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}$ | -1.8 |  | mA |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}$ | -10 | -140 | $\mu \mathrm{A}$ |
| CKO Output |  |  |  |  |
| RAM Power Supply Option Power Requirement | $\mathrm{V}_{\mathrm{R}}=3.3 \mathrm{~V}$ |  | 1.5 | mA |
| TRI-STATE Output Leakage Current |  | -2.5 | +2.5 | $\mu \mathrm{A}$ |
| Total Sink Current Allowed |  |  |  |  |
| All Outputs Combined |  |  | 100 | mA |
| D Port |  |  | 100 | mA |
| L7-L4, G Port |  |  | 4 | mA |
| $L_{3}-L_{0}$ |  |  | 4 | mA |
| Any Other Pin |  |  | 2.0 | mA |
| Total Source Current Allowed |  |  |  |  |
| All I/O Combined |  |  | 120 | mA |
| $\mathrm{L}_{7}-\mathrm{L}_{4}$ |  |  | 60 | mA |
| $\mathrm{L}_{3}-\mathrm{L}_{0}$ |  |  | 60 | mA |
| Each L Pin |  |  | 25 | mA |
| Any Other Pin |  |  | 1.5 | mA |

CKI (Single-Pin RC Oscillator)
Output Source Current Standard Configuration, All Outputs (IOH)

Push-Pull Configuration SO and SK Outputs ( $\left.\mathrm{lOH}^{\mathrm{OH}}\right)$

LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Driver Option (IOH) LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High Current TRI-STATE Configuration, $L_{0}-L_{7}$ Outputs, Low Current Driver Option (lOH) TRI-STATE Configuration, Current Driver Option ( $\mathrm{l}_{\mathrm{OH} \text { ) }}$ Input Load Source Current

## COP310L/COP311L

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin Relative to GND

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+10 \mathrm{~V} \\
-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}
\end{array}
$$

Ambient Operating Temperature
Ambient Storage Temperature
Lead Temperature
(Soldering, 10 seconds)
$300^{\circ} \mathrm{C}$

DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 1) | 4.5 | 5.5 | V |
| Optional Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 | 7.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 8 | mA |
| Input Voltage Levels |  |  |  |  |
| Ceramic Resonator Input ( $\div 8$ ) Crystal Input |  |  |  |  |
| Logic High ( $\mathrm{V}_{\mathbf{I H}}$ ) | $V_{C C}=$ Max | 3.0 |  | V |
| Logic High ( $\mathrm{V}_{1 \mathrm{H}}$ ) | $V_{C C}=5 \mathrm{~V} \pm 5 \%$ | 2.2 |  | $V$ |
| Logic Low (V/L) |  | -0.3 | 0.3 | V |
| Schmitt Trigger Input ( $\div 4$ ) Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) Logic Low (VIL) |  | $\begin{gathered} 0.7 V_{C C} \\ -0.3 \end{gathered}$ | 0.4 | $\begin{aligned} & V \\ & V \end{aligned}$ |
| RESET Input Levels | (Schmitt Trigger Input) |  |  |  |
| Logic High |  | $0.7 \mathrm{~V}_{\text {CC }}$ |  | V |
| Logic Low |  | -0.3 | 0.4 | V |
| SO Input Level (Test Mode) | (Note 2) | 2.2 | 2.5 | V |
| All Other Inputs |  |  |  |  |
| Logic High | $V_{C C}=$ Max | 3.0 |  | V |
| Logic High | With TTL Trip Level Options | 2.2 |  | V |
| Logic Low | Selected, $\mathrm{V}_{\text {CC }}=5 \mathrm{~V} \pm 5 \%$ | -0.3 | 0.6 | V |
| Logic High | With High Trip Level Options | 3.6 |  | V |
| Logic Low | Selected | -0.3 | 1.2 | V |
| Input Capacitance |  |  | 7 | pF |
| Hi Z I Input Leakage |  | -2 | $+2$ | $\mu \mathrm{A}$ |
| Output Voltage Levels |  |  |  | - |
| LSTTL Operation | $V_{C C}=5 \mathrm{~V} \pm 10 \%$ |  |  |  |
| Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) <br> Logic Low (VO) | $\mathrm{IOH}=-20 \mu \mathrm{~A}$ $\mathrm{I}^{\prime}=0.36 \mathrm{~mA}$ | 2.7 |  | v |
| Logic Low (VOL) | $\mathrm{OL}=0.36 \mathrm{~mA}$ |  | 0.4 | V |
| CMOS Operation (Note 3) |  |  |  |  |
| Logic High Logic Low | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-1$ | 0.2 | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ |

Note 1: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: SO output " 0 " level must be less than 0.6 V for normal operation.
Note 3: TRI-STATE and LED configurations are excluded.

## COP310L/COP311L

DC Electrical Characteristics (Continued)
$-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless othewise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels |  |  |  |  |
| Output Sink Current |  |  |  |  |
| SO and SK Outputs (loL) | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 1.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 1.0 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.8 |  | mA |
| $L_{0}-L_{7}$ Outputs, $G_{0}-G_{3}$ and | $\mathrm{V}_{\text {CC }}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
| LSTTL $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs ( $\mathrm{l}_{\text {OL }}$ ) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
| $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with High | $\mathrm{V}_{\text {CC }}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 12 |  | mA |
| Current Options (loL) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 9 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 7 |  | mA |
| $D_{0}-D_{3}$ Outputs with Very | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 24 |  | mA |
| High Current Options (lol) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 18 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 14 |  | mA |
| CKI (Single-Pin RC Oscillator) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {IH }}=3.5 \mathrm{~V}$ | 1.5 |  | mA |
| CKO | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.2 |  | mA |
| Output Source Current |  |  |  |  |
| Standard Configuration, | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -100 | -900 | $\mu \mathrm{A}$ |
| All Outputs (l) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -55 | -600 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -28 | -350 | $\mu \mathrm{A}$ |
| Push-Pull Configuration | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.75 \mathrm{~V}$ | -0.85 |  | mA |
| SO and SK Outputs (IOH) | $V_{\text {CC }}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=2.0 \mathrm{~V}$ | -1.1 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V}$ | -1.2 |  | mA |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -1.4 | -27 | mA |
| Outputs, Low Current Driver Option ( $\mathrm{l}_{\mathrm{OH} \text { ) }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -0.7 | -15 | $\mu \mathrm{A}$ |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -2.7 | -54 | mA |
| Outputs, High Current | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -1.4 | -30 | $\mu \mathrm{A}$ |
| Driver Option (loh) |  |  |  |  |
| TRI-STATE Configuration, | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.0 \mathrm{~V}$ | -0.7 |  | mA |
| $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, Low | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.7 \mathrm{~V}$ | -0.6 |  | mA |
| Current Driver Option (1OH) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}$ | -0.9 |  | mA |
| TRI-STATE Configuration, | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.0 \mathrm{~V}$ | -1.4 |  | mA |
| $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.7 \mathrm{~V}$ | -1.2 |  | mA |
| Current Driver Option (IOH) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}$ | -1.8 |  | mA |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}$ | -10 | -200 | $\mu \mathrm{A}$ |
| CKO Output RAM Power Supply Option Power Requirement | $V_{\mathrm{R}}=3.3 \mathrm{~V}$ |  | 2.0 | mA |
| TRI-STATE Output Leakage Current |  | -5 | +5 | $\mu \mathrm{A}$ |
| Total Sink Current Allowed |  |  |  |  |
| All Outputs Combined |  |  | 100 | mA |
| D Port |  |  | 100 | mA |
| $\mathrm{L}_{7}-\mathrm{L}_{4}, \mathrm{G}$ Port |  |  | 4 | mA |
| $L_{3}-L_{0}$ |  |  | 4 | mA |
| Any Other Pins |  |  | 1.5 | mA |
| Total Source Current Allowed |  |  |  |  |
| All I/O Combined |  |  | 120 | mA |
| $\mathrm{L}_{7}-\mathrm{L}_{4}$ |  |  | 60 | mA |
| $L_{3}-L_{0}$ |  |  | 60 | mA |
| Each L Pin |  |  | 25 | mA |
| Any Other Pins |  |  | 1.5 | mA |

## AC Electrical Characteristics

COP410L/411L: $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted
COP310L/311L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time - $\mathrm{t}_{\mathrm{C}}$ CKI |  | 16 | 40 | $\mu \mathrm{S}$ |
| Input Frequency - $f_{l}$ | $\begin{aligned} & \div 8 \text { Mode } \\ & \div 4 \text { Mode } \end{aligned}$ | $\begin{aligned} & 0.2 \\ & 0.1 \end{aligned}$ | $\begin{gathered} 0.5 \\ 0.25 \end{gathered}$ | $\mathrm{MHz}$ $\mathrm{MHz}$ |
| Duty Cycle |  | 30 | 60 | \% |
| Rise Time | $\mathrm{f}_{\mathrm{l}}=0.5 \mathrm{MHz}$ |  | 500 | ns |
| Fall Time |  |  | 200 | ns |
| $\text { CKI Using RC }(\div 4)$ (Note 1) | $\begin{aligned} & R=56 \mathrm{k} \Omega \pm 5 \% \\ & \mathrm{C}=100 \mathrm{pF} \pm 10 \% \end{aligned}$ |  |  |  |
| Instruction Cycle Time |  | 16 | 28 | $\mu \mathrm{S}$ |
| CKO as SYNC Input tSYnc |  | $400$ |  |  |
| INPUTS |  |  |  |  |
| $\begin{aligned} & \mathrm{G}_{3}-\mathrm{G}_{0,} \mathrm{~L}_{7}-\mathrm{L}_{0} \\ & \mathrm{t}_{\text {SETUP }} \\ & \mathrm{t}_{\text {HOLD }} \end{aligned}$ |  | $\begin{aligned} & 8.0 \\ & 1.3 \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| SI |  |  |  |  |
| tsetup <br> tHOLD |  | $2.0$ |  | $\mu \mathbf{s}$ |
| OUTPUT PROPAGATION DELAY | Test Condition: $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V}$ |  |  |  |
| SO, SK Outputs $t_{p d 1}, t_{p d 0}$ |  |  | 4.0 | $\mu \mathrm{S}$ |
| All Other Outputs $\mathrm{t}_{\mathrm{pd1}}, \mathrm{t}_{\mathrm{pdo}}$ |  |  | 5.6 | $\mu \mathrm{s}$ |

Note 1: Variation due to the device included.

## Connection Diagrams



Top View
Order Number COP310L-XXX/M, COP310L-XXX/N COP4 10L-XXX/M, COP410L-XXX/N See NS Package Number N24A or M24B

Dual-In-Line Package


TL/DD/6919-3

Top Vlew
Order Number COP311L-XXX/M, COP311L-XXX/N
COP411L-XXX/M, COP411L-XXX/N
See NS Package Number N20A or M20B

FIGURE 2

## Pin Descriptions

| Pin | Description | Pin | Description |
| :--- | :--- | :--- | :--- |
| $L_{7}-L_{0}$ | 8 bidirectional I/O ports with TRI-STATE | CKI | System oscillator input |
| $G_{3}-G_{0}$ | 4 bidirectional I/O ports $\left(G_{2}-G_{0}\right.$ for COP411L) | CKO | System oscillator output (or RAM power supply or |
| $D_{3}-D_{0}$ | 4 general purpose outputs $\left(D_{1}-D_{0}\right.$ for COP411L) |  | SYNC input) (COP410L only) |
| SI | Serial input (or counter input) | RESET | System reset input |
| SO | Serial output (or general purpose output) | VCC | Power supply |
| SK | Logic-controlled clock (or general purpose output) | GND | Ground |

## Timing Diagrams



FIGURE 3. Input/Output Timing Diagrams (Ceramic Resonator Divide-by-8 Mode)


TL/DD/6919-5
FIGURE 3a. Synchronization Timing

## Functional Description

A block diagram of the COP410L is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).
All functional references to the COP410L/COP411L also apply to the COP310L/COP311L.

## PROGRAM MEMORY

Program Memory consists of a 512-byte ROM. As can be seen by an examination of the COP410L/411L instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 8 pages of 64 words each.
ROM addressing is accomplished by a 9 -bit PC register. Its binary value selects one of the 5128 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 9 -bit binary count value. Two levels of subroutine nesting are implemented by the 9 -bit subroutine save registers, SA and SB, providing a last-in, first-out (LIFO) hardware subroutine stack.

ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 128-bit RAM, organized as 4 data registers of 84 -bit digits. RAM addressing is implemented by a 6 -bit B register whose upper 2 bits ( Br ) select 1 of 4 data registers and lower 3 bits of the 4 -bit Bd select 1 of 84 -bit digits in the selected data register. While the 4 -bit contents of the selected RAM digit (M) is usually loaded into or from, or exchanged with, the A register (accumulator), it
may also be loaded into the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the XAD 3,15 instruction. The Bd register also serves as a source register for 4 -bit data sent directly to the D outputs. The most significant bit of Bd is not used to select a RAM digit. Hence each physical digit of RAM may be selected by two different values of Bd as shown in Figure 4 below. The skip condition for XIS and XDS instructions will be true if Bd changes between 0 and 15, but NOT between 7 and 8 (see Table III).


TL/DD/6919-6
FIGURE 4. RAM Digit Address to Physical RAM Digit Mapping

## Functional Description (Continued)

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Bd portion of the $B$ register, to load 4 bits of the 8 -bit $Q$ latch data, to input 4 bits of the 8 -bit L I/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions of the COP410L/411L, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.)
The $G$ register contents are outputs to 4 general-purpose bidirectional I/O ports.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are output to the L I/O ports when the L drivers are enabled under program control. (See LEl instruction.)
The 8 L drivers, when enabled, output the contents of latched $Q$ data to the L I/O ports. Also, the contents of $L$ may be read directly into A and M. L I/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with Q data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with A , allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers.
The XAS instruction copies C into the SKL Latch. In the counter mode, SK is the output of SKL in the shift register mode, SK outputs SKL ANDed with internal instruction cycle clock.
The EN register is an internal 4-bit register loaded under program control by the LEl instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $\mathrm{EN}_{3}-\mathrm{EN}_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4-bit binary counter. With $\mathrm{EN}_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon
each low-going pulse (" 1 " to " 0 ") occurring on the S input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. $\mathrm{EN}_{1}$ is not used. It has no effect on COP410L/COP411L operation.
3. With $E N_{2}$ set, the L drivers are enabled to output the data in $Q$ to the L I/O ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high-impedance input state.
4. $E N_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $\mathrm{EN}_{3}$. With $\mathrm{EN}_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ." Table I provides a summary of the modes associated with $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the RESET pin as shown below (Figure 5). The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to $\mathrm{V}_{\mathrm{CC}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.


RC $\geq 5 \times$ Power Supply Rise Time TL/DD/6919-7
FIGURE 5. Power-Up Clear Circuit

TABLE 1. Enable Register Modes-Bits EN ${ }_{3}$ and $E N_{0}$

| $\mathrm{EN}_{3}$ | $\mathrm{EN}_{0}$ | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | If $\mathrm{SKL}=1, \mathrm{SK}=$ Clock |
|  |  |  |  |  | If SKL $=0, \mathrm{SK}=0$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | If SKL $=1, S K=$ Clock |
|  |  |  |  |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | If SKL $=1, \mathrm{SK}=1$ |
|  |  |  |  |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | If $\mathrm{SKL}=1, \mathrm{SK}=1$ |
|  |  |  |  |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |

## Functional Description (Continued)

Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N$, and G registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.

Ceramic Resonator Oscillator

| Resonator <br> Value | Components Values |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | R1 $(\Omega)$ | R2 $(\Omega)$ | $\mathbf{C 1}(\mathbf{p F})$ | $\mathbf{C 2}(\mathrm{pF})$ |
| 455 kHz | 4.7 k | 1 M | 220 | 220 |

RC Controlled Oscillator

| $\mathbf{R ( k \Omega )}$ | $\mathbf{C}(\mathbf{p F})$ | Instruction <br> Cycle Time <br> in $\mu \mathbf{s}$ |
| :---: | :---: | :---: |
| 51 | 100 | $19 \pm 15 \%$ |
| 82 | 56 | $10 \pm 13 \%$ |

Note: $200 \mathrm{k} \Omega \geq \mathrm{R} \geq 25 \mathrm{k} \Omega$. $360 \mathrm{pF} \geq \mathrm{C} \geq 50 \mathrm{pF}$. Does not include tolerances.
FIGURE 6. COP410L/411L Oscillator

## OSCILLATOR

There are three basic clock oscillator configurations available as shown by Figure 6.
a. Resonator Controlled Oscillator. CKI and CKO are connected to an external ceramic resonator. The instruction cycle frequency equals the resonator frequency divided by 8 . This is not available in the COP411L.
b. External Oscillator. CKI is an external clock input signal. The external frequency is divided by 8 to give the instruction frequency time. CKO is now available to be used as the RAM power supply $\left(V_{R}\right)$, or no connection.
Note: No CKO on COP411L.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is available as the RAM power supply ( $\mathrm{V}_{\mathrm{R}}$ ) or no connection.

## CKO PIN OPTIONS

In a resonator controlled oscillator system, CKO is used as an output to the resonator network. As an option, CKO can be a RAM power supply pin $\left(\mathrm{V}_{\mathrm{R}}\right)$, allowing its connection to a standby/backup power supply to maintain the integrity of RAM data with minimum power drain when the main supply is inoperative or shut down to conserve power. Using no connection option is appropriate in applications where the COP410L system timing configuration does not require use of the CKO pin.

## RAM KEEP-ALIVE OPTION

Selecting CKO as the RAM power supply ( $\mathrm{V}_{\mathrm{R}}$ ) allows the user to shut off the chip power supply ( $\mathrm{V}_{\mathrm{CC}}$ ) and maintain data in the RAM. To insure that RAM data integrity is maintained, the following conditions must be met:

1. $\overline{\text { RESET }}$ must go low before $V_{C C}$ goes below spec during power-off; $V_{C C}$ must be within spec before RESET goes high on power-up.
2. During normal operation, $V_{R}$ must be within the operating range of the chip with $\left(V_{C C}-1\right) \leq V_{R} \leq V_{C C}$.
3. $V_{\mathrm{R}}$ must be $\geq 3.3 \mathrm{~V}$ with $\mathrm{V}_{\mathrm{CC}}$ off.

## I/O OPTIONS

COP410L/411L inputs and outputs have the following optional configurations, illustrated in Figure 7:
a. Standard-an enhancement-mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with LSTTL and CMOS input requirements. Available on SO, SK, and all D and G outputs.
b. Open-Drain-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. Available on SO, SK, and all D and G outputs.
c. Push-Pull-an enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{Cc}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. Available on SO and SK outputs only.
d. Standard L-same as a., but may be disabled. Available on $L$ outputs only.
e. Open Drain L-same as b., but may be disabled. Available on $L$ outputs only.
f. LED Direct Drive-an enhancement mode device to ground and to $V_{C C}$, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (see Functional Description, EN Register), placing the outputs in a high-impedance state to provide required LED segment blanking for a multiplexed display. Available on L outputs only.
g. TRI-STATE Push-Pull-an enhancement-mode device to ground and $\mathrm{V}_{\mathrm{CC}}$. These outputs are TRI-STATE outputs, allowing for connection of these outputs to a data bus shared by other bus drivers. Available on $L$ outputs only.

## Functional Description (Continued)

$h$. An on-chip depletion load device to $V_{\text {Cc }}$.
i. A Hi-Z input which must be driven to a " 1 " or " 0 " by external components.
The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6, respectively). Minimum and maximum current (IOUT and $V_{\text {OUT }}$ ) curves are given in Figure 8 for each of these devices to allow the designer to effectively use these I/O configurations in designing a COP410L/411L system.
The SO, SK outputs can be configured as shown in a., b., or c. The D and G outputs can be configured as shown in a . or b. Note that when inputting data to the G ports, the G outputs should be set to " 1 ". The L outputs can be configured as in d., e., f., or g.

An important point to remember if using configuration $\mathbf{d}$. or $f$. with the $L$ drivers is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current. (See Figure 8, device 2.) However, when the $L$ port is used as input, the disabled depletion device CANNOT be relied on to source sufficient current to pull an input to a logic " 1 ".

## COP411L

If the COP410L is bonded as a 20 -pin device, it becomes the COP411L, illustrated in Figure 2, COP410L/411L Connection Diagrams. Note that the COP411L does not contain D2, D3, G3, or CKO. Use of this option of course precludes use of D2, D3, G3, and CKO options. All other options are available for the COP411L.

b. Open-Drain Output

TL/DD/6919-10
e. Open-Drain L Output

f. LED (L Output)

h. Input with Load

i. Hi-Z Input


TL/DD/6919-17
c. Push-Pull Output

g. TRI-STATE Push-Pull (L Output)
d. Standard L Output


FIGURE 7. Input and Output Configurations

## Typical Performance Characteristics



Source Current for SO and SK in Push-Pull Configuration
 AND \#3

LED Output Source Current (for High Current LED Option)

LED Output Source Current (for Low Current LED Option)


Source Current for Standard Output Configuration


TL/DD/6919-18

Source Current for LO through L7 in TRI-STATE Configuration (Low Current Option)


TL/DD/6919-19

LED Output Direct Segment and Direct Drive High Current Options on L0-L7 Very High Current Options on D0-D3


TL/DD/6919-20

Typical Performance Characteristics (Continued)


LED Output Direct Segment Drive

Output Sink Current for SO and SK


Output Sink Current for LO-L7 and Standard Drive Option for D0-D3 and G0-G3



FIGURE 8a. COP410L/COP411L I/O DC Current Characteristics (Continued)

Typical Performance Characteristics (Continued)


Source Current for SO and SK in Push-Pull Configuration


LED Output Source Current (for Low Current LED Option)


Output Sink Current for LO-L7 and Standard Drive Option for D0-D3 and G0-G3


Volvolts)


Source Current for L0-L7 In TRI-STATE Configuration (High Current Option)


LED Output Source Current (for High Current LED Option)


Output Sink Current for D0-D3 with Very High Current Optlon


Volvolts)


Source Current for L0-L7 in TRI-STATE Configuration (Low Current Option)
 Output SInk Current for SO and SK


Volvolts)
Output Sink Current
for D0-D3 (for
High Current Option)

volvolts)
TL/DD/6919-23

## COP410L/411L Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table III provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with each instruction in the COP410L/411L instruction set.

TABLE II. COP410L/411L Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| PC | 9-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| SA | 9-bit Subroutine Save Register A |
| SB | 9-bit Subroutine Save Register B |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |

Symbol Definition
INSTRUCTION OPERAND SYMBOLS
\(\left.$$
\begin{array}{ll}\text { d } & \begin{array}{l}\text { 4-bit Operand Field, } 0-15 \text { binary (RAM Digit Select) } \\
r\end{array}
$$ <br>

\& 2-bit Operand Field, 0-3 binary (RAM Register\end{array}\right]\)| Select) |
| :--- | :--- |

## OPERATIONAL SYMBOLS

$+\quad$ Plus
$-\quad$ Minus
$\rightarrow \quad$ Replaces
$\longleftrightarrow \quad$ Is exchanged with
$=$ Is equal to
$\bar{A} \quad$ The one's complement of $A$
$\oplus \quad$ Exclusive-OR
: $\quad$ Range of values

TABLE III. COP410L/411L Instruction Set

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 10011)0000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 0011 0001 ] | $A+R A M(B) \rightarrow A$ | None | Add RAM to A |
| AISC | y | 5- | 0101\| y | $A+y \rightarrow A$ | Carry | Add Immediate, Skip on Carry ( $\mathrm{y} \neq 0$ ) |
| CLRA |  | 00 | 10000 0000 | $0 \rightarrow A$ | None | Clear A |
| COMP |  | 40 | 010010000) | $\overline{\mathrm{A}} \rightarrow \mathrm{A}$ | None | One's complement of A to A |
| NOP |  | 44 | $0100\|0100\|$ | None | None | No Operation |
| RC |  | 32 | $0011 \mid 0010$ | $" 0$ " $\rightarrow$ C | None | Reset C |
| SC |  | 22 | 0010\|0010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | 000010010 | $A \oplus \operatorname{RAM}(\mathrm{~B}) \rightarrow \mathrm{A}$ | None | Exclusive-OR RAM with A |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE III. COP410L/411L Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | 111111111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 2) |
| JMP | a | 6- | $\begin{gathered} 0110\|000\| a_{8} \\ \hline a_{7: 0} \\ \hline \end{gathered}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  |  | $a \rightarrow P C_{6: 0}$ $a \rightarrow P C_{5: 0}$ | None | Jump within Page (Note 3) |
| JSRP | a | -- | [10) $\mathrm{a}_{5: 0}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 4) |
| JSR | a | $6-$ | $\begin{array}{\|l\|l\|l\|l\|} \hline 0110\|100\| a_{8} \mid \\ \hline & a_{7: 0} \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | 0100\|1000 | $S B \rightarrow S A \rightarrow P C$ | None | Return from Subroutine |
| RETSK |  | 49 | 10100\|1001 | $S B \rightarrow S A \rightarrow P C$ | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 3 C | 0011 0011 <br> 0011 $1100 \mid$ | $A \rightarrow Q_{7: 4}$ | None | Copy A, RAM to Q |
| LD | r | -5 | 00\|r|0101 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into $A$, Exclusive-OR Br with r |
| LQID |  | BF | [1011 11111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SA} \rightarrow \mathrm{SB} \end{aligned}$ | None | Load Q Indirect (Note 2) |
| RMB | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 4 C \\ & 45 \\ & 42 \\ & 43 \end{aligned}$ | 0100 1100 <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{array}{ll} 0 & \rightarrow \operatorname{RAM}(B)_{0} \\ 0 & \rightarrow R A M(B)_{1} \\ 0 & \rightarrow \operatorname{RAM}(B)_{2} \\ 0 & \rightarrow \operatorname{RAM}(B)_{3} \end{array}$ | None | Reset RAM Bit |
| SMB | 0 1 2 3 | $4 D$ 47 46 $4 B$ | 0100 1101 <br> 0100 0111 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} 1 & \rightarrow \operatorname{RAM}(B)_{0} \\ 1 & \rightarrow \operatorname{RAM}(B)_{1} \\ 1 & \rightarrow \operatorname{RAM}(B)_{2} \\ 1 & \rightarrow \operatorname{RAM}(B)_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | y | 7- | 01111 y | $\begin{aligned} & y \rightarrow R A M(B) \\ & B d+1 \rightarrow B d \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | r | -6 | $\underline{00\|r 10110\|}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with $A$, Exclusive-OR Br with r |
| XAD | 3,15 | 23 $B F$ | 0010 0011 <br> 1011 1111 | RAM $(3,15) \longleftrightarrow A$ | None | Exchange A with RAM $(3,15)$ |
| XDS | r | -7 | 00\|r|0111 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd, Exclusive-OR Br with $r$ |
| XIS | $r$ | -4 | $\underline{00\|r 10100\|}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with $A$ and Increment Bd Exclusive-OR Br with r |

Instruction Set (Continued)
TABLE III. COP410L/411L Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code <br> (Binary) | Data Flow | Skip Conditions |
| :--- | :--- | :--- | :--- | :--- | :--- | Description

REGISTER REFERENCE INSTRUCTIONS

| CAB |  | 50 | 0101 0000 | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CBA |  | 4E | 0100\|1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d | - - | $\frac{100\|r\|(d-1)}{(d=0,9: 15)}$ | $r, d \rightarrow B$ | Skip until not a LBI | Load B Immediate with r,d (Note 5) |
| LEI | y | $\begin{aligned} & 33 \\ & 6- \end{aligned}$ | $\begin{array}{\|c\|c\|} \hline 0011 & 0011 \\ \hline 0110 & \mathrm{y} \\ \hline \end{array}$ | $y \rightarrow E N$ | None | Load EN Immediate <br> (Note 6) |

TEST INSTRUCTIONS


Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4-bit A register. Note 2: For additional information on the operation of the XAS, JID, and LQID instructions, see below.
Note 3: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 4: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 5: The machine code for the lower 4 bits of the LBI instruction equals the binary value of the " $d$ " data minus 1, e.g., to load the lower four bits of B (Bd) with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal $15\left(1111_{2}\right)$.
Note 6: Machine code for operand field y for LEl instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP410L/411L programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4 -bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 9 -bit word, $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{8}$ is not affected by this instruction.

Note that JID requires 2 instruction cycles to execute.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8 -bit $Q$ register with the contents of ROM pointed to by the 9 -bit word $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}$. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack ( $\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB}$ ) and replaces the least significant 8 bits of PC as follows: A $\rightarrow$ PC ${ }_{i: 4}$, RAM(B) $\rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the Q latches. Next, the stack is "popped" (SB $\rightarrow$ SA $\rightarrow$ PC), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SA $\rightarrow$ SB, the previous contents of SB are lost. Also, when LQID pops the stack, the previously pushed contents of SA are left in SB. The net result is that the contents of SA are placed in SB $(S A \rightarrow S B)$. Note that LQID takes two instruction cycle times to execute.

## INSTRUCTION SET NOTES

a. The first word of a COP410L/411L program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped.
c. The ROM is organized into 8 pages of 64 words each The Program Counter is a 9-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page 3 or 7 will access data in the next group of 4 pages.

## Option List

The COP410L/411L mask-programmable options are assigned numbers which correspond with the COP410L pins.
The following is a list of COP410L options. When specifying a COP411L chip, Option 2 must be set to 3, Options 20, 21, and 22 to 0 . The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
Option $1=0$ : Ground Pin - no options available
Option 2: CKO Output (no option available for COP411L)
$=0$ : Clock output to ceramic resonator
$=1$ : Pin is RAM power supply $\left(\mathrm{V}_{\mathrm{R}}\right)$ input
= 3: No connection
Option 3: CKI Input
= 0: Oscillator input divided by 8 ( 500 kHz max)
= 1: Single-pin RC controlled oscillator divided by 4
= 2: External Schmitt trigger level clock divided by 4
Option 4: $\overline{\text { RESET }}$ Input
= 0: Load device to $V_{C C}$
$=1$ : $\mathrm{Hi}-\mathrm{Z}$ input
Option 5: L7 Driver
$=0$ : Standard output
= 1: Open-drain output
= 2: High current LED direct segment drive output
= 3: High current TRI-STATE push-pull output
= 4: Low-current LED direct segment drive output
= 5: Low-current TRI-STATE push-pull output
Option 6: $\mathrm{L}_{6}$ Driver
same as Option 5
Option 7: L5 Driver same as Option 5
Option 8: L ${ }_{4}$ Driver
same as Option 5
Option 9: Operating voltage

COP41XL
$=0:+4.5 \mathrm{~V}$ to +6.3 V
COP31XL
$=1:+4.5 \mathrm{~V}$ to $+9.5 \mathrm{~V} \quad+4.5 \mathrm{~V}$ to +7.5 V
Option 10: $\mathrm{L}_{3}$ Driver same as Option 5
Option 11: $L_{2}$ Driver same as Option 5
Option 12: $\mathrm{L}_{1}$ Driver same as Option 5
Option 13: $L_{0}$ Driver same as Option 5
Option 14: SI Input $=0$ : load device to $V_{C C}$ = 1: Hi-Z input
Option 15: SO Driver
= 0: Standard Output
$=1$ : Open-drain output
= 2: Push-pull output
Option 16: SK Driver same as Option 15

## Option List (Continued)

Option 17: Go I/O Port
$=0$ : Standard output
= 1: Open-drain output
Option 18: $\mathrm{G}_{1}$ I/O Port same as Option 17
Option 19: $\mathrm{G}_{2}$ I/O Port same as Option 17
Option 20: $\mathrm{G}_{3}$ I/O Port (no option available for COP411L) same as Option 17
Option 21: $\mathrm{D}_{3}$ Output (no option available for COP411L)
$=0:$ Very-high sink current standard output
= 1: Very-high sink current open-drain output
$=2$ : High sink current standard output
$=3$ : High sink current open-drain output
$=4$ : Standard LSTTL output (fanout $=1$ )
$=5$ : Open-drain LSTTL output (fanout $=1$ )
Option 22: $\mathrm{D}_{2}$ Output (no option available for COP411L) same as Option 21
Option 23: $\mathrm{D}_{1}$ Output same as Option 21
Option 24: $\mathrm{D}_{0}$ Output same as Option 21

Option 25: L Input Levels
$=0$ : Standard TTL input levels (" 0 " $=0.8 \mathrm{~V}, " 1$ " $=2.0 \mathrm{~V}$ )
= 1: Higher voltage input levels (" 0 " = $1.2 \mathrm{~V}, " 1 "=3.6 \mathrm{~V}$ )
Option 26: G Input Levels
same as Option 25
Option 27: SI Input Levels same as Option 25
Option 28: COP Bonding
$=0:$ COP410L (24-pin device)
= 1: COP411L (20-pin device)
$=2$ : Both 24- and 20 -pin versions

## TEST MODE (NON-STANDARD OPERATION)

The SO output has been configured to provide for standard test procedures for the custom-programmed COP410L. With SO forced to logic " 1 ", two test modes are provided, depending upon the value of Sl :
a. RAM and Internal Logic Test Mode $(S I=1)$
b. ROM Test Mode ( $\mathrm{SI}=0$ )

These special test modes should not be employed by the user; they are intended for manufacturing test only.

## Option Table

The following option information is to be sent to National along with the EPROM.

|  | Option Data |  |
| :---: | :---: | :---: |
| OPTION | 1 VALUE = | IS: GROUND PIN |
| OPTION | 2 VALUE $=$ | IS: CKO PIN |
| OPTION | 3 VALUE | IS: CKI INPUT |
| OPTION | 4 VALUE | IS: RESET INPUT |
| OPTION | 5 VALUE | IS: L(7) DRIVER |
| OPTION | 6 VALUE $=$ | IS: L(6) DRIVER |
| OPTION | 7 VALUE | IS: L(5) DRIVER |
| OPTION | 8 VALUE | IS: L(4) DRIVER |
| OPTION | 9 VALUE | IS: V $\mathrm{VCC}^{\text {PIN }}$ |
| OPTION | VALUE | IS: L(3) DRIVER |
| OPTION | VALUE | IS: L(2) DRIVER |
| OPTION | VALUE | IS: L(1) DRIVER |
| OPTION | VALUE | IS: L(0) DRIVER |
| OPTION | VALUE | IS: SI INPUT |



## COP413L/COP313L Single Chip Microcontrollers

## General Description

The COP413L and COP313L Single-Chip N-Channel Microcontrollers are members of the COPSTM family, fabricated using N-channel, silicon gate MOS technology. These Control Oriented Processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, 15 I/O lines with an instruction set, internal architecture and I/O scheme designed to facilitate keyboard input, display output and BCD data manipulation. They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable highdensity fabrication techniques provide the medium to large volume customers with a customized Control Oriented Processor at a very low end-product cost.
The COP313L is an exact functional equivalent but extended temperature version of the COP413L.
The COP401L-R13 and COP410L-X13 should be used for exact emulation.

## Features

- Low cost
- Powerful instruction set
- $512 \times 8$ ROM, $32 \times 4$ RAM
- 15 I/O lines
- Two-Level subroutine stack
- $16 \mu \mathrm{~s}$ instruction time
- Single supply operation (4.5V-6.3V)
- Low current drain ( 6 mA max.)
- Internal binary counter register with MICROWIRETM serial I/O capability
- General purpose outputs
- High noise immunity inputs ( $\mathrm{V}_{\mathrm{IL}}=1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.6 \mathrm{~V}$ )
- Software/hardware compatible with other members of COP400 family
- Extended temperature range device COP313L ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )


## Block Diagram



COP413L Absolute Maximum

## Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin Relative to GND
-0.3 to +7 V
Ambient Operating Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Ambient Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temp. (Soldering, 10 seconds)
$300^{\circ} \mathrm{C}$

Power Dissipation COP413L 0.3 Watt at $70^{\circ} \mathrm{C}$ Total Source Current 25 mA Total Sink Current 25 mA
Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage $\left(V_{C C}\right)$ | (Note 1) | 4.5 | 6.3 | V |
| Power Supply Ripple | Peak to Peak |  | 0.4 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 6 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Ceramic Resonator Input ( $\div 8$ ) <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> CKI (RC), Reset Input Levels <br> Logic High <br> Logic Low <br> SO Input Level (Test Mode) <br> SI Input Level <br> Logic High <br> Logic Low <br> L, G Inputs <br> Logic High <br> Logic Low | (Schmitt Trigger Input) <br> (Note 2) <br> (TTL Level) <br> (High Trip Levels) | 3.0 $0.7 V_{C C}$ 2.5 2.0 3.6 | 0.4 <br> 0.6 <br> 0.8 <br> 1.2 | $\begin{aligned} & V \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & V \\ & v \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Reset Input Leakage |  | -1 | +1 | $\mu \mathrm{A}$ |
| Output Current Levels Output Sink Current SO and SK Outputs (loL) L0-L7 Outpùts, G0-G3 CKO (lou) <br> Output Source Current L0-L7 and G0-G3 SO and SK Outputs (IOH) Push-Pull | $\begin{aligned} & \mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 0.9 \\ & 0.4 \\ & 0.2 \\ & -25 \\ & -1.2 \\ & -25 \\ & \hline \end{aligned}$ |  | mA <br> IIIA <br> mA <br> $\mu \mathrm{A}$ <br> mA <br> $\mu \mathrm{A}$ |
| SI Input Load Source Current | $\mathrm{V}_{1 \mathrm{LL}}=0 \mathrm{~V}$ | -10 | -140 | $\mu \mathrm{A}$ |
| ```Total Sink Current Allowed L7-L4, G Port L3-L0 Any Other Pin``` |  |  | $\begin{gathered} 4 \\ 4 \\ 2.0 \end{gathered}$ | mA <br> mA <br> mA |
| Total Source Current Allowed Each Pin |  |  | 1.5 | mA |

Note 1: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: SO output " 0 " level must be less than 0.8 V for normal operation.

## COP313L Absolute Maximum Ratings

Speclfications for Military/Aerospace products are not contalned in this datasheet. Refer to the assoclated rellability electrical test speciflcatlons document.

Voltage at Any Pin Relative to GND
Ambient Operating Temperature
-0.3 to +7 V
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ $300^{\circ} \mathrm{C}$

Power Dissipation COP313L
0.20 Watt at $85^{\circ} \mathrm{C}$

Total Source Current
Total Sink Current 25 mA 25 mA

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise noted.

| Parameter | Condltions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage (VCC) | (Note 1) | 4.5 | 5.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.4 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 8 | mA |
| ```Input Voltage Levels Ceramic Resonator Input ( }\div8\mathrm{ ) Logic High (VIH) Logic Low (VIL) CKI (RC), Reset Input Levels Logic High Logic Low SO Input (Test Mode) SI Input Level Logic High Logic Low L,G Inputs Logic High Logic Low``` | (Schmitt Trigger Input) <br> (Note 2) <br> (TTL Level) <br> (High Trip Levels) | 3.0 $0.7 V_{C C}$ 2.5 2.2 3.6 | 0.3 <br> 0.4 <br> 0.6 <br> 1.2 | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & \hline \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Reset Input Leakage |  | -2 | +2 | $\mu \mathrm{A}$ |
| ```Output Current Levels Output Sink Current SO and SK Outputs (IOL) L0-L7 Outputs, G0-G3 (IoL) CKO (IoL) Output Source Current LO-L7 and G0-G3 SO and SK Outputs ( \(\mathrm{l}_{\mathrm{OH}}\) ) (Push-Pull)``` | $\begin{aligned} & \mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 0.8 \\ & 0.4 \\ & 0.2 \\ & \\ & -23 \\ & -1.0 \\ & -23 \\ & \hline \end{aligned}$ |  | mA <br> mA <br> mA <br> $\mu A$ <br> mA <br> $\mu \mathrm{A}$ |
| Si Input Load Source Current | $\mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}$ | -10 | -200 | $\mu \mathrm{A}$ |
| ```Total Sink Current Allowed L7-L4, G Port L3-LO Any Other Pin``` |  |  | $\begin{gathered} 4 \\ 4 \\ 1.5 \\ \hline \end{gathered}$ | mA <br> mA <br> mA |
| Total Source Current Allowed Each Pin |  |  | 1.5 | mA |

Note 1: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: SO output " 0 " level must be less than 0.6 V for normal operation.

AC Electrical Characteristics cop413L: $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$
COP313L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time - $\mathrm{t}_{\mathrm{c}}$ |  | 16 | 40 | $\mu \mathrm{s}$ |
| CKI <br> Input Frequency - fi <br> Duty Cycle <br> Rise Time <br> Fall Time | $\div 8$ Mode $\mathrm{fi}=0.5 \mathrm{MHz}$ | $\begin{aligned} & 0.2 \\ & 30 \end{aligned}$ | $\begin{gathered} 0.5 \\ 60 \\ 500 \\ 200 \end{gathered}$ | $\begin{gathered} \mathrm{MHz} \\ \% \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \hline \end{gathered}$ |
| CKI Using RC ( $\div 4$ ) <br> Instruction Cycle Time (Note 1) | $\begin{aligned} & R=56 \mathrm{k} \Omega \pm 5 \% \\ & C=100 \mathrm{pF} \pm 10 \% \end{aligned}$ | 16 | 28 | $\mu \mathrm{S}$ |
| Inputs: <br> G3-G0, L7-L0 <br> tsetup <br> thold <br> SI <br> tsetup <br> thold |  |  | $\begin{aligned} & 8.0 \\ & 1.3 \\ & 2.0 \\ & 1.0 \end{aligned}$ | $\mu \mathrm{S}$ $\mu \mathrm{s}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ |
| Output Propagation Delay <br> SO, SK Outputs <br> tpd1, tpd0 <br> All Other Outputs tpd1, tpd0 | Test Condition: $C_{L}=50 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V}$ |  | $4.0$ <br> 5.6 | $\mu \mathrm{s}$ <br> $\mu \mathrm{S}$ |

Note 1: Variation due to the device included.

## Connection Diagram



TL/DD/8371-2
FIGURE 2
Order Number COP313L-XXX/D, COP313LXXX/N or COP413L-XXX/D or COP413L-XXX/N or COP313LXXX/M or COP413L-XXX/M See NS Package Number D20A or N20A

## Pin Descriptions

\left.| Pin | Description |
| :--- | :--- |
| L7-LO | 8-bit bidirectional I/O port |$\right]$| G3-GO | 4-bit bidirectional I/O port |
| :--- | :--- |
| SI | Serial input (or counter <br> input) |
| SO | Serial output (or general <br> purpose output) |
| SK | Logic-controlled clock (or <br> general purpose output) |
| CKI | System oscillator input |
| CKO | System oscillator output or |
|  | NC |
| RESET | System reset input |
| VCC | Power Supply |
| GND | Ground |



FIGURE 3. Input/Output Timin」Diagrams (Ceramic Resonator Divide-by-8 Mode)

## Functional Description

A block diagram of the COP413L is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).
All functional references to the COP413L also apply to the COP313L.

## PROGRAM MEMORY

Program Memory consists of a 512 -byte ROM. As can be seen by an examination of the COP413L instruction set, these words may be program instructions, program data, or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 8 pages of 64 words each.
ROM addressing is accomplished by a 9-bit PC register. Its binary value selects one of the 5128 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 9 -bit binary count value. Two levels of subroutine nesting are implemented by the 9 -bit subroutine save registers, SA and SB, providing a last-in, first out (LIFO) hardware subroutine stack.

ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 128-bit RAM, organized as 4 data registers of 84 -bit digits. RAM addressing is implemented by a 6 -bit B register whose upper 2 bits ( Br ) select 1 of 4 data registers and lower 3 bits of the 4 -bit Bd select 1 of 84 -bit digits in the selected data register. While the 4 -bit contents of the selected RAM digit ( $M$ ) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the XAD 3, 15 instruction.
The most significant bit of Bd is not used to select a RAM digit. Hence each physical digit of RAM may be selected by two different values of Bd as shown in Figure 4 below. The skip condition for XIS and XDS instructions will be true if Bd changes between 0 and 15, but NOT between 7 and 8 (see Table III).

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Bd portion of the $B$ register, to load 4 bits of the 8 -bit $Q$ latch data, to input 4 bits of the 8 -bit LI/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions of the COP413L, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.)
The G register contents are outputs to 4 general purpose bidirectional I/O ports.


TL/DD/8371-4
FIGURE 4. RAM Digit Address to Physical RAM Digit Mapping
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are output to the LI/O ports when the L drivers are enabled under program control. (See LEI instruction.)
The 8 L drivers, when enabled, output the contents of latched $Q$ data to the L I/O ports. Also, the contents of $L$ may be read directly into $A$ and $M$.
The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with A , allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers.
The XAS instruction copies C into the SKL Latch. In the counter mode, SK is the output of SKL in the shift register mode, SK outputs SKL ANDed with internal instruction cycle clock.
The EN register is an internal 4-bit register loaded under program control by the LEl instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $\mathrm{EN}_{3}-\mathrm{EN}_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$ selects the SIO register as either a 4-bit shift register or a 4bit binary counter. With $E N_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting with each instruction cycle time. The data present at SO goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. $E N_{1}$ is not used. It has no effect on COP413L operation.

## Functional Description (Continued)

TABLE I. Enable Register Modes - Bits EN $\mathrm{E}_{3}$ and EN $\mathrm{N}_{0}$

| $\mathrm{EN}_{3}$ | $E N_{0}$ | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift | 0 | If $\mathrm{SKL}=1, \mathrm{SK}=$ Clock |
|  |  |  | Register |  | If $S K L=0, S K=0$ |
| 1 | 0 | Shift Register | Input to Shift | Serial | If SKL $=1, S K=$ Clock |
|  |  |  | Register | Out | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 0 | 1 | Binary Counter | Input to Binary | 0 | If $S K L=1, S K=1$ |
|  |  |  | Counter |  | If $S K L=0, S K=0$ |
| 1 | 1 | Binary Counter | Input to Binary | 1 | If $\mathrm{SKL}=1, \mathrm{SK}=1$ |
|  |  |  | Counter |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |

3. With $\mathrm{EN}_{2}$ set, the L drivers are enabled to output the data in $Q$ to the L I/O ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high impedance input state.
4. $\mathrm{EN}_{3}$, in conjunction with $\mathrm{EN}_{0}$, affects the SO output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $E N_{3}$. With $E N_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ". Table I provides a summary of the modes associated with $E N_{3}$ and $E N_{0}$.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the RESET pin as shown below (Figure 5). The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to $\mathrm{V}_{\mathrm{CC}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.


TL/DD/8371-5
FIGURE 5. Power-Up Clear Circuit
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, E N$, and $G$ registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.

## OSCILLATOR

There are two basic clock oscillator configurations available as shown by Figure 6.
a. Resonator Controlled Oscillator. CKI and CKO are connected to an external ceramic resonator. The instruction cycle frequency equals the resonator frequency divided by 8 .
b. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO becomes no connection.


TL/DD/8371-6
FIGURE 6. COP413L Oscillator
Ceramic Resonator Oscillator

| Resonator <br> Value | Component Values |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{R 1}(\Omega)$ | $\mathbf{R 2}(\Omega)$ | $\mathbf{C 1}(\mathrm{pF})$ | $\mathbf{C 2}(\mathrm{pF})$ |
| 455 kHz | 4.7 k | 1 M | 220 | 220 |

RC Controlled Osclllator

| $\mathbf{R ( k} \Omega)$ | $\mathbf{C}(\mathrm{pF})$ | Instruction <br> Cycle TIme <br> (In $\mu \mathbf{s})$ |
| :---: | :---: | :---: |
| 51 | 100 | $19 \pm 15 \%$ |
| 82 | 56 | $19 \pm 13 \%$ |

Note: $200 \mathrm{k} \Omega \geq \mathrm{R} \geq 25 \mathrm{k} \Omega$
$220 \mathrm{pF} \geq \mathrm{C} \geq 50 \mathrm{pF}$

Functional Description (Continued)

a. Standard Output

b. Push-Pull Output

c. Standard L Output

d. Input with Load

c. $\mathrm{Hi}-\mathrm{Z}$ Input

FIGURE 7. Input and Output Configurations

## I/O CONFIGURATIONS

COP413L inputs and outputs have the following configurations, illustrated in Figure 7:
a. G0-G3-an enhancement mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$.
b. SO, SK-an enhancement mode device to ground in conjunction with a depletion-mode device paralleled by an
enhancement-mode device to $\mathrm{V}_{\mathrm{CC}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads.
c. LO-L7-same as a., but may be disabled.
d. SI has on-chip depletion load device to $V_{C C}$.
e. $\overline{\text { RESET }}$ has a $\mathrm{Hi}-Z$ input which must be driven to a " 1 " or "0" by external components.

Typical Performance Characteristics


Output Sink Current for SO and SK


Output Sink Current for
L0-L7, GO-G3


FIGURE 8a. COP413L I/O DC Current Characteristics




Source Current for LO-L7, G0-G3 Standard Output Configuration


Output Sink Current for L0-L7, G0-G3
(Standard Drive)


FIGURE 8b. COP313L I/O DC Current Characteristics

## COP413L Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table. Table III provides the mnemonic, oper-
and, machine code data flow, skip conditions and description associated with each instruction in the COP413L instruction set.

TABLE II. COP413L Instruction Set Table Symbols

| Symbol | Definition |
| :---: | :---: |
| Internal Architecture Symbols |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| L | 8 -bit TRI-STATE® \|/O Port |
| M | 4-bit contents of RAM Memory pointed to by B Register |
| PC | 9 -bit ROM Address Register (program counter) |
| Q | 8 -bit Register to latch data for L I/O Port |
| SA | 9 -bit Subroutine Save Register A |
| SB | 9 -bit Subroutine Save Register B |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic Controlled Clock Output |
| Instruction Operand Symbols |  |
| d | 4-bit Operand Field, 0-15 binary (RAM Digit Select) |
| r | 2-bit Operand Field, 0-3 binary (RAM Register Select) |
| a | 9 -bit Operand Field, 0-511 binary (ROM Address) |
| $y$ | 4-bit Operand Field, 0-15 binary (Immediate Data) |
| RAM(s) | Contents of RAM location addressed by s |
| ROM(t) | Contents of ROM location addressed by t |
| Operational Symbols |  |
| + | Plus |
| - | Minus |
| $\rightarrow$ | Replaces |
| $\longleftrightarrow$ | Is exchanged with |
| $=$ | Is equal to |
| $\bar{A}$ | The one's complement of $A$ |
| $\oplus$ | Exclusive-OR |
| : | Range of values |

COP413L Instruction Set (Continued)
TABLE III. COP413L Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 1001110000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 0011\|0001 | $A+R A M(B) \rightarrow A$ | None | Add RAM to A |
| AISC | $y$ | $5-$ | 0101 y | $A+y \rightarrow A$ | Carry | Add Immediate, Skip on Carry ( $y \neq 0$ ) |
| CLRA |  | 00 | 000010000 | $0 \rightarrow A$ | None | Clear A |
| COMP |  | 40 | $\underline{0100 \mid 0000-1 ~}$ | $\bar{A} \rightarrow A$ | None | One's complement of $A$ to A |
| NOP |  | 44 | 010010100 | None | None | No Operation |
| RC |  | 32 | 0011 0010 | $" 0$ " $\rightarrow$ C | None | Reset C |
| SC |  | 22 | -0010\|0010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | 0000\|0010 | $A \oplus \operatorname{RAM}(B) \rightarrow A$ | None | Exclusive-OR RAM with A |

TRANSFER OF CONTROL INSTRUCTIONS

| JID |  | FF | \|1111|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 2) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JMP | a | 6- | [0110\|000|a8 | $a \rightarrow P C$ | None | Jump |
|  |  | - | a7:0 |  |  |  |
| JP | a | - | $\begin{gathered} 1 \text { a6:0 } \\ \text { (pages } 2,3 \text { only) } \\ \text { or } \end{gathered}$ | $\mathrm{a} \rightarrow \mathrm{PC}_{6: 0}$ | None | Jump within-Page (Note 3) |
|  |  | - | $\underset{\text { (all other pages) }}{\|11\| \quad \text { a5:0 }}$ | $a \rightarrow P C_{5: 0}$ |  |  |
| JSRP | a | - | \|10| a5:0 | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 4) |
| JSR | a | 6- |  | $\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB}$ | None | Jump to Subroutine |
|  |  | - |  | $\mathrm{a} \rightarrow \mathrm{PC}$ |  |  |
| RET |  | 48 | 0100\|1000 | $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 10100\|1001 | $S B \rightarrow S A \rightarrow P C$ | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 | 0011 ${ }^{\text {20011 }}$ | $A \rightarrow Q_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C | 0011 [1100 | $\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{Q}_{3: 0}$ |  |  |
| LD | $r$ | -5 | $00 \mid \mathbf{1 0 1 0 1 \|}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A, Exclusive-OR Br with r |
| LQID | r | BF | [1011\|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SA} \rightarrow \mathrm{SB} \end{aligned}$ | None | Load Q Indirect (Note 2) |
| RMB | 0 | 4 C | 10100\|1100 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | 0100\|0101 | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{1}$ |  |  |
|  | 2 | 42 | 10100\|0010 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 43 | 010010011 | $0 \rightarrow$ RAM $(\mathrm{B})_{3}$ |  |  |
| SMB | 0 | 4D | \|0100|1101 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Set RAM Bit |
|  | 1 | 47 | 010010111 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1}$ |  |  |
|  | 2 | 46 | 010010110 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 4 B | 0100/1011 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |



## COP413L Instruction Set (Continued)

TABLE III. COP413L Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code <br> (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 001110011 | $G \rightarrow A$ | None | Input G Ports to A |
|  |  | 2A | 0010\|1010 |  |  |  |
| INL |  | 33 | 0011 0011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2E | 0010\|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OMG |  | 33 | [0011 0011 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{G}$ | None | Output RAM to G Ports |
|  |  | 3 A | \|0011|1010 |  |  |  |
| XAS |  | 4F | -0100/1111 | $\mathrm{A} \longleftrightarrow \mathrm{SIO}, \mathrm{C} \rightarrow \mathrm{SKL}$ | None | Exchange A with SIO (Note 2) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicity defined (e.g., Br and Bd are explicitly defined) Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit A register.
Note 2: For additional information on the operation of the XAS, JID, and LQID instructions, see below.
Note 3: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 4: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3. JSRP may not jump to the last word in page 2.
Note 5: The machine code for the lower 4 bits of the LBI instruction equals the binary value of the "d" data minus 1 e.g., to load the lower four bits of $B$ (Bd) with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 ( $1111_{2}$ ).
Note 6: Machine code for operand field $y$ for LEI instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP413L programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO ) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M . It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 9 -bit word, $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{8}$ is not affected by this instruction.
Note that JID requires 2 instruction cycles to execute.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 9 -bit word $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}$. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack ( $\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB}$ ) and replaces the least significant 8 bits of PC as follows: $\mathrm{A} \rightarrow \mathrm{PC}_{7: 4}, \mathrm{RAM}(\mathrm{B})$
$\rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" ( $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ ), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SA $\rightarrow$ SB, the previous contents of SB are lost. Also, when LQID pops the stack, the previously pushed contents of SA are left in SB. The net result is that the contents of SA are placed in SB $(S A \rightarrow S B)$. Note that LQID takes two instruction cycle times to execute.

## INSTRUCTION SET NOTES

a. The first word of a COP413L program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped.
c. The ROM is organized into 8 pages of 64 words each. The Program Counter is a 9-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page 3 or will access data in the next group of 4 pages.

## Description of Selected Instructions (Continued)

TEST MODE (NON-STANDARD OPERATION)
The SO output has been configured to provide for standard test procedures for the custom-programmable COP413L. With SO forced to logic " 1 ", two test modes are provided, depending upon the value of SI :
a. RAM and internal Logic Test Mode $(\mathrm{SI}=1)$
b. ROM Test Mode $(\mathrm{SI}=0)$

These special test modes should not be employed by the user; they are intended for manufacturing test only.

## Option List

The option selected must be sent in with the EPROM of ROM Code for a Mask order of 413L. Make xerox copy of the table, select the appropriate option, and send it in with the EPROM.

## COP 413L/COP 313L

Option 1: Oscillator Selection
$=0$ Ceramic Resonator or external input frequency divided by 8 . CKO is oscillator output.
$=1$ Single pin RC controlled oscillator divided by 4. CKO is no connection.

## NOTE:

The following option information is to be sent to National along with the EPROM
Option 1: Value = $\qquad$ is: Oscillator Selection


## COP413C/COP413CH/COP313C/COP313CH Single-Chip CMOS Microcontrollers

## General Description

The COP413C, COP413CH, COP313C, and COP313CH fully static, single-chip CMOS microcontrollers are members of the COPSTM family, fabricated using double-poly, silicongate CMOS technology. These controller-oriented processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, with an instruction set, internal architecture, and I/O scheme designed to facilitate keyboard input, display output, and BCD data manipulation. The COP 413 CH is identical to the COP413C except for operating voltage and frequency. They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide a customized controller-oriented processor at a low end-product cost.

The COP313C/COP313CH is the extended temperature range version of the COP413C/COP413CH.
For emulation use the ROMless COP404C.

## Block Diagram



FIGURE 1. COP413C/413CH

## COP413C/COP413CH

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the assoclated reliability electrical test specifications document.
Supply Voltage
6 V
Voltage at Any Pin
Total Allowable Source Current
Total Allowable Sink Current

Operating Temperature Range
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature Range
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}$ unless otherwise spectifed

| Parameter | Conditions | COP413C |  | COP413CH |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Operating Voltage |  | 3.0 | 5.5 | 4.5 | 5.5 | V |
| Power Supply Ripple (Note 4) |  |  | $0.1 \mathrm{~V}_{\mathrm{CC}}$ |  | $0.1 \mathrm{~V}_{\mathrm{CC}}$ | V |
| Supply Current (Note 1) | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=\mathrm{Min} \\ & V_{\mathrm{CC}}=3.0 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=\mathrm{Min} \\ & \left(\mathrm{t}_{\mathrm{C}} \text { is inst. } \mathrm{cyc} \mathrm{Cl}\right. \text { e) } \end{aligned}$ |  | $\begin{aligned} & 500 \\ & 300 \end{aligned}$ |  | 2000 | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| HALT Mode Current (Note 2) | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, F_{1}=0 \mathrm{kHz} \\ & V_{C C}=3.0 \mathrm{~V}, F_{1}=0 \mathrm{kHz} \end{aligned}$ |  | $\begin{aligned} & 20 \\ & 10 \\ & \hline \end{aligned}$ |  | 20 | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| Input Voltage Levels <br> RESET, CKI <br> Logic High <br> Logic Low <br> Alt Other Inputs <br> Logic High <br> Logic Low |  | $\begin{aligned} & 0.9 V_{C C} \\ & 0.7 V_{C C} \end{aligned}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 0.9 \mathrm{~V}_{\mathrm{CC}} \\ & 0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| RESET, SI Input Leakage |  | -1 | +1 | -1 | +1 | $\mu \mathrm{A}$ |
| Input Capacitance |  |  | 7 |  | 7 | pF |
| Output Voltage Levels (SO, SK, L Port) Logic High Logic Low | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.2$ | 0.2 | $V_{C C}-0.2$ | 0.2 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Output Current Levels <br> Sink (Note 3) <br> Source (SO, SK, L Port) <br> Source (G Port) | $\begin{aligned} & V_{C C}=M \text { Min, } V_{O U T}=V_{C C} \\ & V_{C C}=M i n, V_{O U T}=O V \\ & V_{C C}=M i n, V_{O U T}=O V \end{aligned}$ | $\begin{gathered} 0.2 \\ -0.1 \\ -8 \end{gathered}$ | -150 | $\begin{gathered} 1.2 \\ -0.5 \\ -30 \end{gathered}$ | -330 | mA <br> mA <br> $\mu \mathrm{A}$ |
| Allowable Sink/Source Current Per Pin (Note 3) |  |  | 5 |  | 5 | mA |
| TRI-STATE Leakage Current |  | -2 | +2 | -2 | +2 | $\mu \mathrm{A}$ |

COP413C/COP413CH
AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Condlitions | COP413C |  | COP413CH |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Instruction Cycle Time |  | 16 | DC | 4 | DC | $\mu \mathrm{s}$ |
| Operating CKI Frequency | $\div 8$ Mode | DC | 500 | DC | 2000 | kHz |
| Instruction Cycle Time RC Oscillator $\div 4$ | $\begin{aligned} & \mathrm{R}=30 \mathrm{k} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}=82 \mathrm{pF} \pm 5 \% \end{aligned}$ |  |  | 8 | 16 | $\mu \mathrm{S}$ |
| Instruction Cycle Time RC Oscillator $\div 4$ (Note 6) | $\begin{aligned} & R=56 k \pm 5 \%, V_{C C}=5 V \\ & C=100 \mathrm{pF} \pm 5 \% \end{aligned}$ | 16 | 32 | 16 | 32 | $\mu s$ |
| Duty Cycle (Note 5) | $\mathrm{Fi}=\mathrm{Max}$ freq ext clk | 40 | 60 | 40 | 60 | \% |
| Rise Time (Note 5) | $\mathrm{Fi}=$ Max freq ext clk |  | 60 |  | 60 | ns |
| Fall Time (Note 5) | $\mathrm{Fi}=$ Max freq ext clk |  | 40 |  | 40 | ns |
| Inputs (See Figure 3) tsetup $\mathrm{t}_{\mathrm{HOLD}}$ | G Inputs <br> Sl Input <br> L Inputs | $\begin{gathered} \mathrm{tc} / 4+2.8 \\ 1.2 \\ 6.8 \\ 1.0 \\ \hline \end{gathered}$ |  | $\begin{gathered} \mathrm{tc} / 4+0.7 \\ 0.3 \\ 1.7 \\ 0.25 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Output Propagation Delay tpD1 $\mathrm{t}_{\text {PDO }}$ | $\begin{aligned} & V_{\text {OUT }}=1.5, C_{L}=100 \mathrm{pF} \\ & R_{L}=5 k \end{aligned}$ |  | 4.0 |  | 1.0 | $\mu \mathrm{S}$ |

Note 1: Supply current is measured after running for 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled to $V_{C C}$ with 5 k resistors. See current drain equation on page 13.
Note 2: The Halt mode will stop CKI from oscillating.
Note 3: SO output sink current must be limited to keep $V_{O L}$ less tha $0.2 \mathrm{~V}_{\mathrm{CC}}$ when part is running in order to prevent entering test mode.
Note 4: Voltage change must be less than 0.5 V in a 1 ms period.
Note 5: This parameter is only sampled and not $100 \%$ tested.
Note 6: Variation due to the device included.

## COP313C/COP313CH

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated rellability electrical test specifications document.
Supply Voltage
6 V
Voltage at Any Pin
Total Allowable Source Current

Total Allowable Sink Current
25 mA Operating Temperature Range $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Storage Temperature Range $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | COP313C |  | COP313CH |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Operating Voltage |  | 3.0 | 5.5 | 4.5 | 5.5 | V |
| Power Supply Ripple (Note 4) |  |  | $0.1 \mathrm{~V}_{\mathrm{CC}}$ |  | $0.1 \mathrm{~V}_{\mathrm{CC}}$ | V |
| Supply Current (Note 1) | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=\mathrm{Min} \\ & V_{\mathrm{CC}}=3.0 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=\mathrm{Min} \\ & \left(\mathrm{t}_{\mathrm{c}}\right. \text { is inst. cycle) } \end{aligned}$ |  | $\begin{aligned} & 600 \\ & 360 \end{aligned}$ |  | 2500 | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| Halt Mode Current (Note 2) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{Fi}=0 \mathrm{kHz} \\ & \mathrm{~V}_{\mathrm{CC}}=3.0 \mathrm{~V}, \mathrm{Fi}=0 \mathrm{kHz} \end{aligned}$ |  | $\begin{aligned} & 20 \\ & 10 \end{aligned}$ |  | 20 | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Input Voltage Levels RESET, CKI <br> Logic High <br> Logic Low <br> All Other Inputs Logic High Logic Low |  | $\begin{aligned} & 0.9 \mathrm{~V}_{\mathrm{CC}} \\ & 0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 0.1 V_{C C} \\ & 0.2 V_{C C} \end{aligned}$ | $0.9 \mathrm{~V}_{\mathrm{CC}}$ $0.7 \mathrm{~V}_{\mathrm{CC}}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \end{aligned}$ |
| RESET, SI Input Leakage |  | -2 | +2 | -2 | +2 | $\mu \mathrm{A}$ |
| Input Capacitance |  |  | 7 |  | 7 | pF |
| Output Voltage Levels (SO, SK, L Port) Logic High Logic Low | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.2$ | 0.2 | $V_{C C}-0.2$ | 0.2 | $\begin{aligned} & V \\ & V \end{aligned}$ |
| Output Current Levels <br> Sink (Note 3) <br> Source (SO, SK, L Port) <br> Source (G Port) | $\begin{aligned} & V_{C C}=\mathrm{Min}, V_{\text {OUT }}=V_{C C} \\ & V_{C C}=M \text { Min }, V_{\text {OUT }}=O V \\ & V_{C C}=M i n, V_{\text {OUT }}=O V \end{aligned}$ | $\begin{gathered} 0.2 \\ -0.1 \\ -8 \end{gathered}$ | -200 | $\begin{gathered} 1.2 \\ -0.5 \\ -30 \\ \hline \end{gathered}$ | -440 | mA <br> mA $\mu \mathrm{A}$ |
| Allowable Sink/Source Current Per Pin (Note 3) |  |  | 5 |  | 5 | mA |
| TRI-STATE Leakage Current ${ }^{3}$ |  | -4 | +4 | -4 | +4 | $\mu \mathrm{A}$ |

## COP313C/COP313CH

AC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | COP313C |  | COP313CH |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Instruction Cycle Time |  | 16 | DC | 4 | DC | $\mu \mathrm{s}$ |
| Operating CKI Frequency | $\div 8$ Mode | DC | 500 | DC | 2000 | kHz |
| Instruction Cycle Time RC Oscillator $\div 4$ | $\begin{aligned} & R=30 k \pm 5 \%, V_{C C}=5 V \\ & C=82 p F \pm 5 \% \end{aligned}$ |  |  | 8 | 16 | $\mu \mathrm{S}$ |
| Instruction Cycle Time RC Oscillator $\div 4$ (Note 6) | $\begin{aligned} & \mathrm{R}=56 \mathrm{k} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}=100 \mathrm{pF} \pm 5 \% \end{aligned}$ | 16 | 32 | 16 | 32 | $\mu \mathrm{S}$ |
| Duty Cycle (Note 5) | $\mathrm{Fi}=$ Max Freq Ext Clk | 40 | 60 | 40 | 60 | \% |
| Rise Time (Note 5) | $\mathrm{Fi}=$ Max Freq Ext Cik |  | 60 |  | 60 | ns |
| Fall Time (Note 5) | Fi $=$ Max Freq Ext Clk |  | 40 |  | 40 | ns |
| Inputs (See Figure 3) tsetup $t_{\text {HOLD }}$ |  | $\begin{gathered} \mathrm{tc} / 4+2.8 \\ 1.2 \\ 6.8 \\ 1.0 \\ \hline \end{gathered}$ |  | $\begin{gathered} \mathrm{tc} / 4+0.7 \\ 0.3 \\ 1.7 \\ 0.25 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Output Propagation Delay tpD1, tPDO | $\begin{aligned} & V_{\text {OUT }}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} \\ & R_{\mathrm{L}}=5 \mathrm{k} \end{aligned}$ |  | 4.0 |  | 1.0 | $\mu \mathrm{S}$ |

Note 1: Supply current is measured after running for 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled up to $V_{C C}$ with $5 k$ resistors. See current drain equation on page 13.
Note 2: The Halt mode will stop CKI from oscillating.
Note 3: SO output sink current must be limited to keep $V_{O L}$ less than $0.2 \mathrm{~V}_{\mathrm{CC}}$ when part is running in order to prevent entering test mode.
Note 4: Voltage change must be less than 0.5 V in a 1 ms period.
Note 5: This parameter is only sampled and not $100 \%$ tested.
Note 6: Variation due to the device included.

## Connection Diagram



TL/DD/8537-2

Top View

## Pin Descriptions

| Pin | Description |
| :--- | :--- |
| $L_{7}-L_{0}$ | 8-bit bidirectional I/O port with TRI-STATE |
| $\mathrm{G}_{3}-\mathrm{G}_{0}$ | 4-bit bidirectional I/O port |
| SI | Serial input (or counter input) |
| SO | Serial output (or general purpose output) |
| SK | Logic-controlled clock |
|  | (or general purpose output) |
| CKI | System oscillator input |
| CKO | Crystal oscillator output, or NC |
| RESET | System reset input |
| VCC | System power supply |
| GND | System Ground |

FIGURE 2
Order Number COP313C-XXX/D, COP313C-XXX/M, COP313C-XXX/N, COP313CH-XXX/D, COP313CH-XXX/M, COP313CH-XXX/N, COP413C-XXX/D, COP413C-XXX/M, COP413C-XXX/N, COP413CH-XXX/D, COP413CH-XXX/M or

COP413CH-XXX/N
See NS Package Number D20A, M20B or N20A

## Timing Waveform



FIGURE 3. Input/Output Timing Dlagrams (Divide-by-8 Mode)

## Development Support

The MOLE (Microcontroller On Line Emulator) is a low cost development system and real time emulator for COPS' products. They also include TMP, 8050 and the new 16 bit HPC microcontroller family. The MOLE provides effective support for the development of both software and hardware in the user's application.
The purpose of the MOLE is to provide a tool to write and assemble code, emulate code for the target microcontroller and assist in debugging of the system.
The MOLE can be connected to various hosts, IBM PC, STARPLEXTM, Kaypro, Apple and Intel systems, via RS-232 port. This link facilitates the up loading/down loading of code, supports host assembly and mass storage.
The MOLE consists of three parts; brain, personality and optional host software.
The brain board is the computing engine of the system. It is a self-contained computer with its own firmware which provides for all system operation, emulation control, communication, from programming and diagnostic operation. It has three serial ports which can be connected to a terminal, host system, printer, modem or to other MOLE's in a multiMOLE environment.

The personality board contains the necessary hardware and firmware needed to emulate the target microcontroller. The emulation cable which replaces the target controller attaches to this board. The software contains a cross assembler and a communications program for up loading and down loading code from the MOLE.

MOLE Ordering Information

| P/N | Description |
| :---: | :---: |
| MOLE-BRAIN | MOLE Computer Board |
| MOLE-COPS-PB1 | COPS Personality Board |
| MOLE-XXX-YYY $\quad$ Optional Software |  |
| Where XXX | $=$ COPS |
| YYY | $=$ Host System, IBM, Apple, |
|  | KAY (Kaypro), CP/M |

## Functional Description

To ease reading of this description, only COP413C is referenced; however, all such references apply equally to $\mathrm{COP} 413 \mathrm{CH}, \mathrm{COP} 313 \mathrm{C}$, and COP 313 CH .
A block diagram of the COP413C is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 "; when a bit is reset, it is a logic " 0 ".

## PROGRAM MEMORY

Program memory consists of a 512-byte ROM. As can be seen by an examination of the COP413C instruction set, these words may be program instructions, program data, or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID, and LQID instructions, ROM must often be thought of as being organized into 8 pages of 64 words (bytes) each.

## ROM ADDRESSING

ROM addressing is accomplished by a 9 -bit PC register. Its binary value selects one of the 5128 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 9 -bit binary count value. Two levels of subroutine nesting are implemented by two 9 -bit subroutine save registers, SA and SB.
ROM instruction words are fetched, decoded, and executed by the instruction decode, control and skip logic circuitry.

## DATA MEMORY

Data Memory consists of a 128 -bit RAM, organized as four data registers of $8 \times 4$-bit digits. RAM addressing is implemented by a 6-bit B register whose upper two bits ( Br ) selects one of four data registers and lower three bits of the 4bit Bd select one of eight 4-bit digits in the selected data register. While the 4-bit contents of the selected RAM digit (M) are usually loaded into or from, or exchanged with, the A register (accumulator), they may also be loaded into the $Q$ latches or loaded from the L ports. RAM addressing may also be performed directly by the XAD 3, 15 instruction.
The most significant bit of Bd is not used to select a RAM digit. Hence, each physical digit of RAM may be selected by two different values of Bd as shown in Figure 4. The skip condition for XIS and XDS instructions will be true if Bd changes between 0 to 15, but not between 7 and 8 (see Table III).

## INTERNAL LOGIC

The internal logic of the COP413C is designed to ensure fully static operation of the device.
The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Bd portion of the $B$ register, to load four bits of the 8 -bit $Q$ latch data and to perform data exchanges with the SIO register.
The 4-bit adder performs the arithmetic and logic functions of the COP413C, storing its results in A. It also outputs the carry information to a 1-bit carry register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description below.)
The G register contents are outputs to four general purpose bidirectional I/O ports.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded from RAM and A, as well as 8 -bit data from ROM. Its contents are output to the LI/O ports when the L drivers are enabled under program control. (See LEl instruction.)
The eight $L$ drivers, when enabled, output the contents of latched $Q$ data to the L I/O ports. Also, the contents of $L$ may be read directly into $A$ and RAM.


TL/DD/8537-4
FIGURE 4. RAM Digit Address to Physical RAM Digit Mapping

## Functional Description (Continued)

The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter, depending upon the contents of the EN register. (See EN register description below.) Its contents can be exchanged with A , allowing it to input or output a continuous serial data stream. With SIO functioning as a serial-in/serial-out shift register and SK as a sync clock, the COP413C is MICROWIRE compatible. The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK is a sync clock, inhibited when SKL is a logic " 0 ". The EN register is an internal 4-bit register loaded under program control by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register (EN3-EN0).

1. The least significant bit of the enable register, ENO, selects the SIO register as either a 4-bit shift register or as a 4-bit binary counter. With ENO set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of EN3. With ENO reset, SIO is a serial shift register, shifting left each instruction cycle time. The data present at SI is shifted into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each instruction cycle time. (See 4, below.) The SK output becomes a logic-controlled clock.
2. EN 1 is not used, it has no effect on the COP413C.
3. With EN2 set, the L drivers are enabled to output the data in $Q$ to the L I/O ports. Resetting EN2 disables the L drivers, placing the LI/O ports in a high impedance input state.
4. EN3, in conjunction with ENO, affects the SO output. With ENO set (binary counter option selected), SO will output the value loaded into EN3. With ENO reset (serial shift
register option selected), setting EN3 enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting EN3 with the serial shift register option selected, disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ".

## INITIALIZATION

The external RC network shown in Figure 5 must be connected to the RESET pin. The RESET pin is configured as a Schmitt trigger input. If not used, it should be connected to $V_{\text {cc }}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, providing it stays low for at least three instruction cycle times.
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the A, B, C, EN, and G registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA (clear A register).


FIGURE 5. Power-Up Clear Circuit

TABLE I. Enable Reglster Modes-Bits ENO and EN3

| ENO | EN3 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :--- | :---: | :--- |
| 0 | 0 | Shift Register | Input to Shift | 0 | If $S K L=1$, SK $=$ clock |
|  |  |  | Register |  | If $S K L=0$, SK $=0$ |
| 0 | 1 | Shift Register | Input to Shift | Serial | If $S K L=1$, SK $=$ clock |
|  |  |  | Register | out | If $S K L=0, S K=0$ |
| 1 | 0 | Binary Counter | Input to Counter | 0 | SK $=$ SKL |
| 1 | 1 | Binary Counter | Input to Counter | 1 | SK $=$ SKL |

## Functional Description (Continued)

## HALT MODE

The COP413C is a fully static circuit; therefore, the user may stop the system oscillator at any time to halt the chip. The chip may be halted by the HALT instruction. Once in the HALT mode, the internal circuitry does not receive any clock signal, and is therefore frozen in the exact state it was in when halted. All information is retained until continuing. The HALT mode is the minimum power dissipation state.
The HALT mode may be entered into by program control (HALT instruction) which forces CKO to a logic " 1 " state. The circuit can be awakened only by the RESET function.

## POWER DISSIPATION

The lowest power drain is when the clock is stopped. As the frequency increases so does current. Current is also lower at lower operating voltages. Therefore, to minimize power consumption, the user should run at the lowest speed and voltage that his application will allow. The user should take care that all pins swing to full supply levels to ensure that outputs are not loaded down and that inputs are not at some intermediate level which may draw current. Any input with a slow rise or fall time will draw additional current. A crystal- or resonator-generated clock will draw more than a square-wave input. An RC oscillator will draw even more current since the input is a slow rising signal.
If using an external squarewave oscillator, the following equation can be used to calculate the COP413C current drain.

$$
\mathrm{Ic}=\mathrm{Iq}+(\mathrm{V} \times 20 \times \mathrm{Fi})+(\mathrm{V} \times 1280 \times \mathrm{Fl} / \mathrm{DV})
$$

$$
\text { where Ic }=\text { chip current drain in microamps }
$$

$\mathrm{Iq}=$ quiescent leakage current (from curve)
$\mathrm{Fl}=\mathrm{CKI}$ frequency in megahertz
$\mathrm{V}=\mathrm{chip} \mathrm{V}_{\mathrm{CC}}$ in volts
$\mathrm{Dv}=$ divide by option selected
For example, at $5 \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}$ and 400 kHz (divide by 8 ),

$$
\begin{aligned}
& \mathrm{Ic}=30+(5 \times 20 \times 0.4)+(5 \times 1280 \times 0.4 / 8) \\
& \mathrm{Ic}=30+40+320=390 \mu \mathrm{~A}
\end{aligned}
$$

## OSCILLATOR OPTIONS

There are two options available that define the use of CKI and CKO.
a. Cyrstal-Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency divided by 8.
b. RC-Controlled Oscillator. CKI is configured as a single pin RC-controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is NC.
The RC oscillator is not recommended in systems that require accurate timing or low current. The RC oscillator draws more current than an external oscillator (typically an additional $100 \mu \mathrm{~A}$ at 5 V ). However, when the part halts, it stops with CKI high and the halt current is at the minimum.


FIGURE 6. COP413C Oscillator

| Crystal or Resonator | RC-Controlled |
| :---: | :---: |
| Osclllator |  |


| Crystal Value | Component Value |  |  |  | Cycle |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | R1 | R2 | C1 pF | C2 pF | R | C | Time | $V_{\text {cc }}$ |
| 32 kHz | 220k | 20M | 30 | 5-36 | 15k | 82 pF | 4-9 $\mu \mathrm{s}$ | 2 4.5V COP413CH Only |
| 455 kHz | 5k | 10M | 80 | 40 | 30k | 82 pF | 8-16 $\mu \mathrm{s}$ | $\geq 4.5 \mathrm{~V}$ COP413CH Only |
| 2.000 MHz | 2k | 1 M | 30 | 6-36 | 47k | 100 pF | 16-32 $\mu \mathrm{s}$ | 3.0 to 4.5V COP413C Only |
|  |  |  |  |  | 56k | 100 pF | 16-32 $\mu \mathrm{s}$ | 24.5 V |
|  |  |  |  |  | $50 \mathrm{pF} \leq \mathrm{C} \leq 150 \mathrm{pF}$ |  |  |  |

## Functional Description (Continued)

## I/O CONFIGURATIONS

COP413C outputs have the following configurations, illustrated in Figure 7:
a. Standard SO, SK Output. A CMOS push-pull buffer with an N -channel device to ground in conjunction with a P-channel device to $\mathrm{V}_{\mathrm{CC}}$, compatible with CMOS and LSTTL.
b. Low Current G Output. This is the same configuration as (a) above except that the sourcing current is much less.
c. Standard TRI-STATE L Output. L output is a CMOS output buffer similar to (a) which may be disabled by program control.

a. Standard Push-Pull Output

c. Standard TRI-STATE "L" Output

The SI and $\overline{\mathrm{RESET}}$ inputs are $\mathrm{Hi}-\mathrm{Z}$ inputs (Figure 7d).
When using the G I/O port as an input, set the output register to a logic "1" level. The P-channel device will act as a pull-up load. When using the L I/O port as an input, disable the $L$ drivers with the LEl instruction. The drivers are then in TRI-STATE mode and can be driven externally.
All output drivers use one or more of three common devices numbered 1 to 3 . Minimum and maximum current (IOUT and $V_{\text {OUT }}$ ) curves are given in Figure 8 for each of these devices to allow the designer to effectively use these I/O configurations.

b. Low Current Push-Pull Output


TL/DD/8537-7
d. Hi-Z Input

FIGURE 7. I/O Configurations


COP413C/COP413CH Low Current G Port Maximum Source Current


SO, SK, L Port Standard Minimum Source Current


COP313C/COP313CH
Low Current G Port
Maximum Source Current


FIGURE 8


Maximum Quiescent Current



| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TABLE III | OP413C Instruction Set | ontinued) |  |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 2) |
| JMP | a | $6-$ | $\begin{array}{\|c\|c\|c\|c\|c\|} \hline 0110\|000\| a_{8} \\ \hline a_{7: 0} \\ \hline \end{array}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  | $\begin{gathered} \frac{\|1\|}{} \quad a_{6: 0} \\ \text { (pages } 2,3 \text { only) } \\ \text { or } \\ \frac{11 \mid \quad a_{5: 0}}{\text { (all other pages) }} \end{gathered}$ | $\begin{aligned} & \mathrm{a} \rightarrow \mathrm{PC}_{6: 0} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump within Page (Note 1) |
| JSRP | a | - | प10 $\mathrm{a}_{5: 0}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 2) |
| JSR | a | $6-$ - | $\begin{gathered} 0110\|100\| \mathrm{a}_{8} \mid \\ \hline \mathrm{a}_{7}: 0 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | 0100\|1000| | $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 0100\|10011 | $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| HALT |  | $\begin{aligned} & 33 \\ & 38 \end{aligned}$ | 0011 0011 <br> 0011 1000 |  | None | Halt processor |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 30 | 0011 0011 <br> 0011 1100 | $\begin{aligned} & A \rightarrow Q_{7: 4} \\ & R A M(B) \xrightarrow{\rightarrow} Q_{3: 0} \end{aligned}$ | None | Copy A, RAM to Q |
| CQMA |  | $\begin{aligned} & 33 \\ & 2 \mathrm{C} \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0011 & 0011 \\ \hline 0010 & 1100 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{Q}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{Q}_{3: 0} \rightarrow \mathrm{~A} \end{aligned}$ | None | Copy Q to RAM, A |
| LD | r | -5 | -00\|r|0101 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A Exclusive-OR Br with r |
| LQID |  | BF | \|1011 ${ }^{\text {1111 }}$ | $\begin{aligned} & \operatorname{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SA} \rightarrow \mathrm{SB} \end{aligned}$ | None | Load Q Indirect |
| RMB | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 4 C \\ & 45 \\ & 42 \\ & 43 \end{aligned}$ | 0100 1100 <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{aligned} & 0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0} \\ & 0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1} \\ & 0 \rightarrow R A M(B)_{2} \\ & 0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3} \end{aligned}$ | None | Reset RAM Bit |
| SMB | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | $4 D$ 47 46 $4 B$ | $0100\|1101\|$  <br> 0100 0111 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} 1 & \rightarrow \operatorname{RAM}(B)_{0} \\ 1 & \rightarrow \operatorname{RAM}(B)_{1} \\ 1 & \rightarrow \operatorname{RAM}(B)_{2} \\ 1 & \rightarrow \operatorname{RAM}(B)_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | y | $7-$ | 0111 ${ }^{\text {¢ }}$ | $\begin{aligned} & y \rightarrow \operatorname{RAM}(\mathrm{~B}) \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | $r$ | -6 | 100\|r|0110 | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with $A$, Exclusive-OR Br with $r$ |
| XAD | 3,15 | $\begin{aligned} & 23 \\ & \mathrm{BF} \end{aligned}$ | $\begin{array}{\|l\|l\|l\|} \hline 0010 & 0011 \mid \\ \hline 1011 & 1111 \\ \hline \end{array}$ | $\operatorname{RAM}(3,15) \longleftrightarrow \mathrm{A}$ | None | Exchange A with RAM $(3,15)$ |

TABLE III. COP413C Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MEMORY REFERENCE INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| XDS | r | -7 | 00\|r10111 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd Exclusive-OR Br with $r$ |
| XIS | r | -4 | 100\|r10100 | RAM $(B) \longleftrightarrow A$ $\mathrm{Bd}+1 \rightarrow \mathrm{Bd}$ <br> $\mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br}$ | Bd increments past 15 | Exchange RAM with $A$ and Increment Bd <br> Exclusive-OR Br with r |

REGISTER REFERENCE INSTRUCTIONS

| CAB |  | 50 | 10101\|0000 | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CBA |  | 4E | 10100\|1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d | - | $\frac{\|00\| r\|(d-1)\|}{(d=0,9: 15)}$ | $r$ r,d $\rightarrow$ B | Skip until not a LBI | Load B Immediate with r,d |
| LEI | y | 33 | 10011\|0011| | $y \rightarrow E N$ | None | Load EN Immediate |
|  |  | 6- | 0010 y ] |  |  |  |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  | 20 | -0010\|0000 |  | $\mathrm{C}={ }^{\prime} 1{ }^{\prime}$ | Skip if C is True |
| SKE |  | 21 | 0010\|0001 |  | $A=R A M(B)$ | Skip if A Equals RAM |
| SKGZ |  | 33 | \|0011|0011| |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
|  |  | 21 | -0010\|0001 |  |  |  |
| SKGBZ |  | 33 | 0011\|0011 | 1st byte |  | Skip if G Bit is Zero |
|  | 0 | 01 | 0000\|0001 | $\int 2 \mathrm{nd}$ byte | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 00010001 |  | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | \|0000|0011 |  | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 0010/0011 |  | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 10000\|0001 |  | $\operatorname{RAM}(\mathrm{B})_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | 000110001 |  | $\operatorname{RAM}(\mathrm{B})_{1}=0$ |  |
|  | 2 | 03 | 0000\|00111 |  | RAM $(B)_{2}=0$ |  |
|  | 3 | 13 | 0001\|0011 |  | $\operatorname{RAM}(\mathrm{B})_{3}=0$ |  |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | -0011\|00111 | $\mathrm{G} \rightarrow \mathrm{A}$ | None | Input G Ports to A |
|  |  | 2A | 10010\|1010 |  |  |  |
| INL |  | 33 | -0011\|0011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2 E | O010\|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OMG |  | 33 | 00110011 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{G}$ | None | Output RAM to G Ports |
|  |  | 3A |  |  |  |  |
| XAS |  | 4F | [0100\|1111 | $\mathrm{A} \longleftrightarrow \mathrm{SIO}, \mathrm{C}-$ | None | Exchange A with SIO |

Note 1: The JP instruction allows a jump, while in subroutine pages 2 or 3 , to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 2: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP413C programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register.) If SIO is selected as a shift register, an XAS instruction must be performed once every four instruction cycle times to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by $A$ and $M$. It loads the lower eight bits of the ROM address register PC with the contents of ROM addressed by the 9 -bit word, $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{8}$ is not affected by this instruction.
Note: JID uses two instruction cycles if executed, one if skipped.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 9 -bit word $\mathrm{PC}_{8}, A, M$. LQID can be used for table look-up or code conversion such as BCD to 7 -segment. The LQID instruction "pushes" the stack $(P C+1 \rightarrow S A \rightarrow S B)$ and replaces the least significant eight bits of the PC as follows: $\mathrm{A} \rightarrow \mathrm{PC}_{7: 4}$, RAM $(\mathrm{B}) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the Q latches. Next, the stack is "popped" (SB $\rightarrow$ SA $\rightarrow$ PC ), restoring the saved value of the PC to continue sequential program execution. Since LQID pushes SA $\rightarrow$ SB, the previous contents of SB are lost.
Note: LQID uses two instruction cycles if executed, one if skipped.

## INSTRUCTION SET NOTES

a. The first word of a COP413C program (ROM address 0) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths take the same number of cycle times whether instructions are skipped or executed (except JID and LQID).
c. The ROM is organized into eight pages of 64 words each. The program counter is a 9-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID, or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: A JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word in page 3 or 7 will access data in the next group of four pages.

## COPS Programming Manual

For detailed information on writing. COPS programs, the COPS Programming Manual 424410284-001 provides an indepth discussion of the COPS architecture, instruction set and general techniques of COPS programming. This manual is written with the programmer in mind.

## OPTION LIST-OSCILLATOR SELECTION

The oscillator option selected must be sent in with the EPROM of ROM Code for masking into the COP413C. Select the appropriate option, make a photocopy of the table and send it with the EPROM.

## COP413C/COP313C

Option 1: Oscillator selection
$=0$ Ceramic Resonator input frequency divided by 8. CKO is oscillator output.
$=1$ Single pin RC controlled oscillator divided by 4. CKO is no connection.
Note: The following option information is to be sent to Na tional along with the EPROM.
Option 1: Value = $\qquad$ is Oscillator Selected.

# COP414L/COP314L/COP214L Single-Chip N-Channel Microcontrollers 

## General Description

The COP414L Single-Chip N-Channel Microcontrollers are members of the COPSTM family, fabricated using N-channel, silicon gate MOS technology. This Controller Oriented Processor is a complete microcomputer containing all system timing, internal logic, ROM, RAM and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture and I/O scheme designed to facilitate keyboard input, display output and BCD data manipulation. The COP414L is an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized Controller Oriented Processor at a low end-product cost.
The COP314L and COP214L are exact functional equivalents but extended temperature versions of COP414L. The COP414L can be emulated by the COP404C.

## Features

- Late waferfab programming of ROM and I/O for fast delivery of units
- Low cost
- Powerful instruction set
- $512 \times 8$ ROM, $32 \times 4$ RAM
- 15 I/O lines (COP410L)
- Two-level subroutine stack
- $16 \mu \mathrm{~s}$ instruction time

■ Single supply operation (4.5V-6.3V)

- Low current drain ( 6 mA max)
- Internal binary counter register with MICROWIRETM serial I/O capability
■ General purpose and TRI-STATE® outputs
- LSTTL/CMOS compatible in and out
- Inputs and open drain outputs able to withstand 15 V
- Software/hardware compatible with other members of COP400 family
- Extended temperature range device
- COP314L $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
- COP214L ( $-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$ )
m Wider supply range ( $4.5 \mathrm{~V}-9.5 \mathrm{~V}$ ) optionally available

Block Diagram


FIGURE 1

## COP414L

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.

Voltage at Any Pin Relative to GND
Ambient Operating Temperature
Ambient Storage Temperature

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+10 \mathrm{~V} \\
0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
300^{\circ} \mathrm{C}
\end{array}
$$

Power Dissipation COP414L
0.65 W at $25^{\circ} \mathrm{C}$ 0.3 W at $70^{\circ} \mathrm{C}$

Total Source Current 120 mA
Total Sink Current 100 mA Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Mln | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 1) | 4.5 | 6.3 | V |
| Optional Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 | 9.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 6 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Ceramic Resonator Input ( $\div 8$ ) <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> Schmitt Trigger Input ( $\div 4$ ) <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> RESET Input Levels <br> Logic High <br> Logic Low <br> SO Input Level (Test Mode) <br> All Other Inputs <br> Logic High <br> Logic High <br> Logic Low <br> Logic High <br> Logic Low | $\begin{aligned} & V_{C C}=M a x \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ <br> (Schmitt Trigger Input) <br> (Note 2) $V_{C C}=\operatorname{Max}$ <br> With TTL Trip Level Options Selected, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ With High Trip Level Options Selected | $\begin{gathered} 3.0 \\ 2.0 \\ -0.3 \\ 0.7 V_{C C} \\ -0.3 \\ \\ 0.7 V_{C C} \\ -0.3 \\ 2.0 \\ \\ 3.0 \\ 2.0 \\ -0.3 \\ 3.6 \\ -0.3 \\ \hline \end{gathered}$ | $\begin{aligned} & 0.4 \\ & 0.6 \\ & 0.6 \\ & 2.5 \\ & \\ & 0.8 \\ & 1.2 \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & \\ & v \\ & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage | $\begin{aligned} & V_{\text {IN }}<9.5 \mathrm{~V} \\ & 9.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq 15 \mathrm{~V} \end{aligned}$ | $\begin{gathered} -1 \\ -10 \end{gathered}$ | $\begin{gathered} +1 \\ +10 \end{gathered}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Output Voltage Levels LSTTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-25 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=0.36 \mathrm{~mA} \\ & \hline \end{aligned}$ | 2.7 | 0.4 | $\begin{aligned} & v \\ & v \end{aligned}$ |
| CMOS Operation (Note 3) Logic High Logic Low | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-1$ | 0.2 | $\begin{aligned} & V \\ & v \end{aligned}$ |

Note 1: $\mathrm{V}_{\mathrm{CC}}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: SO output " 0 " level must be less than 0.8 V for normal operation.
Note 3: TRI-STATE* and LED configurations are excluded.

| COP414L DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted (Continued) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Parameter | Conditions | Min | Max | Units |
| Output Current Levels <br> Output Sink Current <br> SO and SK Ouputs (loL) <br> $L_{0}-L_{7}$ Outputs, $G_{0}-G_{3}$ and <br> LSTTL $D_{0}-D_{3}$ Outputs (IOL) <br> CKI (Single-pin RC Oscillator) CKO <br> Output Source Current Standard Configuration, All Outputs (IOH) <br> Push-Pull Configuration SO and SK Outputs (IOH) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5, \mathrm{~V}_{\mathrm{IH}}=3.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \\ & \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 1.8 \\ 1.2 \\ 0.9 \\ 0.4 \\ 0.4 \\ 0.4 \\ 2 \\ 0.2 \\ \\ -140 \\ -75 \\ -30 \\ -1.4 \\ -1.4 \\ -1.2 \end{gathered}$ | $\begin{aligned} & -800 \\ & -480 \\ & -250 \end{aligned}$ | mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {IL }}=0 \mathrm{~V}$ | -10 | -140 | $\mu \mathrm{A}$ |
| Open Drain Output Leakage | $\begin{aligned} & V_{\text {OUT }}<9.5 \mathrm{~V} \\ & 9.5 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq 15 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & -2.5 \\ & -25 \end{aligned}$ | $\begin{aligned} & +2.5 \\ & +25 \end{aligned}$ | $\mu \mathrm{A}$ |
| Total Sink Current Allowed All Outputs Combined D Port $L_{7}-L_{4}$, G Port $L_{3}-L_{0}$ Any Other Pin | - |  | $\begin{gathered} 100 \\ 100 \\ 4 \\ 4 \\ 2.0 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |
| Total Source Current Allowed All I/O Combined $\mathrm{L}_{7}-\mathrm{L}_{4}$ $\mathrm{~L}_{3}-\mathrm{L}_{0}$ Each L Pin Any Other Pin |  |  | $\begin{gathered} 120 \\ 60 \\ 60 \\ 25 \\ 1.5 \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |

## COP314L/COP214L

## Absolute Maximum Ratings

Specifications for Military/Aerospace products aré not contained in thls datasheet. Refer to the assoclated rellability electrical test specifications document.

Voltage at Any Pin Relative to GND
Ambient Operating Temperature

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+10 \mathrm{~V} \\
-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}
\end{array}
$$

$300^{\circ} \mathrm{C}$

| Power Dissipation |  |
| :--- | ---: |
| COP314L/COP214L | 0.65 W at $25^{\circ} \mathrm{C}$ |
|  | 0.20 W at $85^{\circ} \mathrm{C}$ |
| Total Source Current | 120 mA |
| Total Sink Current | 100 mA |
| Note: Absolute maximum ratings indicate limits beyond |  |
| which damage to the device may occur. DC and AC electri- |  |
| cal specifications are not ensured when operating the de- |  |
| vice at absolute maximum ratings. |  |

## DC Electrical Characteristics

COP214L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+110^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted
COP314L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage (VCC) | (Note 1) | 4.5 | 5.5 | V |
| Optional Operating Voltage (VCC) |  | 4.5 | 7.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 8 | mA |
| Input Voltage Levels <br> Ceramic Resonator Input ( $\div 8$ ) Crystal Input Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic High ( $\mathrm{V}_{1 \mathrm{H}}$ ) Logic Low ( $\mathrm{V}_{1 \mathrm{~L}}$ ) <br> Schmitt Trigger Input ( $\div 4$ ) <br> Logic High ( $\mathrm{V}_{1 \mathrm{H}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> RESET Input Levels <br> Logic High Logic Low <br> SO Input Level (Test Mode) <br> All Other Inputs <br> Logic High <br> Logic High <br> Logic Low <br> Logic High <br> Logic Low <br> Input Capacitance | $\begin{aligned} & V_{C C}=M a x \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ <br> (Schmitt Trigger Input) <br> (Note 2) $V_{c c}=\operatorname{Max}$ <br> WIth, TTL Trip Level Options <br> Selécted, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ <br> With High Trip Level Options <br> Selected | $\begin{gathered} 3.0 \\ 2.2 \\ -0.3 \\ \\ 0.7 \mathrm{VCC}_{\mathrm{CC}} \\ -0.3 \\ \\ 0.7 \mathrm{VCC} \\ -0.3 \\ 2.2 \\ \\ 3.0 \\ 2.2 \\ -0.3 \\ 3.6 \\ -0.3 \end{gathered}$ | $\begin{gathered} 0.3 \\ 0.4 \\ 0.4 \\ 2.5 \\ \\ \\ 0.6 \\ 1.2 \\ 7 \end{gathered}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & p \\ & \hline \end{aligned}$ |
| Hi-Z Input Leakage | $\begin{aligned} & V_{\text {IN }}<7.5 \mathrm{~V} \\ & 7.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq 15 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} -2 \\ -20 \end{gathered}$ | $\begin{gathered} +2 \\ +20 \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| Output Voltage Levels LSTTL Operation Logic High ( $\mathrm{VOH}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{l}_{\mathrm{OH}}=-20 \mu \mathrm{~A} \\ & \mathrm{l}_{\mathrm{OL}}=0.36 \mathrm{~mA} \end{aligned}$ | 2.7 | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ |
| CMOS Operation (Note 3) Logic High Logic Low | $\begin{aligned} & \mathrm{l}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $V_{C C}-1$ | 0.2 | $\begin{aligned} & V \\ & v \end{aligned}$ |

Note 1: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: SO output "0" level must be less than 0.6 V for normal operation.
Note 3: TRI-STATE and LED configurations are excluded.

DC Electrical Characteristics (Continued)
COP214L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+110^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted
COP314L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels <br> Output Sink Current <br> SO and SK Outputs(lou) <br> $L_{0}-L_{7}$ Outputs, $G_{0}-G_{3}$ and LSTTL, $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs (loL) <br> CKI (Single-pin RC Oscillator) CKO <br> Output Source Current Standard Configuration, All Outputs (IOH) <br> Push-Pull Configuration SO and SK Outputs (lOH) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \\ & \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 1.4 \\ 1.0 \\ 0.8 \\ 0.4 \\ 0.4 \\ 0.4 \\ 1.5 \\ 0.2 \\ \\ -100 \\ -55 \\ -28 \\ -0.85 \\ -1.1 \\ -1.2 \end{gathered}$ | $\begin{aligned} & -900 \\ & -600 \\ & -350 \end{aligned}$ | mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ <br> $\mu A$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}$ | -10 | -200 | $\mu \mathrm{A}$ |
| Open Drain Output Leakage | $\begin{aligned} & V_{\text {OUT }}<7.5 \mathrm{~V} \\ & 7.5 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq 15 \mathrm{~V} \end{aligned}$ | $\begin{gathered} -5 \\ -50 \end{gathered}$ | $\begin{gathered} +5 \\ +50 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Total Sink Current Allowed <br> All Outputs Combined <br> D Port <br> $L_{7}-L_{4}$, G Port <br> $L_{3}-L_{0}$ <br> Any Other Pins |  |  | $\begin{gathered} 100 \\ 100 \\ 4 \\ 4 \\ 1.5 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |
| Total Source Current Allowed All I/O Combined $\mathrm{L}_{7}-\mathrm{L}_{4}$ $L_{3}-L_{0}$ Each L Pin Any Other Pins |  |  | $\begin{gathered} 120 \\ 60 \\ 60 \\ 25 \\ 1.5 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |

## AC Electrical Characteristics

COP414L: $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted
COP314L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted
COP214L: $-40^{\circ} \mathrm{C} \leq T_{A} \leq+110^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V} C \mathrm{C} \leq 7.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time - tc CKI |  | 16 | 40 | $\mu \mathrm{S}$ |
| Input Frequency - $f_{l}$ | $\begin{aligned} & \div 8 \text { Mode } \\ & \div 4 \text { Mode } \end{aligned}$ | $\begin{aligned} & 0.2 \\ & 0.1 \end{aligned}$ | $\begin{gathered} 0.5 \\ 0.25 \end{gathered}$ | MHz MHz |
| Duty Cycle |  | 30 | 60 | \% |
| Rise Time | $\mathrm{f}_{\mathrm{l}}=0.5 \mathrm{MHz}$ |  | 500 | ns |
| Fall Time |  |  | 200 | ns |
| CKI Using RC ( $\div 4$ ) | $\begin{aligned} & R=56 \mathrm{k} \Omega \pm 5 \% \\ & \mathrm{C}=100 \mathrm{pF} \pm 10 \% \end{aligned}$ |  |  |  |
| Instruction Cycle Time (Note 1) |  | 16 | 28 | $\mu \mathrm{s}$ |
| CKO as SYNC Input tsync |  | 400 |  |  |
| Inputs |  |  |  |  |
| $\mathrm{G}_{3}-\mathrm{G}_{0}, L_{7}-L_{0}$ |  |  |  |  |
| tsetup |  | 8.0 |  | $\mu \mathrm{s}$ |
| thold |  | 1.3 |  | $\mu \mathrm{s}$ |
| SI |  |  |  |  |
| ${ }^{\text {t SETUP }}$ |  | 2.0 |  | $\mu \mathrm{s}$ |
| thold |  | 1.0 |  | $\mu \mathrm{S}$ |
| Output Propagation Delay | Test Condition: $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V}$ |  |  |  |
| SO, SK Outputs $t_{\text {pd } 1}, t_{\text {pd }}$ |  |  | 4.0 | $\mu \mathrm{S}$ |
| All Other Outputs $t_{\text {pd1 }}, t_{\text {pd0 }}$ |  |  | 5.6 | $\mu \mathrm{s}$ |

Note 1: Variation due to the device included.

## Connection Diagram

| Dual-In-LIne Package |  |  |  |
| :---: | :---: | :---: | :---: |
| L4-1 | 20 | - 5 |  |
| $\mathrm{V}_{\mathrm{CC}}=2$ | 19 | -L6 |  |
| $13-3$ | 18 | -17 |  |
| 12 - 4 | 17 | - $\overline{\text { RESET }}$ |  |
| $11-5$ | 16 | -CKI |  |
| L0- 6 | 15 | CKO |  |
| $\mathrm{St}-7$ | 14 | G3 |  |
| SO-8 | 13 | -G2 |  |
| SK-9 | 12 | -61 |  |
| GND-10 | 11 | -60 |  |
|  |  |  | TL/DD/8814-2 |

Order Number COP414L/M or N, COP314L/M or N, or COP214L/M or N See NS Package Number M20B or N20A

FIGURE 2

## Pin Descriptions

| Pin | Description | Pln | Description |
| :--- | :--- | :--- | :--- |
| $L_{7}-L_{0}$ | 8 bidirectional I/O ports with TRI-STATE | SK | Logic-controlled clock (or general purpose output) |
| $\mathrm{G}_{3}-\mathrm{G}_{0}$ | 4 bidirectional I/O ports $\left(\mathrm{G}_{2}-\mathrm{G}_{0}\right.$ for COP411L) | CKI | System oscillator input |
| SI | Serial input (or counter input) | CKO | System oscillator output |
| SO | Serial output (or general purpose output) | RESET | System reset input |
|  |  | VCC | Power supply |
|  |  | GND | Ground |

## Timing Diagrams



FIGURE 3. Input/Output Timing Diagrams (Ceramic Resonator Divide-by-8 Mode)


TL/DD/8814-4

## Functional Description

A block diagram of the COP414L is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).
All functional references to the COP414L also apply to the COP314L.

## PROGRAM MEMORY

Program Memory consists of a 512-byte ROM. As can be seen by an examination of the COP414L instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 8 pages of 64 words each.
ROM addressing is accomplished by a 9-bit PC register. Its binary value selects one of the 5128 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 9 -bit binary count value. Two levels of subroutine nesting are implemented by the 9 -bit subroutine save registers, SA and SB, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 128 -bit RAM, organized as 4 data registers of 8 4-bit digits. RAM addressing is implemented by a 6 -bit B register whose upper 2 bits ( Br ) select 1 of 4 data registers and lower 3 bits of the 4 -bit Bd select 1 of 84 -bit digits in the selected data register. While the 4 -bit contents of the selected RAM digit (M) is usually loaded into or from, or exchanged with, the A register (accumulator), it
may also be loaded into the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the XAD 3,15 instruction.
The most significant bit of Bd is not used to select a RAM digit. Hence each physical digit of RAM may be selected by two different values of Bd as shown in Figure 4 below. The skip condition for XIS and XDS instructions will be true if Bd changes between 0 and 15, but NOT between 7 and 8 (see Table III).


TL/DD/8814-5
FIGURE 4. RAM Digit Address to Physical RAM Digit Mapping

## Functional Description (Continued)

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Bd portion of the B register, to load 4 bits of the 8 -bit Q latch data, to input 4 bits of the 8 -bit L I/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions of the COP410L/411L, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.)
The $G$ register contents are outputs to 4 general-purpose bidirectional I/O ports.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are output to the LI/O ports when the L drivers are enabled under program control. (See LEl instruction.)
The 8 L drivers, when enabled, output the contents of latched Q data to the L I/O ports. Also, the contents of L may be read directly into $A$ and $M . L I / O$ ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with $Q$ data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with A , allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers.
The XAS instruction copies C into the SKL Latch. In the counter mode, SK is the output of SKL in the shift register mode, SK outputs SKL ANDed with internal instruction cycle clock.
The EN register is an internal 4-bit register loaded under program control by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $E N_{3}-E N_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4-bit binary counter. With $\mathrm{EN}_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon
each low-going pulse (" 1 " to " 0 ") occuring on the St input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. $E N_{1}$ is not used. It has no effect on COP414L operation.
3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in $Q$ to the L I/O ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high-impedance input state.
4. $E N_{3}$, in conjunction with $E N_{0}$, affects the $S O$ output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $E N_{3}$. With $E N_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with $A$ via an XAS instruction but SO remains reset to " 0 ". Table I provides a summary of the modes associated with $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the $\overline{R E S E T}$ pin as shown below (Figure 5). The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to $\mathrm{V}_{\mathrm{CC}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.


RC $\geq 5 \times$ Power Supply Rise Time TL/DD/8814-6
FIGURE 5. Power-Up Clear CIrcult

TABLE I. Enable Reglster Modes-BIts EN 3 and EN0

| $\mathrm{EN}_{3}$ | EN0 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=\text { Clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | $\begin{aligned} & \text { If } \mathrm{SKL}=1, \mathrm{SK}=\text { Clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | $\begin{aligned} & \text { If } S K L=1, S K=1 \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | $\begin{aligned} & \text { If } S K L=1, S K=1 \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |

## Functional Description (Continued)

Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the A, B, C, D, EN and G registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.


Ceramic Resonator Oscillator

| Resonator <br> Value | Components Values |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | R1 ( $\Omega$ ) | R2 ( $\Omega)$ | $\mathbf{C 1}(\mathrm{pF})$ | $\mathbf{C 2}(\mathrm{pF})$ |
| 455 kHz | 4.7 k | 1 M | 220 | 220 |

RC Controlled Oscillator

| $\mathbf{R ( k \Omega )}$ | $\mathbf{C}(\mathbf{p F})$ | Instruction <br> Cycle Time <br> In $\mu \mathbf{s}$ |
| :---: | :---: | :---: |
| 51 | 100 | $19 \pm 15 \%$ |
| 82 | 56 | $10 \pm 13 \%$ |

Note: $200 \mathrm{k} \Omega \geq \mathrm{R} \geq 25 \mathrm{k} \Omega .360 \mathrm{pF} \geq \mathrm{C} \geq 50 \mathrm{pF}$. Does not include tolerances.
FIGURE 6. COP414L Oscillator

## OSCILLATOR

There are four basic clock oscillator configurations available as shown by Figure 6.
a. Resonator Controlled Oscillator. CKI and CKO are connected to an external ceramic resonator. The instruction cycle frequency equals the resonator frequency divided by 8.
b. External Oscillator. CKI is an external clock input signal. The external frequency is divided by 8 to give the instruction frequency time. CKO is no connection.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is no connection.

## CKO PIN OPTIONS

In a resonator controlled oscillator system, CKO is used as an output to the resonator network. CKO is no connection for External or RC controlled oscillator.

## I/O OPTIONS

COP414 inputs and outputs have the following optional configurations, illustrated in Figure 7:
a. Standard-an enhancement-mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with LSTTL and CMOS input requirements. Available on SO, SK and all D and G outputs.
b. Open-Draln-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. Available on SO, SK and all D and G outputs.
c. Push-Pull-an enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{CC}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. Available on SO and SK outputs only.
d. Standard L-same as a., but may be disabled. Available on $L$ outputs only.
e. Open Drain L-same as b., but may be disabled. Available on L outputs only.
f. An on-chip depletion load device to $V_{C C}$.
g. A Hi-Z input which must be driven to a " 1 " or " 0 " by external components.
The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6, respectively). Minimum and maximum current (lout and $V_{\text {OUT }}$ ) curves are given in Figure 8 for each of these devices to allow the designer to effectively use these I/O configurations in designing a COP414 system.
The SO, SK outputs can be configured as shown in a., b., or c. The $G$ outputs can be configured as shown in a. or b. Note that when inputting data to the $G$ ports, the $G$ outputs should be set to " 1 ". The L outputs can be configured as in d.

An important point to remember if using configuration $d$. with the $L$ drivers is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current. (See Figure 8, device 2.) However, when the L port is used as input, the disabled depletion device CANNOT be relied on to source sufficient current to pull an input to a logic " 1 ".

## COP411L

If the COP410L is bonded as a 20-pin device, it becomes the COP411L, illustrated in Figure 2, COP410L/411L Connection Diagrams. Note that the COP411L does not contain D2, D3, G3 or CKO. Use of this option of course precludes use of D2, D3, G3 and CKO options. All other options are available for the COP411L.

Functional Description (Continued)
a. Standard Output

TL/DD/8814-8
b. Open-Drain Output
c. Push-Pull Output

d. Standard L. Output



TL/DD/8814-9

g. Hi-Z Input

TL/DD/8814-10
e. Open-Drain L Output
DISABLE
TL/DD/8814-12
f. Input with Load

FIGURE 7. Input and Output Configurations

## Typical Performance Curves

Input Current for LO through



TL/DD/8814-15

Source Current for LO through L7 in TRI-STATE Configuration (High Current Option)



Source Current for SO and SK in Push-Pull Configuration


FIGURE 8a. COP414 I/O DC Current Characteristics

Typical Performance Curves (Continued)



Output SInk Current for SO and SK


Source Current for Standard Output Configuration


Output Sink Current for L0-L7 and Standard Drive Option for G0-G3


FIGURE 8b. COP314L/COP214L Input/Output Characteristics

## COP414 Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table III provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with each instruction in the COP410L/411L instruction set.

TABLE II. COP414L Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| PC | 9-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| SA | 9-bit Subroutine Save Register A |
| SB | 9-bit Subroutine Save Register B |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |


| Symbol | Definition |
| :---: | :---: |
| INSTRUCTION OPERAND SYMBOLS |  |
| d | 4-bit Operand Field, 0-15 binary (RAM Digit Select) |
| $r$ d | 2-bit Operand Field, 0-3 binary (RAM Register Select) |
| a | 9 -bit Operand Field, 0-511 binary (ROM Address) |
|  | 4-bit Operand Field, 0-15 binary (Immediate Data) |
| RAM(s) | Contents of RAM location addressed by s |
| ROM(t) | Contents of ROM location addressed by t |
| OPERATIONAL SYMBOLS |  |
| + | Plus |
| - | Minus |
| $\rightarrow$ | Replaces |
| $\longleftrightarrow$ | Is exchanged with |
| $=1$ | Is equal to |
| $\overline{\text { A }}$ | The one's complement of A |
| $\oplus$ | Exclusive-OR |
|  | Range of values |

TABLE III. COP414L Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 0011 ${ }^{\text {0000 }}$ | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 001110001 | $A+\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A}$ | None | Add RAM to A |
| AISC | y | 5- | 0101\| y | $A+y \rightarrow A$ | Carry | Add Immediate, Skip on Carry ( $y \neq 0$ ) |
| CLRA |  | 00 | 0000 0000 | $0 \rightarrow A$ | None | Clear A |
| COMP |  | 40 | 0100/0000 | $\overline{\mathrm{A}} \rightarrow \mathrm{A}$ | None | One's complement of A to A |
| NOP |  | 44 | 010010100 | None | None | No Operation |
| RC |  | 32 | 0011 0010 | $" 0 " \rightarrow \mathrm{C}$ | None | Reset C |
| SC |  | 22 | 001010010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | 0000 0010 | $A \oplus \operatorname{RAM}(\mathrm{~B}) \rightarrow \mathrm{A}$ | None | Exclusive-OR RAM with A |

COP414L Instruction Set (Continued)
TABLE III. COP414L Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code <br> (Binary) | Data Flow | Skip Conditions | Description |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## TRANSFER OF CONTROL INSTRUCTIONS

| JID |  | FF | [1111\|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 2) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JMP | a | 6- | $\frac{0110\|000\| a_{8} \mid}{a_{7: 0}}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  |  | $a \rightarrow P C_{6: 0}$ $a \rightarrow P C_{5: 0}$ | None | Jump within Page (Note 3) |
| JSRP | a | -- | 10\| $\mathbf{a}_{5: 0}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 4) |
| JSR | a | $6-$ | $\begin{array}{\|c\|c\|c\|c\|c\|} \hline a_{7}\|0\| \\ \hline \end{array}$ | $\xrightarrow{\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB}} \mathrm{a} \mathrm{\rightarrow PC}$ | None | Jump to Subroutine |
| RET |  | 48 | 0100\|1000 | SB $\rightarrow$ SA $\rightarrow$ PC | None | Return from Subroutine |
| RETSK |  | 49 | 0100\|1001| | $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | $\begin{aligned} & 33 \\ & 3 C \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0011 & 0011 \\ \hline 0011 & 1100 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{A} \rightarrow Q_{7: 4} \\ & \operatorname{RAM}(B) \xrightarrow{\rightarrow} Q_{3: 0} \end{aligned}$ | None | Copy A, RAM to Q |
| COMA |  | $\begin{aligned} & 23 \\ & 2 C \end{aligned}$ | 0011 0011 <br> 0010 1100 | $\begin{aligned} & \mathrm{Q}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{Q}_{3: 0} \rightarrow \mathrm{~A} \end{aligned}$ | None | Copy Q to RAM, A |
| LD | r | -5 | 00\|r|0101 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A, Exclusive-OR Br with r |
| LQID |  | BF |  <br> 1111 | $\begin{aligned} & \operatorname{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SA} \rightarrow \mathrm{SB} \end{aligned}$ | None | Load Q Indirect (Note 2) |
| RMB | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | $4 C$ 45 42 43 | 0100 1100 <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{array}{lll} 0 & \rightarrow & R A M(B)_{0} \\ 0 & \rightarrow & R A M(B)_{1} \\ 0 & \rightarrow & R A M(B)_{2} \\ 0 & \rightarrow & R A M(B)_{3} \end{array}$ | None | Reset RAM Bit |
| SMB | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | $4 D$ 47 46 48 | 0100 1101 <br> 0100 0111 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} 1 & \rightarrow \text { RAM }(B)_{0} \\ 1 & \rightarrow \text { RAM }(B)_{1} \\ 1 & \rightarrow R A M(B)_{2} \\ 1 & \rightarrow \operatorname{RAM}(B)_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | y | 7- | 0111 ${ }^{\text {d }}$ | $\begin{aligned} & y \rightarrow \operatorname{RAM}(\mathrm{~B}) \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | r | -6 | 00\|r|0110 | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with $A$, Exclusive-OR Br with $r$ |
| XAD | 3,15 | $\begin{aligned} & 23 \\ & \mathrm{BF} \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0010 & 0011 \\ \hline 1011 & 1111 \\ \hline \end{array}$ | $\operatorname{RAM}(3,15) \longleftrightarrow \mathrm{A}$ | None | Exchange A with RAM $(3,15)$ |
| XDS | r | -7 | 00\|r|0111 | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \longrightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd, Exclusive-OR Br with $r$ |
| XIS | r | -4 | $\underline{00\|r\| 0100 \mid}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \longrightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with A and Increment Bd Exclusive-OR Br with $r$ |

TABLE III. COP414L Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REGISTER REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAB |  | 50 | 10101 0000 | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| CBA |  | 4E | [0100\|1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d | -- | $\frac{\|00\| r\|(d-1)\|}{(d=0,9: 15)}$ | $r$ r,d $\rightarrow$ B | Skip until not a LBI | Load B Immediate with r,d (Note 5) |
| LEI | $y$ | $\begin{aligned} & 33 \\ & 6- \\ & \hline \end{aligned}$ | $$ | $y \rightarrow E N$ | None | Load EN Immediate (Note 6) |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  | 20 | $\underline{0010 \mid 0000}$ |  | $\mathrm{C}=$ "1" | Skip if C is True |
| SKE |  | 21 | 10010\|0001 |  | $A=R A M(B)$ | Skip if A Equals RAM |
| SKGZ |  | 33 21 | $0011\|0011\|$ <br> $0010\|0001\|$ |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
| SKGBZ |  |  | \|0011 00011 | | 1st byte |  | Skip if G Bit is Zero |
|  | 0 | 01 | 0000\|0001| |  | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 0001\|00011 | 2nd byte | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 | $\int 2 n d$ byte | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 0001/0011 |  | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 000010001 |  | $\operatorname{RAM}(\mathrm{B})_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | 00010001 |  | $\operatorname{RAM}(B)_{1}=0$ |  |
|  | 2 | 03 | 0000 00011 |  | $\operatorname{RAM}(\mathrm{B})_{2}=0$ |  |
|  | 3 | 13 | 00010011 |  | $\operatorname{RAM}(\mathrm{B})_{3}=0$ |  |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 0011 00011 ] | $G \rightarrow A$ | None | Input G Ports to A |
|  |  | 2 A | \|0010|1010 |  |  |  |
| INL |  | 33 | 10011 0011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2E | \|0010|1110 | $L_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | 0011\|0011| | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3 E | 0011\|1110 |  |  |  |
| OMG |  | 33 | 0011\|0011 | RAM(B) $\rightarrow$ G | None | Output RAM to G Ports |
|  |  | 3A | 0011 1010 |  |  |  |
| XAS |  | 4F | 0100\|1111 | A $\longleftrightarrow$ SIO, C $\rightarrow$ SKL | None | Exchange A with SIO <br> (Note 2) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit $A$ register.
Note 2: For additional information on the operation of the XAS, JID, and LQID instructions, see below.
Note 3: The JP instruction allows a jump, while in subroutine pages 2 or 3 , to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 4: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 5: The machine code for the lower 4 bits of the LBl instruction equals the binary value of the " d " data minus 1, e.g., to load the lower four bits of B (Bd) with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBl instruction should equal $15\left(1111_{2}\right)$.
Note 6: Machine code for operand field y for LEl instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Option List

The COP414L mask-programmable options are assigned numbers which correspond with the COP414L pins.
The following is a list of COP414L options. The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
Option 1: $L_{4}$ Driver
$=0$ : Standard output
= 1: Open-drain output
Option 2: $\mathrm{V}_{\mathrm{CC}}$ Pin
$=0: 4.5 \mathrm{~V}$ to 6.3 V operation
$=1: 4.5 \mathrm{~V}$ to 9.5 V operation
Option 3: $\mathrm{L}_{3}$ Driver
same as Option 1
Option 4: $\mathrm{L}_{2}$ Driver same as Option 1
Option 5: $L_{1}$ Driver same as Option 1
Option 6: $\mathrm{L}_{6}$ Driver same as Option 1
Option 7: SI Input $=0$ : load device to $V_{C C}$ = 1: Hi-Z Output
Option 8: SO Driver
$=0:$ Standard output
= 1: Open-drain output
$=2$ : Push-pull output
Option 9: SK Driver same as Option 8
Option 10:
= 0: Ground Pin-no options available
Option 11: $\mathrm{G}_{0}$ I/O Port
$=0$ : Standard output
= 1: Open-drain output
Option 12: $\mathrm{G}_{1}$ I/O Port same as Option 11
Option 13: $\mathrm{G}_{2}$ I/O Port same as Option 11
Option 14: G $\mathrm{G}_{3}$ /O Port same as Option 11
Option 15: CKO Output $=0$ : Clock output to ceramic resonator = 1: No connection
Option 16: CKI Input $=0$ : Ocillator input divided by $8(500 \mathrm{kHz} \max )$ = 1: Single pin RC controlled oscillator divided by 4
= 2: External Schmitt trigger level clock divided by 4
Option 17: $\overline{\text { RESET Input }}$
$=0$ : Load device to $V_{C C}$
= 1: Hi-Z Input
Option 18: L7 Driver same as Option 3
Option 19: $\mathrm{L}_{6}$ Driver
same as Option 1
Option 20: $\mathrm{L}_{6}$ Driver same as Option 2

Option 21: L Input Levels
$=0$ : Standard TTL input levels (" 0 " $=0.8 \mathrm{~V}, " 1 "=$ 2.0V)
= 1: Higher voltage input levels (" 0 " = $1.2 \mathrm{~V}, " 1 "=$ 3.6V)

Option 22: G Input Levels same as Option 21
Option 23: SI Input Levels same as Option 21
Option 24: Internal Initialization $=0$ : Power on reset enabled = 1: Disabled
Option 25: 15V Hi-Z Inputs/Open Drain Outputs
$=0$ : Regular operation
$=1$ : Must withstand 15 V

## TEST MODE (NON-STANDARD OPERATION)

The SO output has been configured to provide for standard test procedures for the custom-programmed COP414L. With SO forced to logic "1", two test modes are provided, depending upon the value of SI :
a. RAM and Internal Logic Test Mode $(\mathrm{SI}=1)$
b. ROM Test Mode $(\mathrm{SI}=0)$

These special test modes should not be employed by the user; they are intended for manufacturing tests only.

## COP414L Option List

Please fill out the Option List and send it with the EPROM.
Option Data

| OPTION 1 | IS: $L_{4}$ DRIVER |
| :---: | :---: |
| OPTION 2 | IS: $\mathrm{V}_{C C}$ PIN |
| OPTION 3 VALUE | IS: $L_{3}$ DRIVER |
| OPTION 4 VALUE | IS: $L_{2}$ DRIVER |
| OPTION 5 VALUE | IS: $L_{1}$ DRIVER |
| OPTION 6 VALUE | IS: $L_{6}$ DRIVER |
| OPTION 7 VALUE | IS: SI INPUT |
| OPTION 8 VALUE | IS: SO DRIVER |
| OPTION 9 VALUE | IS: SK DRIVER |
| OPTION 10 VALUE | IS: 0 GROUND PIN |
| OPTION 11 VALUE | IS: $\mathrm{G}_{0}$ I/O PORT |
| OPTION 12 VALUE | IS: $\mathrm{G}_{1}$ I/O PORT |
| OPTION 13 VALUE | IS: $\mathrm{G}_{2}$ I/O PORT |
| OPTION 14 VALUE | IS: $\mathrm{G}_{3}$ I/O PORT |
| OPTION 15 VALUE | IS: CKO OUTPUT |
| OPTION 16 VALUE | IS: CKI INPUT |
| OPTION 17 VALUE | IS: RESET INPUT |
| OPTION 18 VALUE | IS: L7 DRIVER |
| OPTION 19 VALUE | IS: $L_{6}$ DRIVER |
| OPTION 20 VALUE | IS: L6 DRIVER |
| OPTION 21 VALUE | IS: L INPUT LEVELS |
| OPTION 22 VALUE | IS: G INPUT LEVELS |
| OPTION 23 VALUE | IS: SI INPUT LEVELS |
| OPTION 24 VALUE | IS: INTERNAL INITIALIZATION |
| OPTION 25 VALUE | IS: 15V Hi-Z INPUTS/ OPEN DRAIN OUTPUTS |

## Development Support

The MOLE (Microcontroller On Line Emulator) is a low cost development system and real time emulator for COPS' products. They also include TMP, 8050 and the new 16 bit HPC microcontroller family. The MOLE provides effective support for the development of both software and hardware in the user's applicaton.
The purpose of the MOLE is to provide a tool to write and assemble code, emulate code for the target microcontroller and assist in debugging of the system.
The MOLE can be connected to various hosts, IBM PC, STARPLEXTM, Kaypro, Apple and Intel systems, via RS-232 port. This link facilitates the up loading/down loading of code, supports host assembly and mass storage.
The MOLE consists of three parts; brain, personality and optional host software.
The brain board is the computing engine of the system. It is a self-contained computer with its own firmware which provides for all system operation, emulation control, communication, from programming and diagnostic operation. It has three serial ports which can be connected to a terminal, host system, printer, modem or to other MOLE's in a multiMOLE environment.

The personality board contains the necessary hardware and firmware needed to emulate the target microcontroller. The emulation cable which replaces the target controller attaches to this board. The software contains a cross assembler and a communications program for up loading and down loading code from the MOLE.

MOLE Ordering Information

| P/N | Description |
| :---: | :---: |
| MOLE-BRAIN | MOLE Computer Board |
| MOLE-COPS-PB1 | COPS Personality Board |
| MOLE-XXX-YYY | Optional Software |
| Where XXX | $=$ COPS |
| YYY | $=$ Host System, IBM, Apple, |
| KAY (Kaypro), CP/M |  |

## COPS Programming Manual

For detailed information on writing COPS programs, the COPS Programming Manual 424410284-001 provides an indepth discussion of the COPS architecture, instruction set and general techniques of COPS programming. This manual is written with the programmer in mind.

# COP417C/COP418C/COP317C/COP318C/ COP217C/COP218C Single-Chip CMOS Microcontrollers 

## General Description

The COP417C, COP418C, COP317C, COP318C, COP217C and COP218C fully static, single-chip CMOS microcontrollers are members of the COPSTM family, fabricated using double-poly, silicon-gate CMOS technology. These control-ler-oriented processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture, and I/O scheme designed to facilitate keyboard input, display output, and BCD data manipulation. The COP418C is identical to the COP417C but with 16 I/O lines instead of 20 . They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized controller-oriented processor at a low end-product cost.
The COP317C/COP318C/COP217C/COP218C is the extended temperature range version of the COP417C/ COP418C.

## Features

- Lowest power dissipation ( $25 \mu \mathrm{~W}$ typical)
- Fully static (can turn off clock)
- Power-saving HALT mode
- $2 \mu \mathrm{~s}$ instruction cycle time, plus software selectable clocks
- $512 \times 8$ ROM, $32 \times 4$ RAM
- 18 I/O lines (COP417C)

■ Two-level subroutine stack
■ Síngle supply operation ( 2.4 V to 6.0 V )

- Internal binary counter register with MICROWIRETM serial I/O capability
- General purpose and TRI-STATE ${ }^{\text {® }}$ outputs
- Open-drain outputs and Hi-Z inputs operational at 12 volts
- Internal initialization on power-up optionally available
- External HALT mode wake-up optionally available
- LSTTL/CMOS compatible
- High-sink current optionally available
- Software/hardware compatible with COP400 family
- Extended temperature range devices COP317C/ COP318C $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
- Military temperature range devices COP217C/COP218C $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

Block Diagram


## COP420/COP421/COP422 and COP320/COP321/COP322 Single-Chip N-Channel Microcontrollers

## General Description

The COP420, COP421, COP422, COP320, COP321 and COP322 Single-Chip N-Channel Microcontrollers are members of the COPSTM family, fabricated using N -channel, silicon gate MOS technology. They are complete microcomputers containing all system timing, internal logic, ROM, RAM and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture and I/O scheme designed to facilitate keyboard input, display output and BCD data manipulation. The COP421 is identical to the COP420, except with 19 I/O lines instead of 23; the COP422 has 15 I/O lines. They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized Controller Oriented Processor at a low end-product cost.
The COP320 is the extended temperature range version of the COP420 (likewise the COP321 and COP322 are the extended temperature range versions of the COP421/ COP422). The COP320/321/322 are exact functional equivalents of the COP420/421/422.

Features
■ Low cost

- Powerful instruction set
- $1 \mathrm{k} \times 8$ ROM, $64 \times 4$ RAM

■ 23 I/O lines (COP420, COP320)
■ True vectored interrupt, plus restart

- Three-level subroutine stack
- $4.0 \mu \mathrm{~s}$ instruction time
- Single supply operation

■ Internal time-base counter for real-time processing
■ Internal binary counter register with MICROWIRETM compatible serial I/O capacity

- General purpose and TRI-STATE® outputs
- TTL/CMOS compatible in and out
- LED direct drive outputs
- MICROBUSTM compatible
- Software/hardware compatible with other members of COP400 family
- Extended temperature range device COP320/COP321/ COP322 $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$


## Block Diagram



FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin
Operating Temperature Range
COP420/COP421/COP422 COP320/COP321/COP322

Storage Temperature Range
Total Sink Current
Total Source Current
-0.3 V to +7 V
$0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ 75 mA 95 mA

Package Power Dissipation 24 and 28 pin

Package Power Dissipation 20 pin

Lead Temperature (soldering, 10 sec .)
Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

## COP420/COP421/COP422

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operation Voltage |  | 4.5 | 6.3 | V |
| Power Supply Ripple | Peak to Peak (Note 3) |  | 0.4 | V |
| Supply Current | Outputs Open |  | 38 | mA |
| Supply Current | Outputs Open, $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | 30 | mA |
| Input Voltage Levels <br> CKI Input Levels Crystal Input Logic High Logic High Logic Low <br> TTL Input Logic High Logic Low <br> Schmitt Trigger Inputs RESET, CKI ( $\div 4)$ <br> Logic High Logic Low <br> SO Input Level (Test Mode) <br> All Other Inputs <br> Logic High <br> Logic High <br> Logic Low <br> Input Levels High Trip Option Logic High <br> Logic Low | $\begin{aligned} & V_{C C}=M a x \\ & V_{C C}=5 \mathrm{~V} \pm 5 \% \\ & V_{C C}=5 \mathrm{~V} \pm 5 \% \end{aligned}$ <br> (Note 2) $\begin{aligned} & V_{C C}=\operatorname{Max} \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ | $\begin{gathered} 3.0 \\ 2.0 \\ -0.3 \\ \\ 2.0 \\ -0.3 \\ \\ \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ 2.0 \\ \\ 3.0 \\ 2.0 \\ -0.3 \\ \\ 3.6 \\ -0.3 \\ \hline \end{gathered}$ | 0.4 <br> 0.8 <br> 0.6 <br> 3.0 <br> 0.8 <br> 1.2 | $\begin{aligned} & V \\ & V \\ & v \\ & v \\ & V \\ & v \\ & v \\ & v \\ & V \\ & V \\ & V \\ & \\ & V \\ & V \\ & \hline \end{aligned}$ |
| Input Load Source Current CKO All Others | $V_{C C}=5 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=0 \mathrm{~V}$ | $\begin{gathered} -4 \\ -100 \end{gathered}$ | $\begin{aligned} & -800 \\ & -800 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage |  | -1 | +1 | $\mu \mathrm{A}$ |
| Output Voltage Levels Standard Outputs TTL Operation Logic High Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{l}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA} \end{aligned}$ | $\begin{gathered} 2.4 \\ -0.3 \\ \hline \end{gathered}$ | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ |
| CMOS Operation (Note 1) Logic High Logic Low | $\begin{aligned} & \mathrm{l}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-1$ | 0.2 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |

Note 1: TRI-STATE and LED configurations are excluded.
Note 2: SO output " 0 " level must be less than 0.8 V for normal operation.

## COP420/COP421/COP422

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels <br> LED Direct Drive Output Logic High CKI Sink Current (R/C Option) CKO (RAM Supply Current) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=3.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{R}}=3.3 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} 2.5 \\ 2 \end{gathered}$ | $14$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| TRI-STATE or Open Drain Leakage Current | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | -2.5 | +2.5 | $\mu \mathrm{A}$ |
| Output Current Levels Output Sink Current (loL) Output Source Current (IOH) | $\mathrm{VCC}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | +1.6 |  | mA |
| Standard Configuration All Outputs | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \end{aligned}$ | $\begin{array}{r} -200 \\ -100 \\ \hline \end{array}$ | $\begin{array}{r} -900 \\ -500 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Push-Pull Configuration SO, SK Outputs | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & -1.0 \\ & -0.4 \end{aligned}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| TRI-STATE Configuration $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & -0.8 \\ & -0.9 \end{aligned}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| LED Configuration $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -1.0 \\ & -0.5 \end{aligned}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Allowable Sink Current <br> Per Pin (L, D, G) <br> Per Pin (All Others) <br> Per Port (L) <br> Per Port (D, G) |  |  | $\begin{gathered} 10 \\ 2 \\ 16 \\ 10 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA |
| Allowable Source Current Per Pin (L) Per Pin (All Others) |  |  | $\begin{aligned} & -15 \\ & -1.5 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |

DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V} \mathrm{CC} \leq 5.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operation Voltage |  | 4.5 | 5.5 | V |
| Power Supply Ripple | Peak to Peak (Note 3) |  | 0.4 | V |
| Supply Current | $T_{A}=-40^{\circ} \mathrm{C}$, Outputs Open |  | 40 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Crystal Input <br> Logic High <br> Logic Low <br> TTL Input Logic High Logic Low <br> Schmitt Trigger Inputs <br> RESET, CKI ( $\div 4$ ) <br> Logic High Logic Low <br> SO Input Level (Test Mode) <br> All Other Inputs <br> Logic High <br> Logic High <br> Logic Low <br> Input Levels High Trip Option Logic High <br> Logic Low | $V_{C C}=5 \mathrm{~V} \pm 5 \%$ <br> (Note 2) $\begin{aligned} & V_{C C}=M a x \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ | $\begin{gathered} 2.2 \\ -0.3 \\ \\ 2.2 \\ -0.3 \\ \\ 0.7 \mathrm{~V}_{\mathrm{cc}} \\ -0.3 \\ 2.0 \\ \\ 3.0 \\ 2.2 \\ -0.3 \\ \\ 3.6 \\ -0.3 \\ \hline \end{gathered}$ | 0.3 <br> 0.6 <br> 0.4 <br> 3.0 <br> 0.6 <br> 1.2 | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & \\ & v \\ & v \\ & v \\ & v \\ & v \\ & V \end{aligned}$ |
| Input Load Source Current CKO <br> All Others | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ | $\begin{gathered} -4 \\ -100 \\ \hline \end{gathered}$ | $\begin{aligned} & -800 \\ & -800 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage |  | -2 | +2 | $\mu \mathrm{A}$ |
| Output Voltage Levels Standard Outputs TTL Operation Logic High Logic Low CMOS Operation (Note 1) Logic High Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-75 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $\begin{gathered} 2.4 \\ -0.3 \\ v_{c c}-1 \\ -0.3 \\ \hline \end{gathered}$ | $\begin{aligned} & 0.4 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & V \\ & v \\ & v \\ & v \end{aligned}$ |
| Output Current Levels <br> LED Direct Drive Output Logic High <br> CKI Sink Current (R/C Option) <br> CKO (RAM Supply Current) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}(\text { Note } 4) \\ & \mathrm{V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=3.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{R}}=3.3 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 1.0 \\ 2 \end{gathered}$ | $12$ <br> 4 | mA <br> mA <br> mA |
| TRI-STATE or Open Drain Leakage Current |  | -5 | +5 | $\mu \mathrm{A}$ |
| Allowable Sink Current <br> Per Pin (L, D, G) <br> Per Pin (All Others) <br> Per Port (L) <br> Per Port ( $\mathrm{D}, \mathrm{G}$ ) |  |  | $\begin{gathered} 10 \\ 2 \\ 16 \\ 10 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA |
| Allowable Source Current Per Pin (L) <br> Per Pin (All Others) |  |  | $\begin{array}{r} -15 \\ -1.5 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |

Note 1: TRI-STATE and LED conflgurations are excluded.
Note 2: SO output " 0 " level must be less than 0.6 V for normal operation.

## AC Electrical Characteristics

COP420/COP421/COP422 $0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted
COP320/COP321/COP322 $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time |  | 4 | 10 | ¢s |
| Operating CKI Frequency | $\begin{aligned} & \div 16 \text { mode } \\ & \div 8 \text { mode } \end{aligned}$ | $\begin{aligned} & 1.6 \\ & 0.8 \end{aligned}$ | $\begin{aligned} & 4.0 \\ & 2.0 \end{aligned}$ | $\begin{aligned} & \mathrm{MHz} \\ & \mathrm{MHz} \end{aligned}$ |
| CKI Duty Cycle (Note 1) Rise Time Fall Time | $\begin{aligned} & \text { Freq. }=4 \mathrm{MHz} \\ & \text { Freq. }=4 \mathrm{MHz} \end{aligned}$ | 40 | $\begin{aligned} & 60 \\ & 60 \\ & 40 \end{aligned}$ | $\begin{aligned} & \hline \% \\ & \text { \% } \\ & \text { ns } \end{aligned}$ |
| CKI Using RC (Figure 8c) Frequency Instruction Cycle Time (Note 5) | $\begin{aligned} & \div 4 \text { mode } \\ & \mathrm{R}=15 \mathrm{k} \Omega \pm 5 \%, \mathrm{C}=100 \mathrm{pF} \end{aligned}$ | $\begin{gathered} 0.5 \\ 4 \end{gathered}$ | $\begin{gathered} 1.0 \\ 8 \end{gathered}$ | $\begin{gathered} \mathrm{MHz} \\ \mu \mathrm{~s} \end{gathered}$ |
| CKO as SYNC Input (Figure 8d) tsync | Figure 3a | 50 |  | ns |
| Inputs: <br> SI <br> tsetup <br> thold <br> All Other Inputs tsetup thold |  | $\begin{aligned} & 0.3 \\ & 250 \\ & \\ & 1.7 \\ & 300 \end{aligned}$ |  | $\mu \mathrm{s}$ ns <br> $\mu \mathrm{s}$ <br> ns |
| Output Propagation Delay <br> All Other Outputs <br> $t_{\text {pd1 }}$ <br> $t_{\text {pdo }}$ | Test Conditions: $\mathrm{R}_{\mathrm{L}}=5 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V}$ | 300 | $\begin{aligned} & 1.0 \\ & 1.0 \\ & \\ & 0.25 \\ & 0.25 \\ & \\ & 1.4 \\ & 1.4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| MICROBUSTM Timing Read Operation (Figure 4) Chip Select Stable before $\overline{\mathrm{RD}}-\mathrm{t}$ CSR Chip Select Hold Time for $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{RCS}}$ $\overline{\text { RD }}$ Pulse Width-t $\mathrm{t}_{\mathrm{RR}}$ Data Delay from $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{RD}}$ $\overline{\mathrm{RD}}$ to Data Floating-tDF | $C_{L}=100 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ | $\begin{aligned} & 65 \\ & 20 \\ & 400 \end{aligned}$ | $\begin{aligned} & 375 \\ & 250 \end{aligned}$ | ns ns ns ns ns |
| Write Operation (Figure 5) Chip Select Stable before $\overline{\mathrm{WR}}-\mathrm{t}_{\mathrm{CSW}}$ Chip Select Hold Time for $\overline{W R}-t_{\text {w }}$ w WR Pulse Width-tww Data Set-Up Time for $\overline{W R}-t_{D W}$ Data Hold Time for WR-twD INTR Transition Time from $\overline{W R}-t_{\text {WI }}$ |  | $\begin{gathered} 65 \\ 20 \\ 400 \\ 320 \\ 100 \end{gathered}$ | 700 | ns ns ns ns ns ns |

Note 1: Duty cycle $=t_{W_{1}} /\left(t_{W_{1}}+t_{w_{0}}\right)$.
Note 2: See Figure 9 for additional I/O characteristics.
Note 3: Voltage change must be less than 0.5 V in a 1 ms period.
Note 4: Exercise great care not to exceed maximum device power dissipation limits when direct driving LEDs (or sourcing similar loads) at high temperature.
Note 5: Variation due to the device included.

## Connection Diagrams

COP420, COP320
Dual-In-Line Package


TL/DD/6921-2
Top View
Order Number COP420-XXX/N, COP320-XXX/N
See NS Package N28B

COP421, COP321
Dual-In-Line Package


TL/DD/6921-3
Top View
Order Number COP421-XXX/M, COP321-XXX/M, COP421-XXX/N, COP321-XXX/N See NS Package M24B or N24A

FIGURE 2

## Pin Descriptions

| Pin | Description | Pin | Description |
| :---: | :---: | :---: | :---: |
| $\mathrm{L}_{7}-\mathrm{L}_{0}$ | 8 bidirectional I/O ports with TRI-STATE | SK | Logic-controlled clock (or general purpose out- |
| $\mathrm{G}_{3}-\mathrm{G}_{0}$ | 4 bidirectional I/O ports |  | put) |
| $\mathrm{D}_{3}-\mathrm{D}_{0}$ | 4 general purpose outputs | CKI | System oscillator input |
| $\mathrm{IN}_{3}-\mathrm{IN}_{0}$ | 4 general purpose inputs (COP420/320 only) | CKO | System oscillator output (or general purpose input |
| SI | Serial input (or counter input) |  | or RAM power supply) |
| SO | Serial output (or general purpose output | RESET | System reset input |
|  |  | $V_{\text {CC }}$ | Power supply |
|  |  | GND | Ground |

## Timing Diagrams



FIGURE 3. Input/Output Timing Diagrams (Crystal Divide by 16 Mode)


FIGURE 3A. Synchronization Timing


TL/DD/6921-7
FIGURE 3B. CKO Output Timing

Timing Diagrams (Continued)


TL/DD/6921-8
FIGURE 4. MICROBUS Read Operation Timing


TL/DD/6921-9
FIGURE 5. MICROBUS Write Operatlon Timing

## Functional Description COP420/COP421/COP422, COP320/COP321/COP322

For ease of reading this description, only COP420 and/or COP421 are referenced; however, all such references apply equally to the COP422, COP322, COP320 and/or COP321, respectively.
A block diagram of the COP420 is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).

## PROGRAM MEMORY

Program Memory consists of a 1,024 byte ROM. As can be seen by an examination of the COP420/421 instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 16 pages of 64 words each.
ROM addressing is accomplished by a 10 -bit PC register. Its binary value selects one of the 1,024 8 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 10 -bit binary count value. Three levels of subroutine nesting are implemented by the 10-bit subroutine save registers, SA, SB and SC, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of 256 -bit RAM, organized as 4 data registers of 164 -bit digits. RAM addressing is implemented by a 6-bit Bregister whose upper 2 bits ( Br ) select 1 of 4 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4 -bit contents of the selected RAM digit (M) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the $Q$ latches or loaded from the $L$ ports.

RAM addressing may also be performed directly by the LDD and XAD instructions based upon the 6-bit contents of the operand field of these instructions. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Br and Bd portions of the B register, to load the input 4 bits of the 8 -bit Q latch data, to input 4 bits of the 8-bit L I/O port data and to perform data exchanges with the SIO register. A 4-bit adder performs the arithmetic and logic functions of the COP420/421, storing its results in A. It also outputs a carry bit to the 1 -bit $\mathbf{C}$ register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.)
Four general-purpose inputs, $\mathbf{I N}_{3}-\boldsymbol{I} \mathbf{N}_{0}$, are provided; $\mathrm{N}_{1}$, $\mathrm{IN}_{2}$ and $\mathrm{IN}_{3}$ may be selected, by a mask-programmable option, as Read Strobe, Chip Select and Write Strobe inputs, respectively, for use in MICROBUS applications.
The D register provides 4 general-purpose outputs and is used as the destination register for the 4 -bit contents of Bd.
The $\mathbf{G}$ register contents are outputs to 4 general-purpose bidirectional I/O ports. $\mathrm{G}_{0}$ may be mask-programmed as an output for MICROBUS applications.
The $\mathbf{Q}$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are output to the L I/O ports when the $L$ drivers are enabled under program control. (See LEI instruction.) With the MICROBUS option selected, Q can also be loaded with the 8 -bit contents of the LI/O ports upon the occurrence of a write strobe from the host CPU.

## Functional Description COP420/COP421/COP422, COP320/COP321/COP322 (Continued)

The 8 L drivers, when enabled, output the contents of latched $Q$ data to the LI/O ports. Also, the contents of $L$ may be read directly into $A$ and $M$. As explained above, the MICROBUS option allows LI/O port data to be latched into the $Q$ register. LI/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with $Q$ data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with A, allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers. For example of additional parallel output capacity see Application \# 2.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the clock.
The EN register is an internal 4-bit register loaded under program control by the LEl instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $E N_{3}-E N_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$ selects the SIO register as either a 4-bit shift register or a 4bit binary counter. With $\mathrm{EN}_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse ("1" to " 0 " occurring on the Sl input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $\mathrm{EN}_{3}$. With $\mathrm{EN}_{0}$ reset, SIO is a serial shift register shifting let each instruction cycle time. The data present at DI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. With the $E N_{1}$ set the $\mathbb{N}_{1}$ input is enabled as an interrupt input. Immediately following an interrupt, $\mathrm{EN}_{1}$ is reset to disable further interrupts.
3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in $Q$ to the L I/O ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high impedance input state.
4. $E N_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $E N_{3}$. With $E N_{0}$ reset (serial shift register option selected), setting EN enables SO as the
output of the SIO shift register outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ". The table below provides summary of the modes associated with $\mathrm{EN}_{3}$ and $\mathrm{EN}_{1}$.

## OSCILLATOR

There are three basic clock oscillator configurations available as shown by Figure 8.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency divided by 16 (optional by 8).
b. External Oscillator. CKI is an external clock input signal. The external frequency is divided by 16 (optional by 8) to give the instruction cycle time. CKO is now available to be used as the RAM power supply $\left(V_{R}\right)$ of as a general purpose input.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is available for non-timing functions.

## CKO PIN OPTIONS

In a crystal controlled oscillator system, CKO is used as an output to the crystal network. As an option CKO can be a general purpose input, read into bit 2 of $A$ (accumulator) upon execution of an INIL instruction. As another option, CKO can be a RAM power supply pin ( $\mathrm{V}_{\mathrm{R}}$ ), allowing its connection to a standby/backup power supply to maintain the integrity of RAM data with minimum power drain when the main supply is inoperative or shut down to conserve power. Using either option is appropriate in applications where the COP420/421 system timing configuration does not require use of the CKO pin.

## RAM KEEP-ALIVE OPTION (NOT AVAILABLE ON COP422)

Selecting CKO as the RAM power supply ( $\mathrm{V}_{\mathrm{R}}$ ) allows the user to shut off the chip power supply ( $\mathrm{V}_{\mathrm{CC}}$ ) and maintain data in the RAM. To insure that RAM data integrity is maintained, the following conditions must be met:

1. $\overline{\text { RESET must go low before } V_{C C} \text { goes below spec during }}$ power off; $V_{\text {CC }}$ must be within spec before RESET goes high on power up.
2. $\mathrm{V}_{\mathrm{R}}$ must be within the operating range of the chip, and equal to $V_{C C} \pm 1 \mathrm{~V}$ during normal operation.
3. $V_{R}$ must be $\geq 3.3 V$ with $V_{C C}$ off.

Enable Register Modes-Bits $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$

| $\mathrm{EN}_{3}$ | EN0 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=C L O C K \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | $\begin{aligned} & \text { If } S K L=1, S K=C L O C K \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | $\begin{aligned} & \text { If } \mathrm{SKL}=1, S K=1 \\ & \text { If } \mathrm{SKL}=0, S K=0 \end{aligned}$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | $\begin{aligned} & \text { If } S K L=1, S K=1 \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |

Functional Description COP420/COP421/COP422, COP320/COP321/COP322 (Continued)


| Crystal Oscillator |  |  |  |
| :---: | :---: | :---: | :---: |
|  | Component Values |  |  |
|  | R1( $\Omega)$ | R2( $\Omega)$ | C(pF) |
| 4 MHz | 1 k | 1 M | 27 |
| 3.58 MHz | 1 k | 1 M | 27 |
| 2.09 MHz | 1 k | 1 M | 56 |

RC Controlled Oscillator

| $\mathbf{R ( k} \Omega)$ | $\mathbf{C}(\mathbf{p F})$ | Instruction <br> Cycle Time <br> $(\mu \mathbf{s})$ |
| :---: | :---: | :---: |
| 12 | 100 | $5 \pm 20 \%$ |
| 6.8 | 220 | $5.3 \pm 23 \%$ |
| 8.2 | 300 | $8 \pm 29 \%$ |
| 22 | 100 | $8.6 \pm 16 \%$ |

Note: $50 \mathrm{k} \Omega \geq \mathrm{R} \geq 5 \mathrm{k} \Omega$
$360 \mathrm{pF} \geq \mathrm{C} \geq 50 \mathrm{pF}$

FIGURE 8. COP420/421/COP320/321 Oscillator

## INTERRUPT

The following features are associated with the $\mathrm{IN}_{1}$ interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once acknowledged as explained below, pushes the next sequential program counter address (PC +1 ) onto the stack, pushing in turn the contents of the other subroutine-save registers to the next lower level $(\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC})$. Any previous contents of SC are lost. The program counter is set to hex address OFF (the last word of page 3 ) and $\mathrm{EN}_{1}$ is reset.
b. An interrupt will be acknowledged only after the following conditions are met:

1. $\mathrm{EN}_{1}$ has been set.
2. A low-going pulse (" 1 " to " 0 ") at least two instruction cycles wide occurs on the $I \mathrm{~N}_{1}$ input.
3. A currently executing instruction has been completed.
4. All successive transfer of control instructions and successive LBIs have been completed (e.g., if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed.
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example, if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at hex address $0 F F$. At the end of the interrupt
routine, a RET instruction is executed to "pop" the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines and LQID instructions should not be nested within the interrupt service routine, since their popping the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The first instruction of the interrupt routine at hex address OFF must be a NOP.
e. A LEI instruction can be put immediately before the RET to re-enable interrupts.

## MICROBUSTM INTERFACE

The COP420 has an option which allows it to be used as a peripheral microprocessor device, inputting and outputting data from and to a host microprocessor ( $\mu \mathrm{P}$ ). $\mathrm{IN}_{1}, \mathrm{IN}_{2}$ and $\mathrm{IN}_{3}$ general purpose inputs become MICROBUS compatible read-strobe, chip-select, and write-strobe lines, respectively. $\mathrm{IN}_{1}$ becomes RD-a logic " 0 " on this input will cause $Q$ latch data to be enabled to the $L$ ports for input to the $\mu \mathrm{P}$. $\mathbb{N}_{2}$ becomes $\overline{C S}-a ~ l o g i c ~ " ~ 0 " ~ o n ~ t h i s ~ l i n e ~ s e l e c t s ~ t h e ~$ COP420 as the $\mu \mathrm{P}$ peripheral device by enabling the operation of the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ lines and allows for the selection of one of several peripheral components. $\mathrm{IN}_{3}$ becomes $\overline{\mathrm{WR}}$-a logic " 0 " on this line will write bus data from the $L$ ports to the $Q$ latches for input to the COP420. $G_{0}$ becomes INTR a "ready" output, reset by a write pulse from the $\mu P$ on the WR line, providing the "handshaking" capability necessary for asynchronous data transfer between the host CPU and the COP420.

## Functional Description COP420/COP421/COP422, COP320/COP321/COP322 (Continued)



TL/DD/6921-12
FIGURE 6. MICROBUS Option Interconnect

This option has been designed for compatibility with National's MICROBUS-a standard interconnect system for 8 -bit parallel data transfer between MOS/LSI CPUs and interfacing devices. (See MICROBUS National Publication.) The functioning and timing relationships between the COP420 signal lines affected by this option are as specified for the MICROBUS interface, and are given in the AC electrical characteristics and shown in the timing diagrams (Figures 4 and 5). Connection of the COP420 to the MICROBUS is shown in Figure 6.
Note: TRI-STATE outputs must be used on L-port.

## INITIALIZATION

The Reset Logic, internal to the COP420/421, will initialize (clear) the device upon power-up if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the RESET pin as shown below. The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to $\mathrm{V}_{\mathrm{cc}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N$, and $G$ registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.


TL/DD/6921-13
FIGURE 7. Power-Up Clear Circuit

## I/O OPTIONS

COP420/421 outputs have the following optional configurations, illustrated in Figure 9a:
a. Standard-an enhancement mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with TTL and CMOS input requirements. Available on SO, SK, and all D and G outputs.
b. Open-Drain-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. Available on SO, SK, and all D and G outputs.
c. Push-Pull-An enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{Cc}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. Available on SO and SK outputs only.
d. Standard L-same as a., but may be disabled. Available on $L$ outputs only.
e. Open Drain L-same as b., but may be disabled. Available on L outputs only.
f. LED Direct Drive-an enhancement-mode device to ground and to $V_{C C}$, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (See Functional Description, EN Register), placing the outputs in a high-impedance state to provide required LED segment blanking for a multiplexed display.
g. TRI-STATE Push-Pull-an enhancement-mode device to ground and $V_{C C}$. These outputs are TRI-STATE outputs, allowing for connection of these outputs to a data bus shared by other bus drivers.
COP420/COP421 inputs have the following optional configurations:
h. An on-chip depletion load device to $V_{C C}$.
I. A Hi-Z input which must be driven to a " 1 " or " 0 " by external components.
The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6, respectively). Minimum and maximum current (lout and $V_{\text {OUT }}$ ) curves are given in Figure $9 b$ for each

## Functional Description COP420/COP421/COP422, COP320/COP321/COP322 (Continued)

of these devices to allow the designer to effectively use these I/O configurations in designing a COP420/421 system.
The SO, SK outputs can be configured as shown in a., b., or c. The D and G outputs can be configured as shown in a . or b. Note that when inputting data to the $G$ ports, the $G$ outputs should be set to "1." The L outputs can be configured as in d., e., f. or g.
An important point to remember if using configuration d. or f. with the $L$ drivers is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current (see Figure 9b, device 2); however, when
the L lines are used as input, the disabled depletion device can not be relied on to source sufficient current to pull an input to logic " 1 ".
COP421
If the COP420 is bonded as a 24 -pin device, it becomes the COP421, illustrated in Figure 2, COP420/421 Connection Diagrams. Note that the COP421 does not contain the four general purpose $\mathbb{I N}$ inputs ( $\mathbb{N}_{3}-\mathbb{N}_{0}$ ). Use of this option precludes, of course, use of the $\mathbb{I N}$ options, interrupt feature, and the MICROBUS option which uses $\mathrm{N}_{1}-\mathrm{IN}_{3}$. All other options are available for the COP421.


TL/DD/6921-14


TL/DD/6921-15
a. Standard Output
d. Standard L Output

TL/DD/6921-20
g. TRI-STATE Push-Pull (L Output)


b. Open-Drain Output


TL/DD/6921-16


TL/DD/6921-18
e. Open-Drain L Output

( $\mathbf{\Delta}$ is Depletion Device)
TL/DD/6921-19
f. LED (L Output)

h. Input with Load

i. Hi-Z Input

FIGURE 9a. Input/Output Configurations

Typical Performance Characteristics


FIGURE 9b. COP420/COP421 Input/Output Characteristics

Typical Performance Characteristics (Continued)



TRI-STATE Output Source Current





LED Output Direct LED Drive


FIGURE 9c. COP320/COP321 Input/Output Characteristics

## Instruction Set

Table I is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table II provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with each instruction in the COP420/COP421/COP422 instruction set.

TABLE I. COP420/421/422/320/321/322 Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| IL | Two 1-bit latches associated with the IN ${ }_{3}$ or |
|  | IN inputs |
| IN | 4-bit Input Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by |
|  | B Register |
| PC | 9-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| SA | 10-bit Subroutine Save Register A |
| SB | 10-bit Subroutine Save Register B |
| SC | 10 Subroutine Save Register A |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |


| Symbol | Definition |
| :---: | :---: |
| INSTRUCTION OPERAND SYMBOLS |  |
| d | 4-bit Operand Field, 0-15 binary (RAM Digit Select) |
|  | 2-bit Operand Field, 0-3 binary (RAM Register Select) |
| a | 10-bit Operand Field, 0-1023 binary (ROM Address) |
| $y$ | 4-bit Operand Field, 0-15 binary (Immediate Data) |
| RAM(s) | Contents of RAM location addressed by s |
| ROM (t) | Contents of ROM location addressed by t |
| OPERATIONAL SYMBOLS |  |
| + | Plus |
| - | Minus |
| $\rightarrow$ | Replaces |
| $\longleftrightarrow$ | Is exchanged with |
| $=$ | Is equal to |
| $\bar{A}$ | The one's complement of A |
| $\oplus$ | Exclusive-OR |
| : | Range of values |

TABLE II. COP420/421/422/320/321/322 Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 10011,0000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 0011 ${ }^{\text {0,0001 }}$ | $A+R A M(B) \rightarrow A$ | None | Add RAM to A |
| ADT |  | 4A | 0100\|1010 | $A+10_{10} \rightarrow A$ | None | Add Ten to A |
| AISC | $y$ | 5- | $0101 \mid$ y | $A+y \rightarrow A$ | Carry | Add immediate, Skip on Carry $(y \neq 0)$ |
| CASC |  | 10 | 0001 0000 | $\begin{aligned} & \bar{A}+R A M(B)+C \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Complement and Add with Carry, Skip on Carry |
| CLRA |  | 00 | 0000\|0000 | $0 \rightarrow \mathrm{~A}$ | None | Clear A |
| COMP |  | 40 | 010010000 | $\overline{\mathrm{A}} \rightarrow \mathrm{A}$ | None | One's complement of A to A |
| NOP |  | 44 | 0100\|0100 | None | None | No Operation |
| RC |  | 32 | 0011 0010 | " 0 " $\rightarrow$ C | None | Reset C |
| SC |  | 22 | 0010/0010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | 0000 10010 | $A \oplus R A M(B) \rightarrow A$ | None | Exclusive-OR RAM with A |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE II. COP420/421/422/320/321/322 Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 3) |
| JMP | a | 6-- | $0110\|00\| a_{8} \mid$ <br> $a_{7: 0}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  | $\begin{aligned} & \frac{1 \mid \quad a_{6: 0}}{\text { (pages } 2,3 \text { only) }} \\ & \frac{\text { or }}{11 \mid \quad a_{5: 0}} \\ & \text { (all other pages) } \end{aligned}$ | $\begin{aligned} & a \rightarrow P C_{6: 0} \\ & a \rightarrow P C_{5: 0} \end{aligned}$ | None | Jump within Page (Note 4) |
| JSRP | a | - - | \|10| $\mathrm{a}_{5: 0}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR | a | $6-$ | $\begin{array}{\|c\|c\|c\|c\|} \hline 0110\|10\| a_{9: 8} \\ \hline a_{7: 0} \end{array}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | \|0100|1000 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 0100\|1001 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 | 0011 0011 <br> 0011 1100 | $A \rightarrow Q_{7: 4} Q_{3: 0}$ | None | Copy A, RAM to Q |
| CQMA |  | 33 2 C | 0011 $0011 \mid$ <br> 0010 1100 | $\begin{aligned} & Q_{7: 4} \rightarrow R A M(B) \\ & Q_{3: 0} \rightarrow A \end{aligned}$ | None | Copy Q to RAM, A |
| LD | $r$ | -5 | 100\|r|0101 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A Exclusive-OR Br with r |
| LDD | r,d | 23 | 0010 0011  <br> $00\|c\| c\|c\|$   <br> 00 r d | RAM $(\mathrm{r}, \mathrm{d}) \rightarrow \mathrm{A}$ | None | Load A with RAM pointed to directly by $\mathrm{r}, \mathrm{d}$ |
| LQID |  | BF | \|1011 [1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC} \mathrm{C}_{9: 8}, \mathrm{~A}, \mathrm{M}\right) \\ & \mathrm{SB} \rightarrow \mathrm{SC} \end{aligned}$ | None | Load Q Indirect (Note 3) |
| RMB | 0 1 2 3 | $4 C$ 45 42 43 | 0100 1100 <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{aligned} 0 & \rightarrow \operatorname{RAM}(\mathrm{~B})_{0} \\ 0 & \rightarrow \operatorname{RAM}(\mathrm{~B})_{1} \\ 0 & \rightarrow \operatorname{RAM}(\mathrm{~B})_{2} \\ 0 & \rightarrow \operatorname{RAM}(\mathrm{~B})_{3} \end{aligned}$ | None | Reset RAM Bit |
| SMB | 0 1 2 3 | $4 D$ 47 46 $4 B$ | 0100 1101 <br> 0100 1101 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} & 1 \rightarrow \text { RAM }(B)_{0} \\ & 1 \rightarrow \text { RAM }(B)_{1} \\ & 1 \rightarrow \text { RAM }(B)_{2} \\ & 1 \rightarrow \text { RAM }(B)_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | $y$ | $7-$ | \|0111 ${ }^{\text {y }}$ | $\begin{aligned} & y \rightarrow R A M(B) \\ & B d+1 \rightarrow B d \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| $x$ | $r$ | -6 | 00\|r|0110 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{Br} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with r |
| XAD | r,d | 23 | 0010  0011 <br> 10 r d | RAM $(\mathrm{r}, \mathrm{d}) \longleftrightarrow \mathrm{A}$ | None | Exchange A with RAM pointed to directly by r ,d |

## Instruction Set (Continued)

TABLE II. COP420/421/422/320/321/322 Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MEMORY REFERENCE INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| XDS | $r$ | -7 | 00\|r10111 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd, Exclusive-OR Br with r |
| XIS | $r$ | -4 | \|00|r|0100 | RAM $(B) \longleftrightarrow A$ <br> $\mathrm{Bd}+1 \rightarrow \mathrm{Bd}$ <br> $\mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br}$ | Bd increments past 15 | Exchange RAM with A and Increment Bd, Exclusive-OR Br with r |
| REGISTER REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAB |  | 50 | \|0101 $0000 \mid$ | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| CBA |  | 4E | \|0100|1110| | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d | $33$ | $\begin{gathered} \|00\| r\|(d-1)\| \\ \hline(d=0,9: 15) \\ \text { or } \\ 00011\|0011\| \\ \hline 10\|r\| d \\ \hline \text { (any d) } \end{gathered}$ | $r, d \rightarrow B$ | Skip until not a LBI | Load B Immediate with r,d (Note 6) |
| LEI | $y$ | $\begin{aligned} & 33 \\ & 6- \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0011 & 0011 \\ \hline 0010 & \mathrm{y} \\ \hline \end{array}$ | $y \rightarrow E N$ | None | Load EN Immediate (Note 7) |
| XABR |  | 12 | [0001\|0010] | $\mathrm{A} \longleftrightarrow \mathrm{Br}\left(0,0 \rightarrow \mathrm{~A}_{3}, \mathrm{~A}_{2}\right)$ | None | Exchange A with Br |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  | 20 | [0010\|0000] |  | $C=" 1 "$ | Skip if C is True |
| SKE |  | 21 | 0010/0001\| |  | $A=R A M(B)$ | Skip if A Equals RAM |
| SKGZ |  | 33 21 | $0011\|0011\|$ <br> $0010\|0001\|$ |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
| SKGBZ |  | 33 | 0011\|0011 | 1st byte |  | Skip if G Bit is Zero |
|  | 0 | 01 | 0000\|0001 | \} 2nd byte | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 0001\|0001| |  | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 |  | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 0010\|0011 |  | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 0000\|0001 |  | RAM $(B)_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | 0001\|0001 |  | $\operatorname{RAM}(\mathrm{B})_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 |  | $\operatorname{RAM}(\mathrm{B})_{2}=0$ |  |
|  | 3 | 13 | 0001\|0011 |  | $\operatorname{RAM}(B)_{3}=0$ |  |
| SKT |  | 41 | 010010001 |  | A time-base counter carry has occurred since last test | Skip on Timer (Note 3) |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE II. COP420/421/422/320/321/322 Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 0011 00011 | $G \rightarrow A$ | None | Input G Ports to A |
|  |  | 2A | 0010 1010 |  |  |  |
| ININ |  | 33 | \|0011 0011 | $\mathrm{IN} \rightarrow \mathrm{A}$ | None | Input IN Inputs to A (Note 2) |
|  |  | 28 | \|0010|1000| |  |  |  |
| INIL |  | 33 | 001110011 | $\mathrm{IL}_{3}, \mathrm{CKO}, ~ " 0$ ', $\mathrm{IL}_{0} \rightarrow \mathrm{~A}$ | None | Input iL Latches to A |
|  |  | 29 | 0010\|1001 |  |  | (Note 3) |
| INL |  | 33 | \|0011 0011 1 | $L_{7: 4} \rightarrow$ RAM $(B)$ | None | Input L Ports to RAM, A |
|  |  | 2 E | \|0010|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | \|0011 0011 | | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E | 0011 1110 |  |  |  |
| OGI | $y$ | 33 | 0011\|0011 | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | 5- | 0101 y |  |  |  |
| OMG |  | 33 | \|0011 0011 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{G}$ | None | Output RAM to G Ports |
|  |  | 3 A | 0011 1010 |  |  |  |
| XAS |  | 4F | \|0100|1111 | A | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered O to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit register.
Note 2: The ININ instruction is not available on the COP421/COP321 and COP422/COP322 since these devices do not contain the iN inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while in subroutine pages 2 or 3 , to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 5: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ " data minus 1 , e.g., to load the lower four bits of $B(B d)$ with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).
Note 7: Machine code for operand field y for LEl instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP420/421 programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If

SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by $A$ and $M$. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 10 -bit word, $\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ are not affected by this instruction.
Note that JID requires 2 instruction cycles to execute.

Description of Selected Instructions INIL INSTRUCTION
INIL (Input IL Latches to A) inputs 2 latches, $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ (see Figure 10) and CKO into A . The $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ latches are set if a low-going pulse (" 1 " to " 0 ") has occurred on the $\mathrm{IN}_{3}$ and $\mathrm{IN}_{\mathrm{O}}$ inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction times. Execution of an INIL inputs $\mathrm{I}_{3}$ and $\mathrm{I}_{0}$ into A 3 and $A 0$ respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the $I N_{3}$ and $I N_{0}$ lines. If CKO is mask programmed as a general purpose input, an INIL will input the state of CKO into A2. If CKO has not been so programmed, a " 1 " will be placed in A2. A " 0 " is always placed in A1 upon the execution of an INIL. The general purpose inputs $\mathbb{N}_{3}-\mathbb{N}_{0}$ are input to $A$ upon execution of an ININ instruction. (See Table II, ININ instruction.) INIL is useful in recognizing pulses of short duration or pulses which occur too often to be read conveniently by an ININ instruction.
Note: IL latches are not cleared on reset.


TL/DD/6921-25
FIGURE 10

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 10 -bit word $\mathrm{PC}_{9}, \mathrm{PC}_{8}, \mathrm{~A}$, M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC + $1 \rightarrow$ SA $\rightarrow$ SB $\rightarrow$ SC) and replaces the least significant 8 bits of PC as follows: A $\rightarrow$ $\mathrm{PC}_{7: 4}, \mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the Q latches. Next, the stack is "popped" (SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow$ PC), restoring the saved value of PC to continue sequential program execu-
tion. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost. Also, when LQID pops the stack, the previously pushed contents of SB are left in SC. The net result is that the content of SB are placed in SC (SB $\rightarrow$ SC). Note that LQID takes two instruction cycle times to execute.

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of an internal 10 -bit time-base counter. This counter divides the instruction cycle clock frequency by 1024 and provides a latched indication of counter overflow. The SKT instruction tests this latch, executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction, therefore, allow the COP420/421 to generate its own time-base for real-time processing rather than relying on an external input signal.
For example, using a 2.097 MHz crystal as the time-base to the clock generator, the instruction cycle clock frequency will be 131 kHz (crystal frequency $\div$ 16) and the binary counter output pulse frequency will be 128 Hz . For time-ofday or similar real-time processing, the SKT instruction can call a routine which increments a "seconds" counter every 128 ticks.

## INSTRUCTION SET NOTES

a. The first word of a COP420/421 program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instruction are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths take the same number of cycle times whether instructions are skipped or executed except JID and LQID. LQID and JID take two cycle times if executed and one if skipped.
c. The ROM is organized into 16 pages of 64 words each. The Program Counter is a 10 -bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page $3,7,11$ or 15 will access data in the next group of four pages.

## Option List

The COP420/421/422 mask-programmable options are assigned numbers which correspond with the COP420 pins.
The following is a list of COP420 options. When specifying a COP421 or COP422 chip, Options $9,10,19,20$ and 29 must all be set to zero. When specifying a COP422 chip, Options 21, 22, 27 and 28 must also be zero, and Option 2 must not be a 1. The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
Option $1=0$ : Ground-no options available
Option 2: CKO Pin
$=0$ : clock generator output to crystal 0 not available if option $3=4$ or 5 )
$=1$ : Pin is RAM power supply $\left(V_{R}\right)$ input
(Not available on COP422/COP322)
$=2$ : general purpose input with load device
$=4$ : general purpose Hi Z input
Option 3: CKI Input
$=0$ : crystal input devided by 16
$=1$ : crystal input divided by 8
$=2$ : TTL external clock input divided by 16
$=3$ : TTL external clock input divided by 8
$=4$ : single-pin RC controlled oscillator ( $\div 4$ )
$=5$ : Schmitt trigger clock input $(\div 4)$
Option 4: RESET Pin
$=0$ : load devices to $V_{C C}$
= 1: $\mathrm{Hi}-\mathrm{Z}$ input
Option 5: L-7 Driver
$=0$ : Standard output (Figure 9D)
$=1$ : Open-Drain output (E)
$=2$ : LED direct drive output (F)
$=3$ : TRI-STATE push-pull output (G)
Option 6: $L_{6}$ Driver same as Option 5
Option 7: $\mathrm{L}_{5}$ Driver same as Option 5
Option 8: $\mathrm{L}_{4}$ Driver same as Option 5
Option 9: $\mathbb{N}_{1}$ Input $=0$ : load devices to $V_{C C}(H)$
$=1: \mathrm{Hi}-\mathrm{Z}$ input ( I )
Option 10: $\mathbb{N}_{2}$ Input same as Option 9
Option $11=0$ : $V_{C C}$ Pin-no options available
Option 12: $\mathrm{L}_{3}$ Driver same as Option 5
Option 13: L2 Driver same as Option 5
Option 14: L $\mathrm{L}_{1}$ Driver same as Option 5
Option 15: Lo Driver same as Option 5

Option 16: SI Input same as Option 9
Option 17: SO Driver $=0$ : standard output (A)
$=1$ : open-drain output (B)
= 2: push-pull output (C)
Option 18: SK Driver same as Option 17
Option 19: $\mathrm{IN}_{0}$ Input same as Option 9
Option 20: $\mathbb{I N}_{3}$ Input same as Option 9
Option 21: $\mathrm{G}_{0}$ I/O Port $=0$ : Standard output (A)
= 1: Open-Drain output (B)
Option 22: $\mathrm{G}_{1}$ I/O Port same as Option 21
Option 23: $\mathrm{G}_{2}$ I/O Port same as Option 21
Option 24: $\mathrm{G}_{3}$ I/O Port same as Option 21
Option 25: $\mathrm{D}_{3}$ Output $=0$ : Standard output (A) = 1: Open-Drain output ( B )
Option 26: $\mathrm{D}_{2}$ Output same as Option 25
Option 27: $\mathrm{D}_{1}$ Output same as Option 25
Option 28: $\mathrm{D}_{0}$ Output same as Option 25
Option 29: COP Function $=0$ : normal operation $=1$ : MICROBUS option
Option 30: COB Bonding = 0: COP420 (28-pin device)
= 1: COP421 (24-pin device)
$=2: 28$ - and 24-pin device
= 3: COP422 (20-pin device)
$=4: 28$ - and 20 -pin device
$=5$ : 24- and $20-$ pin device
$=6: 28$-, 24- and $20-$ pin device
Option 31: In Input Levels
$=0$ : normal input levels
$=1$ : Higher voltage input levels ("0" = $1.2 \mathrm{~V}, " 1 "=3.6 \mathrm{~V}$ )
Option 32: G Input Levels same as Option 31
Option 33: L Input Levels same as Option 31
Option 34: CKO Input Levels same as Option 31
Option 35: SI Input Levels same as Option 31

## Option List (Continuad)

## COP OPTION LIST

The following option information is to be sent to National along with the EPROM.

## OPTION DATA



## TEST MODE (Non-Standard Operation)

The SO output has been configured to provide for standard test procedures for the custom-programmed COP420. With SO forced to logic "1", two test modes are provided, depending upon the value of SI :
a. RAM and Internal Logic Test Mode $(\mathrm{SI}=1)$
b. ROM Test Mode $(\mathrm{SI}=0)$

These special test modes should not be employed by the user; they are intended for manufacturing test only.

## APPLICATION \# 1: COP420 General Controller

Figure 8 shows an interconnect diagram for a COP420 used as a general controller. Operation of the system is as follows:

1. The $L_{7}-L_{0}$ outputs are configured as LED Direct Drive outputs, allowing direct connection to the segments of the display.
2. The $D_{3}-D_{0}$ outputs drive the digits of the mulitplexed display directly and scan the columns of the $4 \times 4$ keyboard matrix.
3. The $I N_{3}-I N_{0}$ inputs are used to input the 4 rows of the keyboard matrix. Reading the $\mathbb{N}$ lines in conjunction with the current value of the D outputs allows detection, debouncing, and decoding of any one of the 16 keyswitches.
4. CKI is configured as a single-pin oscillator input allowing system timing to be controlled by a single-pin RC network. CKO is therefore available for use as a $V_{\mathrm{R}}$ RAM power supply pin. RAM data integrity is thereby assured when the main power supply is shut down (see RAM Keep-Alive option description).
5. SI is selected as the input to a binary counter input. With SIO used as a binary counter, SO and SK can be used as general purpose outputs.
6. The 4 bidirectional G I/O ports $\left(\mathrm{G}_{3}-\mathrm{G}_{0}\right)$ are available for use as required by the user's application.

## APPLICATION \# 2: MUSICAL ORGAN AND MUSIC BOX

Play Mode: Twenty-five musical keys and 25 LEDs are provided to denote $F$ to $F$ with half notes in between. All the keys and LEDs are directly detected and driven by the microprocessor. Depression of the key will give the corresponding musical note and light up the corresponding LED.
Clear: Memory is provided to store a played tune. Depression of the CLEAR key erases the memory and the microprocessor is ready to store new musical notes. A maximum of 28 notes can be stored where each note can be of one to eight musical beats. (Two bytes of memory are required to store one musical note. Any note longer than eight musical beats will require additional memory space for storage.)
Playback: Depression of this button will playback the tune stored in the memory since last "clear."
Preprogrammed Tunes: There are ten preprogrammed tunes (each has an average of 55 notes) masked in the chip. Any tune can be recalled by depressing the "Tune Button" followed by the corresponding "Sharp Key."
Learn Mode: This mode is for the player to learn the ten preprogrammed tunes. By pressing the "Learn Button" followed by the corresponding "Sharp Key," the LEDs will be lighted up one by one to indicate the notes of the selected tune. The LED will remain "on" until the player presses the correct musical key; the LED for the next note will then be lighted up.
Pause: In addition to the 25 musical keys, there is a special pause key. The depression of this key generates a blank note to the memory.
Note: In the Learn Mode when playing "Oh Susanna," the pause key must be used.
Tempo: This is a control input to the musical beat time oscillator for varying the speed of the musical tunes.
VIbrato: This is a switch control to vary the frequency vibration of the note.

Tunes Listing: The following is a listing of the ten preprogrammed tunes: 1) Jingle Bells, 2) Twinkle, Twinkle Little Star, 3) Happy Birthday, 4) Yankee Doodle, 5) Silent Night, 6) This Old Man, 7) London Bridge Is Falling Down, 8) Auld Lang Syne, 9) Oh Susanna, 10) Clementine.

Typical Applications


TL/DD/6921-26
FIGURE 11. COP420 Keyboard Display Interface

Circult Diagram of COP420 Musical Organ


## Typical Applications (Continued)



TL/DD/6921-29
Auto Power Shut-Off Circuit


## 很 <br> National Semiconductor Corporation

## COP420L/COP421L/COP422L/COP320L/COP321L/ COP322L Single-Chip N-Channel Microcontrollers

## General Description

The COP420L, COP421L, COP422L, COP320L, COP321L, and COP322L Single-Chip N-Channel Microcontrollers are members of the COPSTM family, fabricated using N -channel, silicon gate MOS technology. These controller oriented processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture, and I/O scheme designed to facilitate keyboard input, display output, and BCD data manipulation. The COP421L and COP422L are identical to the COP420L, but with 19 and 15 I/O lines, respectively, instead of 23. They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized controller oriented processor at a low end-product cost.
The COP320L, COP321L, and COP322L are exact functional equivalents, but extended temperature range versions, of the COP420L, COP421L, and COP422L respectively.

## Features

■ Low cost

- Powerful instruction set

■ $1 \mathrm{k} \times 8$ ROM, $64 \times 4$ RAM

- 23 I/O lines (COP420L)
- True vectored interrupt, plus restart
- Three-level subroutine stack
- $16 \mu \mathrm{~s}$ instruction time
- Single supply operation (4.5V-6.3V)
- Low current drain (8 mA max)

■ Internal time-base counter for real-time processing

- Internal binary counter register with MICROWIRETM compatible serial I/O
- General purpose and TRI-STATE® outputs
- LSTTL/CMOS compatible in and out
- Direct drive of LED digit and segment lines
- Software/hardware compatible with other members of COP400 family
- Extended temperature range deviceCOP320L/COP321L/COP322L $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
$\square$ Wider supply range ( $4.5 \mathrm{~V}-9.5 \mathrm{~V}$ ) optionally available


## Block Diagram



TL/DD/8825-1
*Not available on COP422L/COP322L
FIGURE 1

## COP420L/COP421L/COP422L

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.

Voltage at Any Pin Relative to GND
Ambient Operating Temperature

$$
-0.5 \mathrm{~V} \text { to }+10 \mathrm{~V}
$$

$$
0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}
$$

Ambient Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering, 10 sec .)

Power Dissipation
COP420L/COP421L
COP422L

Total Source Current 120 mA

Total Sink Current
120 mA
Absolute maximum ratings indicate limits beyond which damage to the device may occur. $D C$ and $A C$ electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 1) | 4.5 | 6.3 | V |
| Optional Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 | 9.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 9 | mA |
| ```Input Voltage Levels CKI Input Levels Crystal Input ( \(\div 32, \div 16, \div 8\) ) Logic High \(\left(V_{I H}\right) V_{C C}=\) Max Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) \(V_{C C}=5 \mathrm{~V} \pm 5 \%\) Logic Low (VIL) Schmitt Trigger Input ( \(\div 4\) ) Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) Logic Low (VIL) RESET Input Levels Logic High Logic Low SO Input Level (Test Mode) All Other Inputs Logic High Logic High Logic Low Logic High Logic Low``` | Schmitt Trigger Input <br> (Note 3) $V_{C C}=M a x$ <br> with TTL Trip Level Options <br> Selected, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ <br> with High Trip Level Options <br> Selected | $\begin{gathered} 3.0 \\ \\ 2.0 \\ -0.3 \\ \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ 2.0 \\ \\ \\ 3.0 \\ 2.0 \\ -0.3 \\ 3.6 \\ -0.3 \\ \hline \end{gathered}$ | 0.4 <br> 0.6 <br> 0.6 <br> 2.5 <br> 0.8 <br> 1.2 | V V V V V v V V $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{v} \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage |  | -1 | +1 | $\mu \mathrm{A}$ |
| Output Voltage Levels LSTTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{l}_{\mathrm{OH}}=-25 \mu \mathrm{~A} \\ & \mathrm{l}_{\mathrm{OL}}=0.36 \mathrm{ma} \\ & \hline \end{aligned}$ | 2.7 | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| CMOS Operation (Note 2) <br> Logic High <br> Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{l}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-1$ | 0.2 | $\begin{aligned} & V \\ & V \end{aligned}$ |

[^0]
## COP420L/COP421L/COP422L

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels <br> Output Sink Current SO and SK Outputs (loL) <br> $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs and Standard $G_{0}-G_{3}, D_{0}-D_{3}$ Outputs (IoL) <br> $G_{0}-G_{3}$ and $D_{0}-D_{3}$ Outputs with High Current Options (loL) <br> $G_{0}-G_{3}$ and $D_{0}-D_{3}$ Outputs with Very High Current Options (loL) <br> CKI (Single-Pin RC Oscillator) CKO | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 1.8 \\ 1.2 \\ 0.9 \\ 0.4 \\ 0.4 \\ 0.4 \\ 15 \\ 11 \\ 7.5 \\ 30 \\ 22 \\ 15 \\ 2 \\ 0 \end{gathered}$ |  | mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Output Source Current Standard Configuration, All Outputs ( $\mathrm{IOH}_{\mathrm{O}}$ ) <br> Push-Pull Configuration SO and SK Outputs (lOH) <br> LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, Low Current Driver Option (IOH) <br> LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ <br> Outputs, High Current Driver Option ( $\mathrm{lOH}_{\mathrm{O}}$ ) <br> TRI-STATE Configuration, $L_{0}-L_{7}$ Outputs, Low Current Driver Option ( $\mathrm{lOH}_{\text {) }}$ TRI-STATE Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High Current Driver Option ( $\mathrm{IOH}_{\mathrm{O}}$ ) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \\ & \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -140 \\ & -75 \\ & -30 \\ & -1.4 \\ & -1.4 \\ & -1.2 \\ & \\ & -1.5 \\ & -1.5 \\ & \\ & -3.0 \\ & -3.0 \\ & -0.75 \\ & -0.8 \\ & -0.9 \\ & -1.5 \\ & -1.6 \\ & -1.8 \\ & \hline \end{aligned}$ | $\begin{aligned} & -800 \\ & -480 \\ & -250 \\ & \\ & -18 \\ & -13 \\ & -35 \\ & -25 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu A$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}$ | -10 | -140 | $\mu \mathrm{A}$ |
| CKO Output RAM Power Supply Option Power Requirement | $\mathrm{V}_{\mathrm{R}}=3.3 \mathrm{~V}$ |  | 3.0 | mA |
| TRI-STATE Output Leakage Current |  | -2.5 | +2.5 | $\mu \mathrm{A}$ |
| Total Sink Current Allowed <br> All Outputs Combined <br> D, G Ports <br> $\mathrm{L}_{7}-\mathrm{L}_{4}$ <br> $\mathrm{L}_{3}-\mathrm{L}_{0}$ <br> All Other Pins |  |  | $\begin{gathered} 120 \\ 120 \\ 4 \\ 4 \\ 1.5 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |
| Total Source Current Allowed All I/O Combined $L_{7}-L_{4}$ $L_{3}-L_{0}$ Each L Pin All Other Pins |  |  | $\begin{gathered} 120 \\ 60 \\ 60 \\ 30 \\ 1.5 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |

## Absolute Maximum Ratings

```
Voltage at Any Pin Relative to GND
    -0.5\textrm{V}\mathrm{ to }+10\textrm{V}
Ambient Operating Temperature }\quad-4\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to }+8\mp@subsup{5}{}{\circ}\textrm{C
Ambient Storage Temperature }\quad-6\mp@subsup{5}{}{\circ}\textrm{C}\mathrm{ to }+15\mp@subsup{0}{}{\circ}\textrm{C
Lead Temperature (Soldering, 10 sec.) 300'C
Power Dissipation
    COP320L/COP321L
    0.75W at 25*'C
    0.4W at 70
    0.25W at 85 %
    0.65W at 25 ' C
    0.20W at 70'⿳一⿻口⿰丨丨一心
```

Total Source Current
120 mA
Total Sink Current
120 mA
Absolute maximum ratings indicate limits beyond which damage to the device may occur．DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings．

DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage（ $\mathrm{V}_{\mathrm{CC}}$ ） | （Note 1） | 4.5 | 5.5 | V |
| Optional Operating Voltage（ $\mathrm{V}_{\mathrm{CC}}$ ） |  | 4.5 | 7.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 11 | mA |
| ```Input Voltage Levels CKI Input Levels Crystal Input Logic High \(\left(\mathrm{V}_{I H}\right) \mathrm{V}_{\mathrm{CC}}=\) Max Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) \(V_{C C}=5 \mathrm{~V} \pm 5 \%\) Logic Low ( \(\mathrm{V}_{\mathrm{IL}}\) ) Schmitt Trigger Input Logic High ( \(\mathrm{V}_{1 \mathrm{H}}\) ) Logic Low ( \(\mathrm{V}_{\mathrm{IL}}\) ) RESET Input Levels Logic High Logic Low SO Input Level (Test Mode) All Other Inputs Logic High Logic High Logic Low Logic High Logic Low``` | Schmitt Trigger Input <br> （Note 3） $V_{C C}=M a x$ <br> with TTL Trip Level Options Selected， $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ with High Trip Level Options Selected | 3.0 2.2 -0.3 $0.7 V_{C C}$ -0.3 $0.7 V_{C C}$ -0.3 2.2 3.0 2.2 -0.3 3.6 -0.3 | 0.3 <br> 0.4 <br> 0.4 <br> 2.5 <br> 0.6 <br> 1.2 | V V V V V V V V $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Hi－Z Input Leakage |  | －2 | ＋2 | $\mu \mathrm{A}$ |
| Output Voltage Levels LSTTL Operation Logic High $\left(\mathrm{VOH}_{\mathrm{OH}}\right)$ Logic Low（VOL） | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-20 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=0.36 \mathrm{~mA} \end{aligned}$ | 2.7 | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| CMOS Operation（Note 2） Logic High Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-1$ | 0.2 | $\begin{aligned} & V \\ & v \end{aligned}$ |

Note 1：$V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation．
Note 2：TRI－STATE and LED configurations are excluded．
Note 3：SO output＂ 0 ＂level must be less than 0.6 V for normal operation．

## COP320L/COP321L/COP322L

## DC Electrical Characteristics

$-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels Output Sink Current SO and SK Outputs (loL) <br> $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs and Standard $\mathrm{G}_{0}-\mathrm{G}_{3}$ and $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs (loL) <br> $G_{0}-G_{3}$ and $D_{0}-D_{3}$ Outputs with High Current Options (loL) <br> $G_{0}-G_{3}$ and $D_{0}-D_{3}$ Outputs with Very High Current Options (loL) <br> CKI (Single-Pin RC Oscillator) CKO | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} 1.4 \\ 1.0 \\ 0.8 \\ 0.4 \\ 0.4 \\ 0.4 \\ 12 \\ 9 \\ 7 \\ 24 \\ 18 \\ 14 \\ 2 \\ 0.2 \\ \hline \end{gathered}$ |  | mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Output Source Current Standard Configuration, All Outputs ( $\mathrm{IOH}^{\prime}$ ) <br> Push-Pull Configuration SO and SK Outputs ( l OH ) <br> LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, Low Current Driver Option (IOH) <br> LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High Current Driver Option (loH) TRI-STATE Configuration, $L_{0}-L_{7}$ Outputs, Low Current Driver Option ( $\mathrm{l}_{\mathrm{OH}}$ ) TRI-STATE Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High Current Driver Option ( $\mathrm{IOH}_{\mathrm{OH}}$ ) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.7 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.7 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} -100 \\ -55 \\ -28 \\ -0.85 \\ -1.1 \\ -1.2 \\ -1.4 \\ -1.4 \\ -0.7 \\ -2.7 \\ -2.7 \\ -1.4 \\ -0.7 \\ -0.6 \\ -0.9 \\ -1.4 \\ -1.2 \\ -1.8 \end{gathered}$ | $\begin{aligned} & -900 \\ & -600 \\ & -350 \\ & \\ & -27 \\ & -17 \\ & -15 \\ & -54 \\ & -34 \\ & -30 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}$ | -10 | -200 | $\mu \mathrm{A}$ |
| CKO Output RAM Power Supply Option Power Requirement | $V_{R}=3.3 V$ |  | 4.0 | mA |
| TRI-STATE Output Leakage Current |  | -5 | +5 | $\mu \mathrm{A}$ |
| Total Sink Current Allowed All Outputs Combined D, G Ports $\mathrm{L}_{7}-\mathrm{L}_{4}$ $L_{3}-L_{0}$ All Other Pins |  |  | $\begin{gathered} 120 \\ 120 \\ 4 \\ 4 \\ 1.5 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |
| Total Source Current Allowed <br> All I/O Combined $L_{7}-L_{4}$ $L_{3}-L_{0}$ <br> Each L Pin <br> All Other Pins |  |  | $\begin{gathered} 120 \\ 60 \\ 60 \\ 30 \\ 1.5 \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |

## AC Electrical Characteristics

COP420L/COP421L/COP422L: $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted COP320L/COP321L/COP322L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time-tc |  | 16 | 40 | $\mu \mathrm{s}$ |
| CKI <br> Input Frequency-fi <br> Duty Cycle <br> Rise Time <br> Fall Time | $\div 32$ Mode <br> $\div 16$ Mode <br> $\div 8$ Mode <br> $\div 4$ Mode $f_{1}=2 \mathrm{MHz}$ | $\begin{aligned} & 0.8 \\ & 0.4 \\ & 0.2 \\ & 0.1 \\ & 30 \end{aligned}$ | $\begin{gathered} 2.0 \\ 1.0 \\ 0.5 \\ 0.25 \\ 60 \\ 120 \\ 80 \end{gathered}$ | MHz <br> MHz <br> MHz <br> MHz <br> \% <br> ns <br> ns |
| CKI Using RC $(\div 4)$ <br> Instruction Cycle Time (Note 1) | $\begin{aligned} & R=56 \mathrm{k} \Omega \pm 5 \% \\ & C=100 \mathrm{pF} \pm 10 \% \end{aligned}$ | 16 | 28 | $\mu \mathrm{S}$ |
| CKO as SYNC Input tsYnc |  | 400 |  | ns |
| INPUTS: ```IN tsetup thold SI tseTUP thold``` |  | $\begin{aligned} & 8.0 \\ & 1.3 \\ & \\ & 2.0 \\ & 1.0 \\ & \hline \end{aligned}$ |  | $\mu \mathrm{S}$ $\mu \mathrm{s}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ |
| OUTPUT PROPAGATION DELAY <br> SO, SK Outputs <br> $t_{\text {pd1 }}, t_{p d 0}$ <br> All Other Outputs <br> $t_{\text {pd1 }}, t_{\text {pd }}$ | Test Condition: $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega, \mathrm{~V}_{\mathrm{OUT}}=1.5 \mathrm{~V}$ |  | $\begin{aligned} & 4.0 \\ & 5.6 \end{aligned}$ | $\mu \mathrm{S}$ $\mu \mathrm{S}$ |

Note 1: Variation due to the device included

## Connection Diagrams


Top View
Order Number COP420L-XXX/N or COP320L-XXX/N
See NS Package Number N28B


TL/DD/8825-3
Top View
Order Number COP421L-XXX/M, COP421L-XXX/N, COP321LXXX-/M or COP321L-XXX/N,
See NS Package Number M20B or N20A


TL/DD/8825-4
Top View
Order Number COP422L-XXX/M, COP422L-XXX/N, COP322L-XXX/M or COP322L-XXX/N
See NS Package Number M24B or N24A

FIGURE 2

## Pin Descriptions

| Pin | Description | Pin | Description |
| :--- | :--- | :--- | :--- |
| $L_{7}-L_{0}$ | 8 bidirectional I/O ports with TRI-STATE | SK | Logic-controlled clock (or general purpose out- <br> $G_{3}-G_{0}$ |
| 4 bidirectional I/O ports |  | put) |  |
| $D_{3}-D_{0}$ | 4 general purpose outputs | CKI | System oscillator input |
| $I_{3}-I_{0}$ | 4 general purpose inputs (COP420L only) | CKO | System oscillator output (or general purpose in- <br> SI |
| Serial input (or counter input) |  | pum power supply or SYNC input) |  |
| SO | Serial output (or general purpose output) |  | RESET |
|  |  | System reset input |  |

## Timing Diagrams



FIGURE 3. Input/Output Timing Diagrams (Crystal Divide-by-16 Mode)


TL/DD/8825-6
FIGURE 3a. Synchronization Timing

## Functional Description

For ease of reading this description, only COP420L and/or COP421L are referenced; however, all such references apply also to COP320L, COP321L, COP322L, or COP422L.
A block diagram of the COP420L is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).

## PROGRAM MEMORY

Program Memory consists of a 1,024 byte ROM. As can be seen by an examination of the COP420L/421L instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 16 pages of 64 words each.
ROM addressing is accomplished by a 10 -bit PC register. Its binary value selects one of the 1,0248 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 10-bit binary count value. Three levels of subroutine nesting are implemented by the 10 -bit subroutine save registers, SA, SB and SC, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 256-bit RAM, organized as 4 data registers of 164 -bit digits. RAM addressing is implemented by a 6 -bit B register whose upper 2 bits ( Br ) select 1 of 4 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4-bit contents of the selected RAM digit ( M ) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the Q latches or loaded from the L ports. RAM addressing may also be performed directly by the LDD and XAD instructions is based upon the 6-bit contents of the operand field of these instructions. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Br and Bd portions of the $B$ register, to load and input 4 bits of the 8 -bit Q latch data, to input 4 bits of the 8 -bit L I/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions of the COP420/421L, storing its results in A. It also outputs a carry bit to the 1-bit $C$ register, most often employed to indicate arithmetic overflow. The C register, in conjunctions with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or
can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.)
Four general-purpose inputs, $\mathrm{N}_{3}-\mathrm{N}_{0}$, are provided.
The D register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd. The D outputs can be directly connected to the digits of a multiplexed LED display.
The G register contents are outputs to 4 general-purpose bidirectional I/O ports. G I/O ports can be directly connected to the digits of a multiplexed LED display.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are outputted to the L I/O ports when the $L$ drivers are enabled under program control. (See LEI instruction.)
The 8 L drivers, when enabled, output the contents of latched Q data to the L I/O ports. Also, the contents of L may be read directly into $A$ and M. L I/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with $Q$ data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with A , allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting.SO to external serial-in/parallel-out shift registers. For example of additional parallel output capacity see Application \#2.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the clock.
The EN register is an internal 4-bit register loaded under program control by the LEl instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $\mathrm{EN}_{3}-\mathrm{EN}_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4bit binary counter. With $E N_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. With $E N_{1}$ set the $\mathrm{IN}_{1}$ input is enabled as an interrupt input. Immediately following an interrupt, $\mathrm{EN}_{1}$ is reset to disable further interrupts.
3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in $Q$ to the $L I / O$ ports. Resetting $E N_{2}$ disables

## Functional Description (Continued)

the L drivers, placing the L I/O ports in a high-impedance input state.
4. $E N_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $\mathrm{EN}_{3}$. With $\mathrm{EN}_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted
data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ". The table below provides a summary of the modes associated with $E N_{3}$ and $E N_{0}$.

Enable Register Modes-Bits $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$

| $\mathrm{EN}_{3}$ | $\mathrm{EN}_{0}$ | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Snift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=\text { Clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | $\begin{aligned} & \text { If } S K L=1, S K=\text { Clock } \\ & \text { If SKL }=0, S K=0 \end{aligned}$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | $\begin{aligned} \text { If } S K L & =1, S K \\ \text { If } S K L & =0, S K=0 \end{aligned}$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | $\begin{aligned} & \text { If } S K L=1, S K=1 \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |

## INTERRUPT

The following features are associated with the $\mathrm{IN}_{1}$ interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once aknowledged as explained below, pushes the next sequential program counter address (PC +1 ) onto the stack, pushing in turn the contents of the other subroutine-save registers to the next lower level (PC + $1 \rightarrow$ SA $\rightarrow$ SB $\rightarrow$ SC). Any previous contents of SC are lost. The program counter is set to hex address OFF (the last word of page 3) and $\mathrm{EN}_{1}$ is reset.
b. An interrupt will be acknowledged only after the following conditions are met:

1. $\mathrm{EN}_{1}$ has been set.
2. A low-going pulse (" 1 " to " 0 ") at least two instruction cycles wide occurs on the $\mathbb{N}_{1}$ input.
3. A currently executing instruction has been completed.
4. All successive transfer of control instructions and successive LBls have been completed (e.g., if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed).
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at address OFF. At the end of the interrupt routine, a RET instruction is executed to "pop" the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines and LQID instructions should not be
nested within the interrupt servicing routine since their popping the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The first instruction of the interrupt routine at hex address OFF must be a NOP.
e. A LEI instruction can be put immediately before the RET to re-enable interrupts.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the RESET pin as shown below. The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to $\mathrm{V}_{\mathrm{CC}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N$, and $G$ registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.


## Functional Description (Continued)

## OSCILLATOR

There are three basic clock oscillator configurations available as shown by Figure 4.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency divided by 32 (optional by 16 or 8 ).
b. External Oscillator. CKI is an external clock input signal. The external frequency is divided by 32 (optional by 16 or 8 ) to give the instruction cycle time. CKO is now available to be used as the RAM power supply $\left(V_{R}\right)$ or as a general purpose input.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is available as the RAM power supply ( $V_{R}$ ) or as a general purpose input.

## CKO PIN OPTIONS

In a crystal controlled oscillator system, CKO is used as an output to the crystal network. As an option CKO can be a general purpose input, read into bit 2 of $A$ (accumulator) upon execution of an INIL instruction. As another option, CKO can be a RAM power supply pin ( $V_{R}$ ), allowing its connection to a standby/backup power supply to maintain the integrity of RAM data with minimum power drain when the main supply is inoperative or shut down to conserve power. Using either option is appropriate in applications where the COP420L/421L system timing configuration does not require use of the CKO pin.

## RAM KEEP-ALIVE OPTION (Not available on COP422L)

Selecting CKO as the RAM power supply ( $\mathrm{V}_{\mathrm{R}}$ ) allows the user to shut off the chip power supply ( $\mathrm{V}_{\mathrm{CC}}$ ) and maintain data in the RAM. To insure that RAM data integrity is maintained, the following conditions must be met:

1. $\overline{\text { RESET }}$ must go low before $V_{c c}$ goes below spec during power-off; $V_{C C}$ must be within spec before RESET goes high on power-up.
2. During normal operation $\mathrm{V}_{\mathrm{R}}$ must be within the operating range of the chip, with $\left(V_{C C}-1\right) \leq V_{R} \leq V_{C C}$.
3. $V_{R}$ must be $\geq 3.3 V$ with $V_{C C}$ off.

Crystal Oscillator




TL/DD/8825-8

| Crystal <br> Value | Component Values |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | R1 $(\Omega)$ | R2 $(\Omega)$ | $\mathbf{C 1}(\mathbf{p F})$ | $\mathbf{C 2}(\mathbf{p F})$ |
| 455 kHz | 4.7 k | 1 M | 220 | 220 |
| 2.097 MHz | 1 k | 1 M | 30 | $6-36$ |

RC Controlled Oscillator

| $\mathbf{R ( k} \Omega)$ | $\mathbf{C}(\mathbf{p F})$ | Instruction <br> Cycle Time <br> $(\mu \mathbf{s})$ |
| :---: | :---: | :---: |
| 51 | 100 | $19 \pm 15 \%$ |
| 82 | 56 | $19 \pm 13 \%$ |

Note: $200 k \geq R \geq 25 k$
$360 \mathrm{pF} \geq \mathrm{C} \leq 50 \mathrm{pF}$

FIGURE 4. COP420L/421L Oscillator

## Functional Description (Continued)

## I/O OPTIONS

COP420L/421L outputs have the following optional configurations, illustrated in Figure 5:
a. Standard-an enhancement mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with LSTTL and CMOS input requirements. Available on SO, SK, and all D and G outputs.
b. Open-Drain-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. Available on SO, SK, and all D and G outputs.
c. Push-Pull-An enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{Cc}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. Available on SO and SK outputs only.
d. Standard L-same as a., but may be disabled. Available on $L$ outputs only.
e. Open Drain L-same as b., but may be disabled. Available on $L$ outputs only.
f. LED Direct Drive-an enhancement-mode device to ground and to $V_{\mathrm{CC}}$, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (see Functional Description, EN Register), placing the outputs in a high-impedance state to provide required LED segment blanking for a multiplexed display. Available on L outputs only.
g. TRI-STATE Push-Pull-an enhancement-mode device to ground and $\mathrm{V}_{\mathrm{CC}}$. These outputs are TRI-STATE outputs, allowing for connection of these outputs to a data bus shared by other bus drivers. Available on L outputs only.
COP420L/COP421L inputs have the following optional configurations:
h. An on-chip depletion load device to $V_{C C}$.
i. A Hi-Z input which must be driven to a " 1 " or " 0 " by external components.

The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6, respectively). Minimum and maximum current (IOUT and $V_{\text {OUT }}$ ) curves are given in Figure 6 for each of these devices to allow the designer to effectively use these I/O configurations in designing a COP420L/421L system.
The SO, SK outputs can be configured as shown in a., b., or c. The D and G outputs can be configured as shown in a. or b. Note that when inputting data to the $G$ ports, the $G$ outputs should be set to " 1 ". The L outputs can be configured as in d., e., f. or g.
An important point to remember if using configuration d. or $f$. with the $L$ drivers is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current (see Figure 6, device 2); however, when the $L$ lines are used as inputs, the disabled depletion device cannot be relied on to source sufficient current to pull an input to a logic 1.

## COP421L

If the COP420L is bonded as a 24-pin device, it becomes the COP421L, illustrated in Figure 2, COP420L/421L Connection Diagrams. Note that the COP421L does not contain the four general purpose $\mathbb{I N}$ inputs ( $\mathrm{N}_{3}-\mathrm{IN}_{0}$ ). Use of this option precludes, of course, use of the $\mathbb{I N}$ options and the interrupt feature. All other options are available for the COP421L.

## COP422L

If the COP421L is bonded as a 20 -pin device, it becomes the COP422L, as illustrated in Figure 2. Note that the COP422L contains all the COP421L pins except $D_{0}, D_{1}, G_{0}$, and $G_{1}$. COP422L also does not allow RAM power supply input as a valid CKO pin option.


TL/DD/8825-9
a. Standard Output


TL./DD/8825-10
b. Open-Drain Output


TL/DD/8825-11
c. Push-Pull Output

Functional Description (Continued)

d. Standard L Output


TL/DD/8825-15
g. TRI-STATE Push-Pull (L Output)

e. Open-Drain L Output

h. Input with Load

FIGURE 5. Output Configurations

## Typical Performance Characteristics



Source Current for SO and SK in Push-Pull Configuration



Source Current for $\mathrm{L}_{0}-\mathrm{L}_{7}$ In TRI-STATE Configuration (High Current Option)


I. HI-Z Input

Source Current for Standard Output Configuration


Source Current for $L_{0}-L_{7}$ in TRI-STATE Configuration (Low Current Option)


TL/DD/8825-18

Typical Performance Characteristics (Continued)


LED Output Source Current (Low Current LED Option)


Output Sink Current for SO and SK


VOL (VOLTS)

LED Output Direct Segment and Digit Drive (High Current Options on $L_{0}$ L $_{7}$; Very High Current Options on $\mathrm{D}_{0}-\mathrm{D}_{3}$ or $\mathrm{G}_{0}-\mathrm{G}_{3}$ )


Output Sink Current for $\mathrm{L}_{0}-\mathrm{L}_{7}$ and Standard Drive Option for $D_{0}-D_{3}$ and $G_{0}-G_{3}$


Vol (Volts)


LED Output Direct Segment Drive

Typical Performance Characteristics (Continued)


FIGURE 7. COP320L/DOP321L/COP322L Input/Output Characteristics

## COP420L/COP421L Instruction Set

Table I is a symbol table providing internal architecture, instruction operand and operational symbols used in the in-

Table II provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with struction set table. each instruction in the COP410L/411L instruction set.

TABLE I. COP420L/421L Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| IL | Two 1-bit Latches associated with the IN ${ }_{3}$ or |
|  | INo inputs |
| IN | 4-bit Input Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| PC | 10-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| SA | 10-bit Subroutine Save Register A |
| SB | 10-bit Subroutine Save Register B |
| SC | 10-bit Subroutine Save Register C |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |


| Symbol | Definition |
| :--- | :--- |
| INSTRUCTION OPERAND SYMBOLS |  |
| d | 4-bit Operand Field, $0-15$ binary (RAM Digit Select) <br> 2-bit Operand Field, $0-3$ binary (RAM Register |
|  | Select) |
| a | 10-bit Operand Field, $0-1023$ binary (ROM Address) <br> 4-bit Operand Field, $0-15$ binary (Immediate Data) |
| RAM(s) | Contents of RAM location addressed by s |
| ROM(t) | Contents of ROM location addressed by t |

Instruction Set (Continued)
TABLE II. COP420L/421L Instruction Set

| Mnemonic Operand | Hex <br> Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |
| ASC | 30 | 10011 0000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD | 31 | 10011 0001 | $A+R A M(B) \rightarrow A$ | None | Add RAM to A |
| ADT | 4A | \|0100|1010 | $A+10_{10} \rightarrow A$ | None | Add Ten to A |
| AISC y | $5-$ | 0101 ${ }^{\text {d }} \mathrm{y}$ | $A+y \rightarrow A$ | Carry | Add Immediate, Skip on Carry $(y \neq 0)$ |
| CASC | 10 | $10001 \mid 0000$ | $\begin{aligned} & \bar{A}+\operatorname{RAM}(B)+C \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Compliment and Add with Carry, Skip on Carry |
| CLRA | 00 | [000010000 | $0 \rightarrow \mathrm{~A}$ | None | Clear A |
| COMP | 40 | -0100\|0000 | $\bar{A} \rightarrow A$ | None | Ones complement of $A$ to $A$ |
| NOP | 44 | 010010100 | None | None | No Operation |
| RC | 32 | -0011 0010 | "0" $\rightarrow$ C | None | Reset C |
| SC | 22 | -0010\|0010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR | 02 | 10000\|0010 | $A \oplus \operatorname{RAM}(\mathrm{~B}) \rightarrow \mathrm{A}$ | None | Exclusive-OR RAM with A |

TRANSFER OF CONTROL INSTRUCTIONS

| JID |  | FF | 1111\|1111 | $\begin{aligned} & \mathrm{ROM}_{\left(\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M}\right)} \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 3) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JMP | a | $6-$ | $\begin{gathered} \|0110\| 00\left\|a_{9: 8}\right\| \\ \hline \mathrm{a}_{7: 0} \\ \hline \end{gathered}$ | $a \rightarrow P C$ | None | Jump |
| JP | a | -- -- | $\left\lfloor 1 \mid \quad a_{6: 0}\right.$ <br> (pages 2,3 only) <br> or <br> $\|11\| \quad a_{5: 0}$ <br> (all other pages) | $\begin{aligned} & a \rightarrow P C_{6: 0} \\ & a \rightarrow P C_{5: 0} \end{aligned}$ | None | Jump within Page (Note 4) |
| JSRP | a | -- | \|10 $\mathrm{a}_{5} \mathbf{0}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \\ & \mathrm{SB} \rightarrow \mathrm{SC} \\ & 0010 \rightarrow \mathrm{PC}_{9: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR | a | 6- | $\begin{array}{\|c\|c\|c\|} \hline 0110\|10\| \mathrm{a}_{9}: 8 \\ \hline \mathrm{a}_{7}: 0 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \\ & \mathrm{SB} \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | 0100\|1000 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 0100\|1001 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE II. COP420L/421L Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 | 0011\|0011 | $A \rightarrow Q_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C | 0011\|1100 | $\operatorname{RAM}(B) \rightarrow Q_{3: 0}$ |  |  |
| CQMA |  | 33 | 0011\|0011 | $\mathrm{Q}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Copy Q to RAM, A |
|  |  | 2 C | 10010\|1100 | $\mathrm{Q}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| LD | $r$ | -5 | O00\|r/0101 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into $A$, Exclusive-OR Br with $r$ |
| LDD | r,d | 23 | 0010 0011  <br> $00\|l\| l \mid$   <br> 00 r d | RAM(r,d) $\rightarrow$ A | None | Load A with RAM pointed to directly by r,d |
| LQID |  | BF | \|1011|1111 | $\begin{aligned} & R O M\left(P C_{9: 8}, A, M\right) \rightarrow Q \\ & S B \rightarrow S C \end{aligned}$ | None | Load Q Indirect (Note 3) |
| RMB | 0 | 4 C | \|0100|1100 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | 0100\|0101 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1}$ |  |  |
|  | 2 | 42 | $0100\|0010\|$ | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 43 | 0100\|0011 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |
| SMB | 0 | 4D | 10100\|1101 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Set RAM Bit |
|  | 1 | 47 | -0100\|1101 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1}$ |  |  |
|  | 2 | 46 | 1010010110 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 4B | -0100/1011 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |
| STII | $y$ | 7- | 0111] y | $\begin{aligned} & y \rightarrow R A M(B) \\ & B d+1 \rightarrow B d \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | $r$ | -6 | 100\|r10110 | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with $A$, Exclusive-OR Br with $r$ |
| XAD | r,d | 23 | $\begin{array}{\|l\|l\|} \hline 0010 & 0011 \\ \hline 10 & \mathrm{r} \\ \hline \end{array}$ | RAM $(r, d) \longleftrightarrow A$ | None | Exchange A with RAM pointed to directly by $(r, d)$ |
| XDS | r | -7 | 100\|r|0111 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd, Exclusive-OR Br with r |
| XIS | r | -4 | $\underline{00\|r\| 0100 \mid}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with $A$ and Increment Bd, Exclusive-OR Br with r |


| TABLE II. COP420L/421L. Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| REGISTER REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAB |  | 50 | 101010000 | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| CBA |  | 4E | 10100\|1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d |  | $\begin{gathered} . \end{gathered}$ | $\mathrm{r}, \mathrm{d} \rightarrow \mathrm{B}$ | Skip until not an LBI | Load B Immediate with r,d (Note 6) |
| LEI | $y$ | 33 $6-$ | $0011 / 0011$ <br> 0110 | $y \rightarrow E N$ | None | Load EN Immediate (Note 7) |
| XABR |  | 12 | 0001 0010 | $A \longleftrightarrow \operatorname{Br}\left(0,0 \rightarrow A_{3}, A_{2}\right)$ | None | Exchange A with Br |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  |  | 0010\|0000 |  | $C=" 1 "$ | Skip if C is True |
| SKE |  | 21 | -0010\|0001 |  | $A=R A M(B)$ | Skip if A Equals RAM |
| SKGZ |  | 33 | \|0011|0011| |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
|  |  |  | 0010\|0001 |  |  |  |
| SKGBZ |  | 33 | 0011\|0011 | 1st byte |  | Skip if G Bit is Zero |
|  | 0 | 01 | 0000\|0001 | \} 2nd byte | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 0001\|0001 |  | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 |  | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 0001\|0011 |  | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 0000\|0001 |  | $\operatorname{RAM}(B)_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | 0001 0001 ] |  | $\operatorname{RAM}(B)_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 |  | $\operatorname{RAM}(\mathrm{B})_{2}=0$ |  |
|  | 3 | 13 | 0001 0011 ] |  | $\operatorname{RAM}(\mathrm{B})_{3}=0$ |  |
| SKT |  | 41 | 0100\|0001 |  | A time-base counter carry has occurred since last test | Skip on Timer (Note 3) |

Instruction Set (Continued)
TABLE II. COP420L/421L Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 001110011 | $\mathrm{G} \rightarrow \mathrm{A}$ | None | Input G Ports to A |
|  |  | 2 A | \|0010|1010 |  |  |  |
| ININ |  | 33 | 0011 0011 | $\mathrm{IN} \rightarrow \mathrm{A}$ | None | Input IN Inputs to A (Note 2) |
|  |  | 28 | 0010\|1000 |  |  |  |
| INIL |  | 33 | 0011 00011 | $\mathrm{IL}_{3}, \mathrm{CKO}, ~ " 0$ ", $\mathrm{IL}_{-0} \rightarrow \mathrm{~A}$ | None | Input IL Latches to A |
|  |  | 29 | \|0010|1001| |  |  | (Note 3) |
| INL |  | 33 | 0011\|0011 | $\mathrm{L}_{7: 4} \rightarrow$ RAM $(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2 E | 0010\|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | 0011 10011 | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E | 0011\|1110 |  |  |  |
| OGI | $y$ | 33 | 0011 00011 | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | $5-$ | -0101\| y |  |  |  |
| OMG |  | 33 | 0011 00011 | $R A M(B) \rightarrow G$ | None | Output RAM to G Ports |
|  |  | 3 A | \|0011|1010 |  |  |  |
| XAS |  | 4F | 0100\|1111 | $A \longleftrightarrow$ SIO, C $\rightarrow$ SKL | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit $A$ register.
Note 2: The ININ instruction is only available on the 28 -pin COP420L as the other devices do not contain the IN inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 5: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ "" data minus 1 , e.g., to load the lower four bits of $B(B d)$ with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).
Note 7: Machine code for operand field y for LEI instruction should equal the binary value to be tatched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP420L/421L programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If

SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 10-bit word, $\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ are not affected by this instruction.
Note that JID requires 2 instruction cycles to execute.

## Description of Selected Instructions (Continued)

## INIL INSTRUCTION

INIL (Input IL Latches to A) inputs 2 latches, $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ (see Figure 8 ) and CKO into A . The $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ latches are set if a low-going pulse (" 1 " to " 0 ") has occurred on the $1 N_{3}$ and $\mathrm{IN}_{0}$ inputs since the last $\mathbb{N} I L$ instruction, provided the input pulse stays low for at least two instruction times. Execution of an INIL inputs $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ into A 3 and AO respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the $\mathrm{IN}_{3}$ and $\mathrm{I} \mathrm{N}_{0}$ lines. If CKO is mask programmed as a general purpose input, an INIL will input the state of CKO into A2. If CKO has not been so programmed, a " 1 " will be placed in A2. A " 0 " is always placed in A1 upon the execution of an INIL. The general purpose inputs $I N_{3}-I N_{0}$ are input to $A$ upon execution of an ININ instruction. (See Table II, ININ instruction.) INIL is useful in recognizing pulses of short duration or pulses which occur too often to be read conveniently by an ININ instruction. IL latches are not cleared on reset.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8 -bit $Q$ register with the contents of ROM pointed to by the 10 -bit word $\mathrm{PC}_{9}, \mathrm{PC}_{8}, \mathrm{~A}$, M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC +1 $\rightarrow$ SA $\rightarrow$ SB $\rightarrow$ SC) and replaces the least significant 8 bits of PC as follows: $A \rightarrow$ $\mathrm{PC}_{7: 4}, \mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" (SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow$ PC), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost. Also, when LQID pops the stack, the previously pushed contents of SB are left in SC. The net result is that the contents of SB are placed in SC (SB $\rightarrow$ SC). Note the LQID takes two instruction cycle times to execute.


FIGURE 8. INIL Hardware Implementation

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of an internal 10 -bit time-base counter. This counter divides the instruction cycle clock frequency by 1024 and provides a latched indication of counter overflow. The SKT instruction tests this latch, executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction, therefore, allow the COP420L/421L to generate its own timebase for real-time processing rather than relying on an external input signal.
For example, using a 2.097 MHz crystal as the time-base to the clock generator, the instruction cycle clock frequency will be 65 kHz (crystal frequency $\div 32$ ) and the binary counter output pulse frequency will be 64 Hz . For time-of-day or similar real-time processing, the SKT instruction can call a routine which increments a "seconds" counter every 64 ticks.

## INSTRUCTION SET NOTES

a. The first word of a COP420L/421L program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped.
c. The ROM is organized into 16 pages of 64 words each. The Program Counter is a 10 -bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page $3,7,11$, or 15 will access data in the next group of four pages.

## Option List

The COP420L/421L mask-programmable options are assigned numbers which correspond with the COP420L pins.
The following is a list of COP420L options. When specifying a COP421L chip, Options 9, 10, 19, and 20 must all be set to zero. When specifying a COP422L chip, options $9,10,19$, and 20 must all be set to zero; options 21 and 22 may not be set to one, three or five; and option 2 may not be set to one. The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
The Option Table should be copied and sent in with your EPROM or disc.

Option 1 = 0: Ground Pin-no options available
Option 2: CKO Output
$=0$ : clock generator output to crystal/resonator ( 0 not allowable value if Option $3=3$ )
$=1$ : pin is RAM power supply $\left(V_{R}\right)$ input (not available on the COP422L)
$=2$ : general purpose input with load device to $\mathrm{V}_{\mathrm{CC}}$
= 3: general purpose input, Hi-Z
Option 3: CKI Input
= 0 : oscillator input divided by 32 ( 2 MHz max.)
$=1$ : oscillator input divided by 16 ( 1 MHz max.)
$=2$ : oscillator input divided by 8 ( 500 kHz max.)
$=3$ : single-pin RC controlled oscillator $(\div 4)$
$=4$ : Schmitt trigger clock input ( $\div 4$ )
Option 4: RESET Input
$=0$ : load device to $V_{C C}$
= 1: Hi-Z Input
Option 5: L $\mathrm{L}_{7}$ Driver
$=0$ : Standard output
= 1: Open-drain output
$=2$ : High current LED direct segment drive output
= 3: High current TRI-STATE push-pull output
$=4$ : Low-current LED direct segment drive output
= 5: Low-current TRI-STATE push-pull output
Option 6: $L_{6}$ Driver
same as Option 5
Option 7: L5 Driver
same as Option 5
Option 8: L4 Driver
same as Option 5
Option 9: $\mathbb{I N}_{\boldsymbol{1}}$ Input
$=0$ : load device to $\mathrm{V}_{\mathrm{CC}}$
$=1: \mathrm{Hi}-\mathrm{Z}$ input
Option 10: $\mathbb{I N}_{2}$ Input
same as Option 9
Option 11: $V_{\mathrm{CC}}$ pin
$=0$ : Standard $V_{C C}$
$=1$ : Optional higher voltage $\mathrm{V}_{\mathrm{CC}}$
Option 12: L3 Driver
same as Option 5
Option 13: L2 Driver
same as Option 5
Option 14: $\mathrm{L}_{1}$ Driver same as Option 5
Option 15: $\mathrm{L}_{0}$ Driver same as Option 5
Option 16: SI Input same as Option 9
Option 17: SO Driver
$=0$ : standard output
$=1$ : open-drain output
= 2: push-pull output
Option 18: SK Driver. same as Option 17

Option 19: $\mathbb{I N}_{0}$ Input same as Option 9
Option 20: $\mathrm{IN}_{3}$ Input same as Option 9
Option 21: $\mathrm{G}_{0}$ I/O Port
$=0$ : very-high current standard output
$=1$ : very-high current open-drain output
$=2$ : high current open-drain output
$=3$ : high current open-drain output
$=4$ : standard LSTTL output (fanout $=1$ )
$=5$ : open-drain LSTTL output (fanout $=1$ )
Option 22: $\mathrm{G}_{1}$ I/O Port
same as Option 21
Option 23: $\mathrm{G}_{2}$ I/O Port same as Option 21
Option 24: $\mathrm{G}_{3}$ I/O Port same as Option 21
Option 25: $\mathrm{D}_{3}$ Output same as Option 21
Option 26: $\mathrm{D}_{2}$ Output same as Option 21
Option 27: $\mathrm{D}_{1}$ Output same as Option 21
Option 28: $\mathrm{D}_{0}$ Output same as Option 21
Option 29: L Input Levels $=0$ : standard TTL input levels (" 0 " $=0.8 \mathrm{~V}, " 1 "=2.0 \mathrm{~V}$ )
$=1$ : higher voltage input levels
(" 0 " $=1.2 \mathrm{~V}, " 1 "=3.6 \mathrm{~V}$ )
Option 30: IN Input Levels same as Option 29
Option 31: G Input Levels same as Option 29
Option 32: SI Input Levels same as Option 29
Option 33: $\overline{\text { RESET Input }}$
$=0$ : Schmitt trigger input
$=1:$ standard TTL input levels
$=2$ : higher voltage input levels
Option 34: CKO Input Levels (CKO = input; Option $2=2,3$ ) same as Option 29
Option 35: COP Bonding
= 0: COP420L (28-pin device)
$=1:$ COP421L (24-pin device)
$=2: 28$ - and 24 -pin versions
$=3:$ COP422L (20-pin device)
$=4: 28$ - and 20 -pin versions
$=5$ : 24- and 20 -pin versions
$=5$ : 28-, 24 -, and 20 -pin versions
Option 36: Internal Initialization Logic
$=0$ : normal operation
$=1$ : no internal initialization logic

## Option Table

The following EPROM option information is to be sent to National along with the EPROM.

OPTION DATA
OPTION 1 VALUE = $\qquad$ IS: GROUND PIN
OPTION 2 VALUE = $\qquad$ IS: CKO OUTPUT

OPTION 3 VALUE = $\qquad$ IS: CKI INPUT
OPTION 4 VALUE $=$ $\qquad$ IS: RESET INPUT
OPTION 5 VALUE = $\qquad$ IS: $L_{7}$ DRIVER
OPTION 6 VALUE = $\qquad$ IS: L6 DRIVER
OPTION 7 VALUE = $\qquad$ IS: $L_{5}$ DRIVER
OPTION 8 VALUE = $\qquad$ IS: L ${ }_{4}$ DRIVER
OPTION 9 VALUE = $\qquad$ IS: IN1 INPUT

OPTION 10 VALUE = $\qquad$ IS: IN2 INPUT
OPTION 11 VALUE = $\qquad$ IS: VCC PIN

OPTION 12 VALUE = $\qquad$ IS: $L_{3}$ DRIVER
OPTION 13 VALUE = $\qquad$ IS: L $L_{2}$ DRIVER
OPTION 14 VALUE $=$ $\qquad$ IS: L ${ }_{1}$ DRIVER
OPTION 15 VALUE = $\qquad$ IS: L L DRIVER
OPTION 16 VALUE = $\qquad$ IS: SI INPUT
OPTION 17 VALUE = $\qquad$ IS: SO DRIVER
OPTION 18 VALUE = $\qquad$ IS: SK DRIVER

## TEST MODE (Non-Standard Operation)

The SO output has been configured to provide for standard test procedures for the customer-programmed COP420L. With SO forced to logic " 1 ", two test modes are provided, depending upon the value of SI :
a. RAM and Internal Logic Test Mode $(\mathrm{SI}=1)$
b. ROM Test Mode $(\mathrm{SI}=0)$

These special test modes should not be employed by the user; they are intended for manufacturing test only.

## APPLICATIONS \# 1: COP420L General Controller

Figure 9 shows an interconnect diagram for a COP420L used as a general controller. Operation of the system is as follows:

1. The $L_{7}-L_{0}$ outputs are configured as LED Direct Drive outputs, allowing direct connection to the segments of the display.

## OPTION DATA

| OPTION 19 VALUE = | IS: $\mathrm{IN}_{0}$ INPUT |
| :---: | :---: |
| OPTION 20 VALUE = | IS: $\mathrm{IN}_{3}$ INPUT |
| OPTION 21 VALUE = | IS: $\mathrm{G}_{0}$ I/O PORT |
| OPTION 22 VALUE = | IS: $\mathrm{G}_{1}$ I/O PORT |
| OPTION 23 VALUE | IS: $\mathrm{G}_{2}$ I/O PORT |
| OPTION 24 VALUE | IS: $\mathrm{G}_{3}$ I/O PORT |
| OPTION 25 VALUE = | IS: $\mathrm{D}_{3}$ OUTPUT |
| OPTION 26 VALUE | IS: $\mathrm{D}_{2}$ OUTPUT |
| OPTION 27 VALUE | IS: $\mathrm{D}_{1}$ OUTPUT |
| OPTION 28 VALUE | IS: $\mathrm{D}_{0}$ OUTPUT |
| OPTION 29 VALUE | IS: L INPUT LEVELS |
| OPTION 30 VALUE $=$ | IS: IN INPUT LEVELS |
| OPTION 31 VALUE | IS: G INPUT LEVELS |
| OPTION 32 VALUE $=$ | IS: SI INPUT LEVELS |
| OPTION 33 VALUE $=$ | IS: $\overline{\text { RESET }}$ INPUT |
| OPTION 34 VALUE $=$ | IS: CKO INPUT LEVELS |
| OPTION 35 VALUE $=$ | IS: COP BONDING |
| OPTION 36 VALUE $=$ | IS: INTERNAL INITIALIZATION LOGIC |

2. The $D_{3}-D_{0}$ outputs drive the digits of the multiplexed display directly and scan the columns of the $4 \times 4$ keyboard matrix.
3. The $\mathbb{I N}_{3}-\mathbb{N}_{0}$ inputs are used to input the 4 rows of the keyboard matrix. Reading the IN lines in conjunction with the current value of the D outputs allows detection, debouncing, and decoding of any one of the 16 keyswitches.
4. CKI is configured as a single-pin oscillator input allowing system timing to be controlled by a single-pin RC network. CKO is therefore available for use as a $V_{\mathrm{R}}$ RAM power supply pin. RAM data integrity is thereby assured when the main power supply is shut down (see RAM Keep-Alive option description).
5. SI is selected as the input to a binary counter input. With SIO used as a binary counter, SO and SK can be used as general purpose outputs.
6. The 4 bidirectional G I/O ports $\left(\mathrm{G}_{3}-\mathrm{G}_{0}\right)$ are available for use as required by the user's application.

## Typical Applications


*SO, SI, SK may also be used for Serial I/O
FIGURE 9. COP420L Keyboard/Display Interface
APPLICATION \#2:
Digitally Tuned Radio Controller and Clock

## Keyboard Matrix Configuration




## Typical Applications (Continued)



TL/DD/8825-24
FIGURE 10. Digital Tuning System Block

## Functional Description

## LOGIC I/Os

CKI Input: This input accepts an external 500 kHz signal, divides it by eight and outputs the quotient at the CLK output as the system clock.
$\overline{\text { RST }}$ Input: Schmitt trigger input to clear device upon initialization.
SDT Input: Interrupt input for station detection. The SDT signal is generated by the radio's station detector and used by the COP420L to determine if there is a valid station on the active frequency. The status of the SDT input is only relevant during station searching mode. A high on SDT will temporarily terminate the search mode for eight seconds.
ALM Input: A high on ALM will activate alarm output via slave device at alarm time. A low on the input will disable alarm function.
DATA Output: Push-pull output providing serial data to external devices.
CLK Output: Push-pull output providing system clock at data transmitting time.
50 Hz Input: A normally high input to accept a 50 Hz external time base for real-time calculation.

## MOMENTARY KEYS DESCRIPTION

MEM 1-MEM 10: Each memory represents data of a favorite station in a certain band. Depression of one of these
keys will recall the previous stored data and transmit it to the PLL. The PLL will in turn change the radio's receiving frequency as well as the band if necessary. Memory recall keys can also turn on the radio.
UP: This key will manually increment receiving frequency. The first four steps of increment will be for fine tuning a station, after which will be fast slewing meant for manual receive frequency changing.
DOWN: Has the same function as UP key except that frequency is decremented.
MEMORY SCAN: This will start the radio scanning through all ten memories automatically at eight seconds per memory starting from Memory 1 . This will also turn on the radio if it was off.
MEMORY STORE: Enables the memory store mode which lasts for three seconds. Depression of any memory key will store the active frequency and band in that memory and disable the store mode. Any function key will also disable the mode to prevent memory data being accidentally destroyed.
HALT: Depression of the HALT key will stop the search and scan functions at current frequency or memory. HALT also turns on the radio during off time and recall frequency display in signal display mode.
SEARCH: Activates station searching in the current band. Search speed is 50 ms per frequency step with wrapping

## Functional Description (Continued)

around at end of band. An 8 -second stop will take place on reaching a valid station. The HALT key or any function key will terminate the search. Search direction will normally be upwards unless the DOWN key has been depressed prior to the SEARCH key or during the search function in which case search direction will be downwards.
OFF: Turns off the radio or alarm when active.
AM/FM: Radio band switch.
SLEEP: Activates sleep mode, turns on radio on depression and off radio at the end of sleep period. Setting of sleep period is done by depressing the SLEEP and MINUTE key simultaneously.
ALARM: Enables alarm time setting. Depressing the HOUR or MINUTE key and ALARM key simultaneously will set the alarm hour and minute respectively.
HOUR: Sets the hour digits of time-related functions.
MINUTE: Sets the minute digits of time-related functions.

## DIODE STRAPS CONNECTIONS

STRAP 0: Controls the on and off of radio. In applications where a toggle type ON/OFF switch is used, momentary OFF key can be omitted; connecting the strap will turn on the radio and vice versa. Must be connected to use momentary OFF key.
STRAP 1, 2: Selects the AM IF options.
STRAP 3: 12/24-hour clock select.
STRAP 4: $3 / 5 \mathrm{kHz}$ AM step size select.
STRAP 5, 6: FM IF offsets select.

|  | STRAP 0 | STRAP 3 | STRAP 4 |
| :--- | :---: | :---: | :---: |
| Connected | Radio ON | 12 hour | 5 kHz step |
| Open | Radio OFF | 24 hour | 3 kHz step |

## AM/FM IF OPTIONS

| AM | STRAP 1 | STRAP 2 |
| :---: | :---: | :---: |
| 455 kHz | $X$ | X |
| 460 kHz | X | $\checkmark$ |
| 450 kHz | $\nu$ | X |
| 260 kHz | $\checkmark$ | $\checkmark$ |
| FM | STRAP 5 | STRAP 6 |
| 10.7 MHz | $X$ | $X$ |
| 10.75 MHz | X | $\checkmark$ |
| 10.65 MHz | $\nu$ | X |
| 10.8 MHz | $\checkmark$ | $\checkmark$ |

## INDIRECT FEATURES AND OPTIONS

As indicated in Figure 10, there are a few options and indirect features provided via the help of a slave device, namely the Phase Lock Loop, DS8906N.

## DISPLAY OPTIONS

As mentioned above, the COP420L-HSB is MICROWIRE compatible. Internal circuitry enables it to directly interface with all of National's serial input MICROWIRE compatible display drivers whether they are of a direct drive or multiplex drive format. On Figure 10 is a list of drivers available for the system. EN1 and EN2 are optional enable outputs meant for a dual display system in which EN3 will not be used. By dual display, it means that one display will be constantly showing time information and the other showing frequency information. Whereas in conventional single display systems, the display shows both time and frequency information in a time-sharing method. The National system provides a timeprioritized display-sharing method. That is, whenever a tuning function is completed, the frequency information will stay on the display for eight seconds then time display will take over. This is achieved by using EN3 for the driver's enable logic.

## CONTROL OUTPUTS

Six open collector outputs controlled by the COP420L are provided from DS8906N, the phase lock loop for controlling radio switching circuits.
Radio ON/OFF: A high from this output indicates that the radio should be switched on and vice versa.
AM/FM: Output for controlling the AM/FM bandswitch. A high level output indicates FM and a low indicates the AM band.
MUTE: For muting the audio output when performing any frequency related function. The output will go high prior to the frequency change except when doing fine tuning.
ALARM ENABLE: Active high output for turning on the alarm circuit at alarm time.
50 kHz IND: For driving the 50 kHz indicator in FM band or the LSB in a 5 -digit display. Output is active high.
MEM STORE IND: For driving the memory store mode indicator. Output is active high.

## TYPICAL IMPLEMENTATION ALTERNATIVES

A full keyboard or any portion of it can be implemented with various applications for features/functions vs. cost/size.
Figure 11 shows two keyboard configurations with 22-key and 11-key keyboards for a desk-top/tuner system or autoradio system, respectively.

Functional Description (Continued)



TL/DD/8825-26

FIGURE 11

## COP220H/COP221H/COP222H/COP320H/ COP321H/COP322H/COP420H/COP421H/COP422H Single-Chip N-Channel Microcontroller

## General Description

The COP420H is an enhanced version of the COP420L. It is fabricated in N-channel MOS. It combines the low power consumption of the COP420L and the faster cycle time of the COP420. It has all the software and hardware features of the COP400 series with some added options, and the LED/TRI-STATE ${ }^{\circledR}$ options replaced by an on chip current limiting resistor design. Also it has been designed for late programming of the ROM and hardware options. This allows for a very fast turnaround time for prototype parts. To meet the higher speed requirements the pull-ups and pull-downs had to be made stronger. They have been selected to meet most of the DC specs of the COP420. Therefore some DC parameters will exceed the maximum of the COP420L.

## Features

- Low cost
- Low current drain ( 5 mA max.)
- Powerful instruction set of the COP420L
- 1k x 8 ROM, $64 \times 4$ RAM
- $4 \mu \mathrm{~s}$ instruction cycle time
- Single supply operation $4.5 \mathrm{~V}-6.3 \mathrm{~V}$
- 23 I/O lines (COP420H)
- True vectored interrupt, plus restart
- Three-level subroutine stack
- Internal binary counter register with MICROWIRETM compatible serial I/O
- Internal time-base counter for real-time processing

■ Direct drive of LED digit and segment lines

- General purpose and TRI-STATE outputs
- LSTTL/CMOS compatible in and out
- Software/hardware compatible with COP400 family of devices
- Wider supply range 4.5-9.5V optionally available
- Extended temperature range devices

COP320H/COP321H/COP322H ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ) $\mathrm{COP} 220 \mathrm{H} / \mathrm{COP} 221 \mathrm{H} / \mathrm{COP} 222 \mathrm{H}\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+110^{\circ} \mathrm{C}\right)$

- Optional internal initialization
- Inputs and open drain outputs able to withstand 15 V


## Block Diagram



FIGURE 1

## COP420H/COP421H/COP422H

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated rellablity electrical test specifications document.
Voltage on Any Pin Relative to GND
Ambient Operating Temperature

$$
\text { Ambient Storage Temperature } \quad-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}
$$

$$
\text { Lead Temperature (Soldering, } 10 \mathrm{sec} . \text { ) }
$$

ESD Susceptibility (Note 4)

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+10 \mathrm{~V} \\
0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\
65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
300^{\circ} \mathrm{C} \\
2000 \mathrm{~V}
\end{array}
$$

Power Dissipation COP420H/COP421H

COP422H

Total Source Current 120 mA
Total Sink Current 120 mA

Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 1) | 4.5 | 6.3 | V |
| Optional Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 | 9.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 5 | mA |
| ```Input Voltage Levels CKI Input Levels Crystal Input ( \(\div 32, \div 16, \div 8\) ) Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) Logic Low (VIL) Schmitt Trigger Input ( \(\div 4\) ) Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) Logic Low (VIL) RESET Input Levels Logic High Logic Low SO Input Level (Test Mode) All Other Inputs Logic High Logic High Logic Low Logic High Logic Low``` | Schmitt Trigger Input <br> (Note 3) <br> $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ <br> with TTL Trip Level Options <br> Selected, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ <br> with High Trip Level Options <br> Selected | $\begin{gathered} 2.0 \\ -0.3 \\ \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ \\ 0.7 \mathrm{VCC} \\ -0.3 \\ 2.0 \\ \\ 3.0 \\ 2.0 \\ -0.3 \\ 3.6 \\ -0.3 \end{gathered}$ | 0.4 <br> 0.6 <br> 0.6 <br> 2.5 <br> 0.8 <br> 1.2 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ V v V V V $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage | $\begin{aligned} & V_{\text {IN }}<9.5 \mathrm{~V} \\ & 9.5 \leq \mathrm{V}_{\mathrm{IN}} \leq 15 \mathrm{~V} \end{aligned}$ | $\begin{gathered} -1 \\ -10 \end{gathered}$ | $\begin{gathered} +1 \\ +10 \end{gathered}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Output Voltage Levels LSTTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-25 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=0.36 \mathrm{ma} \\ & \hline \end{aligned}$ | 2.7 | 0.4 | $\begin{aligned} & V \\ & v \end{aligned}$ |
| CMOS Operation (Note 2) Logic High Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-1$ | 0.2 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ |

Note 1: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: TRI-STATE and LED configurations are excluded.
Note 3: SO output " 0 " level must be less than 0.8 V for normal operation.
Note 4: Human body model, 100 pF discharged through a $1.5 \mathrm{k} \Omega$ resistor.

## COP420H/COP421H/COP422H

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels Output Sink Current |  |  |  |  |
| $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs and Standard $\mathrm{G}_{0}-\mathrm{G}_{3}, \mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs (IoL) SO \& SK | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 3.2 \\ & 2.3 \\ & 1.7 \end{aligned}$ |  | $\begin{gathered} \mathrm{mA} \\ \mathrm{~mA} \\ \mathrm{~mA} \end{gathered}$ |
| $\mathrm{G}_{0}-\mathrm{G}_{3}$ and $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with High Current Options (loL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{COC}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 15 \\ & 11 \\ & 7.5 \end{aligned}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| $\mathrm{G}_{0}-\mathrm{G}_{3}$ and $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with Very High Current Options (loL) | $\begin{aligned} & V_{C C}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & V_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 30 \\ & 22 \\ & 15 \end{aligned}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| CKI (Single-Pin RC Oscillator) CKO | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{H}}=3.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & 2.2 \\ & 1.8 \end{aligned}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Output Source Current Standard Configuration, All Outputs ( $\mathrm{IOH}_{\mathrm{OH}}$ ) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \end{aligned}$ | $\begin{aligned} & -470 \\ & -250 \\ & -100 \end{aligned}$ | $\begin{aligned} & -2350 \\ & -1250 \\ & -500 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Push-Pull Configuration SO and SK Outputs ( $\mathrm{IOH}^{\mathrm{O}}$ ) | $\begin{aligned} & V_{C C}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.75 \mathrm{~V} \\ & V_{C C}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & V_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{l} \end{aligned}$ | $\begin{aligned} & -1.4 \\ & -1.4 \\ & -1.2 \end{aligned}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ <br> Outputs, Low Current <br> Driver Option (loh) | $\begin{aligned} & V_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & V_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} -6 \\ -1.5 \end{gathered}$ | $\begin{aligned} & -18 \\ & -7 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ <br> Outputs, High Current <br> Driver Option (lОH) | $\begin{aligned} & V_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & V_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -12 \\ & -3.0 \end{aligned}$ | $\begin{aligned} & -36 \\ & -14 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| TRI-STATE Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, Low Current Driver Option ( $\mathrm{l}_{\mathrm{OH}}$ ) | $\begin{aligned} & V_{C C}=9.5 \mathrm{~V}, V_{O H}=5.5 \mathrm{~V} \\ & V_{C C}=6.3 \mathrm{~V}, V_{O H}=3.2 \mathrm{~V} \\ & V_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -0.75 \\ & -0.8 \\ & -0.9 \end{aligned}$ |  | $\begin{aligned} & m A \\ & m A \\ & m A \end{aligned}$ |
| TRI-STATE Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High Current Driver Option ( $\mathrm{I}_{\mathrm{OH}}$ ) | $\begin{aligned} & V_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V} \\ & V_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.2 \mathrm{~V} \\ & V_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{l} \end{aligned}$ | $\begin{aligned} & -1.5 \\ & -1.6 \\ & -100 \end{aligned}$ | -800 | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {IL }}=0 \mathrm{~V}$ | -10 | -140 | $\mu \mathrm{A}$ |
| CKO Output RAM Power Supply Option Power Requirement | $\mathrm{V}_{\mathrm{R}}=3.3 \mathrm{~V}$ |  | 3.0 | mA |
| TRI-STATE Output Leakage Current |  | -2.5 | +2.5 | $\mu \mathrm{A}$ |
| Open Drain Output Leakage | $\begin{aligned} & V_{\text {OUT }}<9.5 \mathrm{~V} \\ & 9.5 \mathrm{~V} \leq V_{\text {OUT }}<15 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{array}{r} -2.5 \\ -2.5 \\ \hline \end{array}$ | $\begin{aligned} & +2.5 \\ & +2.5 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ |
| Total Sink Current Allowed All Outputs Combined D, G Ports $\mathrm{L}_{7}-\mathrm{L}_{4}$ $\mathrm{L}_{3}-\mathrm{L}_{0}$ All Other Pins |  |  | $\begin{gathered} 120 \\ 120 \\ 4 \\ 4 \\ 1.5 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Total Source Current Allowed All I/O Combined $\begin{aligned} & L_{7}-L_{4} \\ & L_{3}-L_{0} \end{aligned}$ <br> Each L Pin <br> All Other Pins |  |  | $\begin{aligned} & 120 \\ & 60 \\ & 60 \\ & 30 \\ & 1.5 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |

## COP320H/COP321H/COP322H

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage on Any Pin Relative to GND
-0.5 V to +10 V
Ambient Operating Temperature
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Ambient Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering, 10 sec .) $300^{\circ} \mathrm{C}$
ESD Susceptibility (Note 4) 3000V

DC Electrical Characteristics $\operatorname{COP} 220 \mathrm{H} / 221 \mathrm{H} / 222 \mathrm{H}-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+110^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$;
$\mathrm{COP} 320 \mathrm{H} / 321 \mathrm{H} / 322 \mathrm{H}-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 1) | 4.5 | 5.5 | V |
| Optional Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 | 7.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 8 | mA |
| Input Voltage Levels <br> CKI Input Levels Crystal Input Logic High $\left(V_{H H}\right) V_{C C}=$ Max Logic High ( $\mathrm{V}_{\mid \mathrm{H}}$ ) $V_{C C}=5 \mathrm{~V} \pm 5 \%$ Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> Schmitt Trigger Input Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> RESET Input Levels <br> Logic High <br> Logic Low <br> SO Input Level (Test Mode) <br> All Other Inputs <br> Logic High <br> Logic High <br> Logic Low <br> Logic High <br> Logic Low | Schmitt Trigger Input <br> (Note 3) <br> $V_{C C}=M a x$ <br> with TTL Trip Level Options <br> Selected, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ <br> with High Trip Level Options <br> Selected | $\begin{gathered} 3.0 \\ 2.2 \\ -0.3 \\ \\ 0.7 V_{C C} \\ -0.3 \\ \\ 0.7 V_{C C} \\ -0.3 \\ 2.2 \\ \\ 3.0 \\ 2.2 \\ -0.3 \\ 3.6 \\ -0.3 \\ \hline \end{gathered}$ | 0.3 <br> 0.4 <br> 0.4 <br> 2.5 <br> 0.6 <br> 1.2 | V V <br> V V <br> V V V>$V$ <br> $V$ <br> $V$ <br> $v$ <br> $V$ |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage | $\begin{aligned} & V_{I N}<7.5 \\ & 7.5 \leq V_{I N} \leq 15 V \end{aligned}$ | $\begin{array}{r} -2 \\ -20 \\ \hline \end{array}$ | $\begin{aligned} & +2 \\ & +20 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Output Voltage Levels LSTTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-20 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=0.36 \mathrm{~mA} \\ & \hline \end{aligned}$ | 2.7 | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| CMOS Operation (Note 2) Logic High Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-1$ | 0.2 | $\begin{aligned} & V \\ & v \end{aligned}$ |

[^1]
## COP320H/COP321H/COP322H

## DC Electrical Characteristics

$-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels Output Sink Current $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs and Standard $G_{0}-G_{3}$ and $D_{0}-D_{3}$ Outputs ( $I_{\mathrm{OL}}$ ) <br> $\mathrm{G}_{0}-\mathrm{G}_{3}$ and $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with High Current Options (loL) <br> $G_{0}-G_{3}$ and $D_{0}-D_{3}$ Outputs with Very High Current Options (IOL) <br> CK1 (Single-Pin RC Oscillator) CKO | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 2.5 \\ 1.9 \\ 1.6 \\ 12 \\ 9 \\ 7 \\ 7 \\ 24 \\ 18 \\ 14 \\ 2 \\ 1.6 \end{gathered}$ |  | mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Output Source Current Standard Configuration, All Outputs (IOH) <br> Push-Pull Configuration SO and SK Outputs (IOH) <br> LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, Low Current Driver Option ( OH ) LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High Current Driver Option ( ${ }^{\circ} \mathrm{OH}$ ) TRI-STATE Configuration, $L_{0}-L_{7}$ Outputs, Low Current Driver Option (loH) TRI-STATE Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, High Current Driver Option (loH) | $\begin{aligned} & V_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \\ & V_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \\ & V_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.0 \mathrm{~V} \\ & V_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.7 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \\ & V_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.0 \mathrm{~V} \\ & V_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.7 \mathrm{~V} \\ & V_{\mathrm{CC}}=4.5 \mathrm{~V} \end{aligned}$ | $\begin{gathered} -330 \\ -110 \\ -92 \\ -0.85 \\ -1.1 \\ -1.2 \\ -2.0 \\ -1.5 \\ -2.7 \\ -2.7 \\ \\ -0.7 \\ -0.6 \\ -0.9 \\ -1.4 \\ -1.2 \\ -1.8 \\ \hline \end{gathered}$ | $\begin{aligned} & -900 \\ & -600 \\ & -350 \\ & \\ & -130 \\ & -8.0 \\ & \\ & -30 \\ & -18 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Input Load Source Current | $V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {IL }}=0 \mathrm{~V}$ | -100 | -1150 | $\mu \mathrm{A}$ |
| CKO Output RAM Power Supply Option Power Requirement | $\mathrm{V}_{\mathrm{R}}=3.3 \mathrm{~V}$ |  | 4.0 | mA |
| TRI-STATE Output Leakage Current |  | -5 | + 5 | $\mu \mathrm{A}$ |
| Open Drain Output Leakage | $\begin{aligned} & V_{\text {OUT }}<7.5 \mathrm{~V} \\ & 7.5 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq 15 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} -5 \\ -50 \\ \hline \end{gathered}$ | $\begin{array}{r} +5 \\ +50 \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ |
| Total Sink Current Allowed <br> All Outputs Combined <br> D, G Ports <br> $L_{7}-L_{4}$ <br> $L_{3}-L_{0}$ <br> All Other Pins |  |  | $\begin{gathered} 120 \\ 120 \\ 4 \\ 4 \\ 1.5 \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |
| Total Source Current Allowed All I/O Combined $\mathrm{L}_{7}-\mathrm{L}_{4}$ $L_{3}-L_{0}$ Each L Pin All Other Pins |  |  | $\begin{gathered} 120 \\ 60 \\ 60 \\ 30 \\ 1.5 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA |

## AC Electrical Characteristics

$\mathrm{COP} 420 \mathrm{H} / \mathrm{COP} 421 \mathrm{H} / \mathrm{COP} 422 \mathrm{H}: 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted COP320H/COP $321 \mathrm{H} / \mathrm{COP} 322 \mathrm{H}:-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted
COP220H/COP221H/COP222H: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+110^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time-tc | (Note 4) | 4.0 | 40 | $\mu \mathrm{S}$ |
| CKI <br> Input Frequency-fi <br> Duty Cycle <br> Rise Time <br> Fall Time | $\begin{aligned} & \div 32 \text { Mode } \text { (Note } 5) \\ & \div 16 \text { Mode } \\ & \div 8 \text { Mode } \\ & \div 4 \text { Mode } \\ & f_{I}=4 \mathrm{MHz} \end{aligned}$ | $\begin{aligned} & 0.8 \\ & 0.4 \\ & 0.2 \\ & 0.1 \\ & 40 \end{aligned}$ | $\begin{aligned} & 4.0 \\ & 4.0 \\ & 2.0 \\ & 1.0 \\ & 60 \\ & 60 \\ & 40 \\ & \hline \end{aligned}$ | MHz <br> MHz <br> MHz <br> MHz <br> \% <br> ns <br> ns |
| CKI Using RC $(\div 4)$ <br> Instruction Cycle Time (Note 6) | $\begin{aligned} & \mathrm{R}=15 \mathrm{k} \Omega \pm 5 \% \\ & \mathrm{C}=100 \mathrm{pF} \pm 10 \% \end{aligned}$ | 16 | 28 | $\mu \mathrm{S}$ |
| INPUTS: ```IN tsetup thold SI tsetup thold``` |  | $\begin{gathered} 1.7 \\ 0.3 \\ \\ 0.3 \\ 0.25 \\ \hline \end{gathered}$ |  | $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{s}$ $\mu \mathrm{S}$ |
| OUTPUT PROPAGATION DELAY <br> SO, SK Outputs <br> $t_{\text {pd } 1, ~} t_{\text {pdo }}$ <br> All Other Outputs <br> $\mathrm{t}_{\mathrm{pd} 1}, \mathrm{t}_{\mathrm{pd}} 0$ | Test Condition: $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V}$ |  | $\begin{aligned} & 0.25 \\ & 1.4 \end{aligned}$ | $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ |

Note 4: COP420H Instruction cycle time is $4 \mu \mathrm{~s} \leq \mathrm{T}_{\text {cycle }} \leq 40 \mu \mathrm{~s}$.
Note 5: $T_{\text {cycle }}=4 \mu \mathrm{~s}$ cannot be achieved using CKI \% 32.
Note 6: RC tolerances and the variation due to the device included.

## Connection Diagrams




FIGURE 3. Input/Output Timing Diagrams (Crystal Divide-by-16 Mode)


FIGURE 3a. Synchronization Timing

## Functional Description

For ease of reading this description, only COP 420 H and/or COP421H are referenced; however, all such references apply also to COP220H, COP221H, COP222H, COP320H, COP321H, COP322H, or COP422H.
A block diagram of the COP420H is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic "1" (greater than 2 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).

## PROGRAM MEMORY

Program Memory consists of a 1,024 byte ROM. As can be seen by an examination of the COP $420 \mathrm{H} / 421 \mathrm{H}$ instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 16 pages of 64 words each.
ROM addressing is accomplished by a 10-bit PC register. Its binary value selects one of the 1,0248 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 10 -bit binary count value. Three levels of subroutine nesting are implemented by the 10-bit subroutine save registers, SA, SB and SC, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 256 -bit RAM, organized as 4 data registers of 164 -bit digits. RAM addressing is implemented by a 6 -bit $B$ register whose upper 2 bits ( Br ) select 1 of 4 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4-bit contents of the selected RAM digit (M) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the LDD and XAD instructions is based upon the 6-bit contents of the operand field of these instructions. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Br and Bd portions of the $B$ register, to load and input 4 bits of the 8 -bit Q latch data, to input 4 bits of the 8 -bit L I/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions of the COP420H/421H, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunctions with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or
can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.)
Four general-purpose inputs, $\mathbb{N}_{3}-\mathbb{N}_{0}$, are provided.
The D register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd. The D outputs can be directly connected to the digits of a multiplexed LED display.
The G register contents are outputs to 4 general-purpose bidirectional I/O ports. G I/O ports can be directly connected to the digits of a multiplexed LED display.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are outputted to the L I/O ports when the $L$ drivers are enabled under program control. (See LEI instruction.)
The 8 L drivers, when enabled, output the contents of latched Q data to the L I/O ports. Also, the contents of L may be read directly into $A$ and $M$. LI/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with Q data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with A , allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the clock.
The EN register is an internal 4-bit register loaded under program control by the LEl instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $E N_{3}-E N_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4bit binary counter. With $\mathrm{EN} \mathrm{N}_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse ("1" to " 0 ") occurring on the S input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. With $E N_{1}$ set the $I N_{1}$ input is enabled as an interrupt input. Immediately following an interrupt, $\mathrm{EN}_{1}$ is reset to disable further interrupts.
3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in Q to the $\mathrm{L} / / \mathrm{O}$ ports. Resetting $\mathrm{EN}_{2}$ disables

## Functional Description (Continued)

the L drivers, placing the LI/O ports in a high-impedance input state.
4. $E N_{3}$, in conjunction with $E N_{0}$, affects the $S O$ output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $E N_{3}$. With $E N_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted
data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with $A$ via an XAS instruction but SO remains reset to " 0 ". The table below provides a summary of the modes associated with $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$.

Enable Register Modes-Bits $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$

| $\mathrm{EN}_{3}$ | EN0 | SIO | SI | So | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=\text { Clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | $\begin{aligned} & \text { If } S K L=1, S K=\text { Clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | $\begin{aligned} & \text { If } S K L=1, S K=1 \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | $\begin{aligned} & \text { If } \mathrm{SKL}=1, \mathrm{SK}=1 \\ & \text { If } \mathrm{SKL}=0, \mathrm{SK}=0 \end{aligned}$ |

## INTERRUPT

The following features are associated with the $\mathrm{IN}_{1}$ interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once aknowledged as explained below, pushes the next sequential program counter address (PC +1 ) onto the stack, pushing in turn the contents of the other subroutine-save registers to the next lower level $(P C+1 \rightarrow S A \rightarrow S B \rightarrow S C)$. Any previous contents of SC are lost. The program counter is set to hex address OFF (the last word of page 3) and $\mathrm{EN}_{1}$ is reset.
b. An interrupt will be acknowledged only after the following conditions are met:

1. $E N_{1}$ has been set.
2. A low-going pulse (" 1 " to " 0 ") at least two instruction cycles wide occurs on the $\mathrm{N}_{1}$ input.
3. A currently executing instruction has been completed.
4. All successive transfer of control instructions and successive LBIs have been completed (e.g., if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed).
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at address OFF. At the end of the interrupt routine, a RET instruction is executed to "pop" the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines and LQID instructions should not be
nested within the interrupt servicing routine since their popping the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The first instruction of the interrupt routine at hex address OFF must be a NOP.
e. A LEI instruction can be put immediately before the RET to re-enable interrupts.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the $\overline{R E S E T}$ pin as shown below. The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to $\mathrm{V}_{\mathrm{CC}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N$, and $G$ registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.


RC $\geq 5 \times$ Power Supply Rise Time

$\longmapsto$

Functional Description (Continued)

## OSCILLATOR

There are three basic clock oscillator configurations available as shown by Figure 4.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency divided by 32 (optional by 16 or 8 ).
b. External Oscillator. CKI is an external clock input signal. The external frequency is divided by 32 (optional by 16 or 8 ) to give the instruction cycle time. CKO is now available to be used as the RAM power supply $\left(V_{R}\right)$ or as a general purpose input.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is available as the RAM power supply ( $V_{\mathrm{R}}$ ) or as a general purpose input.

## CKO PIN OPTIONS

In a crystal controlled oscillator system, CKO is used as an output to the crystal network or it can be a general purpose
input read into bit 2 of A (accumulator) upon execution of an INIL Instruction. As another option, CKO can be a RAM power supply pin $\left(\mathrm{V}_{\mathrm{R}}\right)$, allowing its connection to a standby/ backup power supply to maintain the integrity of RAM data with minimum power drain when the main supply is inoperative or shut down to conserve power. Using either option is appropriate in applications where the COP $420 \mathrm{H} / 421 \mathrm{H}$ system timing configuration does not require use of the CKO pin.

## RAM KEEP-ALIVE OPTION (Not available on COP422H)

Selecting CKO as the RAM power supply ( $V_{R}$ ) allows the user to shut off the chip power supply ( $V_{C C}$ ) and maintain data in the RAM. To insure that RAM data integrity is maintained, the following conditions must be met:

1. $\overline{\text { RESET }}$ must go low before $\mathrm{V}_{\mathrm{CC}}$ goes below spec during power-off; $V_{C C}$ must be within spec before RESET goes high on power-up.
2. During normal operation $V_{R}$ must be within the operating range of the chip, with $\left(\mathrm{V}_{\mathrm{CC}}-1\right) \leq \mathrm{V}_{\mathrm{R}} \leq \mathrm{V}_{\mathrm{CC}}$.
3. $\mathrm{V}_{\mathrm{R}}$ must be $\leq 3.3 \mathrm{~V}$ with $\mathrm{V}_{\mathrm{CC}}$ off.

## Crystal Oscillator




Crystal Oscillator

| Crystal <br> Value | Component Values |  |  |
| :---: | :---: | :---: | :---: |
|  | R1 $(\Omega)$ | R2 $(\Omega)$ | $\mathbf{C}(\mathrm{pF})$ |
| 455 kHz | 4.7 k | 1 M | 220 |
| 2.097 MHz | 1 k | 1 M | 56 |
| 3.58 MHz | 1 k | 1 M | 27 |
| 4 MHz | 1 k | 1 M | 27 |



TL/DD/8815-8
RC Controlled Oscillator

| $\mathbf{R ( k \Omega )}$ | $\mathbf{C}(\mathbf{p F})$ | Instruction <br> $\mathbf{C y c l e ~ T I m e}$ <br> $(\mu \mathbf{s})$ |
| :---: | :---: | :---: |
| 51 | 100 | $19 \pm 15 \%$ |
| 82 | 56 | $19 \pm 13 \%$ |
| 12 | 100 | $5 \pm 20 \%$ |
| 6.8 | 220 | $5.3 \pm 23 \%$ |
| 8.2 | 300 | $8 \pm 29 \%$ |
| 22 | 100 | $8.6 \pm 16 \%$ |

Note: $200 \mathrm{k} \geq \mathrm{R} \geq 5 \mathrm{k}$
$360 \mathrm{pF} \geq \mathrm{C} \leq 50 \mathrm{pF}$

FIGURE 4. COP420H/421H Oscillator

## Functional Description (Continued)

## I/O OPTIONS

COP $420 \mathrm{H} / 421 \mathrm{H}$ outputs have the following optional configurations, illustrated in Figure 5:
a. Standard-an enhancement mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with LSTTL and CMOS input requirements. Available on SO, SK, and all D and G outputs.
b. Open-Drain-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. Available on SO, SK, and all D and G outputs.
c. Push-Pull-An enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{Cc}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. Available on SO and SK outputs only.
d. Standard L-same as a., but may be disabled. Available on L outputs only.
e. Open Drain L—same as b., but may be disabled. Available on $L$ outputs only.
f. LED Direct Drive-an enhancement-mode device to ground and to $V_{C C}$, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (see Functional Description, EN Register), placing the outputs in a high-impedance state to provide required LED segment blanking for a multiplexed display. Available on $L$ outputs only.
g. TRI-STATE Push-Pull-an enhancement-mode device to ground and $\mathrm{V}_{\mathrm{CC}}$. These outputs are TRI-STATE outputs, allowing for connection of these outputs to a data bus shared by other bus drivers. Available on L outputs only.
COP420H/COP421H inputs have the following optional configurations:
h. An on-chip depletion load device to $V_{C C}$.
i. A Hi-Z input which must be driven to a " 1 " or " 0 " by external components.

The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6, respectively). Minimum and maximum current (lout and $\mathrm{V}_{\text {OUT }}$ ) curves are given in Figure 6 for each of these devices to allow the designer to effectively use these I/O configurations in designing a COP420H/421H system.
The SO, SK outputs can be configured as shown in a., b., or c. The D and G outputs can be configured as shown in a. or b. Note that when inputting data to the G ports, the G outputs should be set to " 1 ". The L outputs can be configured as in d., e., f. or g.
An important point to remember if using configuration d. or $f$. with the $L$ drivers is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current (see Figure 6, device 2); however, when the $L$ lines are used as inputs, the disabled depletion device cannot be relied on to source sufficient current to pull an input to a logic 1.

## COP421H

If the COP420H is bonded as a 24 -pin device, it becomes the COP421H, illustrated in Figure 2, COP420H/421H Connection Diagrams. Note that the COP421H does not contain the four general purpose $I N$ inputs $\left(\mathrm{IN}_{3}-I N_{0}\right)$. Use of this option precludes, of course, use of the IN options and the interrupt feature. All other options are available for the COP421H.

## COP422H

If the COP421H is bonded as a 20 -pin device, it becomes the COP 422 H , as illustrated in Figure 2. Note that the COP422H contains all the COP421H pins except $D_{0}, D_{1}$, $\mathrm{G}_{0}$, and $\mathrm{G}_{1}$. COP422H also does not allow RAM power supply input as a valid CKO pin option.


TL/DD/8815-9
a. Standard Output

b. Open-Drain Output


TL/DD/8815-11
c. Push-Pull Output

Functional Description (Continued)

d. Standard L Output

g. TRI-STATE Push-Pull (L Output)

e. Open-Drain L Output

h. Input with Load

FIGURE 5. Output Configurations

( $\boldsymbol{\Delta}$ is Depletion Device)
f. LED (L Output)


TL/DD/8815-17
i. HI-Z Input

## Typical Performance Characteristics




TL/DD/8815-19

Input Current for $\mathrm{L}_{0}-\mathrm{L}_{7}$ when Output Programmed OFF by Software


Source Current for $L_{0}-L_{7}$ in TRI-STATE Configuration (High Current Option)


Source Current for Standard


TL/DD/8815-18
Source Current for $L_{0}-L_{7}$ in TRI-STATE Configuration (Low Current Option)


Typical Performance Characteristics (Continued)


LED Output Source Current (Low Current LED Option)


LED Output Direct Segment and Digit Drive (High Current Options on $L_{0}-L_{7}$; Very High Current Options on $D_{0}-D_{3}$ or $\mathrm{G}_{0}-\mathrm{G}_{3}$


TL/DD/8815-22


TL/DD/8815-24

FIGURE 6. COP420H/COP421H/COP422H Input/Output Characteristics

Typical Performance Characteristics (Continued)



Output Sink Current for $L_{0}-L_{7}$ and Standard Drive Option for $D_{0}-D_{3}$ and $G_{0}-G_{3}$



Source Current for $L_{0}-L_{7}$ in TRI-STATE Configuration (High Current Option)


Input Current for $L_{0}-L_{7}$ when Output Programmed OFF by Software


Output Sink Current for $G_{0}-G_{3}$ and $D_{0}-D_{3}$ with Very High Current Option


Source Current for Standard Configuration


Source Current for $L_{0}-L_{7}$ in TRI-STATE Configuration (Low Current Option)




FIGURE 7. COP320H/COP321H/COP322H Input/Output Characteristics

## COP420H/COP421H Instruction Set

Table $I$ is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table II provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with each instruction in the COP420H/421H instruction set.

TABLE I. COP420H/421H Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| IL | Two 1-bit Latches associated with the IN ${ }_{3}$ or |
|  | INo inputs |
| IN | 4-bit Input Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| PC | 10-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| SA | 10-bit Subroutine Save Register A |
| SB | 10-bit Subroutine Save Register B |
| SC | 10-bit Subroutine Save Register C |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE II. COP420H/421H Instruction Set |  |  |  |  |  |  |
| Mnemonic | Operand | $\begin{aligned} & \text { Hex } \\ & \text { Code } \end{aligned}$ | $\begin{gathered} \text { Machine } \\ \text { Language Code } \\ \text { (Binary) } \end{gathered}$ | Data Flow | Skip Conditions | Description |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 10011/0000 | $\begin{aligned} & A+C+\text { RAM(B) } \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 0011/0001 | $A+\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A}$ | None | Add RAM to A |
| ADTD |  | 4 A | 0100\|1010 | $A+10_{10} \rightarrow A$ | None | Add Ten to A |
| AISC | y | $5-$ | 0101 y y | $A+y \rightarrow A$ | Carry | Add Immediate, Skip on Carry ( $y \neq 0$ ) |
| CASC |  | 5- | 0001 0000 | $\left\lvert\, \begin{aligned} & \bar{A}+\operatorname{RAM}(B)+C \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}\right.$ | Carry | Compliment and Add with Carry, Skip on Carry |
| CLRA |  | 00 | 000010000 | $0 \rightarrow \mathrm{~A}$ | None | Clear A |
| COMP |  | 40 | 010010000 | $\overline{\mathrm{A}} \rightarrow \mathrm{A}$ | None | Ones complement of A to A |
| NOP |  | 44 | 010010100 | None | None | No Operation |
| RC |  | 32 | 0011\|0010 | "0" $\rightarrow$ C | None | Reset C |
| Sc |  | 22 | 0010]0010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | 000010010 | $A \oplus R A M(B) \rightarrow A$ | None | Exclusive-OR RAM with A |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | 1111/1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 3) |
| JMP | a | $6-$ | $\frac{\|0110\| 00\left\|\mathrm{ag}_{9} 8\right\|}{\mathrm{a}_{7: 0}}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  | $\begin{gathered} \begin{array}{cc} 1 \mid \quad a_{6: 0} \\ \text { (pages } 2,3 \text { only) } \end{array} \\ \text { or } \\ \begin{array}{l} 11 \mid \quad a_{5: 0} \end{array} \\ \text { (all other pages) } \end{gathered}$ | $a \rightarrow P C_{6: 0}$ $a \rightarrow P C_{5: 0}$ | None | Jump within Page (Note 4) |
| JSRP | a | -- | [10 ${ }^{\text {a }}$ 5:0 | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \\ & \mathrm{SB} \rightarrow \mathrm{SC} \\ & 0010 \rightarrow \mathrm{PC}_{9: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR |  | 6- | $\frac{10110\|10\| a_{9: 8} \mid}{L_{\text {a }} / 0}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \\ & \mathrm{SB} \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | $\underline{0100 \mid 1000]}$ | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 10100/1001 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE II. COP420H/421H Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 | 0011\|0011 | $A \rightarrow Q_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C | 0011 1100 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{Q}_{3: 0}$ |  |  |
| CQMA |  | 33 | \|001110011 | $\mathrm{Q}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Copy Q to RAM, A |
|  |  | 2 C | 0010\|1100 | $\mathrm{Q}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| LD | r | -5 | $\underline{00\|r\| 0101 \mid}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A, Exclusive-OR Br with r |
| LDD | r,d | 23 | 0010 0011  <br> 0010 011  <br> 00 r d | RAM(r,d) $\rightarrow$ A | None | Load A with RAM pointed to directly by r,d |
| LID |  | 33 | 0011 0011 | ROM (PC 9:8, A, M) $\rightarrow$ M, A |  | No Skip Condition |
|  |  | 19 | 0001 1001 |  |  | Load RAM; A Indirect |
| LQID |  | BF | [1011\|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow Q \\ & \mathrm{SB} \rightarrow \mathrm{SC} \end{aligned}$ | None | Load Q Indirect (Note 3) |
| RMB | 0 | 4 C | $0100 \mid 100$ <br> $0100 \mid$ | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | 0100\|0101 | $0 \rightarrow$ RAM $(\mathrm{B})_{1}$ |  |  |
|  | 2 | 42 | $0100 \mid 0010$ | $0 \rightarrow$ RAM $(\mathrm{B})_{2}$ |  |  |
|  | 3 | 43 | 10100/0011 | $0 \rightarrow R A M(B)_{3}$ |  |  |
| SMB | 0 | 4D | 0100\|1101 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Set RAM Bit |
|  | 1 | 47 | 0100\|1101 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1}$ |  |  |
|  | 2 | 46 | 0100\|0110 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 4 B | \|0100|1011 | $1 \rightarrow \mathrm{RAM}(\mathrm{B})_{3}$ |  |  |
| STII | y | $7-$ | 0111 y | $\begin{aligned} & y \rightarrow R A M(B) \\ & B d+1 \rightarrow B d \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | r | -6 | $\underline{00\|r\| 0110 \mid}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with $A$, Exclusive-OR Br with $r$ |
| XAD | r,d | 23 | $0010 \mid 0011$ <br> $10\|r\| r \mid$ | $R A M(r, d) \longleftrightarrow A$ | None | Exchange A with RAM pointed to directly by $(r, d)$ |
| XDS | r | -7 | L00\|r10111 | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd, Exclusive-OR Br with $r$ |
| XIS | r | -4 | 00\|r|0100 | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with $A$ and Increment Bd, Exclusive-OR Br with r |
| OPTION LIST |  |  |  |  |  |  |
| The COP420H/421H mask-programmable options are assigned numbers which correspond with the COP42OH pins. |  |  |  |  |  |  |
| The following is a list of COP420H options. When specifying a COP421H chip, Options $9,10,19$, and 20 must all be set to zero. When specifying a COP422H chip, options $9,10,19$, and 20 must all be set to zero; options 21 and 22 may not be set to one, three or five; and option 2 may not be set to one. The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry. |  |  |  |  |  |  |



Instruction Set (Continued)
TABLE II. COP420H/421H Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 00110011 | $\mathrm{G} \rightarrow \mathrm{A}$ | None | Input G Ports to A |
|  |  | 2 A | \|0010|1010 |  |  |  |
| ININ |  | 33 | 00011 0011 | $\mathrm{IN} \rightarrow \mathrm{A}$ | None | Input IN Inputs to A (Note 2) |
|  |  | 28 | 0010\|1000 |  |  |  |
| INIL |  | 33 | 0011 0011 | $\mathrm{IL}_{3}, \mathrm{CKO}, ~ " 0$ ", $\mathrm{IL} 0 \rightarrow \mathrm{~A}$ | None | Input IL Latches to A (Note 3) |
|  |  | 29 | 10010\|1001 |  |  |  |
| INL |  | 33 | 0011 0011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{~B})$ | None | Input L Ports to RAM, A |
|  |  | 2E | 00101110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | 0011 0011 | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3 E | 10011 1110 |  |  |  |
| OGI | y | 33 | 0011 0011 | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | $5-$ | 0101 y |  |  |  |
| OMG |  | 33 | 10011 0011 | RAM(B) $\rightarrow$ G | None | Output RAM to G Ports |
|  |  | 3A | -00111010 |  |  |  |
| XAS |  | 4F | \|0100|1111 | A | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit A register.
Note 2: The ININ instruction is only available on the 28 -pin COP420L as the other devices do not contain the $\mathbb{N}$ inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while in subroutine pages 2 or 3 , to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 5: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $\mathrm{d}=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " d "' data minus 1 , e.g., to load the lower four bits of $B(B d)$ with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8(10002)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).
Note 7: Machine code for operand field y for LEI instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP420H/421H programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO ) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If

SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by $A$ and $M$. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 10 -bit word, $\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ are not affected by this instruction.
Note that JID requires 2 instruction cycles to execute.
$\qquad$

## Description of Selected Instructions (Continued)

## inil instruction

INIL (Input IL Latches to A) inputs 2 latches, $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ (see Figure 8) and CKO into A . The $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ latches are set if a low-going pulse (" 1 " to " 0 ") has occurred on the $\mathrm{IN}_{3}$ and $\mathrm{IN}_{0}$ inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction times. Execution of an $I N I L$ inputs $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ into A 3 and $A O$ respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the $\mathrm{IN}_{3}$ and $\mathbb{I} N_{0}$ lines. If CKO is mask programmed as a general purpose input, an INIL will input the state of CKO into A2. If CKO has not been so programmed, a " 1 " will be placed in A2. A " 0 " is always placed in A1 upon the execution of an INIL. The general purpose inputs $I N_{3}-\mathbb{N}_{0}$ are input to $A$ upon execution of an ININ instruction. (See Table II, ININ instruction.) INIL is useful in recognizing pulses of short duration or pulses which occur too often to be read conveniently by an ININ instruction. IL latches are not cleared on reset.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit $Q$ register with the contents of ROM pointed to by the 10 -bit word $\mathrm{PC}_{9}, \mathrm{PC}_{8}, \mathrm{~A}$, M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC + $1 \rightarrow$ SA $\rightarrow$ SB $\rightarrow S C$ ) and replaces the least significant 8 bits of PC as follows: $\mathrm{A} \rightarrow$ $\mathrm{PC}_{7: 4}, \mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the Q latches. Next, the stack is "popped" (SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow P C$ ), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost. Also, when LQID pops the stack, the previously pushed contents of SB are left in SC. The net result is that the contents of SB are placed in SC (SB $\rightarrow$ SC). Note the LQID takes two instruction cycle times to execute.


TL/DD/8815-28
FIGURE 8. INIL Hardware Implementation

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of an internal 10-bit time-base counter. This counter divides the instruction cycle clock frequency by 1024 and provides a latched indication of counter overflow. The SKT instruction tests this latch, executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction, therefore, allow the COP $420 \mathrm{H} / 421 \mathrm{H}$ to generate its own timebase for real-time processing rather than relying on an external input signal.
For example, using a 2.097 MHz crystal as the time-base to the clock generator, the instruction cycle clock frequency will be 65 kHz (crystal frequency $\div 32$ ) and the binary counter output pulse frequency will be 64 Hz . For time-of-day or similar real-time processing, the SKT instruction can call a routine which increments a "seconds" counter every 64 ticks.

## INSTRUCTION SET NOTES

a. The first word of a COP $420 \mathrm{H} / 421 \mathrm{H}$ program (ROM address 0 ) must be a CLRA (Clear $A$ ) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped.
c. The ROM is organized into 16 pages of 64 words each. The Program Counter is a 10 -bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page $3,7,11$, or 15 will access data in the next group of four pages.

## Option List

The Option Table should be copied and sent in with your EPROM or disc.

Option $1=0$ : Ground Pin-no options available
Option 2: CKO Output
$=0$ : clock generator output to crystal/resonator ( 0 not allowable value if Option $3=3$ )
$=1$ : pin is RAM power supply $\left(V_{R}\right)$ input (not available on the COP422L)
= 2: general purpose input with load device to $V_{C C}$
= 3: general purpose input, $\mathrm{Hi}-\mathrm{Z}$
Option 3: CKI Input
$=0$ : oscillator input divided by 32 ( 4 MHz max.)
= 1: oscillator input divided by 16 ( 4 MHz max.)
$=2$ : oscillator input divided by $8(2 \mathrm{MHz}$ max. $)$
$=3$ : single-pin RC controlled oscillator ( $\div 4$ )
$=4$ : Schmitt trigger clock input $(\div 4)$
Option 4: RESET Input
$=0$ : load device to $V_{C C}$
= 1: Hi-Z Input
Option 5: $L_{7}$ Driver
$=0$ : Standard output
$=1$ : Open-drain output
$=2$ : High current LED direct segment drive output
$=3$ : High current TRI-STATE push-pull output
$=4$ : Low-current LED direct segment drive output
$=5$ : Low-current TRI-STATE push-pull output
Option 6: $L_{6}$ Driver same as Option 5
Option 7: $\mathrm{L}_{5}$ Driver same as Option 5
Option 8: L $\mathrm{L}_{4}$ Driver same as Option 5
Option 9: $\mathbb{N}_{1}$ Input
$=0$ : load device to $V_{C C}$
= 1: Hi-Z input
Option 10: $\mathrm{IN}_{2}$ Input same as Option 9
Option 11: $V_{C C}$ pin
$=0$ : Standard $V_{C C}$ $=1$ : Optional higher voltage $\mathrm{V}_{\mathrm{CC}}$
Option 12: $L_{3}$ Driver same as Option 5
Option 13: L L Driver same as Option 5
Option 14: L $\mathrm{L}_{1}$ Driver same as Option 5
Option 15: Lo Driver same as Option 5
Option 16: SI Input same as Option 9
Option 17: SO Driver
= 0: standard output
$=1$ : open-drain output
$=2$ : push-pull output
Option 18: SK Driver same as Option 17

Option 19: $\mathrm{IN}_{0}$ Input same as Option 9
Option 20: $\mathrm{IN}_{3}$ Input same as Option 9
Option 21: $\mathrm{G}_{0}$ I/O Port $=0$ : very-high current standard output
$=1$ : very-high current open-drain output
$=2$ : high current open-drain output
= 3: high current open-drain output
$=4$ : standard LSTTL output (fanout $=1$ )
$=5$ : open-drain LSTTL output (fanout $=1$ )
Option 22: $\mathrm{G}_{1}$ I/O Port same as Option 21
Option 23: $\mathrm{G}_{2}$ I/O Port same as Option 21
Option 24: $\mathrm{G}_{3}$ I/O Port same as Option 21
Option 25: $\mathrm{D}_{3}$ Output same as Option 21
Option 26: $\mathrm{D}_{2}$ Output same as Option 21
Option 27: $\mathrm{D}_{1}$ Output same as Option 21
Option 28: $\mathrm{D}_{0}$ Output same as Option 21
Option 29: L Input Levels $=0$ : standard TTL input levels (" 0 " $=0.8 \mathrm{~V}, " 1$ " $=2.0 \mathrm{~V}$ )
$=1$ : higher voltage input levels

$$
(" 0 "=1.2 \mathrm{~V}, " 1 "=3.6 \mathrm{~V})
$$

Option 30: IN Input Levels same as Optjon 29
Option 31: G Input Levels same as Option 29
Option 32: SI Input Levels same as Option 29
Option 33: RESET Input
= 0: Schmitt trigger input
$=1$ : standard TTL input levels
$=2$ : higher voltage input levels
Option 34: CKO Input Levels
(CKO $=$ input; Option $2=2,3$ )
same as Option 29
Option 35: Internal Initialization Logic
$=0: \quad$ Enabled
=1: Disable
Option 36: COP Bonding
$=0:$ COP420L (28-pin device)
$=1$ : COP421L (24-pin device)
$=2: 28$ - and 24 -pin versions
$=3:$ COP422L (20-pin device)
$=4: 28$ - and 20 -pin versions
$=5: 24-$ and 20 -pin versions
$=6: 28-, 24-$, and 20 -pin versions
Option 36: Internal Initialization Logic
= 0: normal operation
$=1$ : no internal initialization logic

## COP420H/COP421H/COP422H Option Table

Please fill out the Option List and send it with the EPROM. Option Data

| OPTION 1 VALUE = | IS: GROUND PIN |
| :---: | :---: |
| OPTION 2 VALUE = | IS: CKO OUTPUT |
| OPTION 3 VALUE = | IS: CKI INPUT |
| OPTION 4 VALUE | IS: RESET INPUT |
| OPTION 5 VALUE $=$ | IS: L (7) DRIVER |
| OPTION 6 VALUE | IS: L (6) DRIVER |
| OPTION 7 VALUE | IS: L (5) DRIVER |
| OPTION 8 VALUE | IS: L (4) DRIVER |
| OPTION 9 VALUE | IS: IN1 INPUT |
| OPTION 10 VALUE | IS: IN2 INPUT |
| OPTION 11 VALUE | IS: VCC PIN |
| OPTION 12 VALUE | IS: L (3) DRIVER |
| OPTION 13 VALUE | IS: L (2) DRIVER |
| OPTION 14 VALUE | IS: L (1) DRIVER |
| OPTION 15 VALUE | IS: L (0) DRIVER |
| OPTION 16 VALUE | IS: SI INPUT |
| OPTION 17 VALUE | IS: SO DRIVER |
| OPTION 18 VALUE | IS: SK DRIVER |
| OPTION 19 VALUE | IS: INO INPUT |
| OPTION 20 VALUE = | IS: IN3 INPUT |
| OPTION 21 VALUE = | IS: GO I/O PORT |
| OPTION 22 VALUE = | IS: G1 I/O PORT |

OPTION 23 VALUE $=\ldots \quad$ IS: G2 I/O PORT
OPTION 24 VALUE =
OPTION 25 VALUE =
$\qquad$ IS: G3 I/O PORT

OPTION 26 VALUE $=$
OPTION 27 VALUE =
$\qquad$ : D3 OUTPUT
$\qquad$ IS: D2 OUTPUT OPTION 28 VALUE $=\ldots$ IS: DO OUTPUT OPTION 29 VALUE = $\qquad$ IS: L INPUT LEVELS OPTION 30 VALUE $=$ $\qquad$ IS: IN INPUT LEVELS OPTION 31 VALUE $=$ $\qquad$ IS: G INPUT LEVELS OPTION 32 VALUE $=$ $\qquad$ IS: SI INPUT LEVELS OPTION 33 VALUE = $\qquad$ IS: RESET INPUT OPTION 34 VALUE $=$ $\qquad$ IS: CKO INPUT LEVELS OPTION 35 VALUE $=$ $\qquad$ IS: INTERNAL INITIALIZATION LOGIC
OPTION 36 VALUE = $\qquad$ IS: COP BONDING

## Development Support

The MOLE (Microcontroller On Line Emulator) is a low cost development system and real time emulator for COPS' products. They also include TMP, 8050 and the new 16 -bit HPC microcontroller family. The MOLE provides effective support for the development of both software and hardware in the user's application.
The purpose of the MOLE is to provide a tool to write and assemble code, emulate code for the target microcontroller and assist in debugging of the system.
The MOLE can be connected to various hosts, IBM PC, STARPLEXTM, Kaypro, Apple and Intel systems, via RS-232 port. This link facilitates the up loading/down loading of code, supports host assembly and mass storage.
The MOLE consists of three parts; brain, personality and optional host software.
The brain board is the computing engine of the system. It is a self-contained computer with its own firmware which provides for all system operation, emulation control, communication, from programming and diagnostic operation. It has three serial ports which can be connected to a terminal, host system, printer, modem or to other MOLE's in a multiMOLE environment.
The personality board contains the necessary hardware and firmware needed to emulate the target microcontrolier. The emulation cable which replaces the target controller attaches to this board. The software contains a cross assembler and a communications program for up loading and down loading code from the MOLE.

MOLE Ordering Information

| P/N | Description |
| :---: | :---: |
| MOLE-BRAIN | MOLE Computer Board |
| MOLE-COPS-PB1 | COPS Personality Board |
| MOLE-XXX-YYY | Optional Software |
| Where XXX $=$ COPS |  |
| YYY $=$ Host System, IBM, Apple, |  |
| KAY (Kaypro), CP/M |  |

## COPS Programming Manual

For detailed information on writing COPS programs, the COPS Programming Manual 424410284-001 provides an indepth discussion of the COPS architecture, instruction set and general techniques of COPS programming. This manual is written with the programmer in mind.

Non Tl $\longrightarrow 0$

National Semiconductor Corporation

## COP420P/COP444CP/COP444LP Piggyback EPROM Microcontrollers

## General Description

The COP420P, COP444CP, and COP444LP are piggyback versions of the COPSTM microcontroller families. These devices are identical to their respective device except the program ROM has been removed. The device package incorporates the circuitry and socket on top of package to accommodate the piggyback EPROM-MM2716, NMC27C16 or other appropriate EPROMs. With the addition of an EPROM the device performs exactly as its masked equivalent.
The device is a complete microcontroller system with CPU, RAM, I/O and EPROM socket in a 28 -lead package. The completed package allows field test of the system in the final electrical and mechanical configuration. This important benefit facilitates development and debug of the COP400 program prior to masking of a production part.
These devices are also economical in low and medium volume applications or when the program may require changing.

| Device | $\begin{array}{c}\text { Device } \\ \text { Selectlon }\end{array}$ | Emulated |
| :--- | :--- | :--- | \(\left.\begin{array}{l}Plggyback <br>

Device\end{array}\right\}\)

## Features

COP444LP

- Low power NMOS
- $16 \mu \mathrm{~s}$ instruction time

COP420P

- $4 \mu \mathrm{~s}$ instruction time


## COP444CP

- $4 \mu$ s instruction time
- Fully static (can turn off clock)
- Power-saving IDLE state and Halt mode
- Lowest power dissipation-CMOS


# COP424C, COP425C, COP426C, COP324C, COP325C, COP326C and COP444C, COP445C, COP344C, COP345C Single-Chip 1k and 2k CMOS Microcontrollers 

## General Description

The COP424C, COP425C, COP426C, COP444C and COP445C fully static, Single-Chip CMOS Microcontrollers are members of the COPSTM family, fabricated using dou-ble-poly, silicon gate microCMOS technology. These Controller Oriented Processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture and I/O scheme designed to facilitate keyboard input, display output and BCD data manipulation. The COP424C and COP444C are 28 pin chips. The COP425C and COP445C are 24 -pin versions ( 4 inputs removed) and COP426C is 20-pin version with 15 I/O lines. Standard test procedures and reliable high-density techniques provide the medium to large volume customers with a customized microcontroller at a low end-product cost. These microcontrollers are appropriate choices in many demanding control environments especially those with human interface.
The COP424C is an improved product which replaces the COP420C.

## Features

■ Lowest power dissipation ( $50 \mu \mathrm{~W}$ typical)

- Fully static (can turn off the clock)
- Power saving IDLE state and HALT mode
- $4 \mu \mathrm{~s}$ instruction time, plus software selectable clocks

■ $2 \mathrm{k} \times 8$ ROM, $128 \times 4$ RAM (COP444C/COP445C)
■ $1 \mathrm{k} \times 8$ ROM, $64 \times 4$ RAM (COP424C/COP425C/ COP426C)

- 23 I/O lines (COP444C and COP424C)
- True vectored interrupt, plus restart
- Three-level subroutine stack
- Single supply operation ( 2.4 V to 5.5 V )
- Programmable read/write 8 -bit timer/event counter
- Internal binary counter register with MICROWIRETM serial I/O capability
- General purpose and TRI-STATE ${ }^{\circledR}$ outputs
- LSTTL/CMOS output compatible
- Microbus ${ }^{\text {TM }}$ compatible
- Software/hardware compatible with COP400 family
- Extended temperature range devices COP324C/ COP325C/COP326C and COP344C/COP345C ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )
- Military devices $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ to be available

Block Diagram


FIGURE 1

## COP424C/COP425C/COP426C and COP444C/COP445C

## Absolute Maximum Ratings

| Supply Voltage (VCC) | 6 V |
| :--- | ---: |
| Voltage at any Pin | -0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Total Allowable Source Current | 25 mA |
| Total Allowable Sink Current | 25 mA |
| Operating Temperature Range | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temperature |  |
| (soldering, 10 seconds) | $300^{\circ} \mathrm{C}$ |

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage <br> Power Supply Ripple (Note 5) | Peak to Peak | 2.4 | $\begin{gathered} 5.5 \\ 0.1 V_{C C} \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Supply Current (Note 1) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{tc}=64 \mu \mathrm{~s} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{tc}=16 \mu \mathrm{~s} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{tc}=4 \mu \mathrm{~s} \\ & \text { (tc is instruction cycle time) } \end{aligned}$ |  | $\begin{array}{r} 120 \\ 700 \\ 3000 \end{array}$ | $\begin{aligned} & \mu A \\ & \mu A \\ & \mu A \end{aligned}$ |
| HALT Mode Current (Note 2) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~F}_{\mathrm{IN}}=0 \mathrm{kHz} \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~F}_{\mathrm{IN}}=0 \mathrm{kHz} \end{aligned}$ |  | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Input Voltage Levels <br> RESET, CKI, $D_{0}$ (clock input) <br> Logic High <br> Logic Low <br> All Other Inputs <br> Logic High <br> Logic Low |  | $\begin{aligned} & 0.9 \mathrm{~V}_{\mathrm{CC}} \\ & 0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & V \\ & V \end{aligned}$ |
| Input Pull-Up Current | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=0$ | 30 | 330 | $\mu \mathrm{A}$ |
| Hi-Z Input Leakage |  | -1 | +1 | $\mu \mathrm{A}$ |
| Input Capacitance (Note 4) |  |  | 7 | pF |
| Output Voltage Levels LSTTL Operation Logic High Logic Low CMOS Operation Logic High Logic Low | $\begin{aligned} & \text { Standard Outputs } \\ & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=400 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $v_{C C}-0.2$ | $\begin{aligned} & 0.4 \\ & 0.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Output Current Levels (except CKO) Sink (Note 6) <br> Source (Standard Option) <br> Source (Low Current Option) | $V_{C C}=4.5 \mathrm{~V}, V_{\text {OUT }}=V_{C C}$ <br> $\mathrm{V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ <br> $V_{C C}=4.5 \mathrm{~V}, V_{\text {OUT }}=0 \mathrm{~V}$ <br> $V_{C C}=2.4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V}$ <br> $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V}$ <br> $\mathrm{V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V}$ <br> $V_{C C}=4.5 \mathrm{~V}, C K I=V_{C C}, V_{O U T}=V_{C C}$ <br> $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{CKI}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=0 \mathrm{~V}$ | $\begin{gathered} 1.2 \\ 0.2 \\ 0.5 \\ 0.1 \\ 30 \\ 6 \\ \\ 0.3 \\ 0.6 \\ 1.2 \\ 0.3 \\ 0.6 \\ 1.2 \end{gathered}$ | $\begin{gathered} 330 \\ 80 \end{gathered}$ | mA mA mA mA $\mu \mathrm{A}$ $\mu \mathrm{A}$ <br> mA mA mA mA mA mA |
| Allowable Sink/Source Current per Pin (Note 6) |  |  | 5 | mA |
| Allowable Loading on CKO (as HALT) |  |  | 100 | pF |
| ```Current Needed to Over-Ride HALT (Note 3) To Continue To Halt``` | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0.2 \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |  | $\begin{aligned} & 0.7 \\ & 1.6 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| TRI-STATE or Open Drain Leakage Current |  | -2.5 | +2.5 | $\mu \mathrm{A}$ |

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

## COP324C/COP325C/COP326C and COP344C/COP345C

## Absolute Maximum Ratings

| Supply Voltage | 6 V |
| :--- | ---: |
| Voltage at any Pin | -0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ |
| Total Allowable Source Current | 25 mA |
| Total Allowable Sink Current | 25 mA |
| Operating Temperature Range | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Storage Temperature Range  <br> Lead Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ <br> (soldering, 10 seconds) $\quad 300^{\circ} \mathrm{C}$ |  |

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq T_{A} \leq+85^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage <br> Power Supply Ripple (Note 5) | Peak to Peak | 3.0 | $\begin{gathered} 5.5 \\ 0.1 V_{C C} \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Supply Current (Note 1) | $\begin{aligned} & V_{\mathrm{CC}}=3.0 \mathrm{~V}, \mathrm{tc}=64 \mu \mathrm{~s} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{tc}=16 \mu \mathrm{~s} \\ & V_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{tc}=4 \mu \mathrm{~s} \\ & \text { (tc is instruction cycle time) } \end{aligned}$ |  | $\begin{gathered} 180 \\ 800 \\ 3600 \end{gathered}$ | $\begin{aligned} & \mu A \\ & \mu A \\ & \mu A \end{aligned}$ |
| HALT Mode Current (Note 2) | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~F}_{\mathrm{IN}}=0 \mathrm{kHz} \\ & V_{\mathrm{CC}}=3.0 \mathrm{~V}, \mathrm{~F}_{\mathrm{IN}}=0 \mathrm{kHz} \end{aligned}$ |  | $\begin{aligned} & 30 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ |
| Input Voltage Levels <br> RESET, CKI, $\mathrm{D}_{\mathrm{O}}$ (clock input) <br> Logic High <br> Logic Low <br> All Other Inputs Logic High Logic Low |  | $\begin{aligned} & 0.9 \mathrm{~V}_{\mathrm{CC}} \\ & 0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & V \\ & V \\ & V \\ & V \end{aligned}$ |
| Input Pull-Up Current | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{~N}}=0$ | 30 | 440 | $\mu \mathrm{A}$ |
| Hi-Z Input Leakage |  | -2 | +2 | $\mu \mathrm{A}$ |
| Input Capacitance (Note 4) |  |  | 7 | pF |
| Output Voltage Levels LSTTL Operation Logic High Logic Low CMOS Operation Logic High Logic Low | $\begin{aligned} & \text { Standard Outputs } \\ & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{IOH}^{2}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=400 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $v_{C C}-0.2$ | $\begin{aligned} & 0.4 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & V \\ & V \\ & V \\ & V \end{aligned}$ |
| Output Current Levels (except CKO) Sink (Note 6) <br> Source (Standard Option) <br> Source (Low Current Option) <br> CKO Current Levels (As Clock Out) | $V_{C C}=4.5 \mathrm{~V}, V_{\text {OUT }}=V_{C C}$ <br> $V_{C C}=3.0 \mathrm{~V}, V_{\text {OUT }}=V_{C C}$ <br> $V_{C C}=4.5 \mathrm{~V}, V_{\text {OUT }}=0 \mathrm{~V}$ <br> $V_{C C}=3.0 \mathrm{~V}, V_{\text {OUT }}=0 \mathrm{~V}$ <br> $V_{C C}=4.5 \mathrm{~V}, V_{\text {OUT }}=0 \mathrm{~V}$ <br> $V_{C C}=3.0 \mathrm{~V}, V_{\text {OUT }}=0 \mathrm{~V}$ <br> $V_{C C}=4.5 \mathrm{~V}, C K I=V_{C C}, V_{O U T}=V_{C C}$ <br> $V_{C C}=4.5 \mathrm{~V}, C K I=0 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V}$ | $\begin{gathered} 1.2 \\ 0.2 \\ 0.5 \\ 0.1 \\ 30 \\ 8 \\ \\ 0.3 \\ 0.6 \\ 1.2 \\ 0.3 \\ 0.6 \\ 1.2 \end{gathered}$ | $\begin{aligned} & 440 \\ & 200 \end{aligned}$ | mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| Allowable Sink/Source Current per Pin (Note 6) |  |  | 5 | mA |
| Allowable Loading on CKO (as HALT) |  |  | 100 | pF |
| ```Current Needed to Over-Ride HALT (Note 3) To Continue To Halt``` | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V}, V_{I N}=0.2 \mathrm{~V} C \mathrm{C} \\ & V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{I N}=0.7 \mathrm{~V}_{C C} \end{aligned}$ |  | $\begin{array}{r} 0.9 \\ 2.1 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ |
| TRI-STATE or Open Drain Leakage Current |  | -5 | +5 | $\mu \mathrm{A}$ |

## COP424C/COP425C/COP426C and COP444C/COP445C

AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ unless otherwise specified.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time (tc) | $\begin{aligned} & V_{c c} \geq 4.5 V \\ & 4.5 V>V_{c c} \geq 2.4 V \end{aligned}$ | $\begin{gathered} 4 \\ 16 \end{gathered}$ | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| $\left.\begin{array}{lr} \text { Operating CKI } & \left.\begin{array}{r} \div 4 \text { mode } \\ \text { Frequency } \\ \\ \\ \\ \\ \div 8 \text { mode } \\ \\ \\ \\ \\ \\ \\ \\ \div 8 \text { mode mode } \\ \div 16 \text { mode } \end{array}\right\} \end{array}\right\}$ | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>V_{C C} \geq 2.4 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \hline \end{aligned}$ | $\begin{array}{r} 1.0 \\ 2.0 \\ 4.0 \\ 250 \\ 500 \\ 1.0 \\ \hline \end{array}$ | MHz <br> MHz <br> MHz <br> kHz <br> kHz <br> MHz |
| Duty Cycle (Note 4) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ | 40 | 60 | \% |
| Rise Time (Note 4) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ External Clock |  | 60 | ns |
| Fall Time (Note 4) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ External Clock |  | 40 | ns |
| Instruction Cycle Time RC Oscillator (Note 4) | $\begin{aligned} & \mathrm{R}=30 \mathrm{k}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}=82 \mathrm{pF}(\div 4 \text { Mode }) \end{aligned}$ | 8 | 16 | $\mu \mathrm{S}$ |
| Inputs: (See Figure 3) tsetup <br> $t_{\text {HOLD }}$ | $\begin{aligned} & \text { G Inputs } \\ & \text { SI Input } \\ & \text { All Others } \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>V_{C C} \geq 2.4 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{tc} / 4+.7 \\ 0.3 \\ 1.7 \\ 0.25 \\ 1.0 \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Output Propagation Delay <br> tpD1 $^{\text {t }}$ tPDO <br> tPD1 $\mathrm{t}_{\mathrm{PDD}}$ | $\begin{aligned} & V_{O U T}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=5 \mathrm{k} \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 2.4 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 1.0 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Microbus Timing <br> Read Operation (Figure 4) <br> Chip Select Stable before $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{CSR}}$ <br> Chip Select Hold Time for $\overline{R D}-t_{\text {RCS }}$ <br> $\overline{R D}$ Pulse Width - $t_{\text {RR }}$ <br> Data Delay from $\overline{R D}-t_{\text {RD }}$ <br> $\overline{\mathrm{RD}}$ to Data Floating $-\mathrm{t}_{\mathrm{DF}}$ (Note 4) <br> Write Operation (Figure 5) <br> Chip Select Stable before $\overline{W R}-t_{C S W}$ <br> Chip Select Hold Time for $\overline{W R}$ - twCs <br> $\overline{\text { WR }}$ Pulse Width - $t_{\text {WW }}$ <br> Data Set-Up Time for $\overline{W R}-t_{\text {DW }}$ <br> Data Hold Time for $\overline{W R}$ - $t_{W D}$ <br> INTR Transition Time from $\overline{W R}-t_{W I}$ | $C L=50 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ | 65 <br> 20 <br> 400 <br> 65 <br> 20 <br> 400 <br> 320 <br> 100 | 375 <br> 250 <br> 700 |  |

Note 1: Supply current is measured after running for 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled up to VCc with 5 k resistors. See current drain equation on page 17.
Note 2: The HALT mode will stop CKI from oscillating in the RC and crystal configurations. Test conditions: all inputs tied to VCC, Lines in TRI-STATE mode and tied to ground, all outputs low and tied to ground.
Note 3: When forcing HALT, current is only needed for a short time (approx. 200 ns ) to flip the HALT flip-flop.
Note 4: This parameter is only sampled and not $100 \%$ tested. Variation due to the device included.
Note 5: Voltage change must be less than 0.5 volts in a 1 ms period.
Note 6: SO output sink current must be limited to keep $V_{O L}$ less than $0.2 V_{C C}$ when part is running in order to prevent entering test mode.
$\Longrightarrow$

## COP324C/COP325C/COP326C and COP344C/COP345C

AC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}$ unless otherwise specified.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time (tc) | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 3.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 4 \\ 16 \end{gathered}$ | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| $\left.\begin{array}{lr}\text { Operating CKI } & \div 4 \text { mode } \\ \text { Frequency } & \div 8 \text { mode } \\ & \div 16 \text { mode } \\ & \div 4 \text { mode } \\ & \div 8 \text { mode } \\ & \div 16 \text { mode }\end{array}\right\}$ | $V_{C C} \geq 4.5 \mathrm{~V}$ $4.5 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 3.0 \mathrm{~V}$ | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ DC $\mathrm{DC}$ | $\begin{aligned} & 1.0 \\ & 2.0 \\ & 4.0 \\ & 250 \\ & 500 \\ & 1.0 \\ & \hline \end{aligned}$ | MHz <br> MHz <br> MHz <br> kHz <br> kHz <br> MHz |
| Duty Cycle (Note 4) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ | 40 | 60 | \% |
| Rise Time (Note 4) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ external clock |  | 60 | ns |
| Fall Time ( Note 4 ) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ external clock |  | 40 | ns |
| Instruction Cycle Time RC Oscillator (Note 4) | $\begin{aligned} & R=30 \mathrm{k}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}=82 \mathrm{pF}(\div 4 \text { Mode }) \end{aligned}$ | 8 | 16 | $\mu \mathrm{S}$ |
| Inputs: (See Figure 3) tsetup <br> $t_{\text {HOLD }}$ | $\begin{aligned} & \text { G Inputs } \\ & \text { SI Inputs } \\ & \text { All Others } \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>V_{C C} \geq 3.0 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{tc} / 4+.7 \\ 0.3 \\ 1.7 \\ 0.25 \\ 1.0 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~S} \\ & \mu \mathrm{~S} \end{aligned}$ |
| Output Propagation Delay <br> tpD1 t $_{\text {PDO }}$ <br> tpD1 $\mathrm{t}_{\mathrm{PDD}}$ | $\begin{aligned} & V_{O U T}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=5 \mathrm{k} \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 3.0 \mathrm{~V} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 1.0 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Microbus Timing <br> Read Operation (Figure 4) <br> Chip Select Stable before $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{CSR}}$ <br> Chip Select Hold Time for $\overline{R D}-t_{\text {RCS }}$ <br> $\overline{\text { RD }}$ Pulse Width - $\mathrm{t}_{\text {RR }}$ <br> Data Delay from $\overline{R D}-t_{R D}$ <br> $\overline{\mathrm{RD}}$ to Data Floating - $\mathrm{t}_{\mathrm{DF}}$ (Note 4) <br> Write Operation (Figure 5) <br> Chip Select Stable before $\overline{W R}-t_{\text {CSW }}$ <br> Chip Select Hold Time for $\overline{W R}$ - ${ }_{\text {WCS }}$ <br> WR Pulse Width - tww $^{\text {W }}$ <br> Data Set-Up Time for $\overline{W R}-t_{D W}$ <br> Data Hold Time for $\overline{W R}-t_{\text {wD }}$ <br> INTR Transition Time from $\overline{W R}-t_{W I}$ | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ | 65 <br> 20 <br> 400 <br> 65 <br> 20 <br> 400 <br> 320 <br> 100 | 375 <br> 250 $700$ |  |

Note 1: Supply current is measured after running for 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled up to $V_{C C}$ with 5 k resistors. See current drain equation on page 17.
Note 2: The HALT mode will stop CKI from oscillating in the RC and crystal configurations. Test conditions: all inputs tied to $V_{C C}$, L lines in TRI-STATE mode and tied to ground, all outputs low and tied to ground.
Note 3: When forcing HALT, current is only needed for a short time (approx. 200 ns ) to flip the HALT flip-flop.
Note 4: This parameter is only sampled and not $100 \%$ tested. Variation due to the device included.
Note 5: Voltage change must be less than 0.5 volts in a 1 ms period.
Note 6: SO output sink current must be limited to keep $V_{O L}$ less than $0.2 \mathrm{~V}_{\mathrm{CC}}$ when part is running in order to prevent entering test mode.

## Connection Diagrams



TL/DD/5259-16

TL/DD/5259-2


FIGURE 2

Order Number COP325C/D, C/N, COP425C/D, C/N, COP345C/D, C/N, or COP445C/D, C/N
See NS Package D24C or N24A

> Order Number COP324C/D, C/N, COP424C/D, C/N, COP344C/D, C/N, or COP444C/D, C/N See NS Package D28C or N28B

## Functional Description

The internal architecture is shown in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 ", when a bit is reset, it is a logic " 0 ".
For ease of reading only the COP424C/425C/COP426C/ 444C/445C are referenced; however, all such references apply equally to COP324C/325C/COP326C/344C/345C.

## PROGRAM MEMORY

Program Memory consists of ROM, 1024 bytes for the COP424C/425C/426C and 2048 bytes for the COP444C/ 445 C . These bytes of ROM may be program instructions, constants or ROM addressing data.
ROM addressing is accomplished by a 11-bit PC register which selects one of the 8 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 11-bit binary count value.
Three levels of subroutine nesting are implemented by a three level deep stack. Each subroutine call or interrupt pushes the next PC address into the stack. Each return pops the stack back into the PC register.

## DATA MEMORY

Data memory consists of a 512-bit RAM for the COP444C/ 445 C , organized as 8 data registers of $16 \times 4$-bit digits. RAM addressing is implemented by a 7 -bit $B$ register whose upper 3 bits ( Br ) select 1 of 8 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. Data memory consists of a 256 -bit RAM for the COP424C/ $425 \mathrm{C} / 426 \mathrm{C}$, organized as 4 data registers of $16 \times 4$-bits digits. The B register is 6 bits long. Upper 2 bits ( Br ) select 1 of 4 data registers and lower 4 bits (Bd) select 1 of 164 -bit
digits in the selected data register. While the 4-bit contents of the selected RAM digit (M) are usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the $Q$ latches or $T$ counter or loaded from the L ports. RAM addressing may also be performed directly by the LDD and XAD instructions based upon the immediate operand field of these instructions.
The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The processor contains its own 4-bit A register (accumulator) which is the source and destination register for most I/O, arithmetic, logic, and data memory access operations. It can also be used to load the Br and Bd portions of the B register, to load and input 4 bits of the 8 -bit $Q$ latch or $T$ counter, to input 4 bits of L I/O ports data, to input 4-bit G, or IN ports, and to perform data exchanges with the SIO register. A 4-bit adder performs the arithmetic and logic functions, storing the results in $A$. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register in conjunction with the XAS instruction and the EN register, also serves to control the SK output.
The 8 -bit $T$ counter is a binary up counter which can be loaded to and from M and A using CAMT and CTMA instructions. This counter may be operated in two modes depending on a mask-programmable option: as a timer or as an external event counter. When the T counter overlows, an overflow flag will be set (see SKT and IT instructions below). The $T$ counter is cleared on reset. A functional block diagram of the timer/counter is illustrated in Figure 10a.
Four general-purpose inputs, IN3-INO, are provided. IN1, IN2 and IN3 may be selected, by a mask-programmable option as Read Strobe, Chip Select, and Write Strobe inputs, respectively, for use in Microbus application.

## Functional Description (Continued)

The D register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd. In the dual clock mode, DO latch controls the clock selection (see dual oscillator below).
The G register contents are outputs to a 4-bit general-purpose bidirectional I/O port. GO may be mask-programmed as an output for Microbus applications.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are outputted to the L I/O ports when the $L$ drivers are enabled under program control. With the Microbus option selected, $Q$ can also be loaded with the 8 -bit contents of the LI/O ports upon the occurrence of a write strobe from the host CPU.
The 8 L drivers, when enabled, output the contents of latched Q data to the L I/O port. Also, the contents of L. may be read directly into $A$ and $M$. As explained above, the Microbus option allows L I/O port data to be latched into the Q register.
The SIO register functions as a 4-bit serial-in/serial-out shift register for MICROWIRE I/O and COPS peripherals, or as a binary counter (depending on the contents of the EN register). Its contents can be exchanged with $A$.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the clock.

EN is an internal 4-bit register loaded by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register:
0 . The least significant bit of the enable register, ENO, selects the SIO register as either a 4-bit shift register or a 4-bit binary counter. With ENO set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output equals the value of EN3. With ENO reset, SIO is a serial shift register left shifting 1 bit each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. The SK outputs SKL. ANDed with the instruction cycle clock.

1. With EN1 set, interrupt is enabled. Immediately following an interrupt, EN1 is reset to disable further interrupts.
2. With EN2 set, the L drivers are enabled to output the data in Q to the L I/O port. Resetting EN2 disables the L drivers, placing the LI/O port in a high-impedance input state.


FIGURE 4. Microbus Read Operation Timing


FIGURE 5. Microbus Write Operation Timing

## Functional Description (Continued)

3. EN3, in conjunction with ENO, affects the SO output. With ENO set (binary counter option selected) SO will output the value loaded into EN3. With ENO reset (serial shift register option selected), setting EN3 enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting EN3 with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains set to " 0 ".

## INTERRUPT

The following features are associated with interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once recognized as explained below, pushes the next sequential program counter address (PC+1) onto the stack. Any previous contents at the bottom of the stack are lost. The program counter is set to hex address OFF (the last word of page 3) and EN1 is reset.
b. An interrupt will be recognized only on the following conditions:

1. EN1 has been set.
2. A low-going pulse ("1" to " 0 ") at least two instruction cycles wide has occurred on the $\mathrm{IN}_{1}$ input.
3. A currently executing instruction has been completed.
4. All successive transfer of control instructions and successive LBls have been completed (e.g. if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed).
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example, if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at hex address OFF. At the end of the interrupt routine, a RET instruction is executed to pop the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines should not be nested within the interrupt service routine, since their popping of the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The instruction at hex address OFF must be a NOP.
e. An LEI instruction may be put immediately before the RET instruction to re-enable interrupts.

## MICROBUS INTERFACE

The COP444C/424C has an option which allows it to be used as a peripheral microprocessor device, inputting and outputting data from and to a host microprocessor ( $\mu \mathrm{P}$ ). IN1, IN2 and IN3 general purpose inputs become Microbus compatible read-strobe, chip-select, and write-strobe lines, respectively. IN1 becomes $\overline{\mathrm{RD}}$ - a logic " 0 " on this input will cause $Q$ latch data to be enabled to the $L$ ports for input to the UP. IN2 becomes $\overline{C S}$ - a logic " 0 " on this line selects the COP444C/424C as the uP peripheral device by enabling the operation of the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ lines and allows for the selection of one of several peripheral components.
IN3 becomes $\overline{W R}$ - a logic " 0 " on this line will write bus data from the $L$ ports to the $Q$ latches for input to the COP444C/424C. G0 becomes INTR a "ready" output, reset by a write pulse from the UP on the $\overline{W R}$ line, providing the "handshaking" capability necessary for asynchronous data transfer between the host CPU and the COP444C/424C.
This option has been designed for compatibility with National's Microbus - a standard interconnect system for 8 -bit parallel data transfer between MOS/LSI CPUs and interfacing devices. (See Microbus National Publication.) The functioning and timing relationships between the signal lines affected by this option are as specified for the Microbus interface, and are given in the AC electrical characteristics and shown in the timing diagrams (Figures 4 and 5). Connection of the COP444C/424C to the Microbus is shown in Figure 6.


FIGURE 6. Microbus Option Interconnect

TABLE I. Enable Register Modes - Bits ENO and EN3

| ENO | EN3 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=\text { clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Shift Register | Input to Shift Register | Serial out | $\begin{aligned} & \text { If } S K L=1, S K=\text { clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Binary Counter | Input to Counter | 0 | SK $=$ SKL |
| 1 | 1 | Binary Counter | Input to Counter | 1 | SK $=$ SKL |

## Functional Description (Continued)

## INITIALIZATION

The internal reset logic will initialize the device upon powerup if the power supply rise time is less than 1 ms and if the operating frequency at CKI is greater than 32 kHz , otherwise the external RC network shown in Figure 7 must be connected to the RESET pin (the conditions in Figure 7 must be met). The RESET pin is configured as a Schmitt trigger input. If not used, it should be connected to $V_{C C}$. Initialization will occur whenever a logic " 0 " is applied to the $\overline{\text { RESET input, providing it stays low for at least three instruc- }}$ tion cycle times.
Note: If CKI clock is less than 32 kHz , the internal reset logic (option \# 29 = 1) MUST be disabled and the external RC circuit must be used.


TL/DD/5259-8

## FIGURE 7. Power-Up Circuit

Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the A, B, C, D, EN, IL, T and G registers are cleared. The SKL latch is set, thus enabling SK as a clock output. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA (clear A register).



Crystal or Resonator

| Crystal <br> Value | Component Values |  |  |  |
| :---: | ---: | :---: | :---: | :---: |
|  | R1 | R2 | C1(pF) | $\mathbf{C 2 ( p F )}$ |
| 32 kHz | 220 k | 20 M | 30 | $6-36$ |
| 455 kHz | 5 k | 10 M | 80 | 40 |
| 2.096 MHz | 2 k | 1 M | 30 | $6-36$ |
| 4.0 MHz | 1 k | 1 M | 30 | $6-36$ |

## TIMER

There are two modes selected by mask option:
a. Time-base counter. In this mode, the instruction cycle frequency generated from CKI passes through a 2-bit divide-by-4 prescaler. The output of this prescaler increments the 8 -bit T counter thus providing a 10 -bit timer. The prescaler is cleared during execution of a CAMT instruction and on reset.
For example, using a 4 MHz crystal with a divide-by- 16 option, the instruction cycle frequency of 250 kHz increments the 10 -bit timer every $4 \mu \mathrm{~s}$. By presetting the counter and detecting overflow, accurate timeouts between $16 \mu \mathrm{~s}$ ( 4 counts) and 4.096 ms ( 1024 counts) are possible. Longer timeouts can be achieved by accumulating, under software control, multiple overflows.
b. External event counter. In this mode, a low-going pulse (" 1 " to " 0 ") at least 2 instruction cycles wide on the IN2 input will increment the 8 -bit $T$ counter.
Note: The IT instruction is not allowed in this mode.

## HALT MODE

The COP444C/445C/424C/425C/426C is a FULLY STATIC circuit; therefore, the user may stop the system oscillator at any time to halt the chip. The chip may also be halted by the HALT instruction or by forcing CKO high when it is mask-programmed as an HALT I/O port. Once in the HALT mode, the internal circuitry does not receive any clock signal and is therefore frozen in the exact state it was in when halted. All information is retained until continuing. The chip may be awakened by one of two different methods:

- Continue function: by forcing CKO low, if it mask-programmed as an HALT I/O port, the system clock is reenabled and the circuit continues to operate from the point where it was stopped.
- Restart: by forcing the RESET pin low (see Initialization).


TL/DD/5259-9
RC Controlled Oscillator

| $\mathbf{R}$ | C | Cycle <br> Time | VCC |
| :---: | :---: | :---: | :---: |
| 15 k | 82 pF | $4-9 \mu \mathrm{~s}$ | 24.5 V |
| 30 k | 82 pF | $8-16 \mu \mathrm{~s}$ | 24.5 V |
| 60 k | 100 pF | $16-32 \mu \mathrm{~s}$ | $2.4-4.5 \mathrm{~V}$ |

[^2]$50 \mathrm{pF} \leq \mathrm{C} \leq 150 \mathrm{pF}$

FIGURE 8. Oscillator Component Values

## Functional Description (Continued)

The HALT mode is the minimum power dissipation state.
Note: If the user has selected dual-clock with DO as external oscillator (option $30=2$ ) AND the COP $444 \mathrm{C} / 424 \mathrm{C}$ is running with the DO clock, the HALT mode - either hardware or software - will NOT be entered. Thus, the user should switch to the CKI clock to HALT. AIternatively, the user may stop the DO clock to minimize power.

## CKO PIN OPTIONS

a. Two-pin oscillator - (Crystal). See Figure 9A.

In a crystal controlled oscillator system, CKO is used as an output to the crystal network. The HALT mode may be entered by program control (HALT instruction) which forces CKO high, thus inhibiting the crystal network. The circuit can be awakened only by forcing the RESET pin to a logic "0" (restart).
b. One-pin oscillator - (RC or external). See Figure $9 B$.

If a one-pin oscillator system is chosen, two options are available for CKO:

- CKO can be selected as the HALT I/O port. In that case, it is an I/O flip-flop which is an indicator of the HALT status. An external signal can over-ride this pin to start and stop the chip. By forcing a high level to CKO, the chip will stop as soon as CKI is high and CKO output will stay high to keep the chip stopped if the external driver returns to high impedance state. By forcing a low level to CKO, the chip will continue and CKO will stay low.
- As another option, CKO can be a general purpose input, read into bit 2 of $A$ (accumulator) upon execution of an INIL instruction.


## OSCILLATOR OPTIONS

There are four basic clock oscillator configurations available as shown by Figure 8.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency optionally divided by 4,8 or 16.
b. External Oscillator. The external frequency is optionally divided by 4,8 or 16 to give the instruction cycle time. CKO is the HALT I/O port or a general purpose input.
c. RC Controlled Oscillator. CKI is configured as a single pin RC conirolled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4 . CKO is the HALT I/O port or a general purpose input.
d. Dual oscillator. By selecting the dual clock option, pin DO is now a single pin oscillator input. Two configurations are available: RC controlled Schmitt trigger oscillator or external oscillator.
The user may software select between the DO oscillator (in that case, the instruction cycle time equals the D0 oscillation frequency divided by 4) by setting the DO latch high or the CKI (CKO) oscillator by resetting DO latch low. Note that even in dual clock mode, the counter, if maskprogrammed as a time-base counter, is always connected to the CKI oscillator.
For example, the user may connect up to a 1 MHz RC circuit to DO for faster processing and a 32 kHz watch crystal to CKI and CKO for minimum current drain and time keeping.
Note: CTMA instruction is not allowed when chip is running from D0 clock.
Figures $10 A$ and $10 B$ show the clock and timer diagrams with and without Dual clock.

## COP445C AND COP425C 24-PIN PACKAGE OPTION

If the COP444C/424C is bonded in a 24 -pin package, it becomes the COP445C/425C, illustrated in Figure 2, Connection diagrams. Note that the COP445C/425C does not contain the four general purpose IN inputs (IN3-INO). Use of this option precludes, of course, use of the IN options, interrupt feature, external event counter feature, and the Microbus option which uses IN1-IN3. All other options are available for the COP445C/425C
Note: If user selects the 24 -pin package, options $9,10,19$ and 20 must be selected as a " 0 " (load to $V_{C C}$ on the IN inputs). See option list.

## COP426C 20-PIN PACKAGE OPTION

If the COP425C is bonded as 20 -pin device it becomes the COP426C. Note that the COP426C contains all the COP425C pins except $D_{0}, D_{1}, G_{0}$, and $G_{1}$.



TL/DD/5259-11
FIGURE 9B. Halt Mode - One-Pin Oscillator


TL/DD/5259-12
FIGURE 10A. Clock and Timer without Dual-Clock


TL/DD/5259-13
FIGURE 10B. Clock and Timer with Dual-Clock

|  |  |
| :--- | :--- |
| Instruction Set |  |
| Table II is a symbol table providing internal architecture, in- |  |
| struction operan and operation symbols used in the instruc- |  |
| tion set table. |  |
| TABLE II. Instruction Set Table Symbols |  |
| Symbol | Definitlon |
| Internal Architecture Symbols |  |
| A | 4-bit accumulator |
| B | 7-bit RAM address register (6-bit for COP424C) |
| Br | Upper 3 bits of B (register address) |
|  | (2-bit for COP424C) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit carry register |
| D | 4-bit data output port |
| EN | 4-bit enable register |
| G | 4-bit general purpose I/O port |
| IL | two 1-bit (IN0 and IN3) latches |
| IN | 4-bit input port |
| L | 8-bit TRI-STATE I/O port |
| M | 4-bit contents of RAM addressed by B |
| PC | 11-bit ROM address program counter |
| Q | 8-bit latch for L port |
| SA,SB,SC | 11-bit 3-level subroutine stack |
| SIO | 4-bit shift register and counter |
| SK | Logic-controlled clock output |
| SKL | 1-bit latch for SK output |
| T | 8-bit timer |

Table III provides the mnemonic, operand, machine code data flow, skip conditions and description of each instruction.

| Instruction Operand Symbols |  |
| :--- | :--- |
| d | 4-bit operand field, $0-15$ binary (RAM digit select) <br> r |
| 3(2)-bit operand field, $0-7(3)$ binary <br> (RAM register select) |  |
| a | 11-bit operand field, $0-2047$ (1023) |
| y | 4-bit operand field; $0-15$ (immediate data) |
| RAM(x) | RAM addressed by variable $x$ |
| ROM $(x)$ | ROM addressed by variable $x$ |

## Operational Symbols

$+\quad$ Plus

- Minus
$\rightarrow \quad$ Replaces
$\longleftrightarrow \quad$ Is exchanged with
$=\quad$ Is equal to
$\bar{A} \quad$ One's complement of A
$\oplus \quad$ Exclusive-or
: Range of values

TABLE III. COP444C/445C Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine <br> Language <br> Code <br> (Binary) |  | Data Flow |
| :--- | :---: | :---: | :--- | :--- | :--- |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Table III. COP444C/445C Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| TRANSFER CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111 | $\mathrm{ROM}\left(\mathrm{PC}_{10: 8} \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{PC}_{7: 0}$ | None | Jump Indirect (Notes 1, 3) |
| JMP | a | $\begin{aligned} & 6- \\ & -- \end{aligned}$ | $\frac{\|0110\| 0\left\|a_{10: 8}\right\|}{\mid a_{7}: 0}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  |  | $a \rightarrow P C_{6: 0}$ $a \rightarrow P C_{5: 0}$ | None | Jump within Page (Note 4) |
| JSRP | a | -- |  | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & 00010 \rightarrow \mathrm{PC}_{10: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR | a | $\begin{aligned} & 6- \\ & -- \end{aligned}$ | $\begin{aligned} & \|0110\| 1 \mid a_{10: 8} \\ & \hline a_{7: 0} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | \|0100|1000 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | \|0100|1001 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| HALT |  | 33 | -0011\|00111 |  | None | HALT Processor |
|  |  | 38 | 0011\|1000 |  |  |  |
| IT |  | 33 | -0011\|0011 |  |  | IDLE till Timer |
|  |  | 39 | \|0011/1001 |  | None | Overflows then Continues |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMT |  | 33 | 0011\|0011 | $A \rightarrow T_{7: 4}$ |  |  |
|  |  | 3F | \|0011|11111 | $\operatorname{RAM}(B) \rightarrow \mathrm{T}_{3: 0}$ | None | Copy A, RAM to T |
| CTMA |  | 33 | 0011\|0011 | $\mathrm{T}_{7: 4} \rightarrow$ RAM(B) |  |  |
|  |  | 2 F | 0010\|11111 | $\mathrm{T}_{3: 0} \rightarrow \mathrm{~A}$ | None | Copy T to RAM, A (Note 9) |
| CAMQ |  | 33 | -0011\|0011 | $A \rightarrow Q_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C | 0011\|1100 | $\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{Q}_{3: 0}$ |  |  |
| CQMA |  | 33 | 0011\|0011 | $\mathrm{Q}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Copy Q to RAM, A |
|  |  | 2 C | 10010\|1100 | $\mathrm{Q}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| LD | $r$ | $-5$ | $\frac{100\|r\| 0101 \mid}{(r=0: 3)}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A, Exclusive-OR Br with r |
| LDD | r,d | $23$ | $\begin{array}{\|l\|l\|l\|} \hline 0010 & 0011 \\ \hline 0 & r & d \\ \hline \end{array}$ | RAM $(\mathrm{r}, \mathrm{d}) \rightarrow \mathrm{A}$ | None | Load A with RAM pointed to directly by r,d |
| LQID |  | BF | \|1011|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{10:}, \mathrm{A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SB} \rightarrow \mathrm{SC} \end{aligned}$ | None | Load Q Indirect (Note 3) |
| RMB | 0 | 4 C | 10100\|1100 | $0 \rightarrow$ RAM $(B)_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | -0100\|0101 | $0 \rightarrow$ RAM $(B)_{1}$ |  |  |
|  | 2 | 42 | 10100\|0010 | $0 \rightarrow$ RAM $(B)_{2}$ |  |  |
|  | 3 | 43 | 0100\|0011 | $0 \rightarrow$ RAM $(\mathrm{B})_{3}$ |  |  |
| SMB | 0 | 4D | -0100\|1101 | $1 \rightarrow$ RAM $(B)_{0}$ | None | Set RAM Bit |
|  | 1 | 47 | 010010111 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1}$ |  |  |
|  | 2 | 46 | -0100\|0110 | $1 \rightarrow$ RAM $(\mathrm{B})_{2}$ |  |  |
|  | 3 | 4B | \|0100|1011 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Table III. COP444C/445C Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex Code | Machine Language Code (BInary) | Data Flow | Skip Conditions | Description |
| MEMORY REFERENCE INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| STII | $y$ | $7-$ | \|0111 y ${ }^{\text {y }}$ | $\begin{aligned} & y \rightarrow \operatorname{RAM}(B) \\ & B d+1 \rightarrow B d \end{aligned}$ | None | Store Memory Immediate 1 and Increment Bd |
| $x$ | $r$ | $-6$ | $\frac{100\|r\| 0110 \mid}{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with $r$ |
| XAD | r,d | $23$ | $\begin{array}{\|l\|l\|} \hline 0010 & 0011 \\ \hline \hline 1\|r\| r \mid \\ \hline \end{array}$ | RAM $(r, d) \longleftrightarrow A$ | None | Exchange A with RAM <br> Pointed to Directly by r,d |
| XDS | r | $-7$ | $\frac{100\|r\| 0111 \mid}{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \longrightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd. <br> Exclusive-OR Br with $r$ |
| XIS | $r$ | $-4$ | $\begin{array}{c\|c\|c\|c\|} \hline 00\|r\| 0100 \mid \\ \hline(r=0: 3) \end{array}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with A and Increment Bd , Exclusive-OR Br with r |
| REGISTER REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAB |  | 50 | 010110000 | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| CBA |  | 4 E | 0100\|1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d | -- 33 -- | $\|00\| r \mid(d-1)$ <br> $(r=0: 3:$ <br> $d=0,9: 15)$ <br> or <br> $0011\|0011\|$ <br> $1\|r\| d$ <br> (any $r$, any $d)$ | $r, d \rightarrow B$ | Skip until not a LBI | Load B Immediate with r,d (Note 6) |
| LEI | $y$ | 33 $6-$ | 0011 0011 <br> 0110 y | $y \rightarrow E N$ | None | Load EN Immediate (Note 7) |
| XABR |  | 12 | 0001\|0010 | $\mathrm{A} \longleftrightarrow \mathrm{Br}$ | None | Exchange A with Br (Note 8) |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  | 20 | 0010\|0000 |  | $\mathrm{C}=$ "1" | Skip if C is True |
| SKE |  | 21 | $0010 \mid 0001$ |  | $A=R A M(B)$ | Skip if A Equals RAM |
| SKGZ |  | $\begin{aligned} & 33 \\ & 21 \end{aligned}$ | $\begin{array}{\|r\|r\|} \hline 0011 \mid 0011 \\ \hline 0010 \mid 0001 \\ \hline \end{array}$ |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
| SKGBZ |  | 33 | -001110011 | 1st byte |  | Skip if G Bit is Zero |
|  | 0 | 01 | 000010001 |  | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 00001\|0001 |  | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | 000010011 | 2nd byte | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 0001)0011. |  | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 0000\|0001| |  | RAM (B) $)_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | 00010001 |  | $\operatorname{RAM}(\mathrm{B})_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 |  | $\mathrm{RAM}(\mathrm{B})_{2}=0$ |  |
|  | 3 | 13 | \|000110011 |  | $\operatorname{RAM}(\mathrm{B})_{3}=0$ |  |
| SKT |  | 41 | 0100\|0001 |  | A time-base counter carry has occurred since last test | Skip on Timer (Note 3) |

## Instruction Set (Continued)

Table III. COP444C/445C Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  | $\cdot$ |
| ING |  | 33 | [0011\|0011] | $\mathrm{G} \rightarrow \mathrm{A}$ | None | Input G Ports to A |
|  |  | 2A | 0010\|1010 |  |  |  |
| ININ |  | 33 | [0011 10011 | $\mathbb{N} \rightarrow \mathrm{A}$ | None | Input IN Inputs to A (Note 2) |
|  |  | 28 | \|0010|1000 |  |  |  |
| INIL |  | 33 | [0011 ${ }^{\text {100111 }}$ | $\mathrm{IL}_{3}, \mathrm{CKO}, \quad{ }^{\prime} \mathrm{O}^{\prime}, \mathrm{IL}_{0} \rightarrow \mathrm{~A}$ | None | Input IL Latches to A (Note 3) |
|  |  | 29 | [0010/1001 |  |  |  |
| INL |  | 33 | 10011 10011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2E | \|0010|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | \|0011 0011 | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E | \|0011|1110 |  |  |  |
| OGI | y | 33 | [0011 [0011] | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | 5- | \|0101 y |  |  |  |
| OMG |  | 33 | \|0011 0011 | | $\mathrm{RAM}(\mathrm{B}) \longrightarrow \mathrm{G}$ | None | Output RAM to G Ports |
|  |  | 3A | 2011 1010 |  |  |  |
| XAS | . | 4F | \|0100|1111 | $\mathrm{A} \longleftrightarrow \mathrm{SIO}, \mathrm{C} \rightarrow \mathrm{SKL}$ | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4-bit $A$ register.
Note 2: The ININ instruction is not available on the 24-pin packages since these devices do not contain the $\mathbb{N}$ inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while in subroutine pages 2 or 3 , to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 5: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ " data minus 1 , e.g., to load the lower four bits of $\mathrm{B}(\mathrm{Bd})$ with the value $9(10012)$, the lower 4 bits of the LBI instruction equal $8\left(100 \mathrm{O}_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).
Note 7: Machine code for operand field y for LEI instruction should equal the binary value to be latched into EN, where a " 1 ", or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)
Note 8: For 2 K ROM devices, $A \longleftrightarrow \mathrm{Br}(0 \longrightarrow \mathrm{~A} 3)$. For 1 K ROM devices, $\mathrm{A} \longleftrightarrow \mathrm{Br}(0,0 \longrightarrow \mathrm{~A} 3, \mathrm{~A} 2)$.
Note 9: Do not use CTMA instruction when dual-clock option is selected and part is running from $D_{0}$ clocks.

## Description of Selected Instructions

## XAS INSTRUCTION

XAS (Exchange A with SIO) copies C to the SKL latch and exchanges the accumulator with the 4 -bit contents of the SIO register. The contents of SIO will contain serial-in/seri-al-out shift register or binary counter data, depending on the value of the EN register. If SIO is selected as a shift register, an XAS instruction can be performed once every 4 instruction cycles to effect a continuous data stream.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8 -bit $Q$ register with the contents of ROM pointed to by the 11-bit word PC10:PC8,A,M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC $+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC}$ ) and replaces the least significant 8 bits of the PC as follows: $A \rightarrow P C(7: 4), R A M(B) \rightarrow P C(3: 0)$, leaving $P C(10), P C(9)$ and $\mathrm{PC}(8)$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" ( $S C \rightarrow S B \rightarrow S A \rightarrow P C$ ), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost.
Note: LQID uses 2 instruction cycles if executed, one if skipped.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by $A$ and $M$. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 11 -bit word, PC10:8,A,M. PC10,PC9 and PC8 are not affected by JID.
Note: JID uses 2 instruction cycles if executed, one if skipped.

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of the T counter overflow latch (see internal logic, above), executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction allow the processor to generate its own time-base for real-time processing, rather than relying on an external input signal.
Note: If the most significant bit of the T counter is a 1 when a CAMT instruction loads the counter, the overflow flag will be set. The following sample of codes should be used when loading the counter:
CAMT ; load T counter
SKT ; skip if overflow flag is set and reset it
NOP

## IT INSTRUCTION

The IT (idle till timer) instruction halts the processor and puts it in an idle state until the time-base counter overflows. This idle state reduces current drain since all logic (except the oscillator and time base counter) is stopped. IT instruction is not allowed if the T counter is mask-programmed as an external event counter (option \#31 = 1).

## INIL INSTRUCTION

INIL (Input IL Latches to A) inputs 2 latches, IL3 and ILO, CKO and 0 into A. The IL3 and ILO latches are set if a lowgoing pulse (" 1 " to " 0 ") has occurred on the IN3 and INO inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction cycles. Execution of an INIL inputs IL3 and ILO into A3 and AO respectively,
and resets these latches to allow them to respond to subsequent low-going pulses on the IN3 and INO lines. If CKO is mask programmed as a general purpose input, an INIL will input the state of CKO into A2. If CKO has not been so programmed, a " 1 " will be placed in A2. AO is input into A1. IL latches are cleared on reset. IL latches are not available on the COP445C/425C, and COP426C.

## INSTRUCTION SET NOTES

a. The first word of a program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, they are still fetched from the program memory. Thus program paths take the same number of cycles whether instructions are skipped or executed except for JID, and LQID.
c. The ROM is organized into pages of 64 words each. The Program Counter is a 11-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID, or LQID is the last word of a page, it operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a JID or LQID located in the last word of every fourth page (i.e. hex address OFF, 1FF, 2FF, 3FF, 4FF, etc.) will access data in the next group of four pages.
Note: The COP424C/425C/426C needs only 10 bits to address its ROM. Therefore, the eleventh bit (P10) is ignored.

## Power Dissipation

The lowest power drain is when the clock is stopped. As the frequency increases so does current. Current is also lower at lower operating voltages. Therefore, the user should run at the lowest speed and voltage that his application will allow. The user should take care that all pins swing to full supply levels to insure that outputs are not loaded down and that inputs are not at some intermediate level which may draw current. Any input with a slow rise or fall time will draw additional current. A crystal or resonator generated clock input will draw additional current. An R/C oscillator will draw even more current since the input is a slow rising signal.
If using an external squarewave oscillator, the following equation can be used to calculate operating current drain.
$I_{C O}=I_{Q}+V \times 40 \times F i+V \times 1400 \times F i / D v$
where $\mathrm{I}_{\mathrm{CO}}=$ chip operating current drain in microamps quiescent leakage current (from curve) CKI frequency in MegaHertz
chip $V_{C C}$ in volts
divide by option selected
For example at 5 volts $V_{C C}$ and 400 kHz (divide by 4)
$\mathrm{I}_{\mathrm{CO}}=20+5 \times 40 \times 0.4+5 \times 1400 \times 0.4 / 4$
$\mathrm{I}_{\mathrm{CO}}=20+80+700=800 \mu \mathrm{~A}$
At 2.4 volts $V_{C C}$ and 30 kHz (divide by 4)

$$
\mathrm{I}_{\mathrm{CO}}=6+2.4 \times 40 \times 0.03+2.4 \times 1400 \times 0.03 / 4
$$

$$
\mathrm{I}_{\mathrm{CO}}=6+2.88+25.2=34.08 \mu \mathrm{~A}
$$

## Power Dissipation (Continued)

If an IT instruction is executed, the chip goes into the IDLE mode until the timer overflows. In IDLE mode, the current drain can be calculated from the following equation:

$$
I c i=l_{Q}+V \times 40 \times F i
$$

For example, at 5 volts $\mathrm{V}_{\mathrm{CC}}$ and 400 kHz

$$
\mid c i=20+5 \times 40 \times 0.4=100 \mu \mathrm{~A}
$$

The total average current will then be the weighted average of the operating current and the idle current:

$$
I_{t a}=I_{C O} \times \frac{T o}{T o+T i}+I c i \times \frac{T i}{T o+T i}
$$

where: Ita $=$ total average current
$\mathrm{I}_{\mathrm{CO}}=$ operating current
lci = idle current
To = operating time
$\mathrm{Ti}=$ idle time

## I/O OPTIONS

Outputs have the following optional configurations, illustrated in Figure 11:
a. Standard - A CMOS push-pull buffer with an N -channel device to ground in conjunction with a $P$-channel device to $V_{C C}$, compatible with CMOS and LSTTL.
b. Low Current - This is the same configuration as a. above except that the sourcing current is much less.

b. Low Current Push-Pull Output

c. Open-Drain Output
c. Open Drain - An N-channel device to ground only, allowing external pull-up as required by the user's application.
d. Standard TRI-STATE L Output - A CMOS output buffer similar to a. which may be disabled by program control.
e. Low-Current TRI-STATE L Output - This is the same as d. above except that the sourcing current is much less.
f. Open-Drain TRI-STATE L Output - This has the N-channel device to ground only.

All inputs have the following options:
g. Input with on chip load device to $V_{C C}$.
h. Hi-Z input which must be driven by the users logic.

When using either the $G$ or $L I / O$ ports as inputs, a pull-up device is necessary. This can be an external device or the following alternative is available: Select the low-current output option. Now, by setting the output registers to a logic "1" level, the P-channel devices will act as the pull-up load. Note that when using the $L$ ports in this fashion the $Q$ registers must be set to a logic " 1 " level and the L drivers MUST BE ENABLED by an LEl instruction (see description above).
All output drivers use one or more of three common devices numbered 1 to 3 . Minimum and maximum current (lout and $V_{\text {OUT }}$ ) curves are given in Figure 12 for each of these devices to allow the designer to effectively use these I/O configurations.

a. Standard Push-Pull Output
d. Standard TRI-STATE "L" Output


d.
e. Low Current TRI-STATE "L" Output


f. Open Drain TRI-STATE "L"Output

g. Input with Load

h. Hi-Z Input

FIGURE 11. Input/Output Configurations

Power Dissipation (Continued)


FIGURE 12. Input/Output Characteristics

## Option List

The COP444C/445C/424C/425C/COP426C mask-programmable options are assigned numbers which correspond with the COP444C/424C pins.
The following is a list of options. The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
PLEASE FILL OUT THE OPTION TABLE on the next page. Xerox the option data and send it in with your disk or EPROM.
Option 1=0: Ground Pin — no options available
Option 2: CKO Pin
=0: clock generator output to crystal/resonator
=1: HALT I/O port
=2: general purpose input with load device to $\mathrm{V}_{\mathrm{CC}}$
=3: general purpose input, high-Z
Option 3: CKI input
$=0$ : Crystal controlled oscillator input divide by 4
=1: Crystal controlled oscillator input divide by 8
=2: Crystal controlled oscillator input divide by 16
=4: Single-pin RC controlled oscillator (divide by 4)
$=5$ : External oscillator input divide by 4
$=6$ : External oscillator input divide by 8
=7: External oscillator input divide by 16

Option 4: $\overline{\text { RESET }}$ input
$=0$ : load device to $V_{C C}$
$=1$ : $\mathrm{Hi}-\mathrm{Z}$ input
Option 5: L7 Driver
$=0$ : Standard TRI-STATE push-pull output
=1: Low-current TRI-STATE push-pull output
=2: Open-drain TRI-STATE output
Option 6: L6 Driver - (same as option 5)
Option 7: L5 Driver - (same as option 5)
Option 8: L4 Driver - (same as option 5)
Option 9: IN1 input
$=0:$ load device to $V_{C C}$
$=1: H i-Z$ input

Option 10: IN2 input - (same as option 9)
Option 11=0: V $\mathrm{V}_{\mathrm{CC}}$ Pin - no option available
Option 12: L3 Driver - (same as option 5)
Option 13: L2 Driver - (same as option 5)
Option 14: L1 Driver - (same as option 5)
Option 15: LO Driver - (same as option 5)
Option 16: SI input - (same as option 9)
Option 17: SO Driver
$=0$ : Standard push-pull output
$=1$ : Low-current push-pull output
=2: Open-drain output

## Option List (Continued)

Option 18: SK Driver - (same as option 17)
Option 19: INO Input - (same as option 9)
Option 20: IN3 Input - (same as option 9)
Option 21: GO I/O Port - (same as option 17)
Option 22: G1 I/O Port - (same as option 17)
Option 23: G2 I/O Port - (same as option 17)
Option 24: G3 I/O Port - (same as option 17)
Option 25: D3 Output - (same as option 17)
Option 26: D2 Output - (same as option 17)
Option 27: D1 Output - (same as option 17)
Option 28: DO Output - (same as option 17)
Option 29: Internal Initialization Logic
$=0$ : Normal operation
=1: No internal initialization logic
Option 30: Dual Clock
$=0$ : Normal operation
$\left.\begin{array}{l}=1 \text { : Dual Clock. DO RC oscillator } \\ =2 \text { : Dual Clock. D0 ext. clock input }\end{array}\right\}$ (opt. \# 28 must $=2$ )
Option 31: Timer
$=0$ : Time-base counter
=1: External event counter

Option 32: Microbus
=0: Normal
=1: Microbus (opt. \#31 must=0)
Option 33: COP bonding
(1k and 2 K Microcontroller)
=0: 28-pin package
=1: 24-pin package
$=2$ : Same die purchased in both 24 and 28 pin version.
(1K Microcontroller only)
=3: 20-pin package
=4: 28 - and 20 -pin package
$=5$ : 24- and 20-pin package
$=6$ : 28-, 24- and 20-pin package
Note:-if opt. \#33=1 or 2 then opt. \#9, 10, 19, 20 and 32 must $=0$-if opt. \#33 $=3,4,5$ or 6 then opt. \#9, 10, 19, $20,21,22,30$ and 32 must $=0$.

## Option Table

The following option information is to be sent to National along with the EPROM.

OPTION DATA

| OPTION | 1 VALUE = | IS: GROUND PIN |
| :---: | :---: | :---: |
| OPTION | 2 VALUE = | IS: CKO PIN |
| OPTION | 3 VALUE $=$ | IS: CKI INPUT |
| OPTION | 4 VALUE $=$ | IS: RESET INPUT |
| OPTION | 5 VALUE $=$ | IS: L(7) DRIVER |
| OPTION | 6 VALUE $=$ | IS: L(6) DRIVER |
| OPTION | 7 VALUE $=$ | IS: L(5) DRIVER |
| OPTION | 8 VALUE $=$ | IS: L(4) DRIVER |
| OPTION | 9 VALUE $=$ | IS: IN1 INPUT |
| OPTION | 10 VALUE $=$ | IS: IN2 INPUT |
| OPTION | 11 VALUE = | IS: VCC PIN |
| OPTION | 12 VALUE $=$ | IS: L(3) DRIVER |
| OPTION | 13 VALUE $=$ | IS: L(2) DRIVER |
| OPTION | 14 VALUE = | IS: L(1) DRIVER |
| OPTION | 15 VALUE = | IS: L(0) DRIVER |
| OPTION | 16 VALUE $=$ | IS: SIINPUT |

## OPTION DATA

| OPTION 17 VALUE = | IS: SO DRIVER |
| :---: | :---: |
| OPTION 18 VALUE = | IS: SK DRIVER |
| OPTION 19 VALUE $=$ | IS: INO INPUT |
| OPTION 20 VALUE = | IS: IN3 INPUT |
| OPTION 21 VALUE = | IS: GO I/O PORT |
| OPTION 22 VALUE = | IS: G1 I/O PORT |
| OPTION 23 VALUE = | IS: G2 I/O PORT |
| OPTION 24 VALUE $=$ | IS: G3 I/O PORT |
| OPTION 25 VALUE = | IS: D3 OUTPUT |
| OPTION 26 VALUE = | IS: D2 OUTPUT |
| OPTION 27 VALUE = | IS: D1 OUTPUT |
| OPTION 28 VALUE = | IS: DO OUTPUT |
| OPTION 29 VALUE = | IS: INT INIT LOGIC |
| OPTION 30 VALUE = | IS: DUAL CLOCK |
| OPTION 31 VALUE = | IS: TIMER |
| OPTION $32 \mathrm{VALUE}=$ | IS: MICROBUS |
| OPTION 33 VALUE $=$ | IS: COP BONDING |

# COP427C, COP428C, COP429C, COP447C, COP448C, COP449C, COP327C, COP328C, COP329C, COP227C, COP228C, COP229C, and COP347C, COP348C, COP349C Single Chip 1k and 2k CMOS Microcontrollers 

## General Description

The COP427C, COP428C, COP429C, COP447C, COP448C and COP449C fully static, Single-Chip CMOS Microcontrollers are members of the COPSTM family, fabricated using double-poly, silicon gate microCMOS technology. These Controller Oriented Processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture and I/O scheme designed to facilitate keyboard input, display output and BCD data manipulation. The COP427C and COP447C are 28 pin chips. The COP428C and COP448C are 24 -pin versions ( 4 inputs removed) and COP429C and COP449C are 20-pin versions with 15 I/O lines. Standard test procedures and reliable high-density techniques provide the medium to large volume customers with a customized microcontroller at a low end-product cost. These microcontrollers are appropriate choices in many demanding control environments especially those with human interface.

## Features

$2 \mu \mathrm{~s}$ instruction time, plus software selectable clocks
Lowest power dissipation ( $25 \mu \mathrm{~W}$ typical)
Fully static (can turn off the clock)
Power saving IDLE state and HALT mode

- $2 \mathrm{k} \times 8$ ROM, $128 \times 4$ RAM (COP447C/COP448C)

■ 1k x 8 ROM, $64 \times 4$ RAM (COP427C/COP428C/ COP429C)

- 23 I/O lines (COP447C and COP427C)
- True vectored interrupt, plus restart
- Three-level subroutine stack
$\square$ Single supply operation ( 2.4 V to 6.0 V )
- Programmable read/write 8 -bit timer/event counter
- Internal binary counter register with MICROWIRETM serial I/O capability
- General purpose and TRI-STATE® outputs
- LSTTL/CMOS output compatible
- MICROBUSTM compatible
- Software/hardware compatible with COP400 family
- Open-drain outputs and $\mathrm{Hi}-\mathrm{Z}$ inputs operational at 12 volts
- Internal initialization on power-up optionally available

■ External HALT mode wake-up optionally available

- On-chip comparator with software enable provided (IN1, IN2)
- High-sink current optionally available
- Malfunction detector option available
- MICROBUS compatible
- Extended temperature range devices COP327C/ COP328C/COP329C and COP347C/COP348C/ COP349C $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
- Militay temperature range devices COP227C/ COP228C/COP229C and COP247C/COP248C/


## Block Diagram

FIGURE 1

## COP427C／COP428C／COP429C and COP447C／COP448C／COP449C COP327C／COP328C／COP329C and COP347C／COP348C／COP349C

| Absolute Maximum Ratings $0^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}$ |  |  |  |
| :--- | :--- | :--- | :--- | ---: |
| Specifications for Miltary／Aerospace products are not | Total Allowable Sink Current | 60 mA |  |
| contained in this datasheet．Refer to the associated | Total Allowable Source Current | 48 mA |  |
| reliability electrical test specifications document． | Allowable Source Current per Pin | 5 mA |  |
| Supply Voltage（VCC） | -0.3 V to 7.0 V | Power Dissipation $\left(T=110^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V}\right)$ | 500 mW |
| Latch－Up Susceptibility（Note 8） | 400 mW | Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| ESD Susceptibility（Note 9 ） | 3500 V | Lead Temperature（soldering， 10 sec．） | $300^{\circ} \mathrm{C}$ |

DC Electrical Characteristics
$0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ for COP400 Series，$-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 85^{\circ} \mathrm{C}$ for COP300 Series

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage |  | 2.4 | 6.0 | V |
| Power Supply Ripple（Note 5） | Peak to Peak |  | $0.1 \mathrm{~V}_{\mathrm{CC}}$ | V |
| Supply Current （Notes 1，7） | $\begin{aligned} & V_{C C}=6.0 \mathrm{~V}, \mathrm{tc}=4 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 32 \\ & V_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{tc}=2 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 16 \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{tc}=2 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 4 \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{tc}=16 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 32 \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{tc}=8 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 16 \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{tc}=8 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 4 \end{aligned}$ |  | $\begin{gathered} 6.2 \\ 6.2 \\ 1.1 \\ 250 \\ 250 \\ 55 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| HALT Mode Current （Note 2） | $\begin{aligned} & V_{C C}=6.0 \mathrm{~V} \\ & V_{C C}=3.0 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 5 \\ & 3 \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Input Voltage Levels <br> RESETp，CKI， <br> $\mathrm{D}_{0}$（clock input） <br> Logic High <br> Logic Low <br> All Other Inputs <br> Logic High <br> Logic Low <br> G－Port <br> Logic High <br> Logic Low <br> IN1，IN2 as <br> Comparator Inputs Common－Mode Voltage Input Offset Voltage | Optional SCHMITT Trigger | $\begin{gathered} 0.8 \mathrm{~V}_{\mathrm{CC}} \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ \\ 0.8 \mathrm{~V}_{\mathrm{CC}} \\ \\ \\ 0 \\ 100 \\ \hline \end{gathered}$ | $0.2 \mathrm{~V}_{\mathrm{CC}}$ <br> $0.3 \mathrm{~V}_{\mathrm{CC}}$ <br> $0.2 \mathrm{~V}_{\mathrm{CC}}$ <br> $\mathrm{V}_{\mathrm{CC}}-1.5$ | V V <br> V <br> v <br> V <br> V <br> V <br> $\mathrm{m} V$ |
| Input Pull－Up Current（optional） | $\mathrm{V}_{\mathrm{CC}}=4 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=0 \mathrm{~V}$ | 30 | 120 | $\mu \mathrm{A}$ |
| Hi－Z Input Leakage | $\begin{aligned} & V_{I N}=V_{C C} \\ & V_{I N}=12 V \end{aligned}$ | $\begin{gathered} \hline-1 \\ -15 \\ \hline \end{gathered}$ | $\begin{gathered} +1 \\ +15 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ |
| Input Capacitance（Note 4） |  |  | 7 | pF |

# COP427C/COP428C/COP429C and COP447C/COP448C/COP449C COP327C/COP328C/COP329C and COP347C/COP348C/COP349C <br> DC Electrical Characteristics 

$0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ for COP400 Series, $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 85^{\circ} \mathrm{C}$ for COP300 Series (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Voltage Levels LSTTL Operation Logic High Logic Low CMOS Operation Logic High Logic Low | (Standard Outputs) <br> $\mathrm{V}_{\mathrm{CC}}=4.0 \mathrm{~V}$ to 6.0 V <br> $\mathrm{l}_{\mathrm{OH}}=-500 \mu \mathrm{~A}$ <br> $\mathrm{loL}=600 \mu \mathrm{~A}$ <br> $2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.0 \mathrm{~V}$ <br> $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ <br> $\mathrm{lOL}=175 \mu \mathrm{~A}$ | $\begin{gathered} 2.7 \\ V_{C C}-0.2 \end{gathered}$ | $0.4$ <br> 0.2 | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & \hline \end{aligned}$ |
| Output Current Levels (except CKO) <br> Sink (Note 6) <br> High Current Option Source <br> Low Current Option | $\begin{aligned} & V_{C C}=4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=2.7 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=2.2 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 15.0 \\ & 50.0 \\ & 5.0 \end{aligned}$ | $\begin{gathered} 300 \\ 30 \end{gathered}$ | mA <br> $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| CKO Current Levels (As Clock Out) Sink $\div 4$ All Others Source $\div 4$ All Others | $\begin{aligned} & V_{C C}=4 \mathrm{~V}, C K I=V_{C C}, V_{\text {OUT }}=V_{C C} \\ & V_{C C}=4 V, C K I=0 V, V_{\text {OUT }}=0 V \end{aligned}$ | $\begin{aligned} & 0.44 \\ & 0.88 \\ & 0.44 \\ & 0.88 \end{aligned}$ |  | mA <br> mA <br> mA <br> mA |
| Allowable Loading on CKO (as HALT) |  |  | 100 | pF |
| Current Needed to Over-Ride HALT <br> (Note 3) <br> To Continue <br> To Halt | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0.3 \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}=4 \mathrm{~V}, \mathrm{~V}_{I N}=0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |  | $\begin{aligned} & 0.7 \\ & 1.6 \end{aligned}$ | $\frac{\mathrm{mA}}{\mathrm{~mA}}$ |
| TRI-STATE or Open Drain Leakage Open-Drain Leakage | $\begin{aligned} & O V \leq V_{\text {OUT }} \leq V_{\text {CC }} \\ & V_{\text {OUT }}=12 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -2.5 \\ & -15 \end{aligned}$ | $\begin{aligned} & +2.5 \\ & +15 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Total Sink Current Allowed All Outputs Combined D, G Ports D or G per pin All Other Pins |  |  | $\begin{gathered} 60 \\ 60 \\ 20 \\ 5 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA |
| Total Source Current Allowed All I/O Combined Each Pin |  |  | $\begin{gathered} 48 \\ 5 \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{mA} \\ \mathrm{~mA} \end{gathered}$ |

## COP427C/COP428C/COP429C and COP447C/COP448C/COP449C COP327C/COP328C/COP329C and COP347C/COP348C/COP349C

## Electrical Characteristics

$0^{\circ} \mathrm{C} \leq T_{A} \leq+70^{\circ} \mathrm{C}$ for COP400 Series, unless otherwise specified, $-40^{\circ} \mathrm{C} \leq T_{A} \leq 85^{\circ} \mathrm{C}$ for COP300 Series (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle | $V_{C C} \geq 4 \mathrm{~V}$ | 2.0 | DC | $\mu \mathrm{s}$ |
| Time (tc) | $2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V}$ | 8.0 | DC | $\mu \mathrm{S}$ |
| Operating CKI Frequency | $\begin{aligned} & \div 4, \mathrm{~V} \mathrm{CC} \geq 4 \mathrm{~V} \\ & \div 8, \mathrm{VCC} \geq 4 \mathrm{~V} \\ & \div 16, \mathrm{VCC} \geq 4 \mathrm{~V} \\ & \div 32, \mathrm{~V}_{\mathrm{CC}} \geq 4 \mathrm{~V} \\ & \text { Crystal } \div 16, \mathrm{~V}_{\mathrm{CC}} \geq 4 \mathrm{~V} \\ & \text { Crystal } \div 32, \mathrm{~V}_{\mathrm{CC}}>4 \mathrm{~V} \\ & \div 4,2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V} \\ & \div 8,2.4 \mathrm{~V} \leq \mathrm{V}<\mathrm{VC} \\ & \div 16,2.4 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V} \\ & \div 32,2.4 \mathrm{~V} \leq \mathrm{V} \mathrm{CC} \end{aligned}$ | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \hline \end{aligned}$ | $\begin{aligned} & 2.0 \\ & 4.0 \\ & 8.0 \\ & 8.0 \\ & 4.0 \\ & 4.0 \\ & 0.5 \\ & 1.0 \\ & 2.0 \\ & 2.0 \\ & 1.0 \\ & 1.0 \end{aligned}$ | MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHz |
| Duty Cycle (Note 4) | $\mathrm{F} 1=8 \mathrm{MHz}$ | 40 | 60 | \% |
| Rise Time (Note 4) | $\mathrm{F} 1 \doteq 8 \mathrm{MHz}$ |  | 15 | ns |
| Fall Time (Note 4) | $\mathrm{F} 1=8 \mathrm{MHz}$ |  | 10 | ns |
| Instruction Cycle Time RC Oscillator (Note 4) | $\begin{aligned} & \mathrm{R}=15 \mathrm{~K} \Omega, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}=82 \mathrm{pF}(\div 4 \text { mode }) \end{aligned}$ | 4 | 8 | $\mu \mathrm{S}$ |
| Inputs (See Figure 3) TSETUP | G Inputs, $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ <br> SI Input, $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ <br> All others, $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ | $\begin{gathered} \mathrm{tc} / 4+0.35 \\ 0.15 \\ 0.85 \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~S} \end{aligned}$ |
| THOLD | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V} \\ & 4 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 2.4 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 0.2 \\ & 0.5 \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Output Propagation Delay TPD1, $T_{P D O}$ TPD1, $\mathrm{T}_{\text {PD }}$ | $\begin{aligned} & V_{O U T}=1.5 \mathrm{~V}, \mathrm{CL}=100 \mathrm{pF}, R_{\mathrm{L}}=5 \mathrm{~K} \\ & V_{C C}=4 \mathrm{~V} \\ & 4 \mathrm{~V}>V_{C C}>=2.4 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} 600 \\ 2.0 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \end{aligned}$ |
| MICROBUS Timing | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ |  |  |  |
| Read Operation (Figure 4) <br> Chip Select Stable before RD - t CSR <br> Chip Select Hold Time for RD - $\mathrm{t}_{\mathrm{CS}}$ R <br> RD Pulse Width - trR <br> Data Delay from RD - $\mathrm{t}_{\mathrm{RD}}$ <br> RD to Data Floating - $t_{D F}$ (Note 4) |  | $\begin{gathered} 65 \\ 20 \\ 400 \end{gathered}$ | $\begin{aligned} & 375 \\ & 250 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |
| Write Operation (Figure 5) <br> Chip Select Stable before WR - $\mathrm{t}_{\mathrm{CSW}}$ <br> Chip Select Hold Time for WR - twCS <br> WR Pulse Width - tww <br> Data Setup Time for WR - $t_{D W}$ <br> Data Hold Time for WR - twD <br> INTR Transition Time from WR $-t_{\text {W1 }}$ |  | $\begin{gathered} 65 \\ 20 \\ 400 \\ 320 \\ 100 \end{gathered}$ | 700 | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |

Note 1: Supply current is measured after running 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled to $\mathrm{V}_{\text {CC }}$ with 20 K resistors. See current drain equation, see power dissipation.
Note 2: The HALT mode will stop CKI from oscillating in the RC and crystal configurations. Test conditions: all inputs tied to $V_{C C}$, L lines in TRI-STATE mode and tied to ground, all outputs low and tied to ground.

Note 3: When forcing HALT, current is only needed for a short time (approx. 200 ns ) to flip the HALT flip-flop.
Note 4: This parameter is only sampled and not $100 \%$ tested.
Note 5: Voltage change must be less than 0.5 volts in a 1 ms period.
Note 6: SO output sink curent must be limited to keep $\mathrm{V}_{\mathrm{OL}}$ less than $0.3 \mathrm{~V}_{\mathrm{CC}}$ when part is running in order to prevent entering test mode.
Note 7: If CKI is crystal divide by 16 option, maximum CKI frequency is $4 \mathrm{MHz}, \mathrm{t}_{\mathrm{C}}=4 \mu \mathrm{~s}$ for $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ and $1 \mathrm{MHz}, \mathrm{t}_{\mathrm{C}}=16 \mu \mathrm{~s}$ for $2.4 \mathrm{~V} \leq \mathrm{V}$ CC $<4 \mathrm{~V}$. If CKI is crystal $\div 32$ option, maximum CKI frequency is $4 \mathrm{MHz}, \mathrm{t}_{\mathrm{c}}=8 \mu \mathrm{~s}$ for $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ and $1 \mathrm{MHz}, \mathrm{t}_{\mathrm{c}}=32 \mu \mathrm{~s}$ for $2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V}$.
Note 8: I/O pin voltage held above $V_{C c}$ or below GND (e.g., $+2 \mathrm{~V} /-2 \mathrm{~V}$ with $+200 \mathrm{~mA} /-200 \mathrm{~mA}$, or $+20 \mathrm{~V} /-20 \mathrm{~V}$ with $+20 \mathrm{~mA} /-20 \mathrm{~mA}$ ).
Note 9: Human Body Model, 100 pF through $1.5 \mathrm{k} \Omega$.

## COP227C/COP228C/COP229C and COP247C/COP248C/COP249C

## Absolute Maximum Ratings

Speclfications for Military/Aerospace products are not contained in thls datasheet. Refer to the assoclated reliability electrical test specifications document.

| Supply Voltage (VCC) | -0.3 V to 7 V |
| :--- | ---: |
| Latch-Up Susceptibility (Note 8) | 400 mW |
| ESD Susceptibility (Note 9) | 3500 V |
| Maximum Voltage at Pin (Hi-Z Inputs <br> $\quad$ and Open Drain Outputs) | 14 V |


| Total Allowable Sink Current | 60 mA |
| :--- | ---: |
| Total Allowable Source Current | 48 mA |
| Allowable Source Current Per Pin | 5 mA |
| Power Dissipation $\left(T=125^{\circ} \mathrm{C} \mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V}\right)$ | 500 mW |
| Operating Temperature Range | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (soldering, 10 sec.) | $300^{\circ} \mathrm{C}$ |

DC Electrical Characteristics $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage <br> Power Supply Ripple (Note 5) | Peak to Peak | 2.4 | $\begin{gathered} 6.0 \\ 0.1 \mathrm{~V}_{\mathrm{CC}} \\ \hline \end{gathered}$ | $\begin{aligned} & v \\ & v \end{aligned}$ |
| Supply Current (Notes 1, 7) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{tc}=5.0 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 32 \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{tc}=2.5 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 16 \\ & \mathrm{~V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{tc}=2.5 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 4 \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{tc}=20.0 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 32 \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{tc}=10.0 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 16 \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{tc}=10.0 \mu \mathrm{~s}, \mathrm{SK}=\mathrm{CKI} / 4 \end{aligned}$ |  | $\begin{array}{r} 9.5 \\ 9.5 \\ 2.4 \\ 1.2 \\ 1.2 \\ 330 \end{array}$ | mA <br> mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ |
| HALT Mode Current (Note 2) | $\begin{aligned} & V_{C C}=6.0 \mathrm{~V} \\ & V_{C C}=3.0 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 25 \\ & 12 \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| Input Voltage Levels <br> RESETp, CKI, <br> $\mathrm{D}_{\mathrm{O}}$ (clock input) <br> Logic High <br> Logic Low <br> All Other Inputs <br> Logic High <br> Logic Low <br> G-Port <br> Logic High <br> Logic Low <br> IN1, IN2 as <br> Comparator Inputs Common-mode Voltage Input Offset Voltage | Optional SCHMITT Trigger | $0.8 V_{C C}$ <br> $0.7 V_{C C}$ <br> $0.8 V_{C C}$ <br> 0 <br> 100 | $\begin{aligned} & 0.2 V_{C C} \\ & 0.3 V_{C C} \\ & 0.2 V_{C C} \\ & V_{C C}-1.5 \end{aligned}$ | V <br> V <br> V <br> V <br> V <br> V <br> mV |
| Input Pull-up <br> Current (Optional) | $V_{C C}=4 \mathrm{~V}, \mathrm{~V}_{\mathbb{N}}=0 \mathrm{~V}$ | 15 | 200 | $\mu \mathrm{A}$ |
| Hi-Z Input Leakage | $\begin{aligned} & V_{\mathbb{I N}}=V_{C C} \\ & V_{I N}=12 V \end{aligned}$ | $\begin{array}{r} -10 \\ -50 \\ \hline \end{array}$ | $\begin{array}{r} +10 \\ +50 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Input Capacitance (Note 4) |  |  | 7 | pF |
| Output Voltage Levels LSTTL Operation Logic High Logic Low CMOS Operation Logic High Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.0 \mathrm{~V} \text { to } 6.0 \\ & \mathrm{I}_{\mathrm{OH}}=-450 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=550 \mu \mathrm{~A} \\ & 2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.0 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=-40 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=150 \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $V_{C C}-0.2$ | $\begin{aligned} & 0.4 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & V \\ & v \end{aligned}$ |

## COP227C/COP228C/COP229C and COP247C/COP248C/COP249C

DC Electrical Characteristics $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ unless otherwise specified (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels (except CKO) <br> Sink (Note 6) <br> High Current Option <br> Source <br> Low Current Option | $\begin{aligned} & V_{C C}=4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=2.0 \mathrm{~V} \\ & V_{\mathrm{CC}}=4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=2.7 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=2.2 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 12.0 \\ 45 \\ 4 \\ \hline \end{gathered}$ | $\begin{gathered} 325 \\ 35 \end{gathered}$ | mA <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| CKO Current Levels  <br> (As Clock Out)  <br> Sink $\div 4$ <br>  All <br>  Others <br> Source $\div 4$ <br>  All <br>  Others | $V_{C C}=4 \mathrm{~V}, \mathrm{CKI}=\mathrm{V}_{\mathrm{CC}}, \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ $V_{C C}=4 \mathrm{~V}, \mathrm{CKI}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=0 \mathrm{~V}$ | $\begin{aligned} & 0.3 \\ & 0.7 \\ & \\ & 0.3 \\ & 0.7 \end{aligned}$ |  | mA <br> mA <br> mA <br> mA |
| Allowable Loading on CKO (as HALT) |  |  | 50 | pF |
| Current Needed to <br> Over-Ride HALT <br> (Note 3) <br> To Continue <br> To Halt | $\begin{aligned} & V_{C C}=4 \mathrm{~V}, V_{I N}=0.3 V_{C C} \\ & V_{C C}=4 \mathrm{~V}, V_{I N}=0.7 V_{C C} \end{aligned}$ |  | $\begin{aligned} & 2.0 \\ & 3.0 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| TRI-STATE or <br> Open Drain Leakage <br> Open-drain Leakage <br> Total Sink Current Allowed <br> All Outputs Combined <br> D, G Ports <br> D or G per Pin <br> All Other Pins | $\begin{aligned} & 0 V \leq V_{\text {OUT }} \leq V_{\text {CC }} \\ & V_{\text {OUT }}=12 V \end{aligned}$ | $\begin{aligned} & -10 \\ & -50 \end{aligned}$ | $\begin{array}{r} +10 \\ +50 \\ \\ 60 \\ 60 \\ 20 \\ 5 \\ \hline \end{array}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA <br> mA |
| Total Source Current Allowed All I/O Combined Each Pin |  |  | $\begin{gathered} 48 \\ 5 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |

## COP227C/COP228C/COP229C and COP247C/COP248C/COP249C

## Electrical Characteristics $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 125^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle | $V_{C C} \geq 4 V$ | 2.5 | DC | $\mu \mathrm{S}$ |
| Time (tc) | $2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V}$ | 10.0 | DC | $\mu \mathrm{S}$ |
| Operating CKI Frequency | $\begin{aligned} & \div 4, \mathrm{~V}_{\mathrm{CC}} \geq 4 \mathrm{~V} \\ & \div 8, \mathrm{~V}_{\mathrm{CC}} \geq 4 \mathrm{~V} \\ & \div 16, \mathrm{~V}_{\mathrm{CC}} \geq 4 \mathrm{~V} \\ & \text { Crystal } \div 16, \mathrm{~V}_{\mathrm{CC}} \geq 4 \mathrm{~V} \\ & \\ & \div 4,2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V} \\ & \div 8,2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V} \\ & \div 16,2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V} \\ & \text { Crystal } \div 16,2.4 \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V} \\ & \hline \end{aligned}$ | DC <br> DC <br> DC <br> DC <br> DC <br> DC <br> DC <br> DC | $\begin{aligned} & 1.6 \\ & 3.2 \\ & 6.4 \\ & 3.2 \\ & \\ & 0.4 \\ & 0.8 \\ & 1.6 \\ & 0.8 \\ & \hline \end{aligned}$ | MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHz <br> MHZ <br> MHz |
| Duty Cycle (Note 4) | $\mathrm{F} 1=6.4 \mathrm{MHz}$ | 40 | 60 | \% |
| Rise Time ( Note 4) | $\mathrm{F} 1=6.4 \mathrm{MHZ}$ |  | 15 | ns |
| Fall Time (Note 4) | $\mathrm{F} 1=6.4 \mathrm{MHZ}$ |  | 10 | ns |
| Instruction Cycle Time RC Oscillator (Note 4) | $\begin{aligned} & \mathrm{R}=15 \mathrm{~K} \Omega, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}=82 \mathrm{pF}(\div 4 \text { mode }) \\ & \hline \end{aligned}$ | 4 | 8 | $\mu \mathrm{S}$ |
| Inputs (See Figure 3) tsetup | G Inputs, $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ <br> SI Input, $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ <br> All Others, $\mathrm{V}_{\mathrm{CC}} \leq 4 \mathrm{~V}$ | $\begin{gathered} \mathrm{tc} / 4+0.4 \\ 0.18 \\ 0.95 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~S} \\ & \hline \end{aligned}$ |
| Thold | $\begin{aligned} & V_{C C}>4 V \\ & 4 V>V_{C C} \geq 2.4 V \end{aligned}$ | $\begin{aligned} & 0.25 \\ & 0.75 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~S} \end{aligned}$ |
| Output Propagation Delay <br> TPD1, $\mathrm{T}_{\text {PDO }}$ <br> TPD1, $T_{P D 0}$ | $\begin{aligned} & V_{\text {OUT }}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=5 \mathrm{~K} \\ & \mathrm{~V}_{\mathrm{CC}} \geq 4 \mathrm{~V} \\ & 4 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 2.4 \mathrm{~V} \end{aligned}$ | 2.5 | 750 | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| MICROBUS Timing | $C_{L}=50 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ |  |  |  |
| Read Operation (Figure 4) <br> Chip Select before RD - $\mathrm{t}_{\mathrm{CSR}}$ <br> Chip Select Hold Time for RD - $t_{C S R}$ <br> RD Pulse Width - $t_{\text {RR }}$ <br> Data Delay from RD - $t_{\text {RD }}$ <br> RD to Data Floating - $t_{D F}$ (Note 4) |  | $\begin{array}{r} 80 \\ 25 \\ 500 \end{array}$ | $\begin{aligned} & 470 \\ & 310 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |
| Write Operation (Figure 5) <br> Chip Select Stable before WR - $\mathrm{t}_{\mathrm{CSW}}$ <br> Chip Select Hold Time for WR - twCs <br> WR Pulse Width - ${ }^{\text {W }}$ WW <br> Data Set-up Time for WR - tow <br> Data Hold Time for WR - $t_{\text {WD }}$ <br> INTR Transition Time from WR - twi |  | $\begin{gathered} 80 \\ 25 \\ 500 \\ 400 \\ 125 \end{gathered}$ | 875 |  |

[^3]
## Connection Diagrams

Dual-In-Line Package


Top View

## Dual-In-Line Package

| $\begin{aligned} & \mathrm{CND}-1 \\ & \mathrm{CKO}-2 \\ & \mathrm{CKI}-3 \end{aligned}$ |  | Pln | Description |
| :---: | :---: | :---: | :---: |
|  | 28-D0 | L7.LO | 8-bit bidirectional port |
|  | 27-D1 |  | with TRI-STATE |
|  | 26-02 | G3-G0 | 4-bit bidirectional I/O port |
| $\overline{\text { RESET }}$-4 | 25-03 | D3-D0 | 4-bit output port |
| L7-5 | 24-G3 | IN3-INO | 4-bit input port (28 pin |
| L6-6 | COP427C 23-G2 |  | package only) |
| L5-7 | COP327C  <br> COP227C $22-G 1$ | SI | Serial input or counter |
| L4-8 | $\begin{array}{ll}\text { COP447C } & 21-60\end{array}$ |  |  |
| $-9$ |  | SO | Serial or general purpose output |
| in2-10 | $19-\mathrm{NO}$ | SK | Logic controlled clock |
| $\mathrm{V}_{\text {c }}-11$ | 18 -Sk |  | output |
| L3-12 | 17-50 | CKI | Chip oscillator input |
| L2-13 | $16-51$ | CKO | Oscillator output, HALT |
| -14 | 15 -L0 |  | I/O port or general |
|  |  |  | purpose input |
|  | TL/DD/9129-4 | RESET | Reset input |
| Top View |  | $V_{C C}$ | Most positive power supply |
|  |  | GND | Ground |

FIGURE 2

## Functional Description

The internal architecture is shown in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 ", when a bit is reset, it is a logic "0".
For ease of reading only the COP427C/428C/429C and COP447C/448C are referenced; however, all such references apply equally to COP327C/328C/329C/347C/348C and COP227C/228C/229C and COP247C/248C.

## PROGRAM MEMORY

Program Memory consists of ROM, 1024 bytes for the COP427C/428C/429C and 2048 bytes for the COP447C/ 448C. These bytes of ROM may be program instructions, constants or ROM addressing data.
ROM addressing is accomplished by a 11 -bit PC register which selects one of the 8 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 11-bit binary count value.
Three levels of subroutine nesting are implemented by a three level deep stack. Each subroutine call or interrupt pushes the next PC address into the stack. Each return pops the stack back into the PC register.

## DATA MEMORY

Data memory consists of a 512-bit RAM for the COP447C/ 448 C , organized as 8 data registers of $16 \times 4$-bit digits. RAM addressing is implemented by a 7 -bit B register whose upper 3 bits ( Br ) select 1 of 8 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. Data memory consists of a 256 -bit RAM for the COP427C/ $428 \mathrm{C} / 429 \mathrm{C}$, organized as 4 data registers of $16 \times 4$-bits digits. The B register is 6 bits long. Upper 2 bits ( Br ) select 1 of 4 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4-bit contents of the selected RAM digit (M) are usually loaded into or from, or exchanged with, the A register (accumulator), it
may also be loaded into or from the $Q$ latches or $T$ counter or loaded from the L ports. RAM addressing may also be performed directly by the LDD and XAD instructions based upon the immediate operand field of these instructions.
The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The processor contains its own 4-bit A register (accumulator) which is the source and destination register for most I/O, arithmetic, logic, and data memory access operations. It can also be used to load the Br and Bd portions of the B register, to load and input 4 bits of the 8 -bit $Q$ latch or $T$ counter, to input 4 bits of L. I/O ports data, to input 4-bit G, or IN ports, and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions, storing the results in A. It also outputs a carry bit to the 1-bit $C$ register, most often employed to indicate arithmetic overflow. The C register in conjunction with the XAS instruction and the EN register, also serves to control the SK output.
The 8 -bit T counter is a binary up counter which can be loaded to and from M and A using CAMT and CTMA instructions. This counter may be operated in two modes depending on a mask-programmable option: as a timer or as an external event counter. When the T counter overflows, an overflow flag will be set (see SKT and IT instructions below). The $T$ counter is cleared on reset. A functional block diagram of the timer/counter is illustrated in Figure 10a.
Note: If desired, the user may mask program the $T$ counter clock source to be permanently external event counter or internally clocked timer. Also, a mask program option is provided to select the $T$ counter to be cleared on chip RESET, or not to be cleared on chip RESET.
The D register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd. In the dual clock mode, DO latch controls the clock selection (see dual oscillator below). On the COP429HC or COP449C (20-pin), D2 may be mask programmed as either dual clock input, IN1 input (for interrupt capability) or as IN2 input (for external event counter). On the COP428C or COP448C

## Functional Description (Continued)

(24-pin), D2 may be mask programmed as either IN1 input or IN2 input NOTE: If D2 is optioned as IN1 or IN2, the comparator is not functional.
The G register contents are outputs to a 4-bit general-purpose bidirectional I/O port. GO may be mask-programmed as an output for Microbus applications. G port inputs can be mask programmed as standard trip or Schmitt trigger inputs. Both the D-port and G-port outputs may be mask programmed with either LSTTL or high sink lol capability (See D.C. Characteristics).

The Q register is an internal, latched, 8 -bit register, used to hold data loaded to or from M and A , as well as 8 -bit data from 'ROM. Its contents are outputted to the L I/O ports when the $L$ drivers are enabled under program control. With the Microbus option selected, Q can also be loaded with the 8 -bit contents of the LI/O ports upon the occurrence of a write strobe from the host CPU.
The 8 L drivers, when enabled, output the contents of latched Q data to the L I/O port. Also, the contents of L may be read directly into $A$ and $M$. As explained above, the Microbus option allows L I/O port data to be latched into the Q register.
The SIO register functions as a 4-bit serial-in/serial-out shift regișter for MICROWIRE I/O and COPS peripherals, or as a binary counter (depending on the contents of the EN register). Its contents can be exchanged with A.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the clock.

An analog comparator has been provided. IN1 feeds directly to the plus ( + ) side of the comparator and IN2 is the input of the minus ( - ) side. The comparator output is latched and the output state can be loaded into the A register by using the INIL instruction. Also, comparator transitions can cause interrupts under program control. Comparator transitions must be at least two instruction cycles wide to be recognized.
EN is an internal 8-bit register loaded by two instructions. LEI loads the lower four bits (EN3-ENO), and LUEI loads the upper four bits (EN7-EN4). The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register.
0 . The least significant bit of the enable register, ENO, selects the SIO register as either a 4-bit shift register or a 4-bit binary counter. With ENO set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output equals the value of EN3. With ENO reset, SIO is a serial shift register left shifting 1 bit each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. The SK outputs SKL ANDed with the instruction cycle clock.

1. With EN1 set, external interrupts or comparator transition are enabled. Immediately following an interrupt or comparator transition interrupt, EN1 is reset to disable further external or comparator transition interrupts.


TL/DD/9129-5
FIGURE 3. Input/Output TIming Diagrams (divide by 8 mode)


TL/DD/9129-6
FIGURE 4. Microbus Read Operation Timing


TL/DD/9129-7
FIGURE 5. Microbus Write Operation Timing

## Functional Description (Continued)

2. With EN2 set, the L drivers are enabled to output the data in the $Q$ latch to the LI/O port. Resetting EN2 disables the $L$ drivers, placing the L I/O port in a high-impedance input state.
3. EN3, in conjunction with ENO, affects the SO output. With ENO set (binary counter option selected) SO will output the value loaded into EN3. With ENO reset (serial shift register option selected), setting EN3 enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting EN3 with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with $A$ via an XAS instruction but SO remains set to " 0 ".
4. As stated above, the $T$ counter clock source can be selected under program control. This is accomplished with EN4. With EN4 set, the T counter operates as an external event counter, clocked by IN2. When EN4 is reset, the T counter operates as a timer, being clocked at the instruction rate with a two bit prescaler.
NOTE: The IT instruction is not allowed when EN4 is set.
5. EN5 controls the access of the comparator latch. When EN5 is set, the comparator is enabled, and the state of the comparator output can be read by the INIL instruction. Also, with EN5 set, an ININ instruction will read 'ones' on the IN1 and IN2 inputs. With EN5 set, the external interrupt source is on comparator transitions. When EN5 is reset, the comparator is disabled (to eliminate any DC current), an INIL will load a 'zero' into bit one of A, and the external interrupt source is on IN1. CAUTION: If the programmer wishes to detect a comparator difference by using interrupts then EN5 should be set before EN1 to avoid false interrupts. Also, EN5 should be reset before going into halt mode to avoid approximately 5 microamps of $D C$ current due to the comparator being enabled.
6. With EN6 set, a T counter overflow will cause an internal interrupt. When EN6 is reset, T counter overflows will not cause an interrupt. If EN6 is set, a timer overflow interrupt will cause EN6 to be reset. The T counter source may also be mask programmed.
7. EN7 is the T counter start/stop enable bit. When EN7 is set, the T counter is disabled from counting. When EN7 is reset, the $T$ counter counts up in binary.

## INTERRUPTS

The following features are associated with interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
A. The interrupt, once recognized as explained below, pushes the next sequential program counter address (PC+1) onto the stack. Any previous contents at the bottom of the stack are lost. The program counter is set to hex address OFF (the last word of page 3) and both EN1 and EN6 are reset.
B. An interrupt will be recognized only on the following conditions:

1. EN1 has been set in anticipation of external interrupts or EN6 has been set for an internal timer overflow interrupt.
2. With EN1 set and EN5 reset, a low going pulse ('1' to ' 0 ') at least two instruction cycles wide on the IN1 input will cause an interrupt.
3. With EN1 set and EN5 set, a transition on the comparator output that is at least two instruction cycles wide will cause an interrupt.
4. With EN6 set, a T counter overflow will cause an interrupt.
5. All currently executing instructions must be completed.
6. All successive transfer of control instructions and successive LBIs must be completed (e.g., if the main program is executing a JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed).
C. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example, if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at hex address OFF. At the end of the interrupt routine, a RET instruction is executed to pop the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines should not be nested within the interrupt service routine, since their popping of the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
D. The instruction at hex address OFF must be a NOP.
E. An LEI or LUEI instruction may be put immediately before the RET instruction to re-enable interrupts. NOTE: EN1 and EN6 may be set together at the same point in time to await both internal and external interrupts. If both are set and an interrupt occurs, then the SKT latch must be checked to see if it was the $T$ counter that overflowed. If both interrupts occur on the same cycle, there is no priority, other than the T-counter will be serviced first if SKT is checked in the interrupt service routine.

## MICROBUS INTERFACE

The COP447C/427C has an option which allows it to be used as a peripheral microprocessor device, inputting and outputting data from and to a host microprocessor ( $\mu \mathrm{P}$ ). IN1, IN2 and IN3 general purpose inputs become Microbus compatible read-strobe, chip-select, and write-strobe lines, respectively. IN1 becomes $\overline{\mathrm{RD}}$ - a logic " 0 " on this input will cause $Q$ latch data to be enabled to the $L$ ports for input to the $\mu \mathrm{P}$. IN2 becomes $\overline{\mathrm{CS}}$ - a logic " 0 " on this line selects the COP $447 \mathrm{C} / 427 \mathrm{C}$ as the $\mu \mathrm{P}$ peripheral device by enabling the operation of the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ lines and allows for the selection of one of several peripheral components. IN3 becomes $\overline{W R}$ - a logic " 0 " on this line will write bus data from the $L$ ports to the $Q$ latches for input to the COP447C/427C. G0 becomes INTR a "ready" output, reset by a write pulse from the $\mu \mathrm{P}$ on the $\overline{\mathrm{WR}}$ line, providing the "handshaking" capability necessary for asynchronous data transfer between the host CPU and the COP447C/427C.
This option has been designed for compatibility with National's Microbus - a standard interconnect system for 8-bit parallel data transfer between MOS/LSI CPUs and interfacing devices. (See Microbus National Publication.) The functioning and timing relationships between the signal lines affected by this option are as specified for the Microbus interface, and are given in the AC electrical characteristics and shown in the timing diagrams (Figures 4 and 5). Connection of the COP447C/427C to the Microbus is shown in Figure 6.

Functional Description (Continued)
TABLE I. Enable Register Modes Bits EN5, EN4 and EN1

| EN1 | EN5 | EN4 | IN1 | IN2 | INIL <br> Bit 1 | Interrupts |
| :---: | :---: | :---: | :--- | :--- | :---: | :---: |
| 0 | 0 | 0 | STD Input | STD Input | 0 | None |
| 0 | 0 | 1 | STD Input | EXT CNTR | 0 | None |
| 0 | 1 | 0 | + of COMPAR | - of COMPAR | CMP | None |
| 1 | 0 | 0 | EXT INTERRUPT | STD Input | 0 | EXT IN1 |
| 1 | 1 | 0 | + of COMPAR | - of COMPAR | CMP | + or - CMP Edge |
| 1 | 0 | 1 | EXT INTERRUPT | EXT CNTR | 0 | EXTIN1 |
| 0 | 1 | 1 | Not Allowed |  |  |  |
| 1 | 1 | 1 | Not Allowed |  |  |  |



TL/DD/9129-8
FIGURE 6. Microbus Optlon Interconnect

## INITIALIZATION

The internal reset logic will initialize the device upon powerup if the power supply rise time is less than 1 ms and if the operating frequency at CKI is greater than 32 kHz , otherwise the external RC network shown in Figure 7 must be connected to the RESET pin (the conditions in Figure 7 must be met). The RESET pin is configured as a Schmitt trigger input. If not used, it should be connected to $\mathrm{V}_{\mathrm{CC}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, providing it stays low for at least three instruction cycle times.
Note: If CKI clock is less than 32 kHz , the internal reset logic (option * $29=1$ ) MUST be disabled and the external RC circuit must be used.


Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the A, B, C, D, EN, IL, T and G registers are cleared. The SKL latch is set, thus enabling SK as a clock output. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA (clear A register).

## TIMER

There are two modes selected by mask option:
a. Time-base counter. In this mode, the instruction cycle frequency generated from CKI passes through a 2-bit divide-by-4 prescaler. The output of this prescaler increments the 8 -bit T counter thus providing a 10 -bit timer. The prescaler is cleared during execution of a CAMT instruction and on reset.
For example, using a 4 MHz crystal with a divide-by- 16 option, the instruction cycle frequency of 250 kHz increments the 10 -bit timer every $4 \mu \mathrm{~s}$. By presetting the counter and detecting overflow, accurate timeouts between $16 \mu \mathrm{~s}$ ( 4 counts) and 4.096 ms ( 1024 counts) are possible. Longer timeouts can be achieved by accumulating, under software control, multiple overflows.
b. External event counter. In this mode, a low-going pulse ("1" to " 0 ") at least 2 instruction cycles wide on the IN2 input will increment the 8 -bit T counter.
Note: The IT instruction is not allowed in this mode.

## HALT MODE

The COP $447 \mathrm{C} / 448 \mathrm{C} / 449 \mathrm{C} / 427 \mathrm{C} / 428 \mathrm{C} / 429 \mathrm{C}$ is a FULLY STATIC circuit; therefore, the user may stop the system oscillator at any time to halt the chip. The chip may also be halted by the HALT instruction or by forcing CKO high when it is mask-programmed as an HALT I/O port. Once in the HALT mode, the internal circuitry does not receive any clock signal and is therefore frozen in the exact state it was in when halted. All information is retained until continuing. The chip may be awakened by one of two different methods:

- Continue function: by forcing CKO low, if it mask-programmed as an HALT I/O port, the system clock is reenabled and the circuit continues to operate from the point where it was stopped.
- Wake up from HALT: Any combination of the L port lines can be mask programmed as wake up pins (this is for crystal oscillator or CKO general purpose input options, where CKO cannot be the HALT I/O port). Before going into HALT mode, user must guarantee that the L lines are held high, i.e., write ones to the $Q$ latch and enable the $L$ line drivers, or leave the $L$ port in TRI-STATE mode and provide external loads to hold logic 'ones'. Then, after going into halt mode, the internal clocks can 'wake up' by forcing any one of the mask programmed $L$ l lines low. (See characteristic curves to determine how much current is needed to override L line loh.) NOTE: L-port output source current can be different. . see options.
- Restart: by forcing the $\overline{\text { RESET }}$ pin low (see Initialization).


## Functional Description (Continued)



TL/DD/9129-10

| Crystal <br> Value | Component Values |  |  |  |
| :---: | ---: | :---: | :---: | :---: |
|  | R1 | R2 | C1(pF) | C2(pF) |
| 32 kHz | 220 k | 20 M | 30 | $6-36$ |
| 455 kHz | 5 k | 10 M | 80 | 40 |
| 2.096 MHz | 2 k | 1 M | 30 | $6-36$ |
| 4.0 MHz | 1 k | 1 M | 30 | $6-36$ |

RC Controlled Oscillator

| $\mathbf{R}$ | C | Cycle <br> Time | VCC |
| :---: | :---: | :---: | :---: |
| 15 k | 82 pF | $4-9 \mu \mathrm{~s}$ | $\geq 4.5 \mathrm{~V}$ |
| 30 k | 82 pF | $8-16 \mu \mathrm{~s}$ | $\geq 4.5 \mathrm{~V}$ |
| 60 k | 100 pF | $16-32 \mu \mathrm{~s}$ | $2.4-4.5 \mathrm{~V}$ |

Note: $15 k \leq R \leq 150 k$
$50 \mathrm{pF} \leq \mathrm{C} \leq 150 \mathrm{pF}$

FIGURE 8. Oscillator Component Values

The HALT mode is the minimum power dissipation state.
Note: If the user has selected dual-clock with DO as external oscillator (option $30=2$ ) AND the COP447C/427C is running with the DO clock, the HALT mode - either hardware or software - will NOT be entered. Thus, the user should switch to the CKI clock to HALT. AIternatively, the user may stop the DO clock to minimize power.

## CKO PIN OPTIONS

a. Two-pin oscillator - (Crystal). See Figure 9A.

In a crystal controlled oscillator system, CKO is used as an output to the crystal network. The HALT mode may be entered by program control (HALT instruction) which forces CKO high, thus inhibiting the crystal network. The circuit can be awakened only by forcing the $\overline{\text { RESET }}$ pin to a logic "0" (restart).
b. One-pin oscillator - (RC or external). See Figure 9B.

If a one-pin oscillator system is chosen, two options are available for CKO:

- CKO can be selected as the HALT I/O port. In that case, it is an I/O flip-flop which is an indicator of the HALT status. An external signal can over-ride this pin to start and stop the chip. By forcing a high level to CKO, the chip will stop as soon as CKI is high and CKO output will stay high to keep the chip stopped if the external driver returns to high impedance state. By forcing a low level to CKO, the chip will continue and CKO will stay low.
- As another option, CKO can be a general purpose input, read into bit 2 of $A$ (accumulator) upon execution of an INiL instruction.


## OSCILLATOR OPTIONS

There are four basic clock oscillator configurations available as shown by Figure 8.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency optionally divided by 4,8 or 16.
b. External Oscillator. The external frequency is optionally divided by 4, 8 or 16 to give the instruction cycle time. CKO is the HALT I/O port or a general purpose input.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4 . CKO is the HALT I/O port or a general purpose input.
d. Dual oscillator. By selecting the dual clock option, pin D0 is now a single pin oscillator input. Two configurations are available: RC controlled Schmitt trigger oscillator or external oscillator.

The user may software select between the D0 oscillator (in that case, the instruction cycle time equals the DO oscillation frequency divided by 4) by setting the DO latch high or the CKI (CKO) oscillator by resetting DO latch low. Note that even in dual clock mode, the counter, if maskprogrammed as a time-base counter, is always connected to the CKI oscillator. If D2 is selected as the DO dual clock function for a 20 pin part, the DO latch controls the clock selection.
For example, the user may connect up to a 2 MHz RC circuit to DO for faster processing and a 32 kHz watch crystal to CKI and CKO for minimum current drain and time keeping.
Note: CTMA instruction is not allowed when chip is running from DO clock.

## Functional Description (Continued)

Figures 10 A and 108 show the clock and timer diagrams with and without Dual clock.

## MALFUNCTION DETECTOR

With a mask option, the user can invoke circuitry which will detect loss of program control. When selected the $G_{3}$ pin is configured as a RESET pin. A high level, VIHMD, on $G_{3}$ will reset the chip. The malfunction detector uses an external RC network connected to the $G_{3}$ pin which pulls $G_{3}$ toward $\mathrm{V}_{\mathrm{CC}}$. Under program control, using the OMG or OGI instruction, the $\mathrm{G}_{3}$ driver will discharge the external RC network. Failure to write a zero to $G_{3}$, loss of program control, will cause the chip to reset itself when the external RC network charges $G_{3}$ to a Logic 1, VIHMD. In this mode the $G_{3}$ latch is configured such that when a zero is written to $G_{3}$ the pin will force a zero until the external RC network is discharged to the VOLMD level, then continue to force a zero for one instruction cycle, then the latch will set and the pad will begin to charge toward $V_{C C}$. This latch configuration allows the use of a large external capacitor and eliminates the need to write a zero followed by a one to the $G_{3}$ pin. The $G_{3}$ driver may optionally be configured with an on-board pull-up enabled so that the only external component required is a capacitor. Sink and source current for the malfunction detector is selected with the $\mathrm{G}_{3}$ driver option, option 24 . See $D C$ specification and characteristic curves to determine charge and discharge times. The $G_{3}$ pad will write a zero when HALT state is entered, the $\mathrm{G}_{3}$ latch is set when a continue occurs. CAUTION must be used when entering IDLE state. If the IT instruction is executed when the $\mathrm{G}_{3}$ pad is writing a zero, $\mathrm{G}_{3}$ latch at a zero, the malfunction detector will be enabled but the $G_{3}$ pad will continue to write a zero until chip clocking resumes. However if the IT instruction is executed when the $G_{3}$ latch is at one the malfunction detector is active and will reset the chip out of IDLE state when the $G_{3}$ pad is charged up to the VIHMD level.

| DC Specs | Min | Max |
| :--- | :---: | :---: |
| VIHMD | $0.45 \mathrm{~V}_{\mathrm{CC}}$ | $0.80 \mathrm{~V}_{\mathrm{CC}}$ |
| VOLMD |  | $0.50 \mathrm{~V}_{\mathrm{CC}}$ |
| VIHMD-VOLMD | $0.20 \mathrm{~V}_{\mathrm{CC}}$ |  |
| External R |  |  |
| STD Sink | $10 \mathrm{~K} \Omega$ |  |
| HIGH Sink | $5 \mathrm{~K} \Omega$ |  |

EXAMPLES
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, temp $=25^{\circ} \mathrm{C}, \mathrm{VIHMD}=2.25 \mathrm{~V}$, VOLMD $=1.0 \mathrm{~V}$, charge to 2.0 V

| Time | Driver | External <br> $\mathbf{R}$ | External <br> C | Discharge <br> Time | Charge |
| :---: | :---: | :---: | :---: | :---: | :---: |
| sec. | HIGH Sink | $20 \mathrm{~K} \Omega$ | $1.0 \mu \mathrm{~F}$ | $40 \mu \mathrm{~s}$ | 5.7 m |
| sec. | HIGH Sink | $560 \mathrm{~K} \Omega$ | $0.22 \mu \mathrm{~F}$ | $10 \mu \mathrm{~s}$ | 36 m |
| sec. | HIGH Sink | $47 \mathrm{~K} \Omega$ | $2.2 \mu \mathrm{~F}$ | $95 \mu \mathrm{~s}$ | 30 m |
| sec. | STD Sink | $200 \mathrm{~K} \Omega$ | $0.1 \mu \mathrm{~F}$ | $20 \mu \mathrm{~s}$ | 5.7 m |

## COP448C AND COP428C 24-PIN PACKAGE OPTION

If the COP447C/427C is bonded in a 24-pin package, it becomes the COP448C/428C, illustrated in Figure 2, Connection diagrams. Note that the COP448C/428C does not contain the four general purpose IN inputs (IN3-INO). Use of this option precludes, of course, use of the IN options, interrupt feature, external event counter feature, and the Microbus option which uses IN1-IN3. However, a mask programmable option exists to select D2 pin to be either IN1 or IN2 for all functions on those pins except Comparator and MICROBUS. All other options are available for the COP448C/428C.

## COP429C AND COP449C 20-PIN PACKAGE OPTION

If the COP428C/COP447C is bonded as a 20 -pin device it becomes the COP429C/COP449C. Note that the COP429C/COP449C contains all the COP427C/COP447C pins except $D_{0}, D_{1}, G_{0}$, and $G_{1}$. However, $D 2$ can be mask optioned as explained above to be either IN1 or IN2, OR it can be optioned to be the dual clock function of DO.
Note: If user selects the 24-pin or 20-pin package, options 9, 10, 19 and 20 must be selected as a " 0 " (load to VCC on the IN inputs). See option list.


FIGURE 9A. Halt Mode - Two-Pin Oscillator

Block Diagrams (Continued)



FIGURE 10A. Clock and Timer without Dual-Clock


TL/DD/9129-14
FIGURE 10B. Clock and Timer with Dual-Clock

| Instruction Set |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Table II is a symbol table providing internal architecture, instruction operand and operation symbols used in the instruction set table. |  |  |  |  | Table III provides the mnemonic, operand, machine code data flow, skip conditions and description of each instruction. |  |  |
| TABLE II. Instruction Set Table Symbols |  |  |  |  | Instruction Operand Symbols |  |  |
| Symbol | Definition |  |  |  | 4 | 4-bit operand field, 0-15 binary (RAM digit select) |  |
| Internal Architecture Symbols |  |  |  |  |  | 3(2)-bit operand field, 0-7(3) binary (RAM register select) |  |
| A | 4-bit accumulator |  |  |  |  |  |  |
| B | 7-bit RAM address register (6-bit for COP427C) |  |  |  | a 1 | 11-bit operand field, 0-2047 (1023) |  |
| Br | Upper 3 bits of B (register address) <br> (2-bit for COP427C) |  |  |  | $\text { RAM }(x)$ | RAM addressed by variable $x$ |  |
| Bd | Lower 4 bits of $B$ (digit address) |  |  |  | ROM (x) R | ROM addressed by variable $x$ |  |
| C | 4-bit data output port |  |  |  |  |  |  |
| D |  |  |  |  | Operational Symbols |  |  |
| EN | 8 -bit enable register |  |  |  | $+\quad P$ | Plus |  |
| G | 4-bit general purpose I/O port |  |  |  | $-\quad M i$ | Minus |  |
| IL | two 1-bit (IN0 and IN3) latches |  |  |  | $\rightarrow \quad R \epsilon$ | Replaces |  |
| IN | 4-bit input port |  |  |  | $\longleftrightarrow \text { Is }$ |  |  |
| L | 8-bit TRI-STATEI/O port |  |  |  | $=\mathrm{ls}$ | Is equal to |  |
| M | 4-bit contents of RAM addressed by B |  |  |  | $\bar{A} \quad$ | One's complement of A |  |
| PC | 11-bit ROM address program counter |  |  |  | $\oplus \quad$ Ex | Exclusive-or |  |
| Q | 8 -bit latch for $L$ port |  |  |  |  | Range of values |  |
| SA,SB,SC | 11-bit 3-level subroutine stack |  |  |  |  |  |  |
| SIO | 4-bit shift register and counter |  |  |  |  |  |  |
| SK | Logic-controlled clock output |  |  |  |  |  |  |
| SKL | 1-bit latch for SK output |  |  |  |  |  |  |
| T | 8-bit timer |  |  |  |  |  |  |
| Cmp | 1-bit latch for comparator output |  |  |  |  |  |  |
| TABLE III. COP427C/447C Instruction Set |  |  |  |  |  |  |  |
| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code (Binary) |  | a Flow | $\begin{array}{r} \text { Sk } \\ \text { Cond } \end{array}$ | Description |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |  |
| ASC |  | 30 | 001110000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ |  | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | \|0011 0001 | $A+R A M(B) \rightarrow A$ |  | None | Add RAM to A |
| ADT |  | 4 A | $0100 \mid 1010$ | $A+10_{10} \rightarrow A$ |  | None | Add Ten to A |
| AISC | $y$ | $5-$ | 0101\| y | $A+y \rightarrow A$ |  | Carry | Add Immediate. Skip on Carry ( $y \neq 0$ ) |
| CASC |  | 10 | 000110000 | $\overline{\mathrm{A}}+\mathrm{RAM}(\mathrm{B})+\mathrm{C} \rightarrow \mathrm{A}$ |  | Carry | Complement and Add with Carry, Skip on Carry |
| CLRA |  | 00 | 0000\|0000 | $0 \rightarrow \mathrm{~A}$ |  | None | Clear A |
| COMP |  | 40 | \|0100|0000 | $\bar{A} \rightarrow A$ |  | None | Ones complement of A to A |
| NOP |  | 44 | 1010010100 | None |  | None | No Operation |
| RC |  | 32 | \|0011|0010 | " 0 " $\rightarrow$ C |  | None | Reset C |
| SC |  | 22 | -0010\|0010 | $" 1 " \rightarrow C$ |  | None | Set C |
| XOR |  | 02 | 1000010010 | $A \oplus R A M(B) \rightarrow A$ |  | None | Exclusive-OR RAM with A |

COP427C/428C/429C/447C/448C/449C/327C/328C/329C/227C/228C/229C/347C/348C/349C
Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TRANSFER CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | 1111\|1111 | $\mathrm{ROM}\left(\mathrm{PG}_{10: 8} \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{PC}_{7: 0}$ | None | Jump Indirect (Notes 1, 3) |
| JMP | a | $\begin{gathered} 6- \\ -- \end{gathered}$ | $\frac{\left.0110\|0\| a_{10}: 8\right]}{\left[a_{7: 0}\right]}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  | $\begin{aligned} & \|1\| a_{6: 0} \mid \\ & \text { (pages } 2,3 \text { only) } \\ & \text { or } \\ & \begin{array}{\|l\|l\|} 11 & a_{5: 0} \\ \text { (all other pages) } \end{array} \end{aligned}$ | $a \rightarrow P C_{6: 0}$ $\mathrm{a} \rightarrow \mathrm{PC}_{5: 0}$ | None | Jump within Page (Note 4) |
| JSRP | a | -- |  | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & 00010 \rightarrow \mathrm{PC}_{10: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR | a | $\begin{gathered} 6- \\ -- \end{gathered}$ | $\begin{gathered} 0110\|1\| a_{10: 8} \\ \mathrm{a}_{7: 0} \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | \|0100|1000 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 0100\|1001 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| HALT |  | 33 | 0011\|0011 |  | None | HALT Processor |
|  |  | 38 | \|0011|1000 |  |  |  |
| IT |  | 33 | 001110011 |  |  | IDLE till Timer |
|  |  | 39 | \|0011|1001 |  | None | Overflows then Continues |

## MEMORY REFERENCE INSTRUCTIONS

| CAMT |  | 33 | 10011 10011 | $A \rightarrow T_{7: 4}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3F | \|0011 1111 | RAM $(\mathrm{B}) \rightarrow \mathrm{T}_{3}: 0$ | None | Copy A, RAM to T |
| CTMA |  | 33 | 001110011 | $\mathrm{T}_{7: 4} \rightarrow$ RAM(B) |  |  |
|  |  | 2 F | 0010\|1111 | $\mathrm{T}_{3: 0} \rightarrow \mathrm{~A}$ | None | Copy T to RAM, A ( Note 9 ) |
| CAMQ |  | 33 | 1001110011 | $A \rightarrow Q_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C | -0011 1100 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{Q}_{3: 0}$ |  |  |
| CQMA |  | 33 | \|0011 0011 | $\mathrm{Q}_{7: 4} \rightarrow$ RAM $(\mathrm{B})$ | None | Copy Q to RAM, A |
|  |  | 2 C | \|0010/1100 | $\mathrm{Q}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| LD | r | -5 | $\frac{100\|r\| 0101 \mid}{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A, Exclusive.OR Br with r |
| LDD | r,d | 23 | $\begin{array}{\|l\|l\|l\|} \hline 0010 & 0011 \\ \hline 0 & r & d \\ \hline \end{array}$ | $R A M(r, d) \rightarrow A$ | None | Load A with RAM pointed to directly by $\mathrm{r}, \mathrm{d}$ |
| LQID |  | BF | [1011 ${ }^{\text {1111 }}$ | $\begin{aligned} & R O M\left(P C_{10: 8}, A, M\right) \rightarrow Q \\ & S B \rightarrow S C \end{aligned}$ | None | Load Q Indirect (Note 3) |
| LID |  | 33 19 | $\left.\begin{array}{\|l\|} \hline 0011 \\ \hline 0001011 \mid \\ \hline 0001 \end{array} 1001 \right\rvert\, \begin{aligned} & \\ & \hline \end{aligned}$ | $R O M\left(\mathrm{PC}_{10: 18}, \mathrm{~A}, \mathrm{M}\right) 7: 4 \rightarrow \operatorname{RAM}(\mathrm{~B})$ $R O M\left(\mathrm{PC}_{10: 18}, \mathrm{~A}, \mathrm{~A} 1\right) 3: 0 \rightarrow \mathrm{~A}$ |  | Load M, A Indirect (Note 3) |
| RMB | 0 | 4 C | 10100\|1100 | $0 \rightarrow$ RAM $(\mathrm{B})_{0}$ | None | Reset RAM Bit |
|  | , | 45 | 010010101 | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{1}$ |  |  |
|  | 2 | 42 | 0100\|0010 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 43 | 0100/0011 | $0 \rightarrow$ RAM $(\mathrm{B})_{3}$ |  |  |

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{7}{|l|}{Instruction Set (Continued)} \\
\hline Mnemonic \& Operand \& \begin{tabular}{l}
Hex \\
Code
\end{tabular} \& Machine Language Code (Binary) \& Data Flow \& Skip Conditions \& Description \\
\hline \multicolumn{7}{|l|}{MEMORY REFERENCE INSTRUCTIONS (Continued)} \\
\hline \multirow[t]{4}{*}{SMB} \& 0 \& 4D \& \begin{tabular}{|c|}
\(0100|1101|\) \\
\hline 010011 \\
\hline
\end{tabular} \& \(1 \rightarrow \mathrm{RAM}(\mathrm{B})_{0}\) \& None \& Set RAM Bit \\
\hline \& 1 \& 47 \& -0100 01111 \& \(1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1}\) \& \& \\
\hline \& 2 \& 46 \& |0100|0110 \& \(1 \rightarrow \mathrm{RAM}(\mathrm{B})_{2}\) \& \& \\
\hline \& 3 \& 4B \&  \& \(1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}\) \& \& \\
\hline \multirow[t]{2}{*}{DRS} \& \& \& 0011 0011 \& \((\mathrm{RAM}(\mathrm{B})-1) 1 \rightarrow\) RAM \((\mathrm{B})\) \& \& Decrement RAM, Skip if \\
\hline \& \& IE \& 0001 1110 \& Skip if RAM \((\mathrm{B})<0\) \& \& less than 0 \\
\hline \multirow[t]{2}{*}{AIBD} \& \(y\) \& 33 \& 0011 0011 \& \& \& \\
\hline \& \& 4 Y \& |0100| y \& \((\mathrm{Bd}+\mathrm{y}) \rightarrow \mathrm{Bd}\) \& None \& Add immediate to Bd \\
\hline STII \& \(y\) \& \(7-\) \& |0111 y \& \[
\begin{aligned}
\& y \rightarrow R A M(B) \\
\& B d+1 \rightarrow B d
\end{aligned}
\] \& None \& Store Memory Immediate 1 and Increment Bd \\
\hline \(x\) \& r \& \[
-6
\] \& \[
\begin{array}{l|l|l|}
\hline 00 \mid \& \mathbf{r} \mid 0110 \\
\hline(\mathbf{r}=0: 3)
\end{array}
\] \& \[
\begin{aligned}
\& \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\
\& \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br}
\end{aligned}
\] \& None \& Exchange RAM with \(A\), Exclusive-OR Br with \(r\) \\
\hline XAD \& r,d \& \[
23
\] \& \[
\begin{array}{|l|l|}
\hline 0010 \& 0011 \\
\hline 1 \& \mathbf{r} \\
\hline
\end{array}
\] \& RAM \((\mathrm{r}, \mathrm{d}) \longleftrightarrow \mathrm{A}\) \& None \& \begin{tabular}{l}
Exchange A with RAM \\
Pointed to Directly by r,d
\end{tabular} \\
\hline XDS \& r \& \[
-7
\] \& \[
\frac{00|r| 0111 \mid}{(r=0: 3)}
\] \& \[
\begin{aligned}
\& \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\
\& \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\
\& \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br}
\end{aligned}
\] \& Bd decrements past 0 \& \begin{tabular}{l}
Exchange RAM with A and Decrement Bd. \\
Exclusive-OR Br with r
\end{tabular} \\
\hline XIS \& \(r\) \& \[
-4
\] \& \[
\frac{00|r| 0100 \mid}{(r=0: 3)}
\] \& \[
\begin{aligned}
\& \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\
\& \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \\
\& \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br}
\end{aligned}
\] \& Bd increments past 15 \& Exchange RAM with \(A\) and Increment Bd , Exclusive-OR Br with r \\
\hline \multicolumn{7}{|l|}{REGISTER REFERENCE INSTRUCTIONS} \\
\hline CAB \& \& 50 \& 0101/0000 \& \(\mathrm{A} \rightarrow \mathrm{Bd}\) \& None \& Copy A to Bd \\
\hline CBA \& \& 4E \& 10100|1110 \& \(\mathrm{Bd} \rightarrow \mathrm{A}\) \& None \& Copy Bd to A \\
\hline LBI \& r,d \& -

33

- \& | $100\|r\|(d-1)$ |
| :---: |
| $(r=0: 3:$ |
| $d=0,9: 15)$ |
| or |

| $0011 \mid 0011$ |
| :---: |
| $1\|r\| d$ |
| (any $r$, any $d)$ | \& $r, d \rightarrow B$ \& Skip until not a LBI \& Load B Immediate with r,d (Note 6) <br>

\hline \multirow[t]{2}{*}{LEI} \& $y$ \& 33 \& 0011|0011 \& $y \rightarrow E N$ \& None \& Load EN Immediate (Note 7) <br>
\hline \& \& 6- \& 0110 y \& \& \& <br>
\hline \multirow[t]{2}{*}{LUEI} \& y \& 33 \& |0011|00111 \& $y \rightarrow E N_{7: 4}$ \& None \& Load Upper <br>
\hline \& \& 7 y \& |0111| y \& \& \& EN Immediate (Note 7) <br>
\hline \multicolumn{2}{|l|}{XABR} \& 12 \& 0001|0010 \& $\mathrm{A} \longleftrightarrow \mathrm{Br}$ \& None \& Exchange A with Br (Note 8) <br>
\hline \multicolumn{7}{|l|}{TEST INSTRUCTIONS} <br>
\hline \multicolumn{2}{|l|}{SKC} \& 20 \& 0010|0000 \& \& $\mathrm{C}=$ " 1 " \& Skip if C is True <br>
\hline \multicolumn{2}{|l|}{SKE} \& 21 \& 0010|0001 \& \& $A=\operatorname{RAM}(\mathrm{B})$ \& Skip if A Equals RAM <br>

\hline \multirow[t]{2}{*}{SKGZ} \& \& $$
33
$$ \& \[

0011 \mid 0011
\] \& \& $\mathrm{G}_{3: 0}=0$ \& Skip if G is Zero <br>

\hline \& \& $$
21
$$ \& \[

$$
\begin{array}{|l|l|}
\hline 0010 \mid 0001 \\
\hline
\end{array}
$$
\] \& \& \& (all 4 bits) <br>

\hline \multirow[t]{5}{*}{SKGBZ} \& \& 33 \& |0011|0011| \& 1st byte \& \& Skip if G Bit is Zero <br>
\hline \& 0 \& 01 \& 0000|0001 \& \& $\mathrm{G}_{0}=0$ \& <br>
\hline \& 1 \& 11 \& 0001|0001 \& \& $\mathrm{G}_{1}=0$ \& <br>
\hline \& 2 \& 03 \& 000010011 \& 2nd byte \& $\mathrm{G}_{2}=0$ \& <br>
\hline \& 3 \& 13 \& 000010011 , \& \& $\mathrm{G}_{3}=0$ \& <br>
\hline
\end{tabular}

Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TEST INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| SKMBZ | 0 | 01 | 10000\|0001 |  | $\begin{aligned} & \operatorname{RAM}(B)_{0}=0 \\ & \operatorname{RAM}(B)_{1}=0 \\ & \operatorname{RAM}(B)_{2}=0 \\ & \operatorname{RAM}(B)_{3}=0 \end{aligned}$ <br> A time-base counter carry has occurred since last test | Skip if RAM Bit is Zero |
|  | 1 | 11 | 0001\|0001 |  |  |  |
|  | 2 | 03 | 0000\|0011 |  |  |  |
|  | 3 | 13 | 0001 0011 |  |  |  |
| SKT |  | 41 | 010010001 |  |  | Skip on Timer (Note 3) |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 10011 0011 | $G \rightarrow A$ | None | Input G Ports to A |
|  |  | 2A | \|00101010 |  |  |  |
| ININ |  | 33 | 0011100111 | $\mathrm{IN} \rightarrow \mathrm{A}$ | None | Input IN Inputs to A (Note 2) |
|  |  | 28 | 0010\|1000 |  |  |  |
| INIL |  | 33 | 001110011 | $\mathrm{IL}_{3}, \mathrm{CKO}, \mathrm{CMP}, \mathrm{IL}_{0} \rightarrow \mathrm{~A}$ | None | Input IL Latches to A (Note 3) |
|  |  | 29 | \|0010|1001 |  |  |  |
| INL |  | 33 | 10011 00011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2 E | \|0010|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | 0011 0011 | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E | 001111110 |  |  |  |
| OGI | $y$ | 33 | 0011100111 | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | $5-$ | 0101 y |  |  |  |
| OMG |  | 33 | 20011 0011 | $R A M(B) \rightarrow G$ | None | Output RAM to G Ports |
|  |  | 3A | \|00111010 |  |  |  |
| XAS |  | 4F | -0100\|1111 | A ${ }_{\text {SIO, }} \rightarrow$ SKL | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit $A$ register.
Note 2: The ININ instruction is not available on the 24-pin packages since these devices do not contain the $\mathbb{I N}$ inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, LID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 5: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ " data minus 1 , e.g., to load the lower four bits of $\mathrm{B}(\mathrm{Bd})$ with the value $9(10012)$, the lower 4 bits of the LBI instruction equal $8\left(100 \mathrm{O}_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).
Note 7: Machine code for operand field y for LEI and LUEI instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)
Note 8: For 2 K ROM devices, $\mathrm{A} \longleftrightarrow \mathrm{Br}(0 \rightarrow \mathrm{~A} 3)$. For 1 K ROM devices, $\mathrm{A} \longleftrightarrow \mathrm{Br}(0,0 \rightarrow \mathrm{~A} 3, \mathrm{~A} 2)$.
Note 9: Do not use CTMA instruction when dual-clock option is selected and part is running from $D_{0}$ clocks.

## Description of Selected Instructions

## XAS INSTRUCTION

XAS (Exchange A with SIO) copies $C$ to the SKL latch and exchanges the accumulator with the 4 -bit contents of the SIO register. The contents of SIO will contain serial-in/seri-al-out shift register or binary counter data, depending on the value of the EN register. If SIO is selected as a shift register, an XAS instruction can be performed once every 4 instruction cycles to effect a continuous data stream.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 11 -bit word PC10:PC8,A,M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC $+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC}$ ) and replaces the least significant 8 bits of the PC as follows: $A \rightarrow \mathrm{PC}(7: 4), \mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{PC}(3: 0)$, leaving $\mathrm{PC}(10), \mathrm{PC}(9)$ and $\mathrm{PC}(8)$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" (SC $\rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ ), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost.
Note: LQID uses 2 instruction cycles if executed, one if skipped.

## LID INSTRUCTION

LID (Load A,M Indirect) has the same operation as LQID except that the ROM contents pointed to by PC(10:8), A,M are loaded back into the $M$ and $A$ rather than the $Q$ latch. Therefore, the data in $A$ and $M$ that is used as the ROM address will be overwritten by the ROM data that is fetched. However, using LID instruction will save the contents of the Q latch which may be used as $L$ port output data and not lose integrity. NOTE: LID is a two-byte instruction and therefore takes three instruction cycle times if executed, two if skipped.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 11-bit word, PC10:8,A,M. PC10,PC9 and PC8 are not affected by JID.
Note: JID uses 2 instruction cycles if executed, one if skipped.

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of the $T$ counter overflow latch (see internal logic, above), executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction allow the processor to generate its own time-base for real-time processing, rather than relying on an external input signal.

## IT INSTRUCTION

The IT (idle till timer) instruction halts the processor and puts it in an idle state until the time-base counter overflows. This idle state reduces current drain since all logic (except the oscillator and time base counter) is stopped. IT instruction is not allowed if the T counter is mask-programmed as
an external event counter (option \#31=1). IT instruction is not allowed if the T counter is mask programmed (option \#31 = 2) or software selected (EN4 = 1) as an external event counter.

## INIL INSTRUCTION

INIL (Input IL Latches to A) inputs two latches, IL3 and ILO into A3 and AO respectively, CKO into A2 (if CKO is mask programmed as a general purpose input) or a logic " 1 " into A2, and the comparator output latch into A1 if EN5 is set. If EN5 is reset, then a logic " 0 " is loaded into A1. The IL3 and ILO latches are set if a low-going pulse (" 1 " to " 0 ") has occurred on the IN3 and INO inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction cycles. Execution of an INIL resets these latches after loading them into A3 and AO to allow them to respond to subsequent low-going pulses on the IN3 and INO lines. IL latches are cleared on reset, and are not available on the COP447C/448C/427C/428C.

## INSTRUCTION SET NOTES

a. The first word of a program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, they are still fetched from the program memory. Thus program paths take the same number of cycles whether instructions are skipped or executed except for JID, and LQID.
c. The ROM is organized into pages of 64 words each. The Program Counter is a 11-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID, LID or LQID is the last word of a page, it operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a JID, LID or LQID located in the last word of every fourth page (i.e. hex address 0FF, 1FF, 2FF, 3FF, 4FF, etc.) will access data in the next group of four pages.
Note: The COP427C/COP428C/COP429C needs only 10 bits to address its ROM. Therefore, the eleventh bit ( P 10 ) is ignored.

## Power Dissipation

The lowest power drain is when the clock is stopped. As the frequency increases so does current. Current is also lower at lower operating voltages. Therefore, the user should run at the lowest speed and voltage that his application will allow. The user should take care that all pins swing to full supply levels to insure that outputs are not loaded down and that inputs are not at some intermediate level which may draw current. Any input with a slow rise or fall time will draw additional current. A crystal or resonator generated clock input will draw additional current. For example, a 500 kHz crystal input will typically draw $100 \mu \mathrm{~A}$ more than a square wave input. An R/C oscillator will draw even more current since the input is a slow rising signal.
If using an external squarewave oscillator, the following equation can be used to calculate operating current drain.
$I_{C O}=I_{Q}+V \times 40 \times \mathrm{Fi}+V \times 1400 \times \mathrm{Fi} / \mathrm{Dv}$
where $\mathrm{I}_{\mathrm{CO}}=$ chip operating current drain in microamps
quiescent leakage current (from curve)
CKI frequency in MegaHertz
chip $V_{C C}$ in volts
divide by option selected

## Power Dissipation (Continued)

For example at 5 volts $\mathrm{V}_{\mathrm{CC}}$ and 400 kHz (divide by 4)

$$
\begin{aligned}
& I_{C O}=20+5 \times 40 \times 0.4+5 \times 1400 \times 0.4 / 4 \\
& I_{C O}=20+80+700=800 \mu \mathrm{~A}
\end{aligned}
$$

At 2.4 volts $\mathrm{V}_{\mathrm{CC}}$ and 30 kHz (divide by 4)

$$
\begin{aligned}
& I_{C O}=6+2.4 \times 40 \times 0.03+2.4 \times 1400 \times 0.03 / 4 \\
& I_{C O}=6+2.88+25.2=34.08 \mu \mathrm{~A}
\end{aligned}
$$

If an IT instruction is executed, the chip goes into the IDLE mode until the timer overflows. In IDLE mode, the current drain can be calculated from the following equation:

$$
\mathrm{Ici}=\mathrm{I}_{\mathrm{Q}}+\mathrm{V} \times 40 \times \mathrm{Fi}
$$

For example, at 5 volts $V_{C C}$ and 400 kHz

$$
\mid c i=20+5 \times 40 \times 0.4=100 \mu \mathrm{~A}
$$

The total average current will then be the weighted average of the operating current and the idle current:

$$
\text { Ita }=I_{C O} \times \frac{T_{0}}{T_{0}+T_{i}}+I \mathrm{Ici} \times \frac{T i}{T_{0}+T_{i}}
$$

where: Ita $=$ total average current
$I_{C O}=$ operating current
$\mathrm{lci}=$ idle current
To $=$ operating time
$\mathrm{Ti}=$ idie time

## I/O OPTIONS

Outputs have the following optional configurations, illustrated in Figure 11:
A. Push-Pull-A CMOS push-pull buffer with an N-Channel device to ground in conjunction with a P-Channel device to $V_{C C}$, compatible with CMOS and LSTTL.
B. Open Drain-An N-Channel device to ground only, allowing external pull up as required by the user's application. Open drain outputs can withstand voltage levels as high as 14 V if the N -Channel device is "off."
C. TRI-STATE L Output-A CMOS output buffer similar to (A), which may be disabled by program control.
D. Open Drain TRI-STATE L Output-Same as (C) except without the P-Channel pull-up.
All inputs except CKI have the following options:
E. Input with on chip load device to $V_{C C}$.
F. Hi-Z input which must be driven by the user's logic. As on Open Drain outputs, $\mathrm{Hi}-\mathrm{Z}$ inputs can withstand up to 14 V .
G. G-line inputs may be programmed as Schmitt trigger inputs (hysteresis) or as regular inverter inputs (no hysteresis).


a. Push-Pull Output

d. Open Drain TRI-STATE "L" Output

b. Open-Drain Output

e. Input with Load

c. TRI-STATE "L" Output

f. Hi-Z Input

g. G-Line Inputs with
Push-Pull G Outputs

h. G-Line Inputs with Open-Drain G Outputs
$\mathrm{N} 1=$ STD IOL, $\mathrm{N} 2=$ HIGH IOL P3 $=$ STD IOH, P4 $=$ LOW IOH, P5 $=$ INPUT LOAD, ILL

Power Dissipation (Continued)


## FIGURE 12. Input/Output Characteristics

Source devices can be mask programmed to be STD current or LOW current IOH. Sink devices can also be mask programmed to be HIGH or STD IOL (on push-pull and open drain outputs, not TRI-STATE "L" outputs). See above DC characteristics for details.
When using either the G or L I/O ports as inputs, a pull-up device is necessary. This can be an external device or the following alternative is available: Select the low-current output option. Now, by setting the output registers to a logic " 1 " level, the P-Channel devices will act as the pull-up load. Note that when using the L ports in this fashion, the $Q$ registers must be set to a logic " 1 " level, and the L drivers MUST BE ENABLED by an LEl instruction (see above description). Minimum and maximum I/V curves are given in FIGURE 12 for each of the I/O configurations to allow the designer to effectively use them.

When using either the G or LI/O ports as inputs, a pull-up device is necessary. This can be an external device or the following alternative is available: Select the low-current output option. Now, by setting the output registers to a logic " 1 " level, the P-channel devices will act as the pull-up load. Note that when using the $L$ ports in this fashion the $Q$ registers must be set to a logic "1" level and the L drivers MUST BE ENABLED by an LEl instruction (see description above).
All output drivers use one or more of three common devices numbered 1 to 3 . Minimum and maximum current (lOUT and $V_{\text {OUT }}$ ) curves are given in Figure 12 for each of these devices to allow the designer to effectively use these I/O configurations.

## Option List

The COP447C/448C/449C/427C/428C/COP429C maskprogrammable options are assigned numbers which correspond with the COP447C/427C pins.
The following is a list of options. The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.
PLEASE FILL OUT THE OPTION TABLE. Xerox the option data and send it in with your disk or EPROM.
Option 1=0: Ground Pin - no options available
Option 2: CKO Pin
=0: clock generator output to crystal/resonator
=1: HALT I/O port
=2: general purpose input with load device to $V_{C C}$
$=3$ : general purpose input, high-Z
=4: Clock generator output to crystal/resonator with Wake-Up
Option 3: CKI input
$=0$ : Crystal controlled oscillator input divide by 4
=1: Crystal controlled oscillator input divide by 8
=2: Crystal controlled oscillator input divide by 16
$=3$ : Single-pin RC controlled oscillator (divide by 4)
=4: External oscillator input divide by 4
$=5$ : External oscillator input divide by 8
=6: External oscillator input divide by 16
$=7$ : Crystal oscillator input divide by 32
$=8$ : External oscillator input divide by 32
Option 4: $\overline{R E S E T}$ input
$=0$ : load device to $V_{C C}$
= 1: Hi-Z input
Option 5: L7 Driver
$=0$ : TRI-STATE push-pull output
$=1$ : Low-current TRI-STATE push-pull output
=2: Open-drain TRI-STATE output
Option 6: L6 Driver - (same as option 5)
Option 7: L5 Driver - (same as option 5)
Option 8: L4 Driver - (same as option 5)
Option 9: IN1 input
$=0$ : load device to $V_{C C}$
=1: Hi-Z input
Option 10: IN2 input - (same as option 9)
Option 11=0: VCC Pin — no option available
Option 12: L3 Driver - (same as option 5)
Option 13: L2 Driver - (same as option 5)
Option 14: L1 Driver - (same as option 5)
Option 15: L0 Driver - (same as option 5)
Option 16: SI input - (same as option 9)
Option 17: SO Driver
$=0$ : Standard push-pull output
=1: Low-current push-pull output
=2: Open-drain output, standard sink device
Option 18: SK Driver - (same as option 17)
Option 19: INO Input - (same as option 9)
Option 20: IN3 Input - (same as option 9)

Option 21: Go Driver
$=0$ : Push-pull output
$=1$ : Push-pull output, low current source device.
=2: Open-drain output
$=3$ : Push-pull output, high current sink device.
Option 22: G1 Driver - (same as option 21)
Option 23: G2 Driver - (same as option 21)
Option 24: G3 Driver
$=0$ : Push-pull output
=1: Push-pull output, low current source device
=2: Open-drain output
$=3$ : Push-pull output, high current sink device
=4: Open-drain output, high current sink device
$=5$ : Push-pull output, high current sink; low current source (option 5 only available if malfunction detector selected)
Option 25: D3 Output - (same as option 21)
Option 26: D2 Driver
$=0$ : Push-pull output
=1: Push-pull output, low current source device
=2: Open-drain output
$=3$ : Push-pull output, high current sink device
$=4$ : Open-drain output, high current sink device
=5: DO Dual Clock, RC controlled oscillator (20 pin part only)
=6: DO Dual Clock, external oscillator (20 pin part only)
=7: IN1 function with load device to $V_{C C}$ (24 and 20 pin parts only)
=8: IN1 function, $\mathrm{Hi}-\mathrm{Z}$ input ( 24 and 20 pin parts only)
$=9$ : $\operatorname{IN} 2$ function, load device to $V_{C C}$ (24 and 20 pin parts only)
$=10$ : IN 2 function, $\mathrm{Hi}-\mathrm{Z}$ input (24 and 20 pin parts only)
Option 27: D1 Output - (same as option 21)
Option 28: Do Output - (same as option 21)
Option 29: Internal Initialization Logic
$=0$ : Normal operation
$=1$ : No internal initialization logic
Option 30: Dual Clock
$=0$ : Normal operation
$\left.\begin{array}{l}\text { =1: Dual Clock. DO is an RC oscillator } \\ =2 \text { : Dual Clock. DO is an ext. oscillator }\end{array}\right\}\binom{$ opt. \# 28 }{ must $=2}$
=3: Dual Clock. D0 function bonded out on D2 (20 pin part only)
Option 31: Timer
$=0$ : T counter source software selectable with EN6
=1: Time-base counter
=2: External event counter
Option 32: Microbus
=0: Normal
$=1$ : Microbus (opt. \#31 must=0)
Option 33: COP bonding
(1K and 2 K Microcontroller)
=0: 28-pin package
=1: 24-pin package
=2: Same die purchased in both 24 and 28 pin version (1K Microcontroller only)
$=3$ : 20-pin package
=4: 28- and 20 -pin package
$=5$ : 24 - and 20 -pin package
=6: 28-, 24- and 20-pin package

Option List (Continued)
Option 34: Wake-up from HALT control pin selection
$=0$ : No wake up from HALT
=1: Wake up on Lo
=2: Wake up on L1
=3: Wake up on L2
=4: Wake up on L3
=5: Wake up on L4
=6: Wake up on L5
=7: Wake up on L6
=8: Wake up on L7
$=9$ : Wake up on all L pins (any pin grounded will make up clocks)
Option 35: G-port Input configuration selection
=0: Normal inverter
=1: Schmitt triggers on G-port inputs
Option 36: 12V operation
=0: normal operation
$=1$ : Hi-Z inputs and open drain outputs must withstand +12 V .

Option 37: T counter initialization
$=0: T$ counter cleared on initialization
$=1$ : $T$ counter not cleared on initialization.
Option 38: Malfunction Indicator
$=0$ : Normal operation (no malfunction detect)
=1: Malfunction detector enabled on G3 pin.
Option 39: COP420C compatible (for internal use only)
=0: not compatible
=1: Disable $\operatorname{Br}(2)$
Note:-If option $33=2$, then options $9,10,19,20$, and 32 must $=0$. If option $33=3,4,5$ or 6 then options $9,10,19$, $20,21,22,30$ and 32 must $=0$. If option $33=0,1,2,4,5$ or 6 , then option 26 must not $=5$ or 6 . If option $33=0,2,4$ or 6 , then option 26 must not $=5,6,7,8,9$ or 10 . If option $38=1$, then option 24 must $=4$ or 5 , and option 35 must $=1$. If option $26=5$ or 6 , then option $28=2$, option $30=$ 3 , and option $33=3$. If option $26=6$, then option $28=2$, option $30=3$, and option $33=3$. If option $26=7$ or 8 , then option $9=0$, option $33=1,3$ or 5 . If option $26=9$ or 10 , then option $10=0$, option $33=1,3$ or 5 .

The following option information is to be sent to National along with the EPROM.

## OPTION DATA

| OPTION | 1 VALUE = | IS: GROUND PIN |
| :---: | :---: | :---: |
| OPTION | 2 VALUE $=$ | IS: CKO PIN |
| OPTION | 3 VALUE $=$ | IS: CKI INPUT |
| OPTION | 4 VALUE $=$ | IS: $\overline{\text { RESET INPUT }}$ |
| OPTION | 5 VALUE $=$ | IS: L(7) DRIVER |
| OPTION | 6 VALUE $=$ | IS: L(6) DRIVER |
| OPTION | 7 VALUE $=$ | IS: L(5) DRIVER |
| OPTION | $8 \mathrm{VALUE}=$ | IS: L(4) DRIVER |
| OPTION | 9 VALUE $=$ | IS: IN1 INPUT |
| OPTION 1 | 10 VALUE $=$ | IS: IN2 INPUT |
| OPTION 1 | 11 VALUE = | IS: VCC PIN |
| OPTION 1 | 12 VALUE = | IS: L(3) DRIVER |
| OPTION 1 | 13 VALUE $=$ | IS: L(2) DRIVER |
| OPTION 1 | 14 VALUE $=$ | IS: L(1) DRIVER |
| OPTION 1 | 15 VALUE = | IS: L(0) DRIVER |
| OPTION 1 | 16 VALUE = | IS: SI INPUT |
| OPTION 1 | 17 VALUE $=$ | IS: SO DRIVER |
| OPTION 1 | 18 VALUE $=$ | IS: SK DRIVER |
| OPTION 1 | 19 VALUE = | IS: INO INPUT |

## OPTION DATA

| OPTION 20 VALUE $=$ | IS: IN3 INPUT |
| :---: | :---: |
| OPTION 21 VALUE = | IS: GO DRIVER |
| OPTION 22 VALUE = | IS: G1 DRIVER |
| OPTION 23 VALUE $=$ | IS: G2 DRIVER |
| OPTION 24 VALUE $=$ | IS: G3 DRIVER |
| OPTION 25 VALUE $=$ | IS: D3 DRIVER |
| OPTION 26 VALUE = | IS: D2 DRIVER |
| OPTION 27 VALUE $=$ | IS: D1 DRIVER |
| OPTION 28 VALUE $=$ | IS: DO DRIVER |
| OPTION 29 VALUE = | IS: INT INIT LOGIC |
| OPTION $30 \mathrm{VALUE}=$ | IS: DUAL CLOCK |
| OPTION 31 VALUE $=$ | IS: TIMER |
| OPTION 32 VALUE = | IS: MICROBUS |
| OPTION 33 VALUE $=$ | IS: COP BONDING |
| OPTION 34 VALUE = | IS: HALT WAKEUP |
| OPTION 35 VALUE = | IS: G PORT CONFIGURATION |
| OPTION 36 VALUE $=$ | IS: 12V OPERATION |
| OPTION 37 VALUE = | IS: T COUNTER INIT |
| OPTION 38 VALUE $=$ | IS: MALFUNCTION INDICATOR |
| OPTION 39 VALUE = | IS: (FOR INTERNAL USE ONLY) |

# COP440/COP441/COP442 and COP340/COP341/COP342 Single-Chip N-Channel Microcontrollers 

## General Description

The COP440, COP441, COP442, COP340, COP341, and COP342 Single-Chip N-Channel Microcontrollers are members of the COPSTM microcontrollers family, fabricated using N -channel, silicon gate MOS technology. These are complete microcontrollers with all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, various output configuration options, and an instruction set, internal architecture, and 1/O scheme designed to facilitate keyboard input, display output, and data manipulation. The COP440 is a 40 -pin chip and the COP441 is a 28 -pin version of the same circuit (12 I/O lines removed). The COP442 is a 24 -pin version (4 more input lines removed). The COP340, COP341, COP342 are functional equivalents of the above devices respectively, but operate with an extended temperature range $\left(-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}$ ). Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized controller oriented processor at a low end-product cost.

## Features

- Enhanced, more powerful instruction set
- $2 \mathrm{k} \times 8$ ROM, $160 \times 4$ RAM
- 35 I/O lines (COP440)
- Zero-crossing detect circuitry with hysteresis

■ True multi-vectored interrupt from 4 selectable sources (plus restart)

- Four-level subroutine stack (in RAM)
- $4 \mu$ s cycle time
- Single supply operation ( $4.5 \mathrm{~V}-6.3 \mathrm{~V}$ )
- Programmable time-base counter
- Internal binary counter/register with MICROWIRETM compatible serial I/O
- General purpose and TRI-STATE® outputs
- TTL/CMOS compatible in and out
- LED drive capability
- MICROBUSTM compatible
- Software/hardware compatible with other members of the COP400 family
- Extended temperature range devices COP340, COP341, COP342 $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
- Compatible dual CPU device available (COP2440 series)


## Block Diagram



## COP440/COP441/COP442

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated rellability electrical test specifications document.
Voltage at Zero-Crossing Detect Pin

Relative to GND
-1.2 V to +15 V
Voltage at Any Other Pin Relative to GND
Ambient Operating Temperature
Ambient Storage Temperature

Lead Temperature (Soldering, 10 sec. )
Power Dissipation

Total Source Current
150 mA
Total Sink Current
75 mA
Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 3) | 4.5 | 6.3 | V |
| Power Supply Ripple | (Peak to Peak) |  | 0.4 | V |
| Operating Supply Current | (All Inputs and Outputs Open) $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C} \end{aligned}$ |  | $\begin{aligned} & 44 \\ & 35 \\ & 27 \\ & \hline \end{aligned}$ | mA <br> mA <br> mA |
| ```Input Voltage Levels CKI Input Levels Crystal Input \((\div 16, \div 8\) ) Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) Logic Low ( \(\mathrm{V}_{\mathrm{IL}}\) ) Schmitt Trigger Input ( \(\div 4\) ) Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) Logic Low ( \(\mathrm{V}_{\mathrm{IL}}\) ) RESET Input Levels Logic High Logic Low``` | $\begin{aligned} & V_{C C}=M a x \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ <br> (Schmitt Trigger Input) | $\begin{gathered} 3.0 \\ 2.0 \\ -0.3 \\ \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ \hline \end{gathered}$ | $\begin{aligned} & 0.4 \\ & 0.6 \\ & 0.6 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ |
| Zero-Crossing Detect Input <br> Trip Point <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) Limit <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) Limit <br> SO Input Level (Test Mode) <br> All Other Inputs <br> Logic High <br> Logic High <br> Logic Low <br> Input Levels High Trip Option <br> Logic High <br> Logic Low | See Figure 7 <br> (Note 5) $\begin{aligned} & V_{C C}=M a x \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ | $\begin{gathered} -0.15 \\ -0.8 \\ 2.0 \\ \\ 3.0 \\ 2.0 \\ -0.3 \\ \\ 3.6 \\ -0.3 \\ \hline \end{gathered}$ | 0.15 <br> 12 <br> 2.5 <br> 0.8 <br> 1.2 | $\begin{aligned} & V \\ & v \\ & v \\ & v \\ & v \\ & v \\ & V \\ & v \\ & \\ & V \\ & V \end{aligned}$ |
| Input Capacitance |  |  | 7.0 | pF |
| $\mathrm{Hi}-\mathrm{Z}$ Input Leakage |  | -1.0 | +1.0 | $\mu \mathrm{A}$ |

Note 1: Duty Cycle $=t_{W I} /\left(t_{W I}+t_{W O}\right)$.
Note 2: See Figure for additional I/O Characteristics.
Note 3: $V_{\text {CC }}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 4: Exercise great care not to exceed maximum device power dissipation limits when direct-driving LEDs (or sourcing similar loads) at high temperature.
Note 5: SO output " 0 " level must be less than 0.8 V for normal operation.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| ```Output Voltage Levels Standard Output TTL Operation Logic High (VOH) Logic Low (VOL) CMOS Operation (Note 1) Logic High (VOH) Logic Low (VOL)``` | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.4$ | $\begin{aligned} & 0.4 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| Output Current Levels <br> Standard Output Source Current <br> LED Direct Drive Output Logic High (IOH) <br> TRI-STATE Output Leakage Current CKO Output <br> Oscillator Output Option <br> Logic High <br> Logic Low <br> $\mathrm{V}_{\mathrm{R}}$ RAM Power Supply Option <br> Supply Current <br> CKI Sink Current (RC Option) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=6 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2 \mathrm{~V} \end{aligned}$ $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{R}}=3.3 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}}=3.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} -100 \\ -2.5 \\ -2.5 \\ \\ -0.2 \\ 0.4 \\ \\ 2.0 \\ \hline \end{gathered}$ | $\begin{aligned} & -650 \\ & -17 \\ & +2.5 \end{aligned}$ $3.0$ | $\mu \mathrm{A}$ <br> mA <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA <br> mA |
| Input Current Levels Zero-Crossing Detect Input Resistance Input Load Source Current | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 0.9 \\ 14 \\ \hline \end{gathered}$ | $\begin{gathered} 4.6 \\ 230 \end{gathered}$ | $\begin{aligned} & \mathrm{k} \Omega \\ & \mu \mathrm{~A} \end{aligned}$ |
| Total Sink Current Allowed All I/O Combined Each L, R Port Each D, G, H Port SO, SK |  |  | $\begin{aligned} & 75 \\ & 20 \\ & 10 \\ & 2.5 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Total Source Current Allowed <br> All I/O Combined <br> L Port <br> $\mathrm{L}_{7}-\mathrm{L}_{4}$ <br> $\mathrm{L}_{3}-\mathrm{L}_{0}$ <br> Each L Pin <br> All Other Output Pins |  |  | $\begin{gathered} 150 \\ 120 \\ 70 \\ 70 \\ 23 \\ 1.6 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA <br> mA |

Note 1: TRI-STATE and LED configurations are excluded.

## COP340/COP341/COP342

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated rellability electrical test specifications document.
Voltage at Zero-Crossing Detect Pin

Relative to GND
Voltage at Any Other Pin
Relative to GND
Ambient Operating Temperature
Ambient Storage Temperature

$$
-1.2 \mathrm{~V} \text { to }+15 \mathrm{~V}
$$

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

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

$$
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}
$$

Lead Temperature (Soldering, 10 sec .)
$300^{\circ} \mathrm{C}$
Power Dissipation

Total Source Current
Total Sink Current 75 mA

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 3) | 4.5 | 5.5 | V |
| Power Supply Ripple | (Peak to Peak) |  | 0.4 | V |
| Operating Supply Current | (All Inputs and Outputs Open) $\begin{aligned} & T_{A}=-40^{\circ} \mathrm{C} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & T_{A}=85^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 54 \\ & 35 \\ & 25 \\ & \hline \end{aligned}$ | mA <br> mA <br> mA |
| Input Voltage Levels <br> CKI Input Levels <br> Crystal Input ( $\div 16, \div 8$ ) <br> Logic High ( $\mathrm{V}_{1 \mathrm{H}}$ ) <br> Logic Low ( $V_{I L}$ ) <br> Schmitt Trigger Input ( $\div 4$ ) <br> Logic High ( $\mathrm{V}_{1 \mathrm{H}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> RESET Input Levels <br> Logic High <br> Logic Low <br> Zero-Crossing Detect Input <br> Trip Point Logic High $\left(\mathrm{V}_{\mathrm{IH}}\right)$ Limit Logic Low ( $V_{\text {IL }}$ ) Limit <br> SO Input Level (Test Mode) <br> All Other Inputs <br> Logic High <br> Logic Low <br> Input Levels High Trip Option Logic High Logic Low | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$ <br> (Schmitt Trigger Input) <br> See Figure 7 <br> (Note 5) $V_{C C}=\operatorname{Max}$ | 3.0 2.2 -0.3 $0.7 V_{C C}$ -0.3 $0.7 V_{C C}$ -0.3 -0.15 -0.8 2.2 3.0 2.2 -0.3 3.6 -0.3 | $\begin{gathered} 0.3 \\ 0.4 \\ 0.4 \\ 0.15 \\ 12 \\ 2.4 \\ 0.6 \\ 1.2 \\ \hline \end{gathered}$ | $\begin{aligned} & V \\ & V \\ & v \end{aligned}$ V V V $V$ $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \end{aligned}$ V $v$ |
| Input Capacitance |  |  | 7.0 | pF |
| Hi-Z Input Leakage |  | -2.0 | +2.0 | $\mu \mathrm{A}$ |

Note 1: Duty Cycle = $t_{w I} /\left(t_{w l}+t_{w o}\right)$.
Note 2: See Figure for additional I/O Characteristics.
Note 3: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 4: Exercise great care not to exceed maximum device power dissipation limits when direct-driving LEDs (or sourcing similar loads) at high temperature.
Note 5: SO output " 0 " level must be less than 0.6 V for normal operation.

## COP340/COP341/COP342

## DC Electrical Characteristics

$-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Voltage Levels Standard Output TTL Operation Logic High $\left(\mathrm{VOH}_{\mathrm{OH}}\right)$ Logic Low (VOU) CMOS Operation (Note 1) Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{IOH}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $V_{C C}-0.5$ | $\begin{aligned} & 0.4 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & V \\ & v \\ & v \\ & v \end{aligned}$ |
| Output Current Levels <br> Standard Output Source Current <br> LED Direct Drive Output <br> Logic High (IOH) <br> TRI-STATE Output Leakage Current <br> CKO Output <br> Oscillator Output Option <br> Logic High <br> Logic Low <br> $V_{\mathrm{R}}$ RAM Power Supply Option <br> Supply Current <br> CKI Sink Current (RC Option) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V}(\text { Note } 4) \\ & \mathrm{V}_{\mathrm{OH}}=2 \mathrm{~V} \\ & \\ & \mathrm{~V}_{\mathrm{OH}}=2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{R}}=3.3 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.5 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} -100 \\ -1.5 \\ -5.0 \\ -0.2 \\ 0.4 \\ \\ 2.0 \end{gathered}$ | $\begin{gathered} -800 \\ -15 \\ +5.0 \end{gathered}$ | $\mu \mathrm{A}$ <br> mA <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA <br> mA |
| Input Current Levels <br> Zero-Crossing Detect Input Resistance Input Load Source Current | $\begin{aligned} & \mathrm{V}_{1 \mathrm{H}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 0.9 \\ 14 \end{gathered}$ | $\begin{aligned} & 4.6 \\ & 280 \end{aligned}$ | $\begin{aligned} & \mathrm{k} \Omega \\ & \mu \mathrm{~A} \end{aligned}$ |
| Total Sink Current Allowed All I/O Combined Each L, R Port Each D, G, H Port SO, SK |  |  | $\begin{aligned} & 75 \\ & 20 \\ & 10 \\ & 2.5 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Total Source Current Allowed <br> All I/O Combined <br> L Port <br> $L_{7}-L_{4}$ <br> $L_{3}-L_{0}$ <br> Each L Pin <br> All Other Output Pins |  |  | $\begin{gathered} 150 \\ 120 \\ 70 \\ 70 \\ 23 \\ 1.6 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> mA <br> mA |

Note 1: TRI-STATE and LED configurations are excluded.

## AC Electrical Characteristics

COP440/COP441/COP442: $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted COP340/COP341/COP342: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Condlitions | MIn | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time-t $\mathrm{t}_{\mathrm{E}}$ <br> CKI Frequency <br> Duty Cycle (Note 1) <br> Rise Time <br> Fall Time <br> CKI Using RC (Figure 9c) <br> Frequency Instruction Execution Time-t $\mathrm{E}_{\mathrm{E}}$ <br> (Note 1) | $\begin{aligned} & \div 16 \mathrm{Mode} \\ & \div 8 \mathrm{Mode} \\ & \div 4 \mathrm{Mode} \\ & f_{1}=4 \mathrm{MHz} \\ & f_{1}=4 \mathrm{MHz} \text { External Clock } \\ & f_{1}=4 \mathrm{MHz} \text { External Clock } \\ & \div 4 \mathrm{Mode} \\ & \mathrm{R}=15 \mathrm{k} \Omega \pm 5 \%, C=100 \mathrm{pF} \pm 10 \% \end{aligned}$ | $\begin{aligned} & 4.0 \\ & 1.6 \\ & 0.8 \\ & 0.4 \\ & 30 \\ & \\ & \\ & 0.5 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & 10 \\ & 4.0 \\ & 2.0 \\ & 1.0 \\ & 60 \\ & 60 \\ & 40 \\ & 1.0 \\ & 8.0 \end{aligned}$ | $\mu \mathrm{s}$ <br> MHz <br> MHz <br> MHz <br> \% <br> ns <br> ns <br> MHz <br> $\mu \mathrm{s}$ |
| INPUTS: (Figure 4) SI <br> tsetup <br> thold <br> All Other Inputs tsetup thold |  | $\begin{gathered} 0.3 \\ 300 \\ \\ 1.7 \\ 300 \end{gathered}$ |  | $\mu \mathrm{s}$ ns $\mu \mathrm{s}$ ns |
| OUTPUT PROPAGATION DELAY <br> CKO <br> $t_{p d 1}, t_{p d 0}$ <br> $t_{p d 1}, t_{p d 0}$ <br> SO, SK <br> $t_{\text {pd1 }}, t_{p d 0}$ <br> All Other Outputs | Test Condition: $C_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V}$ <br> Crystal Input Schmitt Trigger Input $\begin{aligned} & R_{\mathrm{L}}=2.4 \mathrm{k} \Omega \\ & \mathrm{R}_{\mathrm{L}}=5.0 \mathrm{k} \Omega \\ & \hline \end{aligned}$ |  | $\begin{gathered} 0.17 \\ 0.3 \\ \\ 1.0 \\ 1.4 \end{gathered}$ | $\mu \mathrm{S}$ $\mu \mathrm{s}$ <br> $\mu \mathrm{s}$ $\mu \mathrm{S}$ |
| MICROBUS TIMING <br> Read Operation (Figure 2a) <br> Chip Select Stable Before $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{CSR}}$ <br> Chip Select Hold Time for $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{RCS}}$ <br> $\overline{\mathrm{RD}}$ Pulse Width $-\mathrm{t}_{\text {RR }}$ <br> Data Delay from RD- $t_{\text {RD }}$ <br> $\overline{\mathrm{RD}}$ to Data Floating-t $\mathrm{t}_{\mathrm{D}}$ <br> Write Operation (Figure 2b) <br> Chip Select Stable Before $\overline{W R}-t_{\text {CSW }}$ <br> Chip Select Hold Time for WR-t WCS <br> WR Pulse Width-tww <br> Data Set-Up Time for $\overline{W R}-t_{D W}$ <br> Data Hold Time for $\overline{W R}-t_{\text {wD }}$ <br> INTR Transition Time from $\overline{W R}-t_{W I}$ | $C_{L}=100 \mathrm{pF}, V_{C C}=5 \mathrm{~V} \pm 5 \%$ TRI-STATE Outputs | $\begin{gathered} 65 \\ 20 \\ 400 \\ \\ \\ 65 \\ 20 \\ 400 \\ 320 \\ 100 \end{gathered}$ | $\begin{aligned} & 375 \\ & 250 \end{aligned}$ $700$ |  |

Note 1: Variation due to the device included.


TL/DD/6926-2
FIGURE 2a. MICROBUS Read Operation Timing


FIGURE 2b. MICROBUS Write Operation TIming

## Connection Diagrams

Dual-In-Line Package


## Pin Descriptions

Pin Description
$L_{7}-L_{0} \quad 8$-bit Bidirectional I/O Port with TRI-STATE
$\mathrm{G}_{3}-\mathrm{G}_{0}$ 4-bit Bidirectional I/O Port
$D_{3}-D_{0}$ 4-bit General Purpose Output Port
$\mathrm{IN}_{3}-\mathrm{IN}_{0}$ 4-bit General Purpose Input Port (Not Available on COP442/COP342)
SI Serial Input
SO Serial Output (or General Purpose Output)
SK Logic-Controlled Clock (or General Purpose Output)

Pin Description
CKI System Oscillator Input
CKO System Oscillator Output (or General Purpose Input or RAM Power Supply)
RESET System Reset Input
VCC Power Supply
GND Ground
$\mathrm{H}_{3}-\mathrm{H}_{0}$ 4-bit Bidirectional I/O Port (COP440/COP340 Only)
$\mathrm{R}_{7}-\mathrm{R}_{0}$ 8-Bit Bidirectional I/O Port with TRI-STATE (COP440/COP340 Only)

## Timing Diagram



TL/DD/6926-7
FIGURE 4. Input/Output Timing Diagrams (Divide by 16 Mode)

## Functional Description

The block diagram of the COP440 is shown in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2.0 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).

## PROGRAM MEMORY

Program Memory consists of a 2,048 byte ROM. As can be seen by an examination of the COP440 instruction set, these words may be program instructions, constants, or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID, LQID, and LID instructions, ROM must often be thought of as being organized into 32 pages of 64 words each.
ROM addressing is accomplished by an 11-bit PC register. Its binary value selects one of the 2,048 8-bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 11-bit binary count value.
ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 640-bit RAM, organized as 10 data registers of 164 -bit digits. RAM addressing is implemented by an 8 -bit $B$ register whose upper 4 bits ( Br ) select 1 of $10(0-9)$ data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4 -bit contents of the selected RAM digit (M) is usually loaded into, or from, or exchanged with the A register (accumulator), it may also be loaded into or from the $Q$ latches, $L$ port, R port, EN register, and T counter (internal time base counter). RAM may also be loaded from 4 bits of a ROM word. RAM addressing may also be performed directly to the lower 8 registers by the LDD and XAD instructions based upon the 7 -bit contents of the operand field of these instructions. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs. RAM register $8(\mathrm{Br}=8)$ also serves as a subroutine stack. Note that it is possible, but not recommended, to alter the contents of the stack by normal data memory access commands.

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O arithmetic, logic, and data memory access operations. It can also be used to load the Br and Bd portions of the B register, N register, to load and input 4 bits of the 8 -bit $Q$ latch, EN register, or $T$ counter, to input 4 bits of a ROM word, L or R I/O port data, to input 4-bit G, H, or IN ports, and to perform data exchanges with the SIO register. The accumulator is cleared upon reset.
A 4-bit adder performs the arithmetic and logic functions of the COP440, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below).

The 8 -bit T counter is a binary up counter which can be loaded to and from M and $A$. The input to this counter is software selectable from two sources: the first coming from a divide-by-four prescaler (from instruction cycle frequency) thus providing a 10 -bit time base counter; the second coming from $\mathrm{IN}_{2}$ input, changing the T counter into an 8 -bit external event counter (see EN register below). In this mode, a low-going pulse (" 1 " to " 0 ") of at least 2 instruction cycles wide will increment the counter. When the counter overflows, an overflow flag will be set (see SKT instruction below) and an interrupt signal will be sent to processor $X$. The T counter is cleared on reset.
Four general-purpose inputs, $\mathbb{N}_{3}-\mathbb{N}_{0}$, are provided; $\mathbb{N}_{1}$, $\mathbb{N}_{2}$ and $\mathbb{N}_{3}$ may be selected, by a mask-programmable option, as Read Strobe, Chip Select, and Write Strobe inputs, respectively, for use in MICROBUS applications; $\mathrm{N}_{1}$, by another mask-programmable option, can be selected as a true zero-crossing detector with the output triggering an interrupt or being interrogated by an instruction. These two maskprogrammable options are mutually exclusive.
The $D$ register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd. The $G$ register contents are outputs to a 4 -bit general-purpose bidirectional I/O port. $\mathrm{G}_{0}$ may be mask-programmed as an output for MICROBUS applications.
The H register contents are outputs to a 4-bit general-purpose bidirectional I/O port.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are outputted to the L I/O ports when the $L$ drivers are enabled under program control. With the MICROBUS option selected, Q can also be loaded with the 8 -bit contents of the LI/O ports upon the occurrence of a write strobe from the host CPU. Note that unlike most other COPS controllers, $Q$ is cleared on reset.
The 8 L drivers, when enabled, output the contents of latched $Q$ data to the L I/O ports. Also, the contents of $L$ may be read directly into $A$ and $M$. As explained above, the MICROBUS option allows L I/O port data to be latched into the Q register. The LI/O port can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with $Q$ data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The R register, when enabled, outputs to an 8 -bit generalpurpose, bidirectional, I/O port.
The SIO register functions as a 4-bit serial-in/serial-out shift register for MICROWIRE I/O and COPS peripherals, or as a binary counter (depending on the contents of the EN register; see EN register description, below). Its contents can be exchanged with $A$, allowing it to input or output a continuous serial data stream.
The XAS instruction copies the C flag into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the instruction cycle clock.
The 2-bit N register is a stack pointer to the data memory register 8 where the subroutine return address is located. It points to the next location where the address may be stored

## Functional Description (Continued)

and increments by 1 after each push of the stack, and decrements by 1 before each pop. The N register can be accessed by exchanging its value with $A$ and is cleared on reset. The stack is 4 addresses deep, 12 bits wide, and does not check for overflow or empty conditions. The RAM digit locations where the addresses are stored are shown in Figure 5. The LSBs of the addresses are at digits 0, 4, 8, and 12. The MSBs of digits 2, 6, 10, and 14 contain an interrupt status bit (see Interrupt description, below). The four unused digits ( $3,7,11$, and 15 ) can be used as general data storage. When a subroutine call or interrupt occurs, an 11-bit return address and an interrupt status bit are stored in the stack. The N register is then incremented. When a RET or RETSK instruction is executed, the N register is decremented and then the return address is fetched and loaded into the program counter. The address and interrupt status bits remain in the stack, but will be overwritten when the next subroutine call or interrupt occurs.


## FIGURE 5. Subroutine Return Address Stack Organization

The EN register in an internal 8 -bit register loaded under program control by the LEI instruction (lower 4 bits) or by the CAME instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register.
0 . The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4 bit binary counter. With $\mathrm{EN}_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register left shifting 1 bit each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. The SK output becomes a logiccontrolled clock.

1. With $E N_{1}$ set, interrupt is enabled with $E N_{4}$ and $E N_{5}$ selecting the interrupt source. Immediately following an interrupt, $\mathrm{EN}_{1}$ is reset to disable further interrupts.
2. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in $Q$ to the L I/O port. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O port in a high-impedance input state. A special feature of the COP440 and COP441 is that the MICROBUS option will change the function of this bit to disable any writing into $\mathrm{G}_{0}$ when $\mathrm{EN}_{2}$ is set.
3. $E N_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $E N_{3}$. With $E N_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains set to " 0 ". Table I below provides a summary of the modes associated with $E N_{3}$ and $E N_{0}$.
4. $E N_{5}$ and $E N_{4}$ select the source of the interrupt signal.
5. The possible sources are as follows:

| EN $_{5}$ | EN $_{4}$ | Interrupt Source |
| :---: | :---: | :--- |
| 0 | 0 | IN 1 (low-going pulse) |
| 0 | 1 | CKO input (if mask-programmed as an input) |
| 1 | 0 | Zero-crossing (or IN $N_{1}$ level transition) |
| 1 | 1 | T counter overflows |

$\mathrm{EN}_{4}$ determines the interrupt routine location.
6. With $E N_{6}$ set, the internal 8-bit $T$ counter will use $\mathbb{N}_{2}$ as its input. With $\mathrm{EN}_{6}$ reset, the input to the T counter is the output of a divide by four prescaler (from instruction cycle frequency), thus providing a 10-bit time-base counter.
7. With $E N_{7}$ set, the $R$ outputs are enabled; if $E N_{7}=0$, the $R$ outputs are disabled.

## INTERRUPT

The following features are associated with the interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once acknowledged as explained below, pushes the next sequential program counter address (PC +1 ) together with an interrupt status bit, onto the program counter stack residing in data memory. Any previous contents at the bottom of the stack are lost. The program counter is set to hex address OFF (the last word of page 3) and $E N_{1}$ is reset. If $E N_{4}$ is reset, the next program address is hex 100; if $\mathrm{EN}_{4}$ is set, the next program address is hex 300; thus providing a different interrupt location for different interrupt sources.

TABLE I. Enable Register Modes - Bits $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$

| $\mathrm{EN}_{3}$ | $\mathrm{EN}_{0}$ | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } \mathrm{SKL}=1, \mathrm{SK}=\text { Clock } \\ & \text { If } \mathrm{SKL}=0, \mathrm{SK}=0 \\ & \hline \end{aligned}$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | $\begin{aligned} & \text { If } \mathrm{SKL}=1, \text { SK }=\text { Clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | $\begin{aligned} & \text { If } \mathrm{SKL}=1, \mathrm{SK}=1 \\ & \text { If } \mathrm{SKL}=0, \mathrm{SK}=0 \end{aligned}$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | $\begin{aligned} & \text { If } \mathrm{SKL}=1, \mathrm{SK}=1 \\ & \text { If } \mathrm{SKL}=0, S K=0 \end{aligned}$ |

## Functional Description (Continued)

b. An interrupt will be acknowledged only after the following conditions are met:

1. $E N_{1}$ has been set.
2. For an external interrupt input, the signal pulse must be at least two instruction cycles wide.
3. A currently executing instruction has been completed.
4. All successive transfer of control instructions and successive LBls have been completed (e.g., if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed.
c. The instruction at hex address OFF must be a NOP.
d. A CAME or LEI instruction may be put immediately before the RET instruction to re-enable interrupts.
e. If the interrupt signal source is being changed, the interrupt must be disabled prior to, or at, the same time with the change to avoid false interrupts. An interrupt may be enabled only if the interrupt source is not changing. A sample code for changing the interrupt source and enabling the interrupt is as follows:

| CAME | ; disable interrupt \& alter interrupt source |
| :--- | :--- |
| SMB 1 | ; set interrupt enable bit |
| CAME | ; enable interrupt |

f. An interrupt status bit is stored together with the return address in the stack. The status bit is set if an interrupt occurs at a point in the program where the next instruction is to be skipped; upon returning from the interrupt routine, this set status bit will cause the next instruction to be skipped. Subroutine and interrupt nesting inside interrupt routines are allowed. Note that this differs from the COP420/420C/420L/444L series.

## MICROBUS INTERFACE

## (not available in COP442, COP342)

The COP440 series has an option which allows them to be used as peripheral microprocessor devices, inputting and outputting data from and to a host microprocessor ( $\mu$ P). $\mathbb{N}_{1}$, $\mathrm{IN}_{2}$ and $I \mathrm{~N}_{3}$ general purpose inputs become MICROBUScompatible read-strobe, chip-select, and write-strobe lines, respectively. $\mathbb{N}_{1}$ becomes $\overline{R D}$-a logic " 0 " on this input
will cause $Q$ latch data to be enabled to the $L$ ports for input to the $\mu \mathrm{P}$. $\mathrm{N}_{2}$ becomes $\overline{\mathrm{CS}}$-a logic " 0 " on this line selects the COPS processor as the $\mu \mathrm{P}$ peripheral device by enabling the operation of the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ lines and allows for the selection of one of several peripheral components. $\mathrm{IN}_{3}$ becomes $\overline{W R}$-a logic " 0 " on this line will write bus data from the L ports to the $Q$ latches for input to the COPS processor. $\mathrm{G}_{0}$ becomes INTR, a "ready" output, reset by a write pulse from the $\mu \mathrm{P}$ on the $\overline{\mathrm{WR}}$ line, providing the "handshaking" capability necessary for asynchronous data transfer between the host CPU and the COPS processor. $G_{0}$ output can be separated from other G outputs by the $E N_{2}$ bit (see EN description above).
This option has been designed for compatibility with National's MICROBUS-a standard interconnect system for 8 -bit parallel data transfer between MOS/LSI CPUs and interfacing devices. (See MICROBUS National Publication.) The functional and timing relationships between the COPS processor signal lines affected by this option are as specified for the MICROBUS interface, and are given in the AC electrical characteristics and shown in the timing diagrams (Figure 2). Connection of the COP440 to the MICROBUS is shown in Figure 6.
Note: TRI-STATE outputs must be used on L port.

## ZERO-CROSSING DETECTION

## (not available on the COP442, COP342)

The following features are associated with the $\mathrm{IN}_{1}$ pin: $\operatorname{ININ}$ and INIL instructions input the state of $\mathrm{N}_{1}$ to $\mathrm{A}_{1}$; $\mathrm{IN}_{1}$ interrupt generates an interrupt pulse when a low-going transition (" 1 " to " 0 ") occurs on $\mathrm{IN}_{1}$; zero-crossing interrupt generates an interrupt pulse when an $\mathbb{N}_{1}$ transition occurs (both " 1 " to " 0 " and " 0 " to " 1 ").
If the zero-crossing detector is mask-programmed in (see Figure 7a), the INIL instruction and zero-crossing interrupt will input the state of $\mathbb{N}_{1}$ through the true zero-crossing detector (" 1 " if input $>0 \mathrm{~V}$, " 0 " if input < 0 V ). The ININ instruction and $\mathbb{N}_{1}$ interrupt will then have unique logic HIGH and LOW levels depending on the IN port input level chosen. If normal (TTL) level is chosen, logic HIGH level is 3.0V (3.3V for COP340/341) and logic LOW level is 0.8 V


TL/DD/6926-9
FIGURE 6. MICROBUS Option Interconnect

## Functional Description (Continued)



TL/DD/6926-10
*Note: This input has a different set of logic HIGH and LOW levels; see above description.
a. Zero-Crossing Detect Logic Option


TL/DD/6926-11

## b. IN, without Zero-Crossing Detect Logic

FIGURE 7. IN, Mask-Programmable Options
( 0.6 V for COP340/341) ; if high trip level is chosen, logic HIGH level is 5.4 V and logic LOW level is 1.2 V . If the zerocrossing detector is not mask-programmed in (see Figure $7 b$ ), $\mathbb{N}_{1}$ will have logic HIGH and LOW levels that are defined for the IN port (see option list).
The zero-crossing detector input contains a small hysteresis ( 50 mV typical) to eliminate signal noise, and is not a high impedance input but contains a resistive load to ground. Since this input can withstand a voltage range of -0.8 V to +12 V , an external clamping diode is needed for most input signals, as shown in Figure 7a, to limit the voltage below ground. An external resistor, R may be needed for the following two cases:
a. Input signal exceeds $12 \mathrm{~V} ; \mathrm{R}_{\mathrm{S}}$ and the internal resistor act as a voltage divider to reduce the voltage at the input pin to below 12 V .
b. Signal comes from a low impedance source; when the voltage at the pin is clamped to -0.7 V by the forward bias voltage of an external diode, $\mathrm{R}_{\mathrm{S}}$ limits the current going through the diode.

## INITIALIZATION

The $\overline{\text { RESET }}$ pin is configured as a Schmitt trigger input. If not used, it should be connected to $\mathrm{V}_{\mathrm{CC}}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times. The user must provide an external RC network and diode to the RESET pin as in Figure 8. The external POR (Power-on-Reset) delay must be greater than the internal POR. The internal POR delay is 2600 internal clock cycles. Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N, G, H, I L, L, N, Q, R$, and T registers are cleared. The SK output is enabled as a SYNC output by setting the SKL latch, thus providing a clock. RAM (data memory and stack) is not cleared. The first instruction at address 0 must be a CLRA.


RC $\geq 5 \times$ power supply rise time
FIGURE 8. Power-Up Clear Circuit

## OSCILLATOR

There are three basic clock oscillator configurations available, as shown by Figure 9.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The cycle frequency equals the crystal frequency divided by 16 (optional by 8 ). Thus a 4 MHz crystal with the divide-by-16 option selected will give a 250 kHz cycle frequency ( $4 \mu \mathrm{~s}$ instruction cycle time).
b. External Oscillator. CKI is an external clock input signal. The external frequency is divided by 16 (optional by 8 or 4) to give the cycle frequency. If the divide-by-4 option is selected, the CKI input level is the Schmitt-trigger level. CKO is now available to be used as the RAM power supply $\left(V_{R}\right)$ or as a general purpose input.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The cycle frequency equals the oscillation frequency divided by 4. CKO is available for non-timing functions.

## CKO PIN OPTIONS

As an option, CKO can be an oscillator output. In a crystal controlled oscillator system, this signal is used as an output to the crystal network. As another option, CKO can be an interrupt input or a general purpose input, reading into bit 2 of A (accumulator) through the INIL instruction. As another option, CKO can be a RAM power supply pin $\left(\mathrm{V}_{\mathrm{R}}\right)$, allowing

Functional Description (Continued)
a. Crystal Oscillator

b. External Oscillator



TL/DD/6926-15
c. RC Controlled Oscillator

| Crystal Oscillator |  |
| :--- | :--- |
| Crystal Value | $\mathbf{R}_{\mathbf{1}}$ |
| 4 MHz | 1 k |
| 3.58 MHz | 1 k |
| 2.10 MHz | 2 k |

RC Controlled Oscillator

| $R(k \Omega)$ | $\mathbf{C}(\mathbf{p F})$ | Instruction <br> Execution <br> Time $(\mu \mathbf{s})$ |
| :---: | :---: | ---: |
| 13 | 100 | $5.0 \pm 20 \%$ |
| 6.8 | 220 | $5.3 \pm 23 \%$ |
| 8.2 | 300 | $8.0 \pm 22 \%$ |
| 22 | 100 | $8.2 \pm 17 \%$ |

Note: $5 \mathrm{k} \Omega \leq \mathrm{R} \leq 50 \mathrm{k} \Omega$
$50 \mathrm{pF} \leq \mathrm{C} \leq 360 \mathrm{pF}$

## FIGURE 9. COP440/441/442 Oscillators

its connection to a standby/backup power supply to maintain the data integrity of RAM registers $0-3$ with minimum power drain when the main supply is inoperative or shut down to conserve power. Using either of the two latter options is appropriate in applications where the system configuration does not require use of the CKO pin for timing functions.

## RAM KEEP-ALIVE OPTION

Selecting CKO as the RAM power supply ( $\mathrm{V}_{\mathrm{R}}$ ) allows the user to shut off the chip power supply ( $\mathrm{V}_{\mathrm{CC}}$ ) and maintain data in the lower 4 registers of the RAM. To insure that RAM data integrity is maintained, the following conditions must be met:

1. $\overline{\text { RESET }}$ must go low before $V_{C C}$ goes below spec during power-off; $V_{C C}$ must be within spec before RESET goes high on power-up.
2. When $V_{C C}$ is on, $V_{R}$ must be within the operating voltage range of the chip, and within 1 V of $\mathrm{V}_{\mathrm{CC}}$.
3. $V_{R}$ must be $\geq 3.3 V$ with $V_{C C}$ off.

## I/O OPTIONS

COP440 inputs have the following optional configurations, illustrated in Figure 10.
a. An on-chip depletion load device to $V_{C C}$.
b. A Hi-Z input which must be driven to a " 1 " or " 0 " by external components.
c. A resistive load to GND for the zero-crossing input option ( $\mathrm{IN}_{1}$ only).
COP440 outputs have the following optional configurations:
d. Standard-an enhancement mode device to ground in conjunction with a depletion-mode device to $V_{C C}$, compatible with TTL and CMOS input requirements. Available on SO, SK, D, G, and H outputs.
e. Open-Draln-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. Available on SO, SK, D, G, L, H, and R outputs.
f. Push-Pull-an enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{CC}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. Available on SO and SK outputs only.
g. Standard L,R-same as d., but may be disabled. Available on $L$ and $R$ outputs only (disabled on reset).
h. LED Direct Drive-an enhancement-mode device to ground and $V_{C C}$ together with a depletion device to $V_{C C}$ meeting the typical current sourcing requirements of the segments of an LED display. The sourcing devices are clamped to limit current flow. These devices may be turned off under program control (see Functional Description, EN Register), placing the output in a high-impedance state to provide required LED segment blanking for a multiplexed display. Available on L outputs only.
Note 1: When the driver is disabled, the depletion device may cause the output to settle down to an intermediate level between $V_{C C}$ and GND. This voltage cannot be relied upon as a " 1 " level when reading the $L$ inputs. The external signal must drive it to a " 1 " level.
Note 2: Much power is dissipated by this driver in driving an LED. Care must be taken to limit the power dissipation of the chip to within the absolute maximum ratings specified.
i. TRI-STATE Push-Pull-an enhancement-mode device to ground and $\mathrm{V}_{\mathrm{CC}}$. These outputs are TRI-STATE outputs, allowing for connection of these outputs to a data bus shared by other bus drivers. Available on L and R outputs only (in TRI-STATE mode on reset).
j. Push-Pull R—same as f., but may be disabled. Available on R outputs only.
k. Additional depletion pull-up-a depletion load to $V_{C C}$ with the same current sourcing capability as the input load a., in addition to the output drive chosen. Available on $L$ and $R$ outputs only. This device cannot be disabled; therefore, open-drain outputs with " 1 " output and TRISTATE outputs do not show high-impedance characteristics. This device is useful in applications where a pull-up with low source current is desired, e.g., reading keyboards and switches.
The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6 respectively). Minimum and maximum current (lout and VOUT) curves are given in Figures 11 and 12 for each of these devices to allow the designer to effectively use these I/O configurations in designing a COP440 system.

## Functional Description (Continued)




TL/DD/6926-21
f. Push-Pull Output

( $\boldsymbol{*}$ is depletion device)
h. LED (L) Outputs

FIGURE 10. Input/Output Configurations


FIGURE 11. COP440/441/442 I/O Characteristics

## Typical Performance Characteristics (Continued)





g. Push-Pull Source Current


b. Input Load Minimum

Source Current
d. Standard Output Source Current

Wout -

VCC - volts devices 4 and 6




k. LED Output Minimum Source Current
e. Standard Output Minimum
h. TRI-STATE Output Source

I. LED Output Direct LED


TL/DD/6926-28
FIGURE 12. CCOP340/341/342 I/O Characteristics

## Power Dissipation

In order not to damage the device by exceeding the absolute maximum power dissipation rating, the amount of power dissipated inside the chip must be carefully controlled. As an example, an application uses a COP440 in room temperature $\left(25^{\circ} \mathrm{C}\right)$ environment with a $\mathrm{V}_{\mathrm{CC}}$ power supply of 6 V ; IN and SI inputs have internal loads; G and D ports drive loads that may sink up to 2 mA into the chip; H port with standard output option reads switches; L port with the LED option drives a multiplexed seven-segment display; R, SO and SK drive MOS inputs that do not source or sink any current.
a. At $25^{\circ} \mathrm{C}$, maximum power dissipation allowed $=750 \mathrm{~mW}$
b. Power dissipation by chip except

$$
\mathrm{I} / \mathrm{O}=\mathrm{I}_{\mathrm{CC}} \times \mathrm{V}_{\mathrm{CC}}=35 \mathrm{~mA} \times 6 \mathrm{~V}=210 \mathrm{~mW}
$$

c. Maximum power dissipation by $\mathbb{N}$,

$$
\mathrm{SI}=5 \times 0.3 \mathrm{~mA} \times 6 \mathrm{~V}=9 \mathrm{~mW}
$$

d. $G$ and $D$ ports are sinking current from external loads; maximum output voltage with 2 mA sink current is less than 0.4 V . Power dissipation by G and D ports $=$

$$
2 \mathrm{~mA} \times 0.4 \mathrm{~V} \times 8=6.4 \mathrm{~mW}
$$

e. Maximum power dissipation by H port $=$

$$
4 \times 1.5 \mathrm{~mA} \times 6 \mathrm{~V}=36 \mathrm{~mW}
$$

f. When the seven segments of the LED are turned on, the output voltage is about 2 V , so that the segment current is 17 mA . Power dissipation by L port $=$

$$
7 \times 17 \mathrm{~mA} \times(6 \mathrm{~V}-2 \mathrm{~V})=476 \mathrm{~mW}
$$

This power dissipation caused by driving LEDs is usually the highest among the various sources.
g. R, SO, and SK do not dissipate any significant amount of power because they do not need to source or sink any current.

Total power dissipation (TPD) inside the device is the sum of items $b$ through $g$ above.

$$
\mathrm{TPD}=210+9+6+36+476 \mathrm{~mW}=737 \mathrm{~mW}
$$

This is within the 750 mW limit at room temperature. If this application has to operate at $70^{\circ} \mathrm{C}$, then the power dissipation must be reduced to meet the limit at that temperature. Some ways to achieve this would be to limit the LED current or to use an external LED driver.
At $70^{\circ} \mathrm{C}$ the absolute maximum power dissipation rating drops to 400 mW . The user must be careful not to exceed this value.

## COP440 SERIES DEVICES

If the COP440 is bonded as a 28 - or 24 -pin device, it becomes the COP441 or COP442, respectively, as illustrated in Figure 3. Note that the COP441 and COP442 do not include H and R ports. In addition, the COP442 does not include IN inputs; use of this option precludes the use of the IN options, the interrupt feature with $\operatorname{IN}$ as input, the zerocrossing detect option, $\mathbb{N}_{2}$ external event counter input, and the MICROBUS option. All other options are available. COP340, COP341, and COP342 are extended temperature versions of the COP440, COP441, and COP442, respectively.

## COP440 Series Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operation symbols used in the instruction set table.
Table III provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with each instruction in the COP440 series instruction set.

TABLE II. COP440 Series Instruction Set Symbols
Symbol Definition

## INTERNAL ARCHITECTURE SYMBOLS

| A | 4-bit Accumulator |
| :--- | :--- |
| B | 8-bit RAM Address Register |
| Br | Upper 4 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 8-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| H | 4-bit Register to latch data for H I/O Port |
| IL | Two 1-bit Latches associated with the IN $N_{3}$ or IN $N_{0}$ Inputs |
| IN | 4-bit Input Port |
| IN ${ }_{1}$ Z | Zero-Crossing Input |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B Register |
| N | 2-bit subroutine return address stack pointer |
| PC | 11-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| R | 8-bit Register to latch data for R TRI-STATE I/O Port |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |
| T | 8-bit Binary Counter Register |

## Symbol

## Definition

## INSTRUCTION OPERAND SYMBOLS

d 4-bit Operand Field, $0-15$ binary (RAM Digit Select)
r 4-bit Operand Field, 0-9 binary (RAM Register Select)
a 11-bit Operand Field, 0-2047 binary (ROM Address)
y 4-bit Operand Field, $0-15$ binary (Immediate Data)
RAM(s) Content of RAM location addressed by s
RAM $N_{N}$ Content of RAM location addressed by stack pointer $N$
ROM(t) Content of ROM location addressed by $t$


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE III. COP440 Serles Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAME |  | 33 | 0011 0011 <br> 0001 1111 | $\begin{aligned} & A \rightarrow \mathrm{EN}_{7: 4} \\ & \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{EN} \\ & 3: 0 \end{aligned}$ | None | Copy A, RAM to EN |
| CAMQ |  | 33 30 | 0011 0011 <br> 0011 1100 |  | None | Copy A, RAM to Q |
| CAMT |  | 33 $3 F$ | 0011 0011 <br> 0011 1111 | $\underset{\mathrm{RAM}(\mathrm{~B})}{\mathrm{A} \rightarrow \mathrm{~T}_{7: 4}} \underset{\mathrm{~T}: 0}{ }$ | None | Copy A, RAM to T |
| CEMA |  | 33 $0 F$ | 0011 0011 <br> 0000 1111 | $\begin{aligned} & \mathrm{EN}_{7: 4} \rightarrow \text { RAM }(\mathrm{B}) \\ & \mathrm{EN}_{3: 0} \rightarrow \mathrm{~A} \end{aligned}$ | None | Copy EN to RAM, A |
| CQMA |  | 33 $2 C$ | 0011 0011 <br> 0010 1100 | $\begin{aligned} & \mathrm{Q}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{Q}_{3: 0} \rightarrow \mathrm{~A} \end{aligned}$ | None | Copy Q to RAM, A |
| CTMA |  | 33 $2 F$ | 0011 0011 <br> 0010 1111 | $\begin{aligned} & \mathrm{T}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{T}_{3: 0} \rightarrow \mathrm{~A} \end{aligned}$ | None | Copy $T$ to RAM, A |
| LD | r | -5 | $\begin{gathered} \|00\| r\|0101\| \\ r=0: 3 \end{gathered}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A, Exclusive-OR Br with r |
| LDD | r,d | 23 | $$ | RAM(r,d) $\rightarrow$ A | None | Load A with RAM pointed to directly by r,d |
| LID |  | $\begin{aligned} & 33 \\ & 19 \end{aligned}$ | $0011 \mid 0011$ <br> $0001\|1001\|$ | $R O M\left(P C_{10: 8}, A, M\right) \rightarrow M, A$ | None | Load RAM, A Indirect |
| LQID |  | BF | 1011 11111 | $\mathrm{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q}$ | None | Load Q Indirect (Note 3) |
| RMB | 0 1 2 3 | $4 C$ 45 42 43 | 0100 1100 <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{aligned} 0 & \rightarrow R A M(B)_{0} \\ 0 & \rightarrow R A M(B)_{1} \\ 0 & \rightarrow R A M(B)_{2} \\ 0 & \rightarrow \text { RAM }(B)_{3} \end{aligned}$ | None | Reset RAM Bit |
| SMB | 0 1 2 3 | $4 D$ 47 46 $4 B$ | 0100 1101 <br> 0100 0111 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} 1 & \rightarrow \operatorname{RAM}(B)_{0} \\ 1 & \rightarrow \operatorname{RAM}(B)_{1} \\ 1 & \rightarrow \operatorname{RAM}(B)_{2} \\ 1 & \rightarrow \operatorname{RAM}(B)_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | $y$ | $7-$ | 01111 y | $\begin{aligned} & y \rightarrow \text { RAM(B) } \\ & B d+1 \rightarrow B d \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| $x$ | r | -6 | $\frac{100\|r\| 0110 \mid}{r=0: 3}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with r |
| XAD | r,d | $23$ | $\begin{gathered} \|0010\| 0011 \mid \\ \hline 1\|r\| d \\ \hline r=0.7 \end{gathered}$ | RAM (r,d) $\longleftrightarrow \mathrm{A}$ | None | Exchange A with RAM pointed to directly by r,d |
| XDS | $r$ | -7 | $\frac{\|00\| r\|0111\|}{r=0: 3}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd, Exclusive-OR Br with $r$ |
| XIS | r | -4 | $\begin{gathered} \|00\| r\|0100\| \\ r=0: 3 \end{gathered}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \longrightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with $A$ and Increment Bd, Exclusive-OR Br with $r$ |



| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE III. COP440 Series Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| CAMR |  | 33 | 0011\|0011| | $A \rightarrow \mathrm{R}_{7: 4}$ | None | Output A, RAM to R Port |
|  |  | 3D | 0011 1101 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{R}_{3} \mathbf{0}$ |  |  |
| ING |  | 33 | 0011\|0011 | $\mathrm{G} \rightarrow \mathrm{A}$ | None | input G Port to $A$ |
|  |  | 2 A | -0010\|1010 |  |  |  |
| INH |  | 33 | 0011 00011 | $H \rightarrow A$ | None | Input H Port to A |
|  |  | 2 B | \|0010|1011 |  |  |  |
| ININ |  | 33 | 0011 0011 | $\mathbb{N} \rightarrow \mathrm{A}$ | None | Input IN Inputs to A (Note 2) |
|  |  | 28 | -0010 1000 1 |  |  |  |
| INIL |  | 33 | 0011\|0011 | $\mathrm{IL}_{3}, \mathrm{CKO}, \mathrm{IN}_{1} \mathrm{Z}, \mathrm{IL}_{0} \rightarrow \mathrm{~A}$ | None | Input IL Latches to A |
|  |  | 29 | \|0010|1001| |  |  | (Note 3) |
| INL |  | 33 | 0011 00011 | $\mathrm{L}_{7: 4} \rightarrow$ RAM $(\mathrm{B})$ | None | Input L Port to RAM, A |
|  |  | 2 E | \|0010|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| INR |  | 33 | 0011 0011 | $\mathrm{R}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input R Port to RAM, A |
|  |  | 2D | 0010\|1101 | $\mathrm{R}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | 00110011 \| | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Port |
|  |  | 3E | 0011 1110 |  |  |  |
| OGI | $y$ | 33 | 0011 0011 | $y \rightarrow G$ | None | Output to G Port Immediate |
|  |  | 5- | 0101\| y |  |  |  |
| OMG |  | 33 | 00110011 | RAM (B) $\rightarrow$ G | None | Output RAM to G Port |
|  |  | 3A | 0011 1010 |  |  |  |
| OMH |  | 33 | 0011 00011 | RAM(B) $\rightarrow \mathrm{H}$ | None | Output RAM to H Port |
|  |  | 3B | 0011 1011 |  |  |  |
| XAS |  | 4F | 0100 1111 | $\mathrm{A} \longleftrightarrow \mathrm{SIO}, \mathrm{C} \rightarrow$ SKL | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit $A$ register.
Note 2: The $\mathbb{I N I N}$ instruction is not available on the 24-pin COP442/COP342 since this device does not contain the $\mathbb{N}$ inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while in subroutine pages 2 or 3 , to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 5: A JSRP transfers program control to subroutine page 2 ( 00010 is loaded into the upper 5 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ " data minus $t$, e.g., to load the lower four bits of $B(\mathrm{Bd})$ with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(100 \mathrm{O}_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP440 programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN register, above). If SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M . It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 11-bit word, $\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{10}, \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ are not affected by this instruction.
Note that JID requires 2 instruction cycles if executed, 1 instruction cycle time if skipped.

## INIL INSTRUCTION

INIL (Input IL Latches to $A$ ) inputs 2 latches, $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$, CKO and $\mathrm{IN}_{1}$ into A (see Figure 13). The $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ latches are set if a low-going pulse (" 1 " to " 0 ") has occurred on the $\mathrm{IN}_{3}$ and $\mathrm{I} \mathrm{N}_{0}$ inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction cycles. Execution of an $\mathbb{N I L}$ inputs $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ into A 3 and AO respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the $\mathbb{I N}_{3}$ and $\mathbb{N}_{0}$ lines. If CKO is mask-programmed as a general purpose input, an INIL will input the state of CKO into A2. If CKO has not been so programmed, a "1" will be placed in A2. Unlike the COP420/420C/420L/444L series, INIL will input $\mathrm{IN}_{1}$ into A1.


FIGURE 13. INIL Hardware Implementation

If zero-crossing detect is selected, the $\mathbb{N}_{1}$ input will go through the detection logic, thus allowing the user to interrogate the input, sending a " 1 " if the input is above 0 V and a " 0 " if it is below OV. INIL is useful in recognizing pulses of short duration or pulses which occur too often to be read conveniently by an ININ instruction. It is also useful in checking the status of the zero-crossing detect input. The general purpose inputs $I N_{3}-I N_{0}$ are input to $A$ upon execution of an ININ instruction, and the $\mathrm{IN}_{1}$ input does not go through zero-crossing logic so that it has the same logic level as the other $\operatorname{IN}$ inputs for the ININ instruction (see Figure 9).
Note: IL latches are cleared on reset. This is different from the COP420/ 420C/420L/444L series.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 11-bit word $\mathrm{PC}_{10}: \mathrm{PC}_{8}, \mathrm{~A}$, M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. Note that LQID takes two instruction cycles if executed and one instruction cycle if skipped. Unlike most other COPS processors, this instruction does not push the stack.

## LID INSTRUCTION

LID (Load Indirect) loads $M$ and $A$ with the contents of ROM pointed to by the 11-bit word $\mathrm{PC}_{10}: \mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}$. Note that LID takes three instruction cycles if executed and two if skipped.

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of the T counter (see internal logic, above) overflow latch, executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction allow the processor to generate its own time-base for real-time processing, rather than relying on an external input signal.

## INSTRUCTION SET NOTES

a. The first word of a COP440 program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, they are still fetched from program memory. Thus program paths take the same number of cycle times whether instructions are skipped or executed, except for LID, LQID, and JID.
c. The ROM is organized into 32 pages of 64 words each. The Program Counter is an 11-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID, LQID, or LID instruction is the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page $3,7,11,15,19,23,27$, or 31 will access data in the next group of four pages.

## Option List

The COP440 mask-programmable options are assigned numbers which correspond with the COP440 pins.

Option 1: $\mathrm{L}_{1}$ I/O Port (see note below)
$=0$ : Standard output
= 1: Open-drain output
= 2: LED direct drive output
$=3$ : TRI-STATE output
$=4$ : same as 0 with extra load device to $V_{C C}$
$=5$ : same as 1 with extra load device to $V_{C C}$
$=6$ : same as 2 with extra load device to $V_{C C}$
$=7$ : same as 3 with extra load device to $V_{C C}$
Option 2: L L I/O Port
(same as Option 1)
Option 3: SI Input
$=0$ : Input with load device to $V_{C C}$
$=1: \mathrm{Hi}-\mathrm{Z}$ Input
Option 4: SO Output
$=0$ : Standard output
$=1$ : Open-drain output
= 2: Push-pull output
Option 5: SK Output (same as Option 4)
Option 6: $\mathbb{I N}_{0}$ Input (same as Option 3)
Option 7: $\operatorname{IN} 3$ Input (same as Option 3)
Option 8: Go I/O Port $=0$ : Standard output $=1$ : Open-drain output
Option 9, G1 I/O Port (same as Option 8)
Option 10: $\mathrm{G}_{2}$ I/O Port (same as Option 8)
Option 11: $\mathrm{G}_{3}$ I/O Port (same as Option 8)
Option 12: $\mathrm{H}_{0} \mathrm{I} / \mathrm{O}$ Port (same as Option 8)
Option 13: $\mathrm{H}_{1} \mathrm{I} / \mathrm{O}$ Port (same as Option 8)
Option 14: $\mathrm{H}_{2} \mathrm{I} / \mathrm{O}$ Port (same as Option 8)
Option 15: $\mathrm{H}_{3} \mathrm{I} / \mathrm{O}$ Port (same as Option 8)
Option 16: $\mathrm{D}_{3}$ Output (same as Option 8)
Option 17: $\mathrm{D}_{2}$ Output (same as Option 8)
Option 18: $\mathrm{D}_{1}$ Output (same as Option 8)
Option 19: $\mathrm{D}_{0}$ Output (same as Option 8)
Option 20: GND-No options available

Option 21: CKO Pin
$=0$ : Oscillator output
$=1$ : RAM power supply $\left(V_{R}\right)$ input
= 2: General purpose input with load device to $V_{C C}$
= 3: General purpose $\mathrm{Hi}-\mathrm{Z}$ input
Option 22: CKI Input
$=0$ : Crystal input divided by 16
$=1$ : Crystal input divided by 8
$=2$ : Single-pin RC controlled oscillator ( $\div 4$ )
= 3: Schmitt trigger clock input ( $\div 4$ )
Option 23: $\overline{\text { RESET }}$ Input
(same as Option 3)
Option 24: R $\mathrm{R}_{7}$ I/O Port (see note below)
$=0$ : Standard output
= 1: Open-drain output
= 2: Push-pull output
= 3: TRI-STATE output
$=4$ : same as 0 with extra load device to $V_{C C}$
$=5$ : same as 1 with extra load device to $V_{C C}$
$=6$ : same as 2 with extra load device to $V_{C C}$
$=7$ : same as 3 with extra load device to $V_{C C}$
Option 25: $\mathrm{R}_{6}$ I/O Port
(same as Option 24)
Option 26: $\mathrm{R}_{5}$ I/O Port
(same as Option 24)
Option 27: $\mathrm{R}_{4} \mathrm{I} / \mathrm{O}$ Port (same as Option 24)
Option 28: $\mathrm{R}_{3}$ I/O Port (same as Option 24)
Option 29: R2 I/O Port (same as Option 24)
Option 30: R1/O Port (same as Option 24)
Option 31: R I/O Port (same as Option 24)
Option 32: L7 I/O Port (same as Option 1)
Option 33: $\mathrm{L}_{6}$ I/O Port (same as Option 1)
Option 34: $\mathrm{L}_{5}$ I/O Port (same as Option 1)
Option 35: $\mathrm{L}_{4}$ I/O Port (same as Option 1)
Option 36: $\mathbb{N}_{1}$ Input
$=0$ : Input with load device to $V_{C C}$
$=1: \mathrm{Hi}-\mathrm{Z}$ Input
$=2$ : Zero-crossing detect input (Option $41=0$ )
Option 37: $\mathrm{IN}_{2}$ Input
(same as Option 3)
Option 38: $\mathrm{L}_{3}$ I/O Port (same as Option 1)
Option 39: L $\mathrm{L}_{2}$ I/O Port (same as Option 1)
Option 40: $V_{C C}-$ no options available

## Option List (Continued)

Option 41: COP Function
$=0$ : Normal
$=1$ : MICROBUS option
Option 42: IN Input Levels
$=0$ : Standard TTL input levels ("0" $=0.8 \mathrm{~V}$, " 1 " $=2.0 \mathrm{~V}$ )
= 1: Higher voltage input levels (" 0 " = 1.2V, " 1 " = 3.6V)

Option 43: G Input Levels
(same as Option 42)
Option 44: L Input Levels
(same as Option 42)
Option 45: CKO Input Levels
(same as Option 42)

Option 46: SI Input Levels (same as Option 42)
Option 47: R Input Levels (same as Option 42)
Option 48: H Input Levels (same as Option 42)
Option 49: No option available
Option 50: COP Bonding
= 0: COP440 (40-pin device)
= 1: COP441 (28-pin device)
= 2: COP442 (24-pin device)
= 3: COP440 and COP441
= 4: COP440 and COP442
= 5: COP440, COP441, and COP442
= 6: COP441 and COP442

## COP440 Option Table

The following options information is to be sent to National along with the EPROM.


## Note on L and R I/O Port Options

If $L$ and R I/O Ports are used as inputs, the following must be observed:
a. Open-Drain output (selection 1) is allowed only if external pull-up is provided.
b. If $L$ and $R$ output ports are disabled when reading, an external pull-up is required unless selections $4,5,6$, or 7 are chosen.
c. If $L$ output port is enabled, selections 3 and 7 are not allowed.
d. If $R$ output port is enabled, selections $2,3,6$, and 7 are not allowed.

| O | IS: $\mathrm{R}_{5} \mathrm{I} / \mathrm{O}$ PORT |
| :---: | :---: |
| OPTION 27 VALUE | IS: $\mathrm{R}_{4} \mathrm{I} / \mathrm{O}$ PORT |
| OPTION 28 VALUE | IS: $\mathrm{R}_{3} \mathrm{I} / \mathrm{O}$ PORT |
| OPTION 29 VALUE | IS: $\mathrm{R}_{2}$ I/O PORT |
| OPTION 30 VALUE | IS: $\mathrm{R}_{1}$ I/O PORT |
| OPTION 31 VALUE | IS: $\mathrm{R}_{0} \mathrm{I} / \mathrm{O}$ PORT |
| OPTION 32 VALUE | IS: $L_{7}$ I/O PORT |
| OPTION 33 VALUE | IS: $L_{6}$ I/O PORT |
| OPTION 34 VALUE | IS: $L_{5}$ I/O PORT |
| OPTION 35 VALUE | IS: $L_{4}$ I/O PORT |
| OPTION 36 VALUE | IS: $\mathrm{IN}_{1}$ INPUT |
| OPTION 37 VALUE | IS: $\mathrm{IN}_{2}$ INPUT |
| OPTION 38 VALUE | IS: $\mathrm{L}_{3}$ I/O PORT |
| OPTION 39 VALUE | IS: $\mathrm{L}_{2}$ I/O PORT |
| OPTION 40 VALUE | IS: $\mathrm{V}_{\mathrm{CC}}$ |
| OPTION 41 VALUE | IS: COP FUNCTION |
| OPTION 42 VALUE | IS: IN INPUT LEVELS |
| OPTION 43 VALUE | IS: G INPUT LEVELS |
| OPTION 44 VALUE | IS: L INPUT LEVELS |
| OPTION 45 VALUE | IS: CKO INPUT LEVELS |
| OPTION 46 VALUE | IS: SI INPUT LEVELS |
| OPTION 47 VALUE | IS: R INPUT LEVELS |
| OPTION 48 VALUE | IS: H INPUT LEVELS |
| OPTION 49 VALUE | IS: NO OPTION |
| OPTION 50 VALUE | IS: COP BONDING |

## Test Mode (Non-Standard Operation)

The SO output has been configured to provide for standard test procedures for the custom-programmed COP440. With SO forced to logic " 1 ", two test modes are provided, depending upon the value of SI :
a. RAM and Internal Logic Test Mode ( $\mathrm{SI}=1$ )
b. ROM Test Mode ( $\mathrm{SI}=0$ )

These special test modes should not be employed by the user; they are intended for manufacturing test only.

National Semiconductor Corporation

## COP444L/COP445L/COP344L/COP345L Single-Chip N-Channel Microcontrollers

## General Description

The COP444L, COP445L, COP344L, and COP345L SingleChip N-Channel Microcontrollers are members of the COPSTM family, fabricated using N -channel, silicon gate MOS technology. These controller oriented processors are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include single supply operation, a variety of output configuration options, with an instruction set, internal architecture and I/O scheme designed to facilitate keyboard input, display output and BCD data manipulation. The COP445L is identical to the COP444L, but with 19 I/O lines instead of 23. They are an appropriate choice for use in numerous human interface control environments. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a customized controller oriented processor at a low endproduct cost.
The COP344L and COP345L are exact functional equivalents, but extended temperature range versions of the COP444L and COP445L respectively.

## Features

- Low cost
- Powerful instruction set
- $2 k \times 8$ ROM, $128 \times 4$ RAM
- 23 I/O lines (COP444L)
- True vectored interrupt, plus restart
- Three-level subroutine stack
- $15 \mu \mathrm{~s}$ instruction time

■ Single supply operation (4.5-6.3V)

- Low current drain ( 11 mA max.)
- Internal time-base counter for real-time processing
- Internal binary counter register with MICROWIRETM serial I/O capability
- General purpose and TRI-STATE® outputs
- LSTTL/CMOS compatible in and out
- Direct drive of LED digit and segment lines
- Software/hardware compatible with other members of COP400 family
- Extended temperature range devices COP344L/COP345L $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
- Wider supply range (4.5-9.5V) optionally available


## Block Diagram



TL/DD/6928-1
FIGURE 1

## COP444L/COP445L

Absolute Maximum Ratings<br>Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.<br>Voltage at Any Pin Relative to GND<br>Ambient Operating Temperature<br>-0.5 V to +10 V<br>$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$<br>Ambient Storage Temperature<br>$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$<br>Lead Temperature (Soldering, 10 seconds) $300^{\circ} \mathrm{C}$<br>Power Dissipation<br>0.75 Watt at $25^{\circ} \mathrm{C}$<br>0.4 Watt at $70^{\circ} \mathrm{C}$

Total Source Current

120 mA Total Sink current 120 mA

Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolulte maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 1) | 4.5 | 6.3 | V |
| Optional Operating Voltage (VCC) |  | 4.5 | 9.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 13 | mA |
| ```Input Voltage Levels CKI Input Levels Crystal Input \((\div 32, \div 16, \div 8)\) Logic High ( \(\mathrm{V}_{1 \mathrm{H}}\) ) Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) Logic Low ( \(\mathrm{V}_{\mathrm{IL}}\) )``` | $\begin{aligned} & V_{C C}=M a x . \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ | $\begin{gathered} 3.0 \\ 2.0 \\ -0.3 \\ \hline \end{gathered}$ | 0.4 | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |
| ```Schmitt Trigger Input ( \(\div 4\) ) Logic High ( \(\mathrm{V}_{\mathrm{iH}}\) ) Logic Low (VIL)``` |  | $\begin{gathered} 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \end{gathered}$ | 0.6 | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |
| $\overline{\text { RESET Input Levels }}$ Logic High Logic Low | Schmitt Trigger Input | $\begin{gathered} 0.7 V_{\mathrm{CC}} \\ -0.3 \end{gathered}$ | 0.6 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| SO Input Level (Test Mode) | (Note 3) | 2.0 | 2.5 | V |
| All Other Inputs Logic High Logic High Logic Low Logic High Logic Low | $V_{C C}=\operatorname{Max}$ <br> With TTL Trip Level Options <br> Selected, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ <br> With High Trip Level Options <br> Selected | $\begin{gathered} 3.0 \\ 2.0 \\ -0.3 \\ 3.6 \\ -0.3 \\ \hline \end{gathered}$ | $\begin{aligned} & 0.8 \\ & 1.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage |  | -1 | +1 | $\mu \mathrm{A}$ |
| Output Voltage Levels LSTTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% \\ & \mathrm{l}_{\mathrm{OH}}=-25 \mu \mathrm{~A} \\ & \mathrm{l}_{\mathrm{OL}}=0.36 \mathrm{~mA} \end{aligned}$ | 2.7 | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| CMOS Operation (Note 2) Logic High Logic Low | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}{ }^{-1}$ | 0.2 | $\begin{aligned} & V \\ & v \end{aligned}$ |

Note 1: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: TRI-STATE and LED configurations are excluded.
Note 3: SO output " 0 " level must be less than 0.8 V for normal operation.

COP444L/COP445L (Continued)
DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq T_{A} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted. (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels Output Sink Current SO and SK Outputs (loL) |  |  |  |  |
|  |  |  |  |  |
|  | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 1.8 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 1.2 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.9 |  | mA |
| $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs and Standard $\mathrm{G}_{0}-\mathrm{G}_{3}, \mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs (IOL) | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
| $\mathrm{G}_{0}-\mathrm{G}_{3}$ and $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with | $V_{C C}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 15 |  | mA |
| High Current Options (lol) | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 11 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 7.5 |  | mA |
| $\mathrm{G}_{0}-\mathrm{G}_{3}$ and $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 30 |  | mA |
| Very High Current Options (loL) | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 22 |  | mA |
|  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OL }}=1.0 \mathrm{~V}$ | 15 |  | mA |
| CKI (Single-pin RC oscillator) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {IH }}=3.5 \mathrm{~V}$ | 2 |  | mA |
| CKO | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.2 |  | mA |
| Output Source Curre |  |  |  |  |
| Standard Configuration, | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -140 | -800 | $\mu \mathrm{A}$ |
| All Outputs (1OH) | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -75 | -480 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -30 | -250 | $\mu \mathrm{A}$ |
| Push-Pull Configuration | $V_{C C}=9.5 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=4.75 \mathrm{~V}$ | -1.4 |  | mA |
| SO and SK Outputs ( $\mathrm{l}^{\mathrm{OH}}$ ) | $V_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ | -1.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V}$ | -1.2 |  | mA |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ |  |  |  |  |
| Outputs, Low Current | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -1.5 | -18 | mA |
| Drivers Option (loh) | $\mathrm{V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -1.5 | -13 | mA |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ |  |  |  |  |
| Outputs, High CurrentDriver Option (1) | $\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -3.0 | -35 | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -3.0 | -25 | mA |
| TRI-STATE Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, Low Current Driver Option ( $\mathrm{IOH}^{\mathrm{O}}$ ) | $V_{\text {CC }}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ | -0.75 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.2 \mathrm{~V}$ | -0.8 |  | mA |
|  | $V_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}$ | -0.9 |  | mA |
| TRI-STATE Configuration, $L_{0}-L_{7}$ Outputs, High | $V_{C C}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ | -1.5 |  | mA |
|  | $\mathrm{V}_{\text {CC }}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.2 \mathrm{~V}$ | -1.6 |  | mA |
| Current Driver Option ( $\mathrm{l}_{\mathrm{OH}}$ ) | $V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}$ | -1.8 |  | mA |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {IL }}=0 \mathrm{~V}$ | -10 | -140 | $\mu \mathrm{A}$ |
| CKO Output |  |  |  |  |
| RAM Power Supply Option |  |  |  |  |
| Power Requirement | $V_{R}=3.3 V$ |  | 3.0 | mA |
| TRI-STATE Output Leakage Current |  | -2.5 | +2.5 | $\mu \mathrm{A}$ |
| Total Sink Current Allowed |  |  |  |  |
| All Outputs Combined |  |  | 120 | mA |
| D, G Ports |  |  | 120 | mA |
| $\mathrm{L}_{7}-\mathrm{L}_{4}$ |  |  | 4 | mA |
| $\mathrm{L}_{3}-\mathrm{L}_{0}$ |  |  | 4 | mA |
| All Other Pins |  |  | 1.5 | mA |
| Total Source Current Allowed |  |  |  |  |
| All I/O Combined |  |  | 120 | mA |
| $\mathrm{L}_{7}-\mathrm{L}_{4}$ |  |  | 60 | mA |
| L3-L0 |  |  | 60 | mA |
| Each L Pin |  |  | 30 | mA |
| All Other Pins |  |  | 1.5 | mA |

## COP344L/COP345L

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.

| Voltage at Any Pin Relative to GND | -0.5 V to +10 V |
| :--- | ---: |
| Ambient Operating Temperature | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, 10 seconds) | $300^{\circ} \mathrm{C}$ |
| Power Dissipation | 0.75 Watt at $25^{\circ} \mathrm{C}$ |
|  | 0.25 Watt at $85^{\circ} \mathrm{C}$ |


| Total Source Current | 120 mA |
| :--- | :--- |
| Total Sink Current | 120 mA | Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V} C \mathrm{C} \leq 7.5 \mathrm{~V}$ unless otherwise noted.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 1) | 4.5 | 5.5 | V |
| Optional Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 | 7.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 15 | mA |
| ```Input Voltage Levels CKI Input Levels Crystal Input Logic High (V) Logic High (VIH) Logic Low (VIL) Schmitt Trigger Input Logic High (VIH) Logic Low (VIL) RESET Input Levels Logic High Logic Low SO Input Level (Test Mode) All Other Inputs Logic High Logic High Logic Low Logic High Logic Low``` | $\begin{aligned} & V_{C C}=\operatorname{Max} \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ <br> Schmitt Trigger Input $V_{C C}=\operatorname{Max}$ <br> With TTL Trip Level Options Selected, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ With High Trip Level Options Selected | 3.0 2.2 -0.3 $0.7 V_{C C}$ -0.3 $0.7 V_{C C}$ -0.3 2.2 3.0 2.2 -0.3 3.6 -0.3 | 0.3 <br> 0.4 <br> 0.4 <br> 2.5 <br> 0.6 <br> 1.2 | V V |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage |  | -2 | +2 | $\mu \mathrm{A}$ |
| Output Voltage Levels LSTTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-20 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=0.36 \mathrm{~mA} \end{aligned}$ | 2.7 | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| CMOS Operation (Note 2) Logic High Logic Low | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=+10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}{ }^{-1}$ | 0.2 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ |

Note 1: $\mathrm{V}_{\mathrm{CC}}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: TRI-STATE and LED configurations are excluded.
Note 3: SO output " 0 " level must be less than 0.6 V for normal operation.

## COP344L/COP345L (Continued)

## DC Electrical Characteristics

$-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted. (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Output Current Levels Output Sink Current |  |  |  |  |
|  |  |  |  |  |
| SO and SK Outputs (loL) | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 1.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 1.0 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.8 |  | mA |
| $L_{0}-L_{7}$ Outputs, and Standard | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
| $\mathrm{G}_{0}-\mathrm{G}_{3}, \mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs (loL) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.4 |  | mA |
| $\mathrm{G}_{0}-\mathrm{G}_{3}$ and $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 12 |  | mA |
| High Current Options (loL) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ |  |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 7 |  | mA |
| $\mathrm{G}_{0}-\mathrm{G}_{3}$ and $\mathrm{D}_{0}-\mathrm{D}_{3}$ Outputs with | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 24 |  | mA |
| Very High Current Options (10L) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 18 |  | mA |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V}$ | 14 |  | mA |
| CKI (Single-Pin RC Oscillator) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {IH }}=3.5 \mathrm{~V}$ | 2 |  | mA |
| CKO | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.2 |  | mA |
| Output Source Current |  |  |  |  |
| Standard Configuration, | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -100 | -900 | $\mu \mathrm{A}$ |
| All Outputs (IOH) | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=2.0 \mathrm{~V}$ | -55 | -600 | $\mu \mathrm{A}$ |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -28 | -350 | $\mu \mathrm{A}$ |
| Push-Pull Configuration | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.75 \mathrm{~V}$ | -0.85 |  | mA |
| SO and SK Outputs (lor) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -1.1 |  | mA |
|  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V}$ | -1.2 |  | mA |
| LED Configuration, Lo-L7 | $V_{\text {CC }}=7.5 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=2.0 \mathrm{~V}$ | -1.4 | -27 | mA |
| Outputs, Low Current | $\mathrm{V}_{\text {CC }}=6.0 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=2.0 \mathrm{~V}$ | -1.4 | -17 | mA |
| Driver Option(loh) | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=2.0 \mathrm{~V}$ | -0.7 | -15 | mA |
| LED Configuration, $\mathrm{L}_{0}-\mathrm{L}_{7}$ | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -2.7 | -54 | mA |
| Outputs, High Current | $\mathrm{V}_{\text {CC }}=6.0 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=2.0 \mathrm{~V}$ | -2.7 | -34 | mA |
| Driver Option (lor) | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | -1.4 | -30 | mA |
| TRI-STATE Contiguration, | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.0 \mathrm{~V}$ | -0.7 |  | mA |
| $\mathrm{L}_{0}-\mathrm{L}_{7}$ Outputs, Low | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=2.7 \mathrm{~V}$ | -0.6 |  | mA |
| Current Driver Option (lor) | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OH }}=1.5 \mathrm{~V}$ | -0.9 |  | mA |
| TRI-STATE Configuration, | $\mathrm{V}_{\mathrm{CC}}=7.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=4.0 \mathrm{~V}$ | -1.4 |  | mA |
| Lo-L7 Outputs, High | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.7 \mathrm{~V}$ | -1.2 |  | mA |
| Current Driver Option ( $\mathrm{l}^{(\mathrm{OH}}$ ) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}$ | -1.8 |  | mA |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}$ | -10 | -200 | $\mu \mathrm{A}$ |
| CKO Output |  |  |  |  |
| RAM Power Supply Option Power Requirement | $\mathrm{V}_{\mathrm{R}}=3.3 \mathrm{~V}$ |  | 4.0 | mA |
| TRI-STATE Output Leakage Current |  | -5 | +5 | $\mu \mathrm{A}$ |
| Total Sink Current Allowed |  |  |  |  |
| All Outputs Combined |  |  |  |  |
| D, G Ports |  |  | 120 | mA |
| $\mathrm{L}_{7}-\mathrm{L}_{4}$ |  |  | 4 | mA |
| $\mathrm{L}_{3}-\mathrm{L}_{0}$ |  |  | 4 | mA |
| All Other Pins |  |  | 1.5 | mA |
| Total Source Current Allowed |  |  |  |  |
| All I/O Combined |  |  | 120 | mA |
| $\mathrm{L}_{7}-\mathrm{L}_{4}$ |  |  | 60 | mA |
| $\mathrm{L}_{3}-\mathrm{L}_{0}$ |  |  | 60 | mA |
| Each L Pin |  |  | 30 | mA |
| All Other Pins |  |  | 1.5 | mA |

## AC Electrical Characteristics

COP444L/445L: $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted.
COP344L/345L: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 7.5 \mathrm{~V}$ unless otherwise noted.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time- $\mathrm{t}_{\mathrm{C}}$ |  | 16 | 40 | $\mu \mathrm{s}$ |
| CKI <br> Input Frequency-f\| <br> Duty Cycle Rise Time Fall Time | $\div 32$ Mode <br> $\div 16$ Mode <br> $\div 8$ Mode <br> $\div 4$ Mode <br> $\mathrm{f}_{\mathrm{l}}=2 \mathrm{MHz}$ | $\begin{aligned} & 0.8 \\ & 0.4 \\ & 0.2 \\ & 0.1 \\ & 30 \end{aligned}$ | $\begin{gathered} 2.0 \\ 1.0 \\ 0.5 \\ 0.25 \\ 60 \\ 120 \\ 80 \\ \hline \end{gathered}$ | MHz <br> MHz <br> MHz <br> MHz <br> \% <br> ns <br> ns |
| CKI Using RC $(\div 4)$ <br> Instruction Cycle Time (Note 1) | $\begin{aligned} & R=56 \mathrm{k} \Omega \pm 5 \% \\ & C=100 \mathrm{pF} \pm 10 \% \end{aligned}$ | 16 | 28 | $\mu \mathrm{S}$ |
| CKO as SYNC Input tsync |  | 400 |  | ns |
| INPUTS: ```IN tseTUP thold SI tsETUP thold``` |  | $\begin{aligned} & 8.0 \\ & 1.3 \\ & \\ & 2.0 \\ & 1.0 \end{aligned}$ |  | $\mu \mathrm{S}$ $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ $\mu \mathrm{S}$ |
| OUTPUT PROPAGATION DELAY <br> SO, SK Outputs <br> $t_{p d 1}, t_{p d 0}$ <br> All Other Outputs <br> $t_{\text {pd1 }}, t_{p d 0}$ | Test Condition: $C_{L}=50 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V}$ |  | $\begin{aligned} & 4.0 \\ & 5.6 \end{aligned}$ | $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ |

Note 1: Variation due to the device included.

## Connection Diagrams



## Pin Descriptions

| Pin | $\quad$ Description | Pin | Description |
| :--- | :--- | :--- | :--- |
| $L_{7}-L_{0}$ | 8 bidriectional I/O ports with TRI-STATE | CKI | System oscillator input |
| $G_{3}-G_{0}$ | 4 bidirectional I/O ports | CKO | System oscillator output (or general purpose in- |
| $D_{3}-D_{0}$ | 4 general purpose outputs |  | put, RAM power supply, or SYNC input) |
| $\mathrm{IN}_{3}-\mathrm{N}_{0}$ | 4 general purpose inputs (COP444L only) | $\overline{\text { RESET }}$ | System reset input |
| SI | Serial input (or counter input) | $V_{C C}$ | Power supply |
| SO | Serial output (or general purpose output) | GND | Ground |

## Timing Diagrams



FIGURE 3a. Input/Output TIming Diagrams (Crystal Divide-by-16 Mode)


FIGURE 3b. Synchronization Timing

## Functional Description

A block diagram of the COP444L is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic "1" (greater than 2 volts). When a bit is reset, it is a logic " 0 " (less than 0.8 volts).
All functional references to the COP444L/COP445L also apply to the COP344L/COP345L.

## PROGRAM MEMORY

Program Memory consists of a 2048 byte ROM. As can be seen by an examination of the COP444L/445L instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID, and LQID instructions, ROM must often be thought of as being organized into 32 pages of 64 words each.
ROM addressing is accomplished by a 11 -bit PC register. Its binary value selects one of the 20488 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 11-bit binary count value. Three levels of subroutine nesting are implemented by the 11-bit subroutine save registers, SA, SB, and SC, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 512-bit RAM, organized as 8 data registers of 164 -bit digits. RAM addressing is implemented by a 7 -bit B register whose upper 3 bits ( Br ) select 1 of 8 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4-bit contents of the selected RAM digit (M) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the LDD and XAD instructions based upon the 7 -bit contents of the operand field of these instructions. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Br and Bd portions of the $B$ register, to load and input 4 bits of the 8 -bit Q latch data, to input 4 bits of the 8 -bit L I/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register descriptor, below.)
Four general-purpose inputs, $\mathbb{N}_{3}-\mathbb{I} N_{0}$, are provided.
The $D$ register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd. The D outputs can be directly connected to the digits of a multiplexed LED display.

The G register contents are outputs to 4 general-purpose bidirectional I/O ports. G I/O ports can be directly connected to the digits of a multiplexed LED display.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are output to the LI/O ports when the $L$ drivers are enabled under program control. (See LEI instruction.)
The 8 L drivers, when enabled, output the contents of latched $Q$ data to the LI/O ports. Also, the contents of $L$ may be read directly into $A$ and M. L I/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with Q data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with $A$, allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the clock.
The EN register is an internal 4-bit register loaded under program control by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the $E N$ register ( $E N_{3}-E N_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4bit binary counter. With $E N_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. With $E N_{1}$ set the $\mathbb{I N}_{1}$ input is enabled as an interrupt input. Immediately following an interrupt, $\mathrm{EN}_{1}$ is reset to disable further interrupts.
3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in $Q$ to the L I/O ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high-impedance input state.
4. $E N_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $\mathrm{EN}_{0}$ set (binary counter option selected) SO will output the value loaded into $\mathrm{EN}_{3}$. With $\mathrm{EN}_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ". The table below provides a summary of the modes associated with $E N_{3}$ and $E N_{0}$.

Functional Description (Continued)
Enable Register Modes-Bits $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$

| $\mathrm{EN}_{3}$ | EN0 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | If $\mathrm{SKL}=1, \mathrm{SK}=\mathrm{CLOCK}$ |
|  |  |  |  |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | If $\mathrm{SKL}=1, \mathrm{SK}=\mathrm{CLOCK}$ |
|  |  |  |  |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | If $\mathrm{SKL}=1, \mathrm{SK}=1$ |
|  |  |  |  |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 1 | 0 | Binary Counter | Input to Binary Counter | 1 | If $\mathrm{SKL}=1, S K=1$ |
|  |  |  |  |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |

## INTERRUPT

The following features are associated with the $\mathrm{IN}_{1}$ interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once acknowledged as explained below, pushes the next sequential program counter address (PC+1) onto the stack, pushing in turn the contents of the other subroutine-save registers to the next lower level $(\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC})$. Any previous contents of SC are lost. The program counter is set to hex address OFF (the last word of page 3) and $\mathrm{EN}_{1}$ is reset.
b. An interrupt will be acknowledged only after the following conditions are met:

1. $\mathrm{EN}_{1}$ has been set.
2. A low-going pulse (" 1 " to " 0 ") at least two instruction cycles wide occurs on the $\mathrm{IN}_{1}$ input.
3. A currently executing instruction has been completed
4. All successive transfer of control instructions and successive LBIs have been completed (e.g., if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed.
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example, if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at hex address OFF. At the end of the interrupt routine, a RET instruction is executed to "pop" the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines and LQID instructions should not be nested within the interrupt service routine, since their popping the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The first instruction of the interrupt routine at hex address OFF must be a NOP.
e. A LEI instruction can be put immediately before the RET to re-enable interrupts.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user use provide an external RC network and diode to the RESET pin as shown below. If the RC network is not used, the RESET pin must be pulled up to $V_{C C}$ either by the internal load or by an external resistor ( $240 \mathrm{k} \Omega$ ) to $V_{C C}$. The RESET pin is configured as a Schmitt trigger input. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.


TL/DD/6928-6
RC $\geq 5 \times$ Power Supply Rise Time ( $\mathrm{R} \geq 40 \mathrm{~K}$ )
Power-Up Clear Circuit
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N$, and $G$ registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instuction at address 0 must be a CLRA.

## OSCILLATOR

There are four basic clock oscillator configurations available as shown by Figure 4.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency divided by 32 (optional by 16 or 8 ).
b. External Oscillator. CKI is an external clock input signal. The external frequency is divided by 32 (optional by 16 or 8) to give the instruction cycle time. CKO is now available to be used as the RAM power supply $\left(V_{R}\right)$, as a general purpose input.
c. RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4. CKO is available as the RAM power supply ( $V_{R}$ ) or as a general purpose input.

Functional Description (Continued)


RC Controlled Oscillator

| $\mathbf{R ( k} \Omega)$ | $\mathbf{C}(\mathbf{p F})$ | Instruction <br> Cycle TIme <br> $(\mu \mathbf{s})$ |
| :---: | :---: | :---: |
| 51 | 100 | $19 \pm 15 \%$ |
| 82 | 56 | $19 \pm 13 \%$ |

NOTE: $200 \mathrm{k} \Omega \geq \mathrm{R} \geq 25 \mathrm{k} \Omega$
$360 \mathrm{pF} \geq \mathrm{C} \geq 50 \mathrm{pF}$
FIGURE 4. COP444L/445L Oscillator

## CKO PIN OPTIONS

In a crystal controlled oscillator system, CKO is used as an output to the crystal network. As an option CKO can be a general purpose input, read into bit 2 of $A$ (accumulator) upon execution of an INIL instruction. As another option, CKO can be a RAM power supply pin ( $V_{R}$ ), allowing its connection to a standby/backup power supply to maintain the integrity of RAM data with minimum power drain when the main supply is inoperative or shut down to conserve power. Using either option is appropriate in applications where the COP444L/445L system timing configuration does not require use of the CKO pin.

## I/O OPTIONS

COP444L/445L outputs have the following optional configurations, illustrated in Figure 5.
a. Standard-an enhancement mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with LSTTL and CMOS input requirements. Available on SO, SK, and all D and G outputs.
b. Open-Drain-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. Available on SO, SK, and all D and G outputs.
c. Push-Pull-An enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{CC}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. Available on SO and SK outputs only.
d. Standard L-same as a., but may be disabled. Available on $L$ outputs only.
e. Open Drain L-same as b., but may be disabled. Available on L outputs only.
f. LED Direct Drive-an enhancement-mode device to ground and to $V_{C c}$, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (See Functional Description, EN Register), placing the outputs in a high impedance state to provide required LED segment blanking for a multiplexed display. Available on L outputs only.
g. TRI-STATE Push-Pull-an enhancement-mode device to ground and $\mathrm{V}_{\mathrm{CC}}$. These outputs are TRI-STATE outputs, allowing for connection of these outputs to a data bus shared by other bus drivers. Available on L outputs only.
COP444L/COP445L inputs have the following optional configurations:
h. An on-chip depletion load device to $V_{C C}$.
I. A Hi-Z input which must be driven to a " 1 " or " 0 " by external components.
The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6, respectively). Minimum and maximum current (lout and VOUT curves are given in Figure 6 for each of these devices to allow the designer to effectively use these I/O configurations in designing a system.
The SO, SK outputs can be configured as shown in a., b., or c. The D and G outputs can be configured as shown in a . or b. Note that when inputting data to the G ports, the G outputs should be set to " 1 ". The L outputs can be configured in d., e., f. or g.
An important point to remember if using configuration $d$. or f. with the $L$ drivers is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current (see Figure 6, device 2); however, when the L-lines are used as inputs, the disabled depletion device can not be relied on to source sufficient current to pull an input to logic "1".

## RAM KEEP-ALIVE OPTION

Selecting CKO as the RAM power supply ( $\mathrm{V}_{\mathrm{R}}$ ) allows the user to shut off the chip power supply ( $\mathrm{V}_{\mathrm{CC}}$ ) and maintain data in the lower four ( $\mathrm{Br}=0,1,2,3$ ) registers of RAM. To insure that RAM data integrity is maintained, the following conditions must be met:

1. $\overline{\text { RESET }}$ must go low before $V_{C C}$ goes low during power off; $V_{C C}$ must go high before $\overline{\text { RESET }}$ goes high on powerup.
2. $\mathrm{V}_{\mathrm{R}}$ must be within the operating range of the chip, and equal to $V_{C C} \pm 1 \mathrm{~V}$ during normal operation.
3. $V_{R}$ must be $\geq 3.3 V$ with $V_{C C}$ off.

Functional Description (Continued) COP445L
If the COP444L is bonded as a 24 -pin device, it becomes the COP455L, illustrated in Figure 2, COP444L/445L Connection Diagrams. Note that the COP445L does not contain
the four general purpose $\operatorname{IN}$ inputs $\left(\mathrm{IN}_{3}-\mathrm{N}_{0}\right)$. Use of this option precludes, of course, use of the IN options and the interrupt feature, which uses $\mathbb{N}_{1}$. All other options are available for the COP445L.


TL/DD/6928-9
a. Standard Output


TL/DD/6928-12
d. Standard L Output


TL/DD/6928-15
g. TRI-STATE Push-Pull (L Output)


TL/DD/6928-10
b. Open-Drain Output

e. Open-Drain L Output

h. Input with Load

FIGURE 5. Output Configuration


TL/DD/6928-11
c. Push-Pull Output

( $\Delta$ is Depletion Device)
f. LED (L Output)

i. Hi-Z Input

## Typical Performance Characteristics



Source Current for SO and SK in Push-Pull Configuration


Input Current for $L_{0}$ through $L_{7}$ when Output Programmed Off by Software


Source Current for $L_{0}$ through $L_{7}$ In TRI-STATE Configuration (High Current Option)


Source Current for Standard Output Configuration


Source Current for $L_{0}$ through $\mathrm{L}_{7}$ in TRI-STATE configuration (Low Current Option)


## Typical Performance Characteristics (Continued)



FIGURE 6a. COP444L/COP445L Input/Output Characteristics
COP444L/COP445L/COP344L/COP345L

Typical Performance Characteristics (Continued)

Input Current $\mathbb{N}_{\mathbf{0}}-\mathrm{IN}_{3}$



LED Output Source
Current (for Low Current LED Option


Output Sink Current for $\mathrm{L}_{0}-\mathrm{L}_{7}$ and Standard Drive Option for $D_{0}-D_{3}$ and $G_{0}-G_{3}$


Input Current for L0-L7 when Output Programmed Off by Software


Source Current for LO-L7 In TRi-STATE Configuration (High Current Option)


LED Output Source
Current (for High Current LED Option


Output Sink Current $\mathrm{G}_{0}-\mathrm{G}_{3}$
and $D_{0}-D_{3}$ with Very High
Current Option


Source Current for
Standard Output
Configuration


Source Current for L0-L7 In TRI-STATE Configuration (Low Current Option)


Output Sink Current for
$G_{0}-G_{3}$ and $D_{0}-D_{3}$ (for High Current Option)


TL/DD/6928-20
Fiare 6b. COP344L/COP345L Input/Output Characteristics

## COP444L/COP445L/COP344L/COP345L Instruction Set

Table 1 is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table II provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with each instruction in the COP444L/445L instruction set.

TABLE I. COP444L/445L/344L/345L Instruction Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 3 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| IL | Two 1-bit latches associated with the IN ${ }_{3}$ or |
|  | INo inputs |
| IN | 4-bit Input Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| PC | 11-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| SA | 11-bit Subroutine Save Register A |
| SB | 11-bit Subroutine Save Register B |
| SC | 11-bit Subroutine Save Register C |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |


| Symbol | Definition |
| :--- | :--- |
| INSTRUCTION OPERAND SYMBOLS |  |
| d | 4-bit Operand Field, $0-15$ binary (RAM Digit Select) <br> 3-bit Operand Field, $0-7$ binary (RAM Register |
| a | Select) <br> 11-bit Operand Field, $0-2047$ binary (ROM Address) |
| y | 4-bit Operand Field, $0-15$ binary (Immediate Data) |
| RAM(s) | Contents of RAM location addressed by s |
| ROM(t) | Contents of ROM location addressed by t |

TABLE II. COP444L/445L Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 0011 0000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 0011\|0001 | $A+\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A}$ | None | Add RAM to A |
| ADT |  | 4 A | $0100 \mid 1010$ | $A+10_{10} \rightarrow A$ | None | Add Ten to A |
| AISC | $y$ | $5-$ | 0101\| y | $A+y \rightarrow A$ | Carry | Add Immediate, Skip on Carry $(y \neq 0)$ |
| CASC |  | 10 | 000110000 | $\begin{aligned} & \bar{A}+\operatorname{RAM}(B)+C \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Complement and Add with Carry, Skip on Carry |
| CLRA |  | 00 | 10000\|0000 | $0 \rightarrow \mathrm{~A}$ | None | Clear A |
| COMP |  | 40 | 010010000 | $\overline{\mathrm{A}} \rightarrow \mathrm{A}$ | None | Ones complement of $A$ to $A$ |
| NOP |  | 44 | 1010010100 | None | None | No Operation |
| RC |  | 32 | 10011 0010 | $" 0$ " $\rightarrow$ C | None | Reset C |
| SC |  | 22 | -0010\|0010 | $" 1 " \rightarrow C$ | None | Set C |


| TABLE II. COP444L/445L Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| XOR |  | 02 | 0000\|0010 | $A \oplus \operatorname{RAM}(\mathrm{~B}) \rightarrow \mathrm{A}$ | None | Exclusive-OR RAM with A |
| JID |  | FF | \|1111|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 3) |
| JMP | a | $6-$ | $\frac{0110\|0\| a_{10: 8} \mid}{a_{7}: 0}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  | $\begin{gathered} \frac{11 \mid}{(\text { pages } 2,3 \text { only) }} \\ \text { or } \\ \|11\| a_{5: 0} \\ \text { (all other pages) } \end{gathered}$ | $a \rightarrow P C_{6: 0}$ $a \rightarrow P C_{5: 0}$ | None | Jump within Page (Note 4) |
| JSRP | a | -- |  | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & \rightarrow \mathrm{SC} \\ & \mathrm{OOO10} \rightarrow \mathrm{PC}_{10: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR | a | $6-$ -- | $\begin{aligned} & \|0110\| 1\left\|a_{10: 8}\right\| \\ & L_{7}: 0 \end{aligned}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | 10100\|1000 | SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow$ PC | None | Return from Subroutine |
| RETSK |  | 49 | 0100\|1001 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | $\begin{aligned} & 33 \\ & 3 \mathrm{C} \end{aligned}$ | 0011 0011 <br> 0011 1100 | $\begin{aligned} & A \rightarrow Q_{7: 4} \\ & \operatorname{RAM}(B) \xrightarrow{ } Q_{3: 0} \end{aligned}$ | None | Copy A, RAM to Q |
| CQMA |  | $\begin{aligned} & 33 \\ & 2 \mathrm{C} \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0011 & 0011 \\ \hline 0010 & 1100 \\ \hline \end{array}$ | $\begin{aligned} & Q_{7: 4} \rightarrow \text { RAM(B) } \\ & Q_{3: 0} \rightarrow A \end{aligned}$ | None | Copy Q to RAM, A |
| LD | r | -5 | $\begin{gathered} \|00\| r\|0101\| \\ (r=0: 3) \end{gathered}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A Exclusive-OR Br with r |
| LDD | r,d | 23 | $\begin{array}{\|l\|l\|l\|} \hline 0010 & 0011 \\ \hline 0\|0\| r\|r\| \\ \hline \end{array}$ | $R A M(r, d) \rightarrow A$ | None | Load A with RAM pointed to directly by r,d |
| LQID |  | BF | \|011|1111 | $\begin{aligned} & \begin{array}{l} \operatorname{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow Q \\ \mathrm{SB} \rightarrow \mathrm{SC} \end{array} \end{aligned}$ | None | Load Q Indirect (Note 3) |
| RMB | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 4 C \\ & 45 \\ & 42 \\ & 43 \end{aligned}$ | 0100 1100 <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{aligned} & 0 \rightarrow \text { RAM }(B)_{0} \\ & 0 \rightarrow \text { RAM }(B)_{1} \\ & 0 \rightarrow \text { RAM }(B)_{2} \\ & 0 \rightarrow \text { RAM }(B)_{3} \end{aligned}$ | None | Reset RAM Bit |
| SMB | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 4 D \\ & 47 \\ & 46 \\ & 4 B \end{aligned}$ | 0100 1101 <br> 0100 1101 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} 1 & \rightarrow \text { RAM }(B)_{0} \\ 1 & \rightarrow \text { RAM }(B)_{1} \\ 1 & \rightarrow \text { RAM }(B)_{2} \\ 1 & \rightarrow \text { RAM }(B)_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | y | 7- | 0111\| ${ }^{\text {y }}$ | $\begin{aligned} & y \rightarrow \operatorname{RAM}(B) \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| $x$ | r | -6 | $\frac{\|00\| r\|0110\|}{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with r |
| XAD | r,d | 23 | 0010  0011 <br> $1\|r\| c \mid$   <br> 1 r d | RAM $(\mathrm{r}, \mathrm{d}) \longleftrightarrow \mathrm{A}$ | None | Exchange A with RAM pointed to directly by $\mathrm{r}, \mathrm{d}$ |

Instruction Set (Continued)
TABLE II. COP444L/445L Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MEMORY REFERENCE INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| XDS | $r$ | -7 | $\frac{\|00\| r\|0111\|}{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd, Exclusive-OR Br with $r$ |
| XIS | $r$ | -4 | $\frac{00\|r\| 0100 \mid}{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with A and Increment Bd, Exclusive-OR Br with $r$ |
| REGISTER REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAB |  | 50 | 0101\|0000 | $\mathrm{A} \rightarrow \mathrm{Bd}$ | None | Copy A to Bd |
| CBA |  | 4E | 10100/1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d | -- | $\begin{gathered} \begin{array}{c} 00\|r\|(d-1) \mid \\ \hline(r=0: 3 ; \\ d=0,9: 15) \\ \text { or } \\ \hline 0011\|0011\| \\ \hline 1\|r\| d \\ \hline \text { any } r, \text { any } d) \end{array} \end{gathered}$ | $r$ r,d $\rightarrow$ B | Skip until not a LBI | Load B Immediate with r,d (Note 6) |
| LEI | $y$ | $\begin{aligned} & 33 \\ & 6- \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0001 \mid 0011 \\ \hline 00110 & y \\ \hline \end{array}$ | $y \rightarrow E N$ | None | Load EN Immediate (Note 7) |
| XABR |  | 12 | 10001\|0010| | $\mathrm{A} \longleftrightarrow \mathrm{Br}\left(0 \rightarrow \mathrm{~A}_{3}\right)$ | None | Exchange A with Br |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  | 20 | 10010\|0000 |  | $C=$ "1" | Skip if C is True |
| SKE |  | 21 | 0010\|0001 |  | $A=\operatorname{RAM}(B)$ | Skip if A Equals RAM |
| SKGZ |  | 33 21 | $0011\|0011\|$ <br> $0010\|0001\|$ |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
| SKGBZ |  | 33 | 0011 10011 | 1st byte |  | Skip if G Bit is Zero |
|  | 0 | 01 | 0000\|0001] |  | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 0001\|0001 |  | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 | $\int 2 n d$ byte | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 0001\|0011 |  | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 0000 00001 |  | $\operatorname{RAM}(\mathrm{B})_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | 000110001 |  | RAM (B) ${ }_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 |  | $\operatorname{RAM}(B)_{2}=0$ |  |
|  | 3 | 13 | 0001\|0011 |  | $\operatorname{RAM}(B)_{3}=0$ |  |
| SKT |  | 41 | 0100\|0001 |  | A time-base counter carry has occurred since last test | Skip on Timer (Note 3) |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | [0011 0011 | $G \rightarrow A$ | None | Input G Ports to A |
|  |  | 2A | 0010/1010 |  |  |  |
| ININ |  | 33 | $\underline{0011100111}$ | $\mathrm{IN} \rightarrow \mathrm{A}$ | None | Input IN Inputs to $A$ |
|  |  | 28 | \|0010|1000 |  |  | (Note 2) |
| INIL |  | 33 | 001110011 | $\mathrm{IL}_{3}, \mathrm{CKO}, ~ " 0$ ', $\mathrm{IL}_{0} \rightarrow \mathrm{~A}$ | None | Input IL Latches to A |
|  |  | 29A | 001011001 |  |  | (Note 3) |


| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| INL |  | 33 | \|0011 0011 | | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2 E | 0010\|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | 0011 0011 | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E | 0011 1110 |  |  |  |
| OGI | $y$ | 33 | 0011 0011 | $y \rightarrow G$ | None | Output to G Ports |
|  |  | 5- | 0101 t |  |  | Immediate |
| OMG |  | 33 | 0011 10011 | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{G}$ | None | Output RAM to G Ports |
|  |  | 3A | 0011\|1010 |  |  |  |
| XAS |  | 4F | 10100\|1111 | A | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit $A$ register.
Note 2: The ININ instruction is not available on the 24-pin COP445L or COP345L since these devices do not contain the IN inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64-word page. JP may not jump to the last word of a page.
Note 5: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$ or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ " data minus 1 , e.g., to load the lower four bits of $B(B d)$ with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).
Note 7: Machine code for operand field y for LEI instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP444L/445L programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 11-bit word, $\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{10}, \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ are not affected by this instruction.
Note that JID requires 2 instruction cycles to execute.

## INIL INSTRUCTION

INIL (Input IL Latches to A) inputs 2 latches, $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ (see Figure 7 ) and CKO into A . The $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ latches are set if a low-going pulse (" 1 " to " 0 ") has occurred or the $\mathrm{IN}_{3}$ and
$\mathrm{IN}_{0}$ inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction times. Execution of an $I N I L$ inputs $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ into A 3 and AO respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the $I N_{3}$ and $I N_{0}$ lines. If CKO is mask programmed as a general purpose input, an INIL will input the state of CKO into A2. If CKO has not been so programmed, a " 1 " will be placed in A2. A " 0 " is always placed in A1 upon the execution of an INIL. The general purpose inputs $I N_{3}-I N_{0}$ are input to $A$ upon execution of an ININ instruction. (See Table II, ININ instruction.) INIL is useful in recognizing pulses of short duration or pulses which occur too often to be read conveniently by an ININ instruction.
Note: IL latches are not cleared on reset; $\mathrm{IL}_{3}-\mathrm{LL}_{0}$ not input on 445 L

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 11-bit word $\mathrm{PC}_{10}, \mathrm{PC}_{9}$, $\mathrm{PC}_{8} \mathrm{~A}, \mathrm{M}$. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack ( $\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC}$ ) and replaces the least significant 8 bits of PC as follows: A $\rightarrow \mathrm{PC}_{7: 4}, \mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{10}, \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the Q latches. Next, the stack is "popped" (SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow$ PC), restoring the saved value of PC to continue sequential program execution. Since LQID pushes $S B \rightarrow$ SC, the previous contents

## Description of Selected Instructions (Continued)



TL/DD/6928-21
FIGURE 7. INIL Hardware Implementation
of SC are lost. Also, when LQID pops the stack, the previously pushed contents of SB are left in SC. The net result is that the contents of SB are placed in SC (SB $\rightarrow$ SC). Note that LQID takes two instruction cycle times to execute.

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of an internal 10-bit time-base counter. This counter divides the instruction cycle clock frequency by 1024 and provides a latched indication of counter overflow. The SKT instruction tests this latch, executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction, therefore, allow the COP444L/445L to generate its own timebase for real-time processing rather than relying on an external input signal.
For example, using a 2.097 MHz crystal as the time-base to the clock generator, the instruction cycle clock frequency will be 65 kHz (crystal frequency $\div 32$ ) and the binary counter output pulse frequency will be 64 Hz . For time-of-day or similar real-time processing, the SKT instruction can call a routine which increments a "seconds" counter every 64 ticks.

## INSTRUCTION SET NOTES

a. The first word of a COP444L/445L program (ROM address 0) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped.
c. The ROM is organized into 32 pages of 64 words each. The Program Counter is an 11-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last work of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page $3,7,11,15,19,23$ or 27 will access data in the next group of four pages.

## Option List

The COP444L/445L mask-programmable options are assigned numbers which correspond with the COP 444 L pins.

The following is a list of COP444L options. When specifying a COP445L chip, Options 9, 10, 19, and 20 must all be set to zero. The options are programmed at the same time as the ROM pattern to provide the user with the hardware flexibility to interface to various I/O components using little or no external circuitry.

Option $1=0$ : Ground Pin-no options available
Option 2: CKO Output
= 0 : clock generator ouput to crystal/resonator ( 0 not allowable value if option $3=3$ )
$=1$ : pin is RAM power supply $\left(V_{R}\right)$ input
$=2$ : general purpose input, load device to $V_{C C}$
= 3: general purpose input, $\mathrm{Hi}-\mathrm{Z}$
Option 3: CKI Input
$=0$ : oscillator input divided by 32 ( 2 MHz max.)
$=1$ : oscillator input divided by 16 ( 1 MHz max.)
$=2$ : oscillator input divided by 8 ( 500 kHz max.)
$=3$ : single-pin RC controlled oscillator divided by 4
$=4$ : oscillator input divided by 4 (Schmitt)
Option 4: $\overline{\operatorname{RESET}}$ Input
$=0$ : load device to $V_{C C}$
$=1: \mathrm{Hi}-\mathrm{Z}$ input
Option 5: $L_{7}$ Driver
$=0$ : Standard output
= 1: Open-drain output
$=2$ : High current LED direct segment drive output
= 3: High current TRI-STATE push-pull output
$=4$ : Low-current LED direct segment drive output
$=5$ : Low-current TRI-STATE push-pull output
Option 6: $L_{6}$ Driver
same as Option 5
Option 7: L5 Driver
same as Option 5
Option 8: L $\mathrm{L}_{4}$ Driver
same as Option 5
Option 9: $\mathbb{N}_{1}$ Input
$=0$ : load device to $V_{C C}$
= 1: Hi-Z input
Option 10: $\mathrm{IN}_{2}$ Input
same as Option 9
Option 11: $\mathrm{V}_{\mathrm{CC}}$ pin Operating Voltage
COP44XL
COP34XL
$=0:+4.5 \mathrm{~V}$ to $+6.3 \mathrm{~V} \quad+4.5 \mathrm{~V}$ to +5.5 V
$=1:+4.5 \mathrm{~V}$ to $+9.5 \mathrm{~V} \quad+4.5 \mathrm{~V}$ to +7.5 V
Option 12: $\mathrm{L}_{3}$ Driver same as Option 5
Option 13: $\mathrm{L}_{2}$ Driver same as Option 5
Option 14: $L_{1}$ Driver same as Option 5
Option 15: Lo Driver
same as Option 5
Option 16: SI Input
same as Option 9

Option List (Continued)

Option 17: SO Driver
$=0$ : standard output
$=1$ : open-drain output
= 2: push-pull output
Option 18: SK Driver same as Option 17
Option 19: $\mathrm{IN}_{0}$ Input same as Option 9
Option 20: $\mathbb{N}_{3}$ Input same as Option 9
Option 21: $\mathrm{G}_{0}$ 1/O Port
$=0$ : very-high current standard output
$=1$ : very-high current open-drain output
$=2$ : high current standard output
$=3$ : high current open-drain output
$=4$ : standard LSTTL output (fanout $=1$ )
$=5$ : open-drain LSTTL output (fanout $=1$ )
Option 22: $\mathrm{G}_{1}$ I/O Port same as Option 21
Option 23: $\mathrm{G}_{2}$ I/O Port same as Option 21
Option 24: $\mathrm{G}_{3}$ I/O Port same as Option 21
Option 25: $D_{3}$ Output same as Option 21
Option 26: $\mathrm{D}_{2}$ Output same as Option 21

Option 27: $\mathrm{D}_{1}$ Output same as Option 21
Option 28: $\mathrm{D}_{0}$ Output same as Option 21
Option 29: L Input Levels
$=0$ : standard TTL input levels

$$
(" 0 "=0.8 \mathrm{~V}, " 1 "=2.0 \mathrm{~V})
$$

$=1$ : higher voltage input levels

$$
(" 0 "=1.2 \mathrm{~V}, " 1 "=3.6 \mathrm{~V})
$$

Option 30: IN Input Levels
same as Option 29
Option 31: G Input Levels same as Option 29
Option 32: SI Input Levels same as Option 29
Option 33: RESET Input
= 0 : Schmitt trigger input levels
$=1$ : standard TTL input levels
$=2$ : higher voltage input levels
Option 34: CKO Input Levels (CKO=input; Option 2=2,3) same as Option 29
Option 35: COP Bonding
$=0:$ COP444L (28-pin device)
$=1:$ COP445L (24-pin device)
$=2$ : both 28 - and 24 -pin versions
Option 36: Internal Initialization Logic
$=0$ : normal operation
$=1$ : no internal initialization logic

## COP444L Option Table

The following option information is to be seNt to National along with the EPROM.

## OPTION DATA

OPTION 1 VALUE= $\qquad$ IS: GROUND PIN
OPTION 2 VALUE= $\qquad$ IS: CKO PIN
OPTION 3 VALUE= $\qquad$ IS: CKI PIN
OPTION 4 VALUE $=$ $\qquad$ IS: RESET INPUT
OPTION 5 VALUE $=$ $\qquad$ IS: L(7) DRIVER
OPTION 6 VALUE= $\qquad$ IS: L(6) DRIVER
OPTION 7 VALUE $=$ $\qquad$ IS: L(5) DRIVER
OPTION 8 VALUE= $\qquad$ IS: L(4) DRIVER
OPTION 9 VALUE= $\qquad$ IS: IN1 INPUT
OPTION 10 VALUE = $\qquad$ IS: IN2 INPUT
OPTION 11 VALUE = $\qquad$ IS: VCC PIN
OPTION 12 VALUE= $\qquad$ IS: L(3) DRIVER
OPTION 13 VALUE $=$ $\qquad$ IS: L(2) DRIVER
OPTION 14 VALUE= $\qquad$ IS: L(1) DRIVER
OPTION 15 VALUE= $\qquad$ IS: L(0) DRIVER
OPTION 16 VALUE $=$ $\qquad$ IS: SI INPUT
OPTION 17 VALUE $=$ $\qquad$ IS: SO DRIVER
OPTION 18 VALUE= $\qquad$ IS: SK DRIVER
OPTION 19 VALUE= $\qquad$ IS: INO INPUT
OPTION 20 VALUE $=$ $\qquad$ IS: IN3 INPUT

OPTION DATA

|  |  |
| :---: | :---: |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |

## Typical Applications <br> TEST MODE (NON-STANDARD OPERATION)

The SO output has been configured to provide for standard test procedures for the custom-programmed COP444L. With SO forced to logic " 1 ", two test modes are provided, depending upon the value of Sl :
a. RAM and Internal Logic Test Mode $(\mathrm{SI}=1)$
b. ROM Test Mode ( $\mathrm{SI}=0$ )

These special test modes should not be employed by the user; they are intended for manufacturing test only.

## APPLICATION \# 1: COP444L GENERAL CONTROLLER

Figure 8 shows an interconnect diagram for a COP444L used as a general controller. Operation of the system is as follows:

1. The $L_{7}-L_{0}$ outputs are configured as LED Direct Drive outputs, allowing direct connection to the segments of the display
2. The $D_{3}-D_{0}$ outputs drive the digits of the multiplexed display directly and scan the columns of the $4 \times 4$ keyboard matrix.
3. The $\mathbb{N}_{3}-\mathbb{N}_{0}$ inputs are used to input the 4 rows of the keyboard matrix. Reading the IN lines in conjunction with the current value of the $D$ outputs allows detection, debouncing, and decoding of any one of the 16 keyswitches.
4. CKI is configured as a single-pin oscillator input allowing system timing to be controlled by a single-pin RC network. CKO is therefore available for use as a general-purpose input.
5. SI is selected as the input to a binary counter input. With SIO used as a binary counter, SO and SK can be used as general purpose outputs.
6. The 4 bidirectional G I/O ports ( $\mathrm{G}_{3}-\mathrm{G}_{0}$ ) are available for use as required by the user's application.
7. Normal reset operation is selected.

## COP444L EVALUATION (See COP Note 4)

The $444 \mathrm{~L}-\mathrm{EVAL}$ is a pre-programmed COP444L, containing several routines which facilitate user familiarization and evaluation of the COP444L operating characteristics. It may be used as an up/down counter or timer, interfacing to any combination of (1) an LED digit or lamps, (2) 4-digit LED Display Controller, (3) a 4-digit VF Display Controller, and/or (4) a 4-digit LCD Display Controller. Alternatively, it may be used as a simple music synthesizer.

## SAMPLE CIRCUITS

1. By making only the oscillator, power supply and "L7" connections, (Figure 9) an approximate 1 Hz square wave will be produced at output "D1." This output may be observed with an oscilloscope, or connected to additional TTL or CMOS circuitry.
2. By making the indicated connections to a small LED digit (NSA1541A, NSA1166, or equiv.-larger digits will be proportionately dimmer), the counter actions may be observed. Place the "up/down" switch in the "up" (open) position and apply a TTL-compatible signal at the "coun-ter-input." Placing the "up/down" switch in the "down" (closed) position causes the count to decrement on each high-to-low input transition.
3. All 4 digits of the counter may be displayed by connecting a standard display controller (COP470 for VF, COP472 for LCD, MM5450 for LED) as shown in Figure 9.


FIGURE 8. COP444L Keyboard/Display Interface

## Typical Applications (Continued)

Any combination of the single LED digit and display controllers may be used simultaneously, and will display the same data.
4. The simple counter described above becomes a timer when the 1 Hz output is connected to the "counter input." Up or down counting may be used with input frequencies up to 1 kHz . Improved timing accuracies may be obtained by subsituting the 2.097 MHz crystal oscillator circuit of Figure $4 a$ for the RC network shown in Figure 9, or by connecting a more stable external frequency to the "counter input" in place of the 1 Hz signal.
5. An "entertaining" use of the 444L-EVAL is as a simple music synthesizer (or electronic organ). By attaching a simple switch matrix (or keyboard), a speaker or piezo-ceramic transducer, and grounding " $L 7$ ", the user can play "music" (Figure 10). Three modes of operation are available: Play a note, play one of four stored tunes, or record a tune for subsequent replay.
a. Play A Note

Twelve keys, representing the 12 notes in one octave, are labeled " $C$ " through " $B$ "; depressing a key causes
a square wave of the corresponding frequency to be outputted to the speaker. Depressing "LShift" or "UShift" causes the next note to be shifted to the next lower octave (one-half frequency) or the next upper octave (double frequency), respectively.
b. Play Stored Tune

Depressing "Play" followed by " $1 / 8$ ", " $1 / 4$ ", " $1 / 2$ ", or " 1 " will cause one of 4 stored tunes to be played.

## c. Record Tune

Any combination of notes and rests up to a total of 48 may be stored in RAM for later replay. To store a note, press the appropriate note key, followed by the duration of the note ( $1 / 8$-note, $1 / 4$-note, $1 / 2$-note, whole (1)note, followed by "Store"; a rest is stored by selecting the duration and pressing "Store." When the tune is complete, press "Play" followed by "Store"; the tune will be played for immediate audition. Subsequent depression of "Play" and "Store" will replay the last stored tune.

Note: The accuracy of the tones produced is a function of the oscillator accuracy and stability; the crystal oscillator is recommended.


FIGURE 9. Counter/Timer


National Semiconductor Corporation

## COP401L ROMless N-Channel Microcontroller

## General Description

The COP401L ROMless Microcontroller is a member of the COPSTM family of microcontrollers, fabricated using N -channel, silicon gate MOS technology. The COP401L contains CPU, RAM, I/O and is identical to a COP410L device except the ROM has been removed and pins have been added to output the ROM address and to input the ROM data. In a system the COP401L will perform exactly as the COP410L. This important benefit facilitates development and debug of a COP program prior to masking the final part.
The COP401L is intended for emulation only, not intended for volume production. Use COP402 or COP404L for volume production.

## Features

- Circuit equivalent of COP410L
- Low cost
- Powerful instruction set
- $512 \times 8$ ROM, $32 \times 4$ RAM
- Separate RAM power supply pin for RAM keep-alive applications
- Two-level subroutine stack
- $15 \mu \mathrm{~s}$ instruction time

■ Single supply operation (4.5-9.5V)
n Low current drain ( 8 mA max.)

- Internal binary counter register with serial I/O
- MICROWIRETM compatible serial I/O
- General purpose outputs
- LSTTL/CMOS compatible in and out

■ Direct drive of LED digit and segment lines
■ Software/hardware compatible with other members of COP400 family

- Pin-for-pin compatible with COP402 and COP404L


## Block Diagram



TL/DD/6913-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at any Pin Relative to GND

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+10 \mathrm{~V} \\
0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
300^{\circ} \mathrm{C}
\end{array}
$$

Power Dissipation
0.75 W at $25^{\circ} \mathrm{C}$ 0.4 W at $70^{\circ} \mathrm{C}$ 120 mA
Total Source Current 120 mA
Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 2) | 4.5 | 9.5 | V |
| Power Supply Ripple | Peal to Peak |  | 0.5 | $\checkmark$ |
| Operating Supply Current | All Inputs and Outputs Open |  | 8 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Crystal Input <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low ( $\mathrm{V}_{1 \mathrm{~L}}$ ) <br> RESET Input Levels <br> Logic High <br> Logic Low <br> IP0-IP7 Input Levels <br> Logic High <br> Logic High <br> Logic Low <br> All Other Inputs <br> Logic High <br> Logic High <br> Logic Low <br> Input Capacitance | Schmitt Trigger Input $\begin{aligned} & V_{C C}=9.5 \mathrm{~V} \\ & V_{C C}=5 \mathrm{~V} \pm 5 \% \end{aligned}$ $\begin{aligned} & V_{C C}=9.5 \mathrm{~V} \\ & V_{C C}=5 \mathrm{~V} \pm 5 \% \end{aligned}$ | $\begin{gathered} 2.0 \\ -0.3 \\ \\ 0.7 \mathrm{VCC} \\ -0.3 \\ \\ 2.4 \\ 2.0 \\ -0.3 \\ \\ 3.0 \\ 2.0 \\ -0.3 \end{gathered}$ | 0.4 <br> 0.6 <br> 0.8 <br> 0.8 <br> 7 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{v} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{pF} \\ & \hline \end{aligned}$ |
| Output Voltage Levels LSTTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) IP0-IP7, P8, SKIP Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-25 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=0.36 \mathrm{~mA} \\ & \text { (Note } 1 \text { ) } \\ & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \hline \end{aligned}$ | 2.7 | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ |
| $\begin{aligned} & \text { Output Current Levels } \\ & \text { Output Sink Current } \\ & \text { SO and SK Outputs (loL) } \\ & L_{0}-L_{7} \text { and } G_{0}-G_{3} \text { Outputs } \\ & D_{0}-D_{3} \text { Outputs } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 1.8 \\ & 0.9 \\ & 0.8 \\ & 0.4 \\ & 30 \\ & 15 \end{aligned}$ |  | mA <br> mA <br> mA <br> mA <br> mA <br> mA |
| CKO <br> RAM Power Supply Input | $\mathrm{V}_{\mathrm{R}}=3.3 \mathrm{~V}$ |  | 1.5 | mA |



AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ unless otherwise specified.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time |  | 15 | 40 | $\mu \mathrm{S}$ |
| CKI <br> Input Frequency $f_{1}$ <br> Duty Cycle <br> Rise Time <br> Fall Time | $(\div 32$ Mode) $f_{I}=2.097 \mathrm{MHz}$ | $\begin{aligned} & 0.8 \\ & 30 \end{aligned}$ | $\begin{gathered} 2.1 \\ 60 \\ 120 \\ 80 \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{MHz} \\ \% \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \hline \end{gathered}$ |
| INPUTS: <br> SI, IP7-IP0 <br> tsetup <br> thold |  | $\begin{aligned} & 2.0 \\ & 1.0 \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| $\begin{gathered} \mathrm{G}_{3}-\mathrm{G}_{0, L_{7}-\mathrm{L}_{0}} \\ \mathrm{t}_{\text {SETUP }} \\ \text { thOLD }^{2} \\ \hline \end{gathered}$ |  | $\begin{aligned} & 8.0 \\ & 1.3 \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| OUTPUT PROPAGATION DELAY $\begin{aligned} & \text { SO, SK Outputs } \\ & t_{\text {pd1 }}, t_{\text {pdo }} \\ & D_{3}-D_{0}, G_{3}-G_{0}, L_{7}-L_{0} \\ & t_{\text {pd1 }}, t_{\text {pdo }} \\ & \text { IP7-IPO, P8, SKIP } \\ & t_{\text {pd1 }}, t_{\text {pdO }} \\ & \hline \end{aligned}$ | Test Condition: $\begin{aligned} C_{L} & =p F, V_{\text {OUT }}=1.5 \mathrm{~V} \\ R_{\mathrm{L}} & =20 \mathrm{k} \Omega \\ R_{\mathrm{L}} & =\mathrm{k} \Omega \\ R_{\mathrm{L}} & =5 \mathrm{k} \Omega \end{aligned}$ |  | $\begin{aligned} & 4.0 \\ & 5.6 \\ & 7.2 \end{aligned}$ | $\mu \mathrm{s}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{s}$ |

Note 1: Pull-up resistors required.
Note 2: $\mathrm{V}_{\mathrm{CC}}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.

## Connection Diagram



Order Number COP401L/N NS Package Number N40A

FIGURE 2

## Pin Descriptions

| Pin | Description |
| :--- | :--- |
| $L_{7}-L_{0}$ | 8 bidirectional I/O ports with LED <br> segment drive |
| $\mathrm{G}_{3}-\mathrm{G}_{0}$ | 4 bidirectional I/O ports |
| $\mathrm{D}_{3}-\mathrm{D}_{0}$ | 4 general purpose outputs |
| SI | Serial input (or counter input) |
| SO | Serial output (or general purpose output) |
| SK | Logic-controlled clock (or general |
|  | purpose output) |

## Timing Diagram

| Pin | Description |
| :--- | :--- |
| CKI | System oscillator input |
| CKO | RAM power supply input |
| RESET | System reset input |
| VCC | Power supply |
| GND | Ground |
| IP7-IPO | 8 bidirectional ROM address and data ports |
| P8 | Most significant ROM address bit output |
| SKIP | Instruction skip output |



## Functional Description

A block diagram of the COP401L is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " greater than 2 volts). When a bit is reset, it is a logic " 0 " (less than 0.8 volts).

## PROGRAM MEMORY

Program Memory consists of a 512-byte external memory. As can be seen by an examination of the COP401L instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 8 pages of 64 words each.
ROM addressing is accomplished by a 9-bit PC register. Its binary value selects one of the 5128 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transer of control instruction, the PC register is loaded with the next sequential 9-bit binary count value. Two levels of subroutine nesting are implemented by the 9 -bit subroutine save registers, SA and SB, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 128-bit RAM, organized as 4 data registers of 8 4-bit digits. RAM addressing is implemented by a 6 -bit $B$ register whose upper 2 bits $(\mathrm{Br})$ select 1 of 4 data registers and lower 3 bits of the 4 -bit Bd select 1 of 84 -bit digits in the selected data register. While the 4 -bit contents of the selected RAM digit (M) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the XAD 3, 15 instruction. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.
The most significant bit of Bd is not used to select a RAM digit. Hence each physical digit of RAM may be selected by two different values of Bd as shown in Figure 4 below. The skip condition for XIS and XDS instructions will be true if Bd changes between 0 and 15, but NOT between 7 and 8 (see Table 3).


FIGURE 4. RAM DIglt Address to Physical RAM Digit Mapping

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Bd portion of the $B$ register, to load 4 bits of the 8 -bit $Q$ latch data, to input 4 bits of the 8 -bit LI/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions of the COP401L, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.)
The G register contents are outputs to 4 general-purpose bidirectional I/O ports.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are output to the LI/O ports when the L drivers are enabled under program control. (See LEI instruction.)
The 8 L drivers, when enabled, output the contents of latched Q data to the L I/O ports. Also, the contents of $L$ may be read directly into $A$ and $M$. LI/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with Q data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with A , allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift register.

The XAS instruction copies C into the SKL Latch. In the counter mode, SK is the output of SKL in the shift register mode, SK outputs SKL ANDed with internal instruction cycle clock.
The EN register is an internal 4-bit register loaded under program control by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $\mathrm{EN}_{3}-E N_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4-bit binary counter. With $E N_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. $E N_{1}$ is not used. It has no effect on COP401L operation.

Functional Description (Continued)
TABLE I. Enable Register Modes-Bits $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$

| $\mathrm{EN}_{3}$ | EN0 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=\text { Clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | $\begin{aligned} & \text { If } S K L=1, S K=\text { Clock } \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | If $\mathrm{SKL}=1, \mathrm{SK}=1$ |
|  |  |  |  |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | $\begin{aligned} & \text { If } S K L=1, S K=1 \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |

3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in Q to the $\mathrm{L} \mathrm{I} / \mathrm{O}$ ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high-impedance input state.
4. $E N_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $\mathrm{EN}_{0}$ set (binary counter option selected) SO will output the value loaded into $\mathrm{EN}_{3}$. With $\mathrm{EN}_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ". Table I provides a summary of the modes associated with $E N_{3}$ and $E N_{0}$.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the RESET pin as shown below (Figure 5). The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to $V_{C c}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.


TL/DD/6913-5
RC $\geq$ Power Supply Rise Time
FIGURE 5. Power-Up Clear Circuit

Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N$, and $G$ registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.

## EXTERNAL MEMORY INTERFACE

The COP401L is designed for use with an external Program Memory. This memory may be implemented using any devices having the following characteristics:

1. random addressing
2. TTL-compatible TRI-STATE® outputs
3. TTL-compatible inputs
4. access time $=5 \mu \mathrm{~s}$ max.

Typically these requirements are met using bipolar or MOS PROMs.
During operation, the address of the next instruction is sent out on P8 and IP7 through IPO during the time that $\mathrm{AD} / \overline{\mathrm{DATA}}$ is high (logic " 1 " = address mode). Address data on the IP lines is stored into an external latch on the high-to-low transition of the AD/ $\overline{\mathrm{DATA}}$ line; P8 is a dedicated address output, and does not need to be latched. When AD/ $\overline{D A T A}$ is low (logic " 0 " = data mode), the output of the memory is gated onto IP7 through IPO, forming the input bus. Note that the AD/ $\overline{D A T A}$ output has a period of one instruction time, a duty cycle of approximately $50 \%$, and specifies whether the IP lines are used for address output or instruction input.

## OSCILLATOR

CKI is an external clock input signal. The external frequency is divided by 32 to give the instruction cycle time. The di-vide-by-32 configuration was chosen to make the COP 401L compatible with the COP404L and the COPSTM Development System. However, the $\div 32$ configuration is not available on the COP410L/COP411L. It is therefore possible to exactly emulate the system speed (cycle time), but not possible to drive the 401L with the system clock during emulation.

## Functional Description (Continued)

## CKO (RAM POWER)

CKO is configured as a RAM power supply pin ( $V_{R}$ ), allowing its connection to a standby/backup power supply to maintain the integrity of RAM data with minimum power drain when the main supply is inoperative or shut down to conserve power. This pin must be connected to $V_{C C}$ if the power backup feature is not used. To insure that RAM integrity is maintained, the following conditions must be met:

1. $\overline{\text { RESET }}$ must go low before $V_{C C}$ goes below spec during power-off; $V_{C C}$ must be within spec before RESET goes high on power-up.
2. During normal operation, $V_{R}$ must be within the operating range of the chip with $\left(V_{C C}-1\right) \leq V_{R} \leq V_{C C}$.
3. $V_{R}$ must be $\geq 3.3 V$ with $V_{C C}$ off.

## INPUT/OUTPUT CONFIGURATIONS

COP401L outputs have the following configurations, illustrated in Figure 6:
a. Standard-an enhancement mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with LSTTL and CMOS input requirements. (Used on D and G outputs.)
b. Open-Drain-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application. (Used on IP, P and SKIP outputs.)
c. Push-Pull-An enhancement-mode device to ground in conjunction with a depletion-mode device paralleled en-
hancement-mode device to $\mathrm{V}_{\mathrm{CC}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads. (Used on SO and SK outputs.)
d. LED Direct Drive-an enhancement-mode device to ground and to $V_{C C}$, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (See Functional Description, EN Register), placing the outputs in a high-impedance state to provide required LED segment blanking for a multiplexed display. (Used on L outputs.)
COP401L inputs have an on-chip depletion load device to VCC.
The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of five devices (numbered 1-5, respectively). Minimum and maximum current (lout and $\mathrm{V}_{\text {OUT }}$ ) curves are given in Figure 7 for each of these devices to allow the designer to effectively use these I/O configurations in designing a system.
An important point to remember is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current (see Figure 7, Device 2); however, when the L-lines are used as inputs, the disabled depletion device can not be relied on to source sufficient current to pull, an input to a logic ' 1 '.


TL/DD/6913-6

## a. Standard Output



TL/DD/6913-8
c. Push-Pull Output

TL/DD/6913-10
( $\triangle$ is Depletion Device)
d. L Output (LED)

b. Open-Drain Output

TL/DD/6913-9
e. Input with Load

FIGURE 6. Output Configurations

## Typical Performance Characteristics



FIGURE 7. I/O Characterlstics

## COP401L Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table III provides the mnemonic, operand, machine code, data flow, skip conditions, and description associated with each instruction in the COP401L instruction set.

TABLE II. COP401L Instruction Set Table Symbols

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| PC | 9-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L l/O Port |
| SA | 9-bit Subroutine Save Register A |
| SB | 9-bit Subroutine Save Register B |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |


| Symbol | Definition |
| :---: | :---: |
| INSTRUCTION OPERAND SYMBOLS |  |
| d | 4-bit Operand Field, 0-15 binary (RAM Digit Select) |
| r | 2-bit Operand Field, 0-3 binary (RAM Register Select) |
| a | 9 -bit Operand Field, $0-511$ binary (ROM Address) |
| y | 4-bit Operand Field, 0-15 binary (Immediate Data) |
| RAM(s) | Contents of RAM location addressed by s |
| ROM (t) | Contents of ROM location addressed by t |
| OPERATIONAL SYMBOLS |  |
| $+$ | Plus |
| - | Minus |
| $\rightarrow$ | Replaces |
| $\longleftrightarrow$ | Is exchanged with |
| = | Is equal to |
| $\overline{\mathrm{A}}$ | The one's complement of A |
| $\oplus$ | Exclusive-OR |
| : | Range of values |

TABLE III. COP401L Instruction Set

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 0011 [0000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 00110001 | $A+\operatorname{RAM}(B) \rightarrow A$ | None | Add RAM to A |
| AISC | y | 5- | 0101 ${ }^{\text {y }}$ y | $A+y \rightarrow A$ | Carry | Add immediate, Skip on Carry ( $y \neq 0$ ) |
| CLRA |  | 00 | $0000\|0000\|$ | $0 \rightarrow A$ | None | Clear A |
| COMP |  | 40 | 010010000 | $\bar{A} \rightarrow A$ | None | One's complement of A to A |
| NOP |  | 44 | 0100\|0100 | None | None | No Operation |
| RC |  | 32 | 0011 0010 | $" 0 " \rightarrow C$ | None | Reset C |
| SC |  | 22 | 001010010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | 000010010 | $A \oplus \operatorname{RAM}(\mathrm{~B}) \rightarrow \mathrm{A}$ | None | Exclusive-OR RAM with $A$ |

## COP410L Instruction Set (Continued)

TABLE III. COP401L Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111 | $\begin{aligned} & \mathrm{ROM}_{\mathrm{PC}_{7: 0}}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \longrightarrow \end{aligned}$ | None | Jump Indirect (Note 2) |
| JMP | a | $6-$ | $\begin{array}{\|c\|c\|c\|c\|} \hline 0110\|000\| a_{8} \mid \\ \hline \mathrm{a}_{7}: 0 \\ \hline \end{array}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  | $\begin{aligned} & \begin{array}{\|l\|} \|1\| \\ \text { (pages } 2,3 \\ 2,3 \\ \text { only) } \end{array} \\ & \frac{11 \mid \quad a_{5: 0}}{\text { (all other pages) }} \end{aligned}$ | $\begin{aligned} & a \rightarrow P C_{6: 0} \\ & a \rightarrow P C_{5: 0} \end{aligned}$ | None | Jump within Page (Note 3) |
| JSRP | a | - - | $\underline{10 \mid \quad} \mathbf{a}_{5} \mathbf{0}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 4) |
| JSR | a | $6-$ | $\begin{array}{\|l\|l\|l\|l\|} \hline 0110\|100\| & a_{8} \\ \hline \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | 0100\|1000 | $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | 10100\|1001 | $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | $\begin{aligned} & 33 \\ & 3 \mathrm{C} \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0011 & 0011 \\ \hline 0011 & 1100 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{A} \rightarrow \mathrm{Q}_{7: 4} \\ & \mathrm{RAM}(\mathrm{~B}) \\ & \\ & Q_{3: 0} \end{aligned}$ | None | Copy A, RAM to Q |
| LD | r | -5 | 00\|r|0101| | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into $A$, Exclusive-OR Br with r |
| LQID |  | BF | \|1011 1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SA} \rightarrow \mathrm{SB} \end{aligned}$ | None | Load Q Indirect (Note 2) |
| RMB | 0 1 2 3 | $4 C$ 45 42 43 | $0100\|1100\|$  <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{aligned} 0 & \rightarrow \operatorname{RAM}(\mathrm{~B})_{0} \\ 0 & \rightarrow R A M(B)_{1} \\ 0 & \rightarrow \operatorname{RAM}(B)_{2} \\ 0 & \rightarrow \text { RAM }(B)_{3} \end{aligned}$ | None | Reset RAM Bit |
| SMB | 0 1 2 3 | $4 D$ 47 46 $4 B$ | 0100 1101 <br> 0100 0111 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} 1 & \rightarrow \operatorname{RAM}(B)_{0} \\ 1 & \rightarrow \operatorname{RAM}(B)_{1} \\ 1 & \rightarrow \operatorname{RAM}(B)_{2} \\ 1 & \rightarrow \text { RAM }(B)_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | y | 7- | 0111 y | $\begin{aligned} & \mathrm{y} \rightarrow \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | $r$ | -6 | (00\|r|0110| | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with r |
| XAD | 3,15 | 23 $B F$ | 0010 0011 <br> 1011 1111 | RAM $(3,15) \longleftrightarrow A$ | None | Exchange A with RAM $(3,15)$ |
| XDS | r | -7 | 00\|r|0111 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with A and Decrement Bd, Exclusive-OR Br with r |
| XIS | r | -4 | 100\|r|0100| | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \longrightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with A and Increment Bd, Exclusive-OR Br with r |



Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit $A$ register.
Note 2: For additional information on the operation of the XAS, JID, and LQID instructions, see below.
Note 3: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 4: A JSRP transfers program control to subroutine page 2 ( 010 is loaded into the upper 3 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2 .
Note 5: The machine code for the lower 4 bits of the LBI instruction equals the binary value of the " $d$ " data minus 1 , e.g., to load the lower four bits of $B$ (Bd) with the value $9(10012)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal $15\left(1111_{2}\right)$.
Note 6: Machine code for operand field $y$ for LEl instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP401L programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by $A$ and $M$. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 9 -bit word, $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{8}$ is not affected by this instruction.
Note that JID requires 2 instruction cycles to execute.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 9-bit word $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}$. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack ( $\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB}$ ) and replaces the least significant 8 bits of PC as follows: $A \rightarrow \mathrm{PC}_{7: 4}, \mathrm{RAM}(\mathrm{B})$ $\rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" (SB $\rightarrow$ SA $\rightarrow$ PC), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SA $\rightarrow$ SB, the previous contents of SB are lost. Also, when LQID pops the stack, the previously pushed contents of SA are left in SB. The net result is that the contents of SA are placed in SB $(\mathrm{SA} \rightarrow \mathrm{SB})$. Note that LQID takes two instruction cycle times to execute.

## INSTRUCTION SET NOTES

a. The first word of a COP401L program (ROM address 0) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped.
c. The ROM is organized into 8 pages of 64 words each. The Program Counter is a 9 -bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page 3 or 7 will access data in the next group of 4 pages.

## Typical Applications

## PROM-BASED SYSTEM

The COP401L may be used to emulate the COP410L. Figure 8 shows the interconnect to implement a COP401L hardware emulation. This connection uses one MM5204 EPROM as external memory. Other memory can be used such as bipolar PROM or RAM.

Pins $\mathrm{IP}_{7}-\mathrm{IP}_{0}$ are bidirectional inputs and outputs. When the AD/ $\overline{\text { DATA }}$ clocking output turns on, the EPROM drivers are disabled and $\mathrm{P}_{7}-\mathrm{IP}_{0}$ output addresses. The 8 -bit latch (MM74C373) latches the address to drive the memory.
When AD/ $\overline{\text { DATA }}$ turns off, the EPROM is enabled and the $\mathrm{IP}_{7}-\mathrm{IP}_{0}$ pins will input the memory data. P8 outputs the most significant address bit to the memory. (SKIP output may be used for program debug if needed.)
24 of the COP401L pins may be configured exactly the same as a COP410L.

Typical Applications (Continued)


FIGURE 8. COP401L Used to Emulate a COP410L

## Option Table

## COP401L. MASK OPTIONS

The following COP410L options have been implemented in this basic version of the COP401L.

| Option Value | Comment | Option Value | Comment |
| :---: | :---: | :---: | :---: |
| Option $1=0$ | Ground-no option | Option $14=0$ | SI has load to $\mathrm{V}_{\mathrm{CC}}$ |
| Option $2=1$ | CKO is RAM power supply input | Option $15=2$ | SO is push-pull output |
| Option $3=\mathrm{N} / \mathrm{A}$ | CKI is external clock divide-by- | Option $16=2$ | SK is push-pull output |
|  | 32 (not available on COP410L) | Option $17=0$ |  |
| Option $4=0$ | Reset has load to $V_{\text {cc }}$ | Option $18=0$ | G outputs are standard |
| Option $5=2$ |  | Option $19=0$ |  |
| Option $6=2$ | L outputs are LED direct-drive | Option $20=0$ |  |
| Option $7=2$ |  | Option $21=0$ |  |
| Option $8=2$ |  | Option $22=0$ | D outputs are standard |
| Option $9=1$ | $V_{C C} \operatorname{pin} 4.5 \mathrm{~V}$ to 9.5 V operation | Option $23=0$ | very high current |
| Option $10=2$ |  | Option $24=0$ |  |
| Option $11=2$ | L outputs are LED direct-drive | Option $25=0$ | L |
| Option $12=2$ |  | Option $26=0$ | G Have standard TTL input levels |
| Option $13=2$ |  | Option $27=0$ | SI |
|  |  | Option $28=\mathrm{N} / \mathrm{A}$ | 40-pin package |

## COP401L-X13/COP401L-R13 ROMless N-Channel Microcontroller

## General Description

The COP401L-X13/COP401L-R13 ROMless Microcontrollers are members of the COPSTM family of microcontrollers, fabricated using N-channel, silicon gate MOS technology. The COP401L-X13/COP401L-R13 contain CPU, RAM, I/O and are identical to a COP413L device except the ROM has been removed and pins have been added to output the ROM address and to input the ROM data. In a system the COP401L-X13/COP401L-R13 will perform exactly as the COP413L. This important benefit facilitates development and debug of a COP program prior to masking the final part. There are two clock oscillator configurations available. The crystal oscillator configuration is called COP401L-X13 and the RC oscillator configuration is called COP401L-R13.

## Features

- Circuit equivalent of COP413L
- Low cost
- Powerful instruction set
- $512 \times 8$ ROM, $32 \times 4$ RAM
- Two-level subroutine stack
- $16 \mu \mathrm{~s}$ instruction time

■ Single supply operation (4.5-5.5V)

- Low current drain ( 8 mA max)
- Internal binary counter register with serial I/O
- MICROWIRETM compatible serial I/O
- General purpose outputs
- Software/hardware compatible with other members of COP400 family
- Pin-for-pin compatible with COP402 and COP404L

■ High noise immunity inputs ( $\mathrm{V}_{\mathrm{IL}}=1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=3.6 \mathrm{~V}$ )

## Block Diagram



TL/DD/8528-1
FIGURE 1

## COP401L-X13/COP401L-R13 Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained In this datasheet. Refer to the assoclated reliability electrical test specifications document.

Voltage at Any Pin Relative to GND
Ambient Operating Temperature
Ambient Storage Temperature
Lead Temp. (Soldering, 10 seconds)
-0.3 to +7 V
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
$300^{\circ} \mathrm{C}$

Power Dissipation COP413L 0.3 Watt at $70^{\circ} \mathrm{C}$

Total Source Current 25 mA
Total Sink Cuirrent 40 mA
Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise noted.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standard Operating Voltage ( $V_{C C}$ ) | (Note 1) | 4.5 | 5.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.4 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 8 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Ceramic Resonator Input ( $\div 8$ ) <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> CKI (RC), Reset Input Levels <br> Logic High <br> Logic Low <br> SO Input Level (Test Mode) <br> IPO-IP7, SI Input Level <br> Logic High <br> Logic Low <br> L, G Inputs <br> Logic High <br> Logic Low | (Schmitt Trigger Input) <br> (Note 2) <br> (TTL Level) <br> (High Trip Levels) | 3.0 $0.7 V_{C C}$ 2.5 2.0 3.6 | 0.4 <br> 0.6 <br> 0.8 <br> 1.2 | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Reset Input Leakage |  | -1 | +1 | $\mu \mathrm{A}$ |
| ```Output Current Levels Output Sink Current (lOL) SO and SK Outputs LO-L7 Outputs, G0-G3 CKO IP0-IP7, P8, SKIP, AD/\overline{DATA} Output Source Current (IOH) L0-L7 G0-G3, SO, SK IP0-IP7, P8, SKIP, AD/\overline{DATA} SO,SK IPO-IP7, P8, SKIP, AD/\overline{DATA}``` | $\begin{aligned} & \mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{VOL}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \\ & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \end{aligned}$ | $\begin{array}{r} 0.9 \\ 0.4 \\ 0.2 \\ 1.6 \\ \\ -25 \\ -25 \\ -1.2 \\ -1.2 \\ \hline \end{array}$ |  | mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ <br> $\mu A$ <br> mA <br> mA |
| SI Input Load Source Current | $\mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}$ | -10 | $-140$ | $\mu \mathrm{A}$ |
| ```Total Sink Current Allowed L7-L4, G Port L3-LO Any Other Pin``` |  |  | $\begin{gathered} 4 \\ 4 \\ 2.0 \\ \hline \end{gathered}$ | mA <br> mA <br> mA |
| Total Source Current Allowed Each Pin |  |  | 1.5 | mA |

Note 1: $\mathrm{V}_{\mathrm{CC}}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: SO output " 0 " level must be less than 0.8 V for normal operation.

AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time - $\mathrm{t}_{\mathrm{c}}$ |  | 16 | 40 | $\mu \mathrm{S}$ |
| CKI <br> Input Frequency - fi <br> Duty Cycle <br> Rise Time <br> Fall Time | $\div 8$ Mode $\mathrm{fi}=0.5 \mathrm{MHz}$ | $\begin{aligned} & 0.2 \\ & 30 \end{aligned}$ | $\begin{gathered} 0.5 \\ 60 \\ 500 \\ 200 \end{gathered}$ | $\begin{gathered} \mathrm{MHz} \\ \% \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \hline \end{gathered}$ |
| CKI Using RC $(\div 4)$ <br> Instruction Cycle Time (Note 1) | $\begin{aligned} & R=56 \mathrm{k} \Omega \pm 5 \% \\ & C=100 \mathrm{pF} \pm 10 \% \end{aligned}$ | 16 | 28 | $\mu \mathrm{s}$ |
| Inputs: $\begin{aligned} & \text { G3-G0, L7-LO } \\ & \text { tsETUP } \\ & \text { t }_{\text {HOLD }} \\ & \text { SI, IPO-IP7 } \\ & \text { tSETUP } \\ & \text { t }_{\text {HOLD }} \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & 8.0 \\ & 1.3 \\ & \\ & 2.0 \\ & 1.0 \\ & \hline \end{aligned}$ | $\mu \mathrm{S}$ $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{S}$ |
| Output Propagation Delay <br> SO, SK Outputs <br> tpd1, tpd0 <br> L, G Outputs <br> tpd1, tpd0 <br> IPO-IP7, P8, SKIP <br> tpd1, tpd0 | Test Condition: $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V} \\ & \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega \\ & \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega \\ & \mathrm{R}_{\mathrm{L}}=5 \mathrm{k} \Omega \end{aligned}$ |  | $\begin{aligned} & 4.0 \\ & 5.6 \\ & 7.2 \end{aligned}$ | $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{S}$ |

Note 1: Variation due to the device included.

## Connection Diagram



TL/DD/8528-2

## Pin Descriptions

| Pin | Description |
| :--- | :--- |
| L $_{7}-L_{0}$ | 8 bidirectional I/O ports |
| $G_{3}-G_{0}$ | 4 bidirectional I/O ports |
| SI | Serial input (or counter input) |
| SO | Serial output (or general purpose output) |
| SK | Logic-controlled clock (or general |
|  | purpose output) |
| AD/DATA | Address out/data in flag |
| CKI | System oscillator input |
| CKO | System oscillator output or NC |
| RESET | System reset input |
| VCC | Power supply |
| GND | Ground |
| IP7-IPO | 8 bidirectional ROM address and data ports |
| P8 | Most significant ROM address bit output |
| SKIP | Instruction skip output |

Instruction skip output

FIGURE 2
Order Number COP401L-X13N or COP401L-R13N See NS Package Number N40A

## Timing Waveform



## Development Support

The MOLE (Microcontroller On Line Emulator) is a low cost development system and real time emulator for COP's products. They also include TMP, 8050, and the new 16-bit HPC Microcontroller Family. The MOLE provides effective support for the development of both software and hardware in the user's application.
The purpose of the MOLE is to provide a tool to write and assemble code, emulate code for the target microcontroller and assist in debugging of the system.
The MOLE can be connected to various hosts, IBM PC STARPLEXTM, Kaypro, Apple, and Intel Systems, via RS232 port. This link facilitate the up loading/down loading of code, supports host assembly and mass storage.
The MOLE consists of three parts; brain, personality and optional host software.
The brain board is the computing engine of the system. It is a self contained computer with its own firmware which provides for all system operation, emulation control, communication, from programming and diagnostic operation. It has three serial ports which can be connected to a terminal, host system, printer, modem or to other MOLE's in a multiMOLE environment.

The personality board contains the necessary hardware and firmware needed to emulate the target microcontroller. The emulation cable which replaces the target controller attaches to this board. The software contains a cross assembler and communications program for up loading and down loading code from the MOLE.

MOLE Ordering Information

| MOLE Ordering Information |  |
| :---: | :---: |
| P/N | Description |
| MOLE-BRAIN | MOLE Computer Board |
| MOLE-COPS-PB1 | COPS' Personality Board |
| MOLE-XXX-YYY | Optional Software |
| Where XXX $=$ COPS, TMP, 8050, or HPC |  |
| YYY $=$ Host System, IBM, APPLE, KAY (Kaypro), |  |
| CP/M |  |

Where $X X X=$ COPS, TMP, 8050, or HPC

$$
\begin{aligned}
& Y Y Y= \text { Host System, IBM, APPLE, KAY (Kaypro), } \\
& \text { CP/M }
\end{aligned}
$$

FIGURE 3. Input/Output Timing Diagram
TL/DD/8528-3

## Functional Description

A block diagram of the COP401L-X13/COP401L-R13 is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2 volts). When a bit is reset, it is a logic " 0 " (less than 0.8 volts).

## PROGRAM MEMORY

Program Memory consists of a 512-byte external memory. As can be seen by an examination of the COP401L-X13/ COP401L-R13 instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 8 pages of 64 words each.
ROM addressing is accomplished by a 9-bit PC register. Its binary value selects one of the 5128 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 9 -bit binary count value. Two levels of subroutine nesting are implemented by the 9-bit subroutine save registers, SA and SB, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 128 -bit RAM, organized as 4 data registers of 8 -bit digits. RAM addressing is implemented by a 6 -bit B register whose upper 2 bits $(\mathrm{Br})$ select 1 of 4 data registers and lower 3 bits of the 4 -bit Bd select 1 of 84 -bit digits in the selected data register. While the 4 -bit contents of the selected RAM digit ( $M$ ) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the XAD 3,15 instruction.
The most significant bit of Bd is not used to select a RAM digit. Hence each physical digit of RAM may be selected by two different values of Bd as shown in Figure 4 below. The skip condition for XIS and XDS instructions will be true if Bd changes between 0 and 15, but NOT between 7 and 8 (see Table 3).


TL/DD/8528-4

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Bd portion of the B register, to load 4 bits of the 8 -bit Q latch data, to input 4 bits of the 8 -bit LI/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions of the COP401L-X13/COP401L-R13, storing its results in A. It also outputs a carry bit to the 1 -bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below).
The G register contents are outputs to 4 general-purpose bidirectional I/O ports.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded from M and A , as well as 8 -bit data from ROM. Its contents are output to the LI/O ports when the L drivers are enabled under program control. (See LEl instruction.)
The 8 L drivers, when enabled, output the contents of latched $Q$ data to the L I/O ports. Also, the contents of L may be read directly into $A$ and $M$.
The SIO register functions as a 4 -bit serial-in-/serial-out shift register or as a binary counter depending on the contents of the EN Register. (See EN register description, below.) Its contents can be exchanged with $A$, allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers.
The XAS instruction copies C into the SKL Latch. In the counter mode, SK is the output of SKL in the shift register mode, SK outputs SKL ANDed with internal instruction cycle clock.
The EN register is an internal 4-bit register loaded under program control by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN registers ( $E N_{3}-\mathrm{EN}_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO Register as either a 4-bit shift register or a 4-bit binary counter. With $E N_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI Input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO Output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data pesent at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. $E N_{1}$ is not used. It has no effect on COP401L-X13/ COP401L-R13 operation.
3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in $Q$ to the L I/O ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high impedance input state.

FIGURE 4. RAM Digit Address to Physical RAM Digit Mapping

Functional Description (Continued)
TABLE I. Enable Register Modes - Blts EN ${ }_{3}$ and $\mathrm{EN}_{0}$

| $\mathrm{EN}_{3}$ | $\mathrm{EN}_{0}$ | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift | 0 | If $\mathrm{SKL}=1, \mathrm{SK}=$ Clock |
|  |  |  | Register |  | If $S K L=0, S K=0$ |
| 1 | 0 | Shift Register | Input to Shift | Serial | If $\mathrm{SKL}=1, \mathrm{SK}=$ Clock |
|  |  |  | Register | Out | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 0 | 1 | Binary Counter | Input to Binary | 0 | If $S K L=1, S K=1$ |
|  |  |  | Counter |  | If $S K L=0, S K=0$ |
| 1 | 1 | Binary Counter | Input to Binary | 1 | If $S K L=1, S K=1$ |
|  |  |  | Counter |  | If $S K L=0, S K=0$ |

4. $E N_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $\mathrm{EN}_{0}$ set (binary counter option selected) SO will output the value loaded into $\mathrm{EN}_{3}$. With $\mathrm{EN}_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ". Table 1 provides a summary of the modes associated with $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the RESET pin as shown below (Figure 5). The RESET pin is configured as a Schmitt trigger input. If not used it should be connected to VCc. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.


TL/DD/8528-5
Figure 5. Power-Up Clear Circuit
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the A, B, C, EN, and G registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.

## EXTERNAL MEMORY INTERFACE

The COP401L-X13/COP401L-R13 is designed for use with an external Program Memory. This memory may be implemented using any devices having the following characteristics:

1. random addressing
2. TTL-compatible TRI-STATE ${ }^{\circledR}$ outputs
3. TTL-compatible inputs
4. access time $=5 \mu \mathrm{~s}$ max.

Typically these requirements are met using bipolar or MOS PROMs.
During operation, the address of the next instruction is sent out on P8 and IP7 through IP0 during the time that AD/ $\overline{\text { DATA }}$ is high (logic " 1 " = address mode). Address data on the IP lines is stored into an external latch on the high-to-low transition of the AD/DATA line; P8 is a dedicated address output, and does not need to be latched. When AD/ $\overline{\text { DATA }}$ is low (logic " 0 " = data mode), the output of the memory is gated onto IP7 through IPO, forming the input bus. Note that the AD/ $\overline{\mathrm{DATA}}$ output has a period of one instruction time, a duty cycle of approximately $50 \%$, and specifies whether the IP lines are used for address output or instruction input.

## OSCILLATOR

There are two basic clock oscillator configurations available as shown by Figure 6.
a. The COP401L-X13 is a Resonator Controlled Oscillator. CKI and CKO are connected to an external ceramic resonator. The instruction cycle frequency equals the resonator frequency divided by 8.
b. The COP401L-R13 is a RC Controlled Oscillator. CKI is configured as a single pin RC controlled Schmitt trigger oscillator. The instruction cycle equals the oscillation frequency divided by 4 . CKO becomes no connection.


TL/DD/8528-6
FIGURE 6. COP401L-X13/COP401L-R13 Oscillator

Functional Description (Continued)


TL/DD/8528-7
a. Standard Output

b. Push-Pull Output


c. Standard L Ouput



TL/DD/8528-10
d. Input With Load

e. HI-Z Input

TL/DD/8528-11

FIGURE 7. Input and Output Configurations

Ceramic Resonator Oscillator

| Resonator <br> Value | Component Values |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | R1 $(\Omega)$ | R2 $(\Omega)$ | $\mathbf{C 1}(\mathrm{pF})$ | $\mathbf{C 2}(\mathrm{pF})$ |
| 455 kHz | 4.7 k | 1 M | 220 | 220 |

RC Controlled Oscillator

| $\mathbf{R ( k} \Omega)$ | $\mathbf{C}(\mathrm{pF})$ | Instruction <br> Cycle Time <br> (in $\mu \mathbf{s})$ |
| :---: | :---: | :---: |
| 51 | 100 | $19 \pm 15 \%$ |
| 82 | 56 | $19 \pm 13 \%$ |

Note: $200 \mathrm{k} \Omega \geq \mathrm{R} \geq 25 \mathrm{k} \Omega$
$220 \mathrm{pF} \geq \mathrm{C} \geq 50 \mathrm{pF}$

## I/O CONFIGURATIONS

COP401L-X13/COP401L-R13 inputs and outputs have the following configurations, illustrated in Figure 7.
a. G0-G3-an enhancement mode device to ground in conjunction with depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$.
b. SO, SK, IPO-IP7, P8, SKIP, AD/DATA-an enhancement mode device to ground in conjunction with a depletionmode device paralleled by an enhancement-mode device to $V_{C C}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads.
c. LO-L7-same as a, but may be disabled.
d. SI has on-chip depletion load device to $V_{\text {CC }}$.
e. $\overline{\text { RESET }}$ has a $\mathrm{Hi}-\mathrm{Z}$ input which must be driven to a " 1 " or "0" by external components.
Curves are given in Figure 8 to allow the designer to effectively use the I/O configurations in designing a system.
An important point to remember is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current, however, when the $L$ lines are used as inputs, the disabled depletion device can not be relied on to source sufficient current to pull an input to a logic "1".

## Typical Performance Characteristics



Source Current for SO, SK, IP0, IP7, P8, SKIP, AD/DATA Configuration




Output Sink Current IPO-IP7, P8, SKIP, AD/ $\overline{D A T A}$


TL/DD/8528-12

FIGURE 8. I/O Characteristics

## COP401L-X13/COP401L-R13 Instruction Set

Table II is a symbol table providing internal architecture, Instruction operand and operational symbols used in the instruction set table.

Table III provides the mnemonic, operand, machine code, data flow, skip conditions, and description associated with each instruction in the COP401L-X13/COP401L-R13 instruction set.

TABLE II. COP401L-X13/COP401L-R13 Instruction Set Table Symbols

| Symbol | Definition |
| :---: | :---: |
| Internal Architecture Symbols |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G l/O Port |
| L | 8 -bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B Register |
| PC | 9 -bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L //O Port |
| SA | 9-bit Subroutine Save Register A |
| SB | 9 -bit Subroutine Save Register B |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic Controlled Clock Output |
| Instruction Operand Symbols |  |
| d | 4-bit Operand Field, $0-15$ binary (RAM Digit Select) |
| r | 2-bit Operand Field, 0-3 binary (RAM Register Select) |
| a | 9 -bit Operand Field, 0-511 binary (ROM Address) |
| y | 4-bit Operand Field, 0-15 binary (Immediate Data) |
| RAM(s) | Contents of RAM location addressed by s |
| ROM(t) | Contents of ROM location addressed by t |
| Operational Symbols |  |
| + | Plus |
| - | Minus |
| $\rightarrow$ | Replaces |
| $\longleftrightarrow$ | Is exchanged with |
| = | Is equal to |
| $\bar{A}$ | The one's complement of A |
| $\oplus$ | Exclusive-OR |
| : | Range of values |


| TABLE III. COP401L-X13/COP401L-R13 Instruction Set |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 0011\|0000 | $\begin{aligned} & A+C+\operatorname{RAM}(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 001110001 | $A+\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{A}$ | None | Add RAM to A |
| AISC | $y$ | 5- | 0101 ${ }^{\text {y }}$ | $A+y \rightarrow A$ | Carry | Add Immediate, Skip on Carry ( $y \neq 0$ ) |
| CLRA |  | 00 | 1000010000 | $\underset{\sim}{0} \rightarrow A$ | None | Clear A |
| COMP |  | 40 | 0100\|0000 | $\bar{A} \rightarrow A$ | None | One's complement of A to A |
| NOP |  | 44 | 010010100 | None | None | No Operation |
| RC |  | 32 | 0011 0010 | "0" $\rightarrow$ C | None | Reset C |
| SC |  | 22 | 0010\|0010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | 0000\|0010 | $A \oplus R A M(B) \rightarrow A$ | None | Exclusive-OR RAM with A |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 2) |
| JMP | a | 6- | $\frac{\|0110\| 000 \mid a_{8}}{\mid a_{7: 0}}$ | $a \rightarrow P C$ | None | Jump |
| JP | a | - | $\square$ <br> 1) $a_{6: 0}$ <br> (pages 2, 3 only) <br> or $\qquad$ <br> (all other pages) | $\mathrm{a} \rightarrow \mathrm{PC}_{6: 0}$ $\mathrm{a} \rightarrow \mathrm{PC}_{5: 0}$ | None | Jump within-Page (Note 3) |
| JSRP | a | - | 10\| a5:0 | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & 010 \rightarrow \mathrm{PC}_{8: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 4) |
| JSR | a | 6- | \|0110|100|a8 | $\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB}$ | None | Jump to Subroutine |
|  |  | - 48 | $\frac{a 7: 0}{\|0100\| 1000 \mid}$ | $\mathrm{a} \rightarrow \mathrm{PC}$ $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ |  |  |
| RETSK |  | $49$ | $10100\|1001\|$ | SB $\rightarrow$ SA $\rightarrow$ PC | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 | 0011 0011 | $A \rightarrow Q_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C |  | $\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{Q}_{3: 0}$ |  |  |
| LD | r | -5 | \|00|r|0101 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into $A$, Exclusive-OR Br with $r$ |
| LQID |  | BF | 1011 [1111 | $\begin{aligned} & R O M\left(P C_{8}, A, M\right) \rightarrow Q \\ & S A \rightarrow S B \end{aligned}$ | None | Load Q Indirect (Note 2) |
| RMB | 0 | 4 C | 0100\|1100| | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | 010010101 | $0 \rightarrow \operatorname{RAM}(\mathrm{~B})_{1}$ |  |  |
|  | 2 | 42 | -0100\|0010 | $0 \rightarrow$ RAM $(\mathrm{B})_{2}$ |  |  |
|  | 3 | 43 | $0100\|0011\|$ <br> $0100 \mid 11011$ | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{3}$ |  |  |
| SMB | 0 | 4D | 0100 1101 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{0}$ | None | Set RAM Bit |
|  | 1 | 47 | 010010111 | $1 \rightarrow \mathrm{RAM}(\mathrm{B})_{1}$ |  |  |
|  | 2 | 46 | 010010110 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 4B |  | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{3}$ |  |  |
| STII | $y$ | 7- | 0111) y | $\begin{aligned} & y \rightarrow \text { RAM(B) } \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| $x$ | r | -6 | $\underline{00\|r\| 0110 \mid}$ | $\begin{aligned} & \operatorname{RAM}(\mathrm{B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with $A$, Exclusive-OR Br with r |

TABLE III. COP401L-X13/COP401L-R13 Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| XAD | 3,15 | 23 | \|0010|0011 | $\operatorname{RAM}(3,15) \longleftrightarrow A$ | None | Exchange A with RAM$(3,15)$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | BF | 1011\|1111 |  |  |  |
| XDS | 「 | -7 |  | RAM $(B) \longleftrightarrow A$ | Bd decrements past 0 | Exchange RAM with $A$ |
|  |  |  |  | $\mathrm{Bd}-1 \rightarrow \mathrm{Bd}$ |  | and Decrement Bd, |
|  |  |  |  | $\mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br}$ |  | Exclusive-OR Br with $r$ |
| XIS | r | -4 | $\underline{\text { LOO\|r }}$ [0100\| | RAM $(\mathrm{B}) \longleftrightarrow \mathrm{A}$ | Bd increments past 15 | Exchange RAM with A |
|  |  |  |  | $\mathrm{Bd}+1 \rightarrow \mathrm{Bd}$ |  | and Increment Bd, |
|  |  |  |  | $\mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br}$ |  | Exclusive-OR Br with r |

## REGISTER REFERENCE INSTRUCTIONS



## INPUT/OUTPUT INSTRUCTIONS

| ING | 33 | 10011\|0011 | $\mathrm{G} \rightarrow \mathrm{A}$ | None | Input G Ports to A |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 2A | 10010\|1010 |  |  |  |
| INL | 33 | 0011\|0011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  | 2 E | \|0010|1110 | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OMG | 33 | 0011\|0011 | RAM (B) $\rightarrow$ G | None | Output RAM to G Ports |
|  | 3A | 0011\|1010 |  |  |  |
| XAS | 4F | \|0100|1111 | $\mathrm{A} \longleftrightarrow \mathrm{SIO}, \mathrm{C} \rightarrow \mathrm{SKL}$ | None | Exchange A with SIO (Note 2) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined) Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4-bit A register.
Note 2: For additional information on the operation of the XAS, JID, and LQID instructions, see below.
Note 3: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 4: A JSRP transfers program control to subroutine page 2 ( 010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 5: The machine code for the lower 4 bits of the LBI instruction equals the binary value of the " $d$ " data minus 1 e.g., to load the lower four bits of $B$ ( $B d$ ) with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal $15\left(1111_{2}\right)$.
Note 6: Machine code for operand field $y$ for LEI instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP401L-X13/C0P401L-R13 programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 9 -bit word, $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{8}$ is not affected by this instruction.
Note that JID requires 2 instruction cycles to execute.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 9-bit word $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}$. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack ( $\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB}$ ) and replaces the least significant 8 bits of PC as follows: $\mathrm{A} \rightarrow \mathrm{PC}_{7: 4}$, RAM (B) $\rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the Q latches. Next, the stack is "popped" ( $\mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ ), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SA $\rightarrow$ SB, the previous contents of SB are lost. Also, when LQID pops the stack, the previously pushed contents of SA are left in SB. The net result is that the contents of SA are placed in SB $(S A \rightarrow S B)$. Note that LQID takes two instruction cycle times to execute.

## INSTRUCTION SET NOTES

a. The first word of a COP401L-X13/COP401L-R13 program (ROM address 0 ) must be a CLRA (Clear $A$ ) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped.
c. The ROM is organized into 8 pages of 64 words each. The Program Counter is a 9-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page 3 or will access data in the next group of 4 pages.

## COPS Programming Manual

For detailed information on writing COPS programs, the COPS Programming Manual 424410284-001 provides an indepth discussion of the COPS architecture, instruction set and general techniques of COPS programming. This manual is written with the programmer in mind.

## Typical Applications

## PROM-Based System

The COP401L-X13/COP401L-R13 may be used to emulate the COP413L. Figure 9 shows the interconnect to implement a COP401L-X13/COP401L-R13 hardware emulation. This connection uses one MM2716 EPROM as external memory. Other memory can be used such as bipolar PROM or RAM.
Pins $\mathrm{IP}_{7}-I \mathrm{P}_{0}$ are bidirectional inputs and outputs. When the AD/ $\overline{\text { DATA }}$ clocking output turns on, the EPROM drivers are disabled and $\mathrm{IP}_{7}-\mathrm{IP}_{0}$ output addresses. The 8 -bit latch (MM74C373) latches the addresses to drive the memory.
When AD/ $\overline{\text { DATA }}$ turns off, the EPROM is enabled and the $\mathrm{IP}_{7}-\mathrm{IP}_{0}$ pins will input the memory data. P8 outputs the most significant address bit to the memory. (SKIP output may be used for program debug if needed.)
Twenty of the COP401L-X13/COP401L-R13 pins may be configured exactly the same as the COP413L. Selection of the COP401L-X13 or COP401L-R13 depends upon which oscillator is selected for the COP413L.

| Oscillator Requirement | Order <br> ROMIess |
| :--- | :---: |
| COP413L Option $1=0$ | Ceramic Resonator |
| or external input |  |
| COP401L-X13 |  |
| frequency divided by |  |

Option $1=1$ Single Pin RC COP401L-R13 controlled oscillator divided by 4. CKO is no connection.

Typical Applications (Continued)


TL/DD/8528-13
FIGURE 9. COP401L-X13/COP401L-R13 Used to Emulate a COP413L

## COP402/COP402M ROMIess N -Channel Microcontrollers

## General Description

The COP402/COP402M ROMless Microcontrollers are members of the COPSTM family, fabricated using $N$-channel silicon gate MOS technology. Each part contains CPU, RAM, and I/O, and is identical to a COP420 device, except the ROM has been removed; pins have been added to output the ROM address and to input ROM data. In a system, the COP402 or 402M will perform exactly as the COP420; this important benefit facilitates development and debug of a COP420; this important benefit facilitates development and debug of a COP420 program prior to masking the final part. These devices are also appropriate in low volume applications, or when the program may require changing. The COP402M is identical to the COP402, except the MICROBUSTM interface option has been implemented.
The COP402 may also be used to emulate the COP410L, 411 L , or 420 L by appropriately reducing the clock frequency.

## Features

- Extended temperature $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ COP302/ COP302M, available as special order
- Low cost
- Exact circuit equivalent of COP420
- Standard 40-pin dual-in-line package
- Interfaces with standard PROM or ROM
- $64 \times 4$ RAM, addresses up to $1 \mathrm{k} \times 8$ ROM
- MICROBUS compatible (COP402M)
- Powerful instruction set
- True vectored interrupt, plus restart
- Three-level subroutine stack
- $4.0 \mu \mathrm{~s}$ instruction time

【 Single supply operation ( 4.5 V to 6.3 V )

- Internal time-base counter for real-time processing
- Internal binary counter register with MICROWIRETM serial I/O capability
- Software/hardware compatible with other members of COP400 family


## Block Diagram



FIGURE 1

## COP402/COP402M and COP302/COP302M

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.

Voltage at Any Pin
-0.3 V to +7 V
Operating Temperature Range
COP402/COP402M
$0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature Range $\quad-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (soldering, 10 sec. )

Package Power Dissipation
750 mW at $25^{\circ} \mathrm{C}$ 400 mW at $70^{\circ} \mathrm{C}$ 250 mW at $85^{\circ} \mathrm{C}$

Total Sink Current 50 mA 70 mA

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

## COP402/COP402M

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operation Voltage |  | 4.5 | 6.3 | V |
| Power Supply Ripple | Peak to Peak (Note 3) |  | 0.4 | V |
| Supply Current | All Outputs Open $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |  | 40 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Crystal Input <br> Logic High <br> Logic Low <br> Schmitt Trigger Input <br> RESET <br> Logic High <br> Logic Low <br> All Other Inputs <br> Logic High <br> Logic High <br> Logic Low | $\begin{aligned} & V_{C C}=M a x \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ | $\begin{gathered} 2.4 \\ -0.3 \\ \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ \\ 3.0 \\ 2.0 \\ -0.3 \\ \hline \end{gathered}$ | $\begin{aligned} & 0.4 \\ & 0.6 \\ & 0.8 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| Input Load Source Current | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ | -100 | -800 | $\mu \mathrm{A}$ |
| Input Capacitance |  |  | 7 | pF |
| Hi-Z Input Leakage | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | -1 | +1 | $\mu \mathrm{A}$ |
| ```Output Voltage Levels D, G, L, SK, SO Outputs TTL Operation Logic High Logic Low IP0-IP7, P8, P9, SKIP, CKO, AD/ \(\overline{\text { DATA }}\) Logic High Logic Low CMOS Operation (Note 1) Logic High Logic Low``` | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-75 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=400 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $\begin{gathered} 2.4 \\ -0.3 \\ \\ 2.4 \\ -0.3 \\ V_{C C}-1 \\ -0.3 \end{gathered}$ | 0.4 <br> 0.4 <br> 0.2 | $\begin{aligned} & V \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Output Current Levels LED Direct Drive (COP402) Logic High | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \hline \end{aligned}$ | 2.5 | 14 | mA |
| TRI-STATE ${ }^{\oplus}$ (COP402M) Leakage Current | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | -50 | +50 | $\mu \mathrm{A}$ |
| Allowable Sink Current Per Pin (L, D, G) Per Pin (All Others) Per Port (L) Per Port ( $\mathrm{D}, \mathrm{G}$ ) |  |  | $\begin{gathered} 10 \\ 2 \\ 16 \\ 10 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Allowable Source Current Per Pin (L) <br> Per Pin (All Others) |  |  | $\begin{array}{r} -15 \\ -1.5 \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |

Note 1: TRI-STATE and LED configurations are excluded.

## COP402/COP402M

AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time |  | 4 | 10 | $\mu \mathrm{s}$ |
| Operating CKI Frequency | $\div 16$ Mode | 1.6 | 4.0 | MHz |
| CKI Duty Cycle (Note 1) <br> Rise Time Fall Time | $\begin{aligned} & \text { Frequency }=4 \mathrm{MHz} \\ & \text { Frequency }=4 \mathrm{MHz} \end{aligned}$ | 40 | $\begin{aligned} & 60 \\ & 60 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & \% \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |
| ```Inputs: SI tsetup thOLD All Other Inputs tsETUP thold``` |  | $\begin{gathered} 0.3 \\ 250 \\ \\ 1.7 \\ 300 \\ \hline \end{gathered}$ |  | $\mu \mathrm{S}$ ns <br> $\mu \mathrm{s}$ <br> ns |
| Output Propagation Delay ```SO and SK tpd1 tpd0 CKO tpd1 tpd0 AD/\overline{DATA, SKIP} tpd1 tpd0 All Other Outputs tpd1 tpdo``` | Test Conditions: $R_{L}=5 k, C_{L}=50 \mathrm{pF}, V_{\text {OUT }}=1.5 \mathrm{~V}$ |  | $\begin{aligned} & 1.0 \\ & 1.0 \\ & \\ & 0.25 \\ & 0.25 \\ & \\ & 0.6 \\ & 0.6 \\ & \\ & 1.4 \\ & 1.4 \\ & \hline \end{aligned}$ | $\mu \mathrm{S}$ $\mu \mathrm{S}$ <br> $\mu \mathrm{s}$ $\mu \mathrm{S}$ <br> $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{S}$ $\mu \mathrm{s}$ |
| MICROBUS Timing <br> Read Operation (Figure 4) <br> Chip Select Stable before $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{CSR}}$ <br> Chip Select Hold Time for $\overline{R D}$ - $_{\text {RCS }}$ <br> $\overline{R D}$ Puise Width-t ${ }_{\text {RR }}$ <br> Data Delay from $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{RD}}$ <br> $\overline{\mathrm{RD}}$ to Data Floating- $\mathrm{t}_{\mathrm{DF}}$ | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ | $\begin{gathered} 65 \\ 20 \\ 400 \end{gathered}$ | $\begin{aligned} & 375 \\ & 250 \\ & \hline \end{aligned}$ |  |
| Write Operation (Figure 5) <br> Chip Select Stable before $\overline{W R}-t_{C S W}$ Chip Select Hold Time for WR-twcs WR Pulse Width-tww Data Set-Up Time for $\overline{W R}-t_{D W}$ Data Hold Time for $\overline{W R}-t_{\text {wD }}$ INTR Transition Time from $\overline{\text { WR }}-t_{\text {wI }}$ |  | $\begin{gathered} 65 \\ 20 \\ 400 \\ 320 \\ 100 \end{gathered}$ | 700 |  |

Note 1: Duty Cycle $=\mathrm{t}_{\mathrm{w}} /\left(\mathrm{t}_{\mathrm{w}} 1+\mathrm{t}_{\mathrm{w}}{ }\right.$ ).
Note 2: See Figure 9 tor additional I/O characteristics.
Note 3: Voltage change must be less than 0.5 V in a 1 ms period.
Note 4: Exercise great care not to exceed maximum device power dissipation limits when direct driving LEDs (or sourcing similar loads) at high temperature.

## Connection Diagram

Dual-In-Line Package


Top View
Order Number COP402N or COP402MN See NS Package Number N40A

## Pin Descriptions

| Pin | Description |
| :---: | :---: |
| $\mathrm{L}_{7}-\mathrm{L}_{0}$ | 8 bidirectional I/O ports with TRI-STATE |
| $\mathrm{G}_{3}-\mathrm{G}_{0}$ | 4 bidirectional I/O ports |
| $\mathrm{D}_{3}-\mathrm{D}_{0}$ | 4 general purpose outputs |
| $\mathrm{IN}_{3}-\mathrm{IN}_{0}$ | 4 general purpose inputs |
| SI | Serial input (or counter input) |
| SO | Serial output (or general purpose output) |
| SK | Logic-controlled clock (or general purpose out put) |
| AD/ $\overline{\text { DATA }}$ | Address out/data in flag |
| SKIP | Instruction skip output |
| CKI | System oscillator input |
| CKO | System oscillator output |
| RESET | System reset input |
| $V_{C C}$ | Power supply |
| GND | Ground |
| IP7-IP0 | 8 bidirectional ROM address and data ports |
| P8, P9 | 2 most significant ROM address outputs |

$\mathrm{L}_{7}-\mathrm{L}_{0} \quad 8$ bidirectional I/O ports with TRI-STATE
$\mathrm{G}_{3}-\mathrm{G}_{0} \quad 4$ bidirectional I/O ports
$D_{3}-D_{0} \quad 4$ general purpose outputs
$\mathrm{IN}_{3}-\mathrm{IN}_{0} 4$ general purpose inputs
Serial input (or counter input)
. Serial output (or general purpose output)
SK Logic-controlled clock (or general purpose output)
AD/ $\overline{\text { DATA }}$ Address out/data in flag
SKIP Instruction skip output
CKI System oscillator input
CKO System oscillator output
RESET System reset input
$V_{C C} \quad$ Power supply
GND Ground
IP7-IPO 8 bidirectional ROM address and data ports
P8, P9 2 most significant ROM address outputs

FIGURE 2.

## Timing Diagrams



FIGURE 3a. Input/Output Timing Diagrams (Crystal $\div 16$ Mode)


FIGURE 3b. CKO Output Timing

## Timing Diagrams (Continued)



FIGURE 4. MICROBUS Read Operation Timing


FIGURE 5. MICROBUS Write Operation Timing

## Functional Description

A block diagram of the COP402 is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).

## PROGRAM MEMORY

Program Memory consists of a 1,024-byte external memory (typically PROM). Words of this memory may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 16 pages of 64 words each.
ROM addressing is accomplished by a 10 -bit PC register. Its binay value selects one of the 1,024 8-bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 10 -bit binary count value. Three levels of subroutine nesting are implemented by the 10 -bit subroutine save registers, SA, SB and SC, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 256 -bit RAM, organized as 4 data registers of 164 -bit digits. RAM addressing is implemented by a 6-bit B register whose upper 2 bits ( Br ) select 1 of 4 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4-bit contents of the selected RAM digit ( $M$ ) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the LDD and XAD instruction based upon the 6-bit
contents of the operand field of these instructions. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Br and $B d$ portions of the $B$ register, to load and input 4 bits of the 8 -bit $Q$ latch data, to input 4 bits of the 8 -bit L I/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions of the COP402/402M, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below.)
Four general-purpose inputs, $\mathbb{N}_{3}-\mathbb{I} \mathbb{N}_{0}$, are provided; $\mathbb{N}_{1}$, $I N_{2}$, and $I N_{3}$ may be selected, by a mask-programmable option, as Read Strobe, Chip Select and Write Strobe inputs, respectively, for use in MICROBUS applications.
The $\mathbf{D}$ register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd.
The $\mathbf{G}$ register contents are outputs to 4 general-purpose bidirectional I/O ports. $\mathrm{G}_{0}$ may be mask-programmed as a "ready" output for MICROBUS applications.
The $\mathbf{Q}$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are output to the L I/O ports when the $L$ drivers are enabled under program control. (See LEI instruction.) With the MICROBUS option selected, Q can also be loaded with the 8 -bit contents of the L I/O ports upon the occurrence of a write strobe from the host CPU.

## Functional Description (Continued)

The 8 L drivers, when enabled, output the contents of latched $Q$ data to the L I/O ports. Also, the contents of $L$ may be read directly into $A$ and $M$. As explained above, the MICROBUS option allows L I/O port data to be latched into the $Q$ register. L I/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with $Q$ data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description below.) Its contents can be exchanged with A , allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL. In the shift register mode, SK outputs SKL ANDed with internal instruction cycle clock.
The EN register is an internal 4-bit register loaded under program control by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $E N_{3}-E N_{0}$ ).

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4-bit binary counter. With $\mathrm{EN}_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. With $E N_{1}$ set the $\mathrm{IN}_{1}$ input is enabled as an interrupt input. Immediately following an interrupt, $\mathrm{EN}_{1}$ is reset to disable further interrupts.
3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in $Q$ to the $\mathrm{L} / / \mathrm{O}$ ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high-impedance input state. If the MICROBUS option is being used, $\mathrm{EN}_{2}$ does not affect the $L$ drivers.
4. $E N_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $E N_{3}$. With $E N_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial
shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains reset to " 0 ." The table below provides a summary of the modes associated with $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$.

## INTERRUPT

The following features are associated with the $\mathbb{N}_{1}$ interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once acknowledged as explained below, pushes the next sequential program counter address (PC +1 ) onto the stack, pushing in turn the contents of the other subroutine-save registers to the next lower level $(\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC})$. Any previous contents of SC are lost. The program counter is set to hex address OFF (the last word of page 3) and $\mathrm{EN}_{1}$ is reset.
b. An interrupt will be acknowledged only after the following conditions are met:

1. $E N_{1}$ has been set.
2. A low-going pulse (" 1 " to " 0 ") at least two instruction cycles wide occurs on the $\mathrm{N}_{1}$ input.
3. A currently executing instruction has been completed.
4. All successive transfer of control instructions and successive LBIs have been completed (e.g., if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed.
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon the popping of the stack. For example, if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at hex address OFF. At the end of the interrupt routine, a RET instruction is executed to "pop" the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines and the LQID instruction should not be nested within the interrupt servicing routine since their popping of the stack enables any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The first instruction of the interrupt routine at hex address OFF must be a NOP.
e. An LEI instruction can be put immediately before the RET to re-enable interrupts.

TABLE I. Enable Register Modes-Bits $E N_{3}$ and $E N_{0}$

| $\mathrm{EN}_{3}$ | $\mathrm{EN}_{0}$ | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=S Y N C \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | $\begin{aligned} & \text { If } S K L=1, S K=S Y N C \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | If $\mathrm{SKL}=1, \mathrm{SK}=1$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | $\begin{aligned} & \text { If } \mathrm{SKL}=0, S K=0 \\ & \text { If } \mathrm{SKL}=1, \mathrm{SK}=1 \\ & \text { If } \mathrm{SKL}=0, \mathrm{SK}=0 \end{aligned}$ |

## Functional Description (Continued)

## MICROBUS INTERFACE

The COP402M can be used as a peripheral microprocessor device, inputting and outputting data from and to a host microprocessor ( $\mu \mathrm{P}$ ). $\mathrm{IN}_{1}, \mathrm{IN}_{2}$, and $\mathrm{IN}_{3}$ general purpose inputs become MICROBUS compatible read-strobe, chip-select, and write-strobe lines, respectively. $\mathrm{IN}_{1}$ becomes $\overline{\mathrm{RD}}-\mathrm{a}$ logic " 0 " on this input will cause $Q$ latch data to be enabled to the $L$ ports for input to the $\mu \mathrm{P}$. $\mathrm{IN}_{2}$ becomes $\overline{\mathrm{CS}}-\mathrm{a}$ logic " 0 " on this line selects the COP402M as the $\mu \mathrm{P}$ peripheral device by enabling the operation of the $\overline{\mathrm{RD}}$ and $\overline{W R}$ lines and allows for the selection of one of several peripheral components. $\mathbb{I N}_{3}$ becomes $\overline{W R}$-a logic " 0 " on this line will write bus data from the L ports to the $Q$ latches for input to the COP402M. $G_{0}$ becomes INTR, a "ready" output reset by a write pulse from the $\mu \mathrm{P}$ on the $\overline{\mathrm{WR}}$ line, providing the "handshaking" capability necessary for asynchronous data transfer between the host CPU and the COP402M.
This option has been designed for compatibility with National's MICROBUS-a standard interconnect system for 8 -bit parallel data transfer between MOS/LSI CPUs and interfacing devices. (See MICROBUS, National Publication.) The functioning and timing relationships between the COP402M signal lines affected by this option are as specified for the MICROBUS interface, and are given in the AC electrical characteristics and shown in the timing diagrams (Figures 4 and 5). Connection to the MICROBUS is shown in Figure 6.


TL/DD/6915-7
FIGURE 6. MICROBUS Option Interconnect

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the RESET pin as shown below. The $\overline{\text { RESET }}$ pin is configured as a Schmitt trigger input. If not used it should be connected to $V_{C C}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least two instruction cycle times.

Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the A, B, C, D, EN, G, and SO are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.


RC $\geq 5 \times$ Power Supply Rise Time
TL/DD/6915-8
FIGURE 7. Power-Up Clear CIrcuit

## OSCILLATOR

There are two basic clock oscillator configurations available as shown by Figure 8.
a. Crystal Controlled Oscillator. CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency divided by 16.
b. External Oscillator. CKI is driven by an external clock signal. The instruction cycle time is the clock frequency divided by 16.


| Crystal <br> Value | Component Values |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | R1 | R2 | C |  |
| 4 MHz | 1 k | 1 M | 27 pF |  |
| 3.58 MHz | 1 k | 1 M | 27 pF |  |
| 2.09 MHz | 1 k | 1 M | 56 pF |  |

FIGURE 8. COP402/402M Oscillator

## EXTERNAL MEMORY INTERFACE

The COP402 and COP402M are designed for use with an external Program Memory. This memory may be implemented using any devices having the following characteristics:

1. random addressing
2. TTL-compatible TRI-STATE outputs
3. $T T L=$ compatible inputs
4. access time $=1.0 \mu \mathrm{~s}$, max.

Typically these requirements are met using bipolar or MOS PROMs.

## Functional Description (Continued)

During operation, the address of the next instruction is sent out on P9, P8, and IP7 through IPO during the time that AD $\overline{\text { DATA }}$ is high (logic " 1 " = address mode). Address data on the IP lines is stored into an external latch on the high-to-low transition of the AD/DATA line; P9 and P8 are dedicated address outputs, and do not need to be latched. When AD/DATA is low (logic " 0 " = data mode), the output of the memory is gated onto IP7 through IPO, forming the input bus. Note that the AD/ $\overline{\text { DATA }}$ output has a period of one instruction time, a duty cycle of approximately $50 \%$, and specifies whether the IP lines are used for address output or instruction input. A simplified block diagram of the external memory interface is shown in Figure 9.


TL/DD/6915-10
FIGURE 9. External Memory Interface to COP402

## INPUT/OUTPUT

COP402 outputs have the following configurations, illustrated in Figure 10.
a. Standard-an enhancement-mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with TTL and CMOS input requirements.
b. High Drive-same as a. except greater current sourcing capability.
c. Push-Pull-an enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{Cc}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads.
d. LED Direct Drive-an enhancement-mode device to ground and to $\mathrm{V}_{\mathrm{CC}}$, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (see Functional Description, EN Register), placing the outputs in a high-impedance state to provide required LED segment blanking for a multiplexed display.
e. TRI-STATE Push-Pull-an enhancement-mode device to ground and $V_{C C}$ intended to meet the requirements associated with the MICROBUS option. These outputs are TRI-STATE outputs, allowing for connection of these outputs to a data bus shared by other bus drivers.
$f$. Inputs have an on-chip depletion load device to $V_{C C}$, as shown in Figure 10 .
The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6, respectively). Minimum and maximum current (lout and $V_{\text {OUT }}$ ) curves are given in Figure 10 for each of these devices.
The SO, SK outputs are configured as shown in Figure 10c. The D and G outputs are configured as shown in Figure 10a.

## Functional Description (Continued)

Note that when inputting data to the G ports, the G outputs should be set to " 1 ". The L outputs are configured as in Figure 10d on the COP402. On the COP402M the L outputs are as in Figure $10 e$.
An important point to remember if using configuration $d$ with the L drivers is that even when the L drivers are disabled,

TL/DD/6915-12
b. High Drive

e. TRI-STATE Push-Pull

FIGURE 10. Input/Output Configurations




TL/DD/6915-13
c. Push-Pull

f. Input with Load
the depletion load device will source a small amount of current. (See Figure 11.)
IP7 through IPO outputs are configured as shown in Figure 10c; P9, P8, SKIP, and AD/ $\overline{\bar{A} A T A}$ are configured as shown in Figure $10 b$.
a. Standard
( $\mathbf{4}$ is Depletion Device)


Typical Performance Characteristics






TRI-STATE
Output Source Current


Standard Output Source Current



FIGURE 11. COP402/COP402M Input/Output Characteristics
TL/DD/6915-17

## Typical Performance Characteristics (Continued)



LED Output Source Current


TRI-STATE Output Source Current


L Output Depletion Load Off Source Current


Push Pull Source Current


LED Output Device LED Drive


Input Load Source Current


FIGURE 11a. COP302/COP302M Input/Output Characteristics

## Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table III provides the mnemonic, operand, machine code, data flow, skip conditions and description associated with each instruction in the COP402/402M instruction set.

TABLE II. COP402/COP402M Instruction Set Table Symbols Definition

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 6-bit RAM Address Register |
| Br | Upper 2 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G - | 4-bit Register to latch data for G I/O Port |
| IL | Two 1-bit Latches Associated with the IN ${ }_{3}$ or |
|  | IN inputs |
| IN | 4-bit Input port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| P | 2-bit ROM Address Port |
| PC | 10-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for LI/O Port |
| SA | 10-bit Subroutine Save Register A |
| SB | 10-bit Subroutine Save Register B |
| SC | 10-bit Subroutine Save Register C |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |

Symbol Definition

## INSTRUCTION OPERAND SYMBOLS

d 4-bit Operand Field, $0-15$ binary (RAM Digit Select)
r 2-bit Operand Field, 0-3 binary (RAM Register Select)
a 9-bit Operand Field, 0-511 binary (ROM Address)
y 4-bit Operand Field, 0-15 binary (Immediate Data)
RAM(s) Contents of RAM location addressed by $s$
ROM(t) Contents of ROM location addressed by $t$
OPERATIONAL SYMBOLS
$+\quad$ Plus

- Minus
$\rightarrow \quad$ Replaces
$\longleftrightarrow$ Is exchanged with
$=$ Is equal to
$\bar{A} \quad$ The one's complement of $A$
$\oplus \quad$ Exclusive-OR
: Range of values

TABLE III. COP402/COP402M Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | 0011 0000 | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | 0011 0001 | $A+R A M(B) \rightarrow A$ | None | Add RAM to A |
| ADT |  | 4 A | 0100\|1010| | $\mathrm{A}+10_{10} \rightarrow \mathrm{~A}$ | None | Add Ten to A |
| AISC | $y$ | 5- | 0101\| y | $A+y \rightarrow A$ | Carry | Add Immediate, Skip on Carry ( $\mathrm{y} \neq 0$ ) |
| CASC |  | 10 | 0001 10000 | $\begin{aligned} & \bar{A}+R A M(B)+C \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Complement and Add with Carry, Skip on Carry |
| CLRA |  | 00 | 10000\|0000 | $0 \rightarrow \mathrm{~A}$ | None | Clear A |
| COMP |  | 40 | -0100\|0000 | $\overline{\mathrm{A}} \rightarrow \mathrm{A}$ | None | One's complement of A to A |
| NOP |  | 44 | 0100\|0100 | None | None | No Operation |
| RC |  | 32 | \|0011 10010 | $" 0$ " $\rightarrow$ C | None | Reset C |
| SC |  | 22 | 0010\|0010 | $" 1 " \rightarrow C$ | None | Set C |
| XOR |  | 02 | 000010010 | $A \oplus \operatorname{RAM}(\mathrm{~B}) \rightarrow \mathrm{A}$ | None | Exclusive-OR RAM with A |


| Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TABLE III. COP402/COP402M Instruction Set (Continued) |  |  |  |  |  |  |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 3) |
| JMP | a | $6-$ | $\frac{\|0110\| 00\left\|a_{9: 8}\right\|}{L a_{7: 0}}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  |  | $a \rightarrow P C_{6: 0}$ $a \rightarrow P C_{5: 0}$ | None | Jump within Page (Note 4) |
| JSRP | a | -- |  | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \\ & \mathrm{SB} \rightarrow \mathrm{SC} \\ & 0010 \rightarrow \mathrm{PC}_{9: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR | $\mathrm{a}$ | $6-$ | $\frac{\|0110\| 10\left\|a_{9: 8}\right\|}{\mathrm{a}_{7: 0}}$ | $\underset{\mathrm{PC}+1 \rightarrow \mathrm{PC}}{ } \underset{\mathrm{PA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC}}{ }$ | None | Jump to Subroutine |
| RET |  | 48 | \|0100|1000 | $S C \rightarrow S B \rightarrow S A \rightarrow P C$ | None | Return from Subroutine |
| RETSK |  | 49 | [0100\|1001 | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | 33 | $\left.$001100011 \right\rvert\,0011 | $\begin{aligned} & A \rightarrow Q_{7: 4} \\ & R A M(B) \xrightarrow{\rightarrow} Q_{3: 0} \end{aligned}$ | None | Copy A, RAM to Q |
| CQMA |  | 33 2 C | 0011 0011 <br> 0010 1100 | $\begin{aligned} & Q_{7: 4} \rightarrow \text { RAM }(B) \\ & Q_{3: 0} \rightarrow A \end{aligned}$ | None | Copy Q to RAM, A |
| LD | r | -5 | $\underline{00\|r\| 0101]}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into $A$, Exclusive-OR Br with r |
| LDD | r,d | 23 | $$ | RAM $(\mathrm{r}, \mathrm{d}) \rightarrow \mathrm{A}$ | None | Load A with RAM pointed to directly by $\mathrm{r}, \mathrm{d}$ |
| LQID |  | BF | \|1011|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SB} \rightarrow \mathrm{SC} \end{aligned}$ | None | Load Q Indirect (Note 3) |
| RMB | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 4 C \\ & 45 \\ & 42 \\ & 43 \end{aligned}$ | 0100 1100 <br> 0100 0101 <br> 0100 0010 <br> 0100 0011 | $\begin{array}{lll} 0 & \rightarrow & \operatorname{RAM}(\mathrm{~B})_{0} \\ 0 & \rightarrow & \operatorname{RAM}(\mathrm{~B})_{1} \\ 0 & \rightarrow & \operatorname{RAM}(\mathrm{~B})_{2} \\ 0 & \rightarrow & \operatorname{RAM}(\mathrm{~B})_{3} \end{array}$ | None | Reset RAM Bit |
| SMB | 0 1 2 3 | $4 D$ 47 46 $4 B$ | 0100 1101 <br> 0100 0111 <br> 0100 0110 <br> 0100 1011 | $\begin{aligned} 1 & \rightarrow \operatorname{RAM}(\mathrm{~B})_{0} \\ 1 & \rightarrow \mathrm{RAM}(\mathrm{~B})_{1} \\ 1 & \rightarrow \mathrm{RAM}(\mathrm{~B})_{2} \\ 1 & \rightarrow \mathrm{RAM}(\mathrm{~B})_{3} \end{aligned}$ | None | Set RAM Bit |
| STII | $y$ | 7- | \|0111 ${ }^{\text {y }}$ | $\begin{aligned} & \mathrm{y} \rightarrow \mathrm{RAM}(\mathrm{~B}) \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | $r$ | -6 | O0\|r|0110 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with r |
| XAD | r,d | 23 | 0010 0011  <br> 10 r d | RAM $(\mathrm{r}, \mathrm{d}) \longleftrightarrow \mathrm{A}$ | None | Exchange A with RAM pointed to directly by $r, d$ |


| TABLE III. COP402/COP402M Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Operand | Hex Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| MEMORY REFERENCE INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| XDS | $r$ | -7 | 00\|r|0111 | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with $A$ and Decrement Bd, Exclusive-OR Br with r |
| XIS | $r$ | -4 | $\underline{00\|r\| 0100 \mid}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}+1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd increments past 15 | Exchange RAM with $A$ and Increment Bd, Exclusive-OR Br with r |
| REGISTER REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAB |  | 50 | 0101 10000 | $A \rightarrow B d$ | None | Copy A to Bd |
| CBA |  | 4E | 0100\|1110 | $\mathrm{Bd} \rightarrow \mathrm{A}$ | None | Copy Bd to A |
| LBI | r,d | -- 33 -- | $\begin{gathered} \|00\| r\|(d-1)\| \\ \hline(d=0,9: 15) \\ \text { or } \\ 0011\|0011\| \\ \hline 10\|r\| d \\ \hline \text { (any d) } \end{gathered}$ | $r, d \rightarrow B$ | Skip until not a LBI | Load B Immediate with r,d (Note 6) |
| LEI | $y$ | 33 $6-$ | $0011\|0011\|$ <br> 0110 <br> $0 y$ | $y \rightarrow E N$ | None | Load EN Immediate (Note 7) |
| XABR |  | 12 | 0001 [0010] | $A \longleftrightarrow \operatorname{Br}\left(0,0 \rightarrow A_{3}, A_{2}\right)$ | None | Exchange A with Br |
| TEST INSTRUCTIONS |  |  |  |  |  |  |
| SKC |  | 20 | 001010000 | 1st byte \} 2nd byte | $\mathrm{C}=$ "1" | Skip if C is True |
| SKE |  | 21 | 0010\|0001 |  | $A=R A M(B)$ | Skip if A Equals RAM |
| SKGZ |  | 33 21 | $0011 \mid 0011$  <br> 0010 00011 |  | $\mathrm{G}_{3: 0}=0$ | Skip if G is Zero (all 4 bits) |
| SKGBZ |  | 33 | 0011\|0011 |  |  | Skip if G Bit is Zero |
|  | 0 | 01 | 0000 0001 |  | $\mathrm{G}_{0}=0$ |  |
|  | 1 | 11 | 00010001 <br> 000010011 |  | $\mathrm{G}_{1}=0$ |  |
|  | 2 | 03 | 0000 0011 |  | $\mathrm{G}_{2}=0$ |  |
|  | 3 | 13 | 00010011 |  | $\mathrm{G}_{3}=0$ |  |
| SKMBZ | 0 | 01 | 000010001 |  | $\operatorname{RAM}(B)_{0}=0$ | Skip if RAM Bit is Zero |
|  | 1 | 11 | 0001 0001 |  | $\operatorname{RAM}(\mathrm{B})_{1}=0$ |  |
|  | 2 | 03 | 0000\|0011 |  | $\operatorname{RAM}(\mathrm{B})_{2}=0$ |  |
|  | 3 | 13 | 0001 0011 |  | $\operatorname{RAM}(\mathrm{B})_{3}=0$ |  |
| SKT |  | 41 | 1010010001 |  | A time-base counter carry has occurred since last test | Skip on Timer (Note 3) |

Instruction Set (Continued)
TABLE III. COP402/COP402M Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | 0011 0011 | $\mathrm{G} \rightarrow \mathrm{A}$ | None | Input G Ports to A |
|  |  | 2 A | 0010 1010 |  |  |  |
| ININ |  | 33 | 0011. 00111 | $\mathrm{IN} \rightarrow \mathrm{A}$ | None | Input IN Inputs to A |
|  |  | 28 | 00101000 |  |  | (Notes 2 and 8) |
| INIL |  | 33 | 0011\|0011 | $\mathrm{IL}_{3}$, " 0 ', $\mathrm{IL}_{0} \rightarrow \mathrm{~A}$ | None | Input IL Latches to A |
|  |  | 29 | [0010\|1001 |  |  | (Note 3) |
| INL |  | 33 | 0011\|0011 | $\mathrm{L}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2E | 0010\|1110 | $L_{3: 0} \rightarrow$ A |  |  |
| OBD |  | 33 | 0011\|0011 | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E | $0011 \mid 1110$ |  |  |  |
| OGI | $y$ | 33 | 0011 00011 | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | $5-$ | 0101 y |  |  |  |
| OMG |  | 33 | 0011 00011 | RAM(B) $\rightarrow$ G | None | Output RAM to G Ports |
|  |  | 3A | 0011 1010 |  |  |  |
| XAS |  | 4F | 10100\|1111 | A | None | Exchange A with SIO (Note 3) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit register.
Note 2: The ININ instruction is not available on the 24-pin COP421 since this device does not contain the $\mathbb{N}$ inputs.
Note 3: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 4: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 5: A JSRP transters program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 6: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ " data minus 1 , e.g., to load the lower four bits of $B(8 d)$ with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal $15\left(1111_{2}\right)$.
Note 7: Machine code for operand field y for LEl instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selected Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing programs.

## XAS INSTRUCTION

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register.
The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register, above.) If SIO is selected as a shift register, an XAS instruction must be performed once evey 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 10 -bit word, $\mathrm{PC}_{9: 8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ are not affected by this instruction.
Note that JID requires 2 instruction cycles.

## INIL INSTRUCTION

INIL (Input IL Latches to $A$ ) inputs 2 latches, $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ (see Figure 12) and CKO into $A$. The $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ latches are set if a low-going pulse (" 1 " to " 0 ") has occurred on the $\mathrm{IN}_{3}$ and $\mathrm{IN}_{0}$ inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction times. Execution of an INIL inputs $\mathrm{IL}_{3}$ and $\mathrm{I} \mathrm{N}_{0}$ into A 3 and AO respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the $\mathrm{IN}_{3}$ and $\mathbb{I} N_{0}$ lines. If CKO is mask programmed as a general purpose input, an INIL will input the state of CKO into A2. If CKO has not been so programmed, a " 1 " will be placed in A2. A " 0 " is always placed in A1 upon the execution of an INIL. The general purpose inputs $\mathrm{N}_{3}-\mathrm{N}_{0}$ are input to $A$ upon the execution of an ININ instruction. (See Table III, ININ instruction.) INIL is useful in recognizing pulses of short duration or pulses which occur too often to be read conveniently by an ININ instruction.


TL/DD/6915-19
FIGURE 12. $\mathrm{IN}_{0} / \mathrm{IN}_{3}$ Latches

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 10 -bit word $\mathrm{PC}_{9}, \mathrm{PC}_{8}, \mathrm{~A}$, M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC + $1 \rightarrow$ SA $\rightarrow$ SB $\rightarrow$ SC) and replaces the least significant 8 bits of PC as follows: $\mathrm{A} \rightarrow$ $\mathrm{PC}_{7: 4}, \mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" (SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow P C$ ), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost. Also, when LQID pops the stack, the previously pushed contents of SB are left in SC. The net result is that the contents of SB are placed in SC (SB $\rightarrow$ SC). Note that LQID takes two instruction cycle times to execute.

## SKT INSTRUCTION

The SKT (Skip on Timer) instruction tests the state of an internal 10-bit time-base counter. This counter divides the instruction cycle clock frequency by 1024 and provides a latched indication of counter overflow. The SKT instruction tests this latch, executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction, therefore, allow the controller to generate its own time-base for real-time processing rather than relying on an external input signal.
For example, using a 2.097 MHz crystal as the time-base to the clock generator, the instruction cycle clock frequency will be 131 kHz (crystal frequency $\div 16$ ) and the binary counter output pulse frequency will be 128 Hz . For time-ofday or similar real-time processing, the SKT instruction can call a routine which increments a "seconds" counter every 128 ticks.

## INSTRUCTION SET NOTES

a. The first word of a program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths take the same number of cycle times whether instructions are skipped or executed, except JID and LQID. LQID and JID take two cycle times if executed and one if skipped.
c. The ROM is organized into 16 pages of 64 words each. The Program Counter is a 10 -bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page $3,7,11$, or 15 will access data in the next group of 4 pages.

## Typical Application: PROM-Based System

The COP402 may be used to exactly emulate the COP420, Figure 13 shows the interconnect to implement a COP420 hardware emulation. This connection uses two MM5204 EPROMs as external memory. Other memory can be used such as bipolar PROM or RAM.
Pins IP7-IP0 are bidirectional inputs and outputs. When the AD/DATA clocking output turns on, the EPROM drivers are disabled and IP7-IPO output addresses. The 8-bit latch (MM74C373) latches the addresses to drive the memory.

When AD/DATA turns off, the EPROMs are enabled and the IP7-IP0 pins will input the memory data. P8 and P9 output the most significant address bits to the memory. (SKIP output may be used for program debug if needed.)

The other 28 pins of the COP402 may be configured exactly the same as a COP420. The COP402M chip can be used if the MICROBUS feature of the COP420 is needed.


FIGURE 13. COP402 Used to Emulate a COP420

## Option List

## COP402 MASK OPTIONS

The following COP420 options have been implemented in this basic version of the COP402. Subsequent versions of the COP402 will implement different combinations of available options; such versions will be identified as COP402-A, COP402-B, etc.

Option Value
Option $1=0$
Option $2=0$

Option $3=0$

Option $4=0$
Option $5=2(402) \quad$ L7 has LED direct-drive output $=3(402 \mathrm{M}) \mathrm{L} 7$ has TRI-STATE push-pull output
Option $6=2,3 \quad$ L6 same as L7
Option $7=2,3 \quad$ L5 same as L7
Option $8=2,3 \quad$ L4 same as L7
Option $9=0(402) \quad$ IN1 has load device to $V_{C C}$ $=1$ (402M) Hi Z
Option $10=0(402) \quad$ IN2 has load device to $V_{C C}$ $=1$ (402M) Hi Z
Option $11=0 \quad V_{C C}$ pin—no option available
Option $12=2,3 \quad$ L3 same as L7
Option $13=2,3 \quad$ L2 same as L7
Option $14=2,3 \quad$ L1 same as L7

Option Value
Option $15=2,3$
Option $16=0 \quad$ SI has load device to $V_{C C}$
Option $17=2 \quad$ SO has push-pull output
Option $18=2 \quad$ SK has push-pull output
Option $19=0 \quad$ INO has load device to $V_{C C}$
Option $20=0$ (402) IN3 has load device to $V_{C C}$ $=1$ (402M) Hi Z
Option $21=0 \quad$ G0 has standard output
Option $22=0 \quad$ G1 same as G0
Option $23=0 \quad$ G2 same as G0
Option $24=0 \quad$ G3 same as G0
Option $25=0 \quad$ D3 has standard output
Option $26=0 \quad$ D2 same as D3
Option $27=0 \quad$ D1 same as D3
Option $28=0 \quad$ D0 same as D3
Option $29=0(402)$ normal operation
$=1(402 \mathrm{M})$ MICROBUS operation
Option $30=\mathrm{N} / \mathrm{A} \quad 40$-pin package

## COP404 ROMIess N-Channel Microcontroller

## General Description

The COP404 ROMless N -Channel Microcontrollers are members of the COPSTM family, fabricated using N -channel, silicon gate MOS technology. Each microcontroller contains all system timing, internal logic, RAM and I/O necessary to implement dedicated control functions in a variety of applications, and is identical to the COP440/COP340 devices, except that the ROM has been removed; pins have been added to output the ROM address and to input ROM data. In a system, the COP404 will perform exactly as the COP440; this important benefit facilitates development and debug of a COP440 program prior to masking the final part. Features include single supply operation, various output configurations, and an instruction set, internal architecture, and I/O scheme designed to facilitate keyboard input, display output and data manipulation. Standard test procedures and reliable high-density fabrication techniques provide the medium to large volume customers with a control-ler-oriented processor at a low end-product cost.
For extended temperature range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ COP304 available on special order.

## Features

- Exact circuit equivalent of COP440
- Standard 48 -pin dual-in-line package
- Interfaces with standard PROM or ROM
- Enhanced, more powerful instruction set
- $160 \times 4$ RAM, addresses up to $2 k \times 8$ ROM
- MICROBUSTM compatible
- Zero-crossing detect circuitry with hysteresis
- True multi-vectored interrupt from four selectable sources (plus restart)
- Four-level subroutine stack (in RAM)
- $4 \mu$ s cycle time

■ Single supply operation (4.5V-6.3V)

- Programmable time-base counter for real-time processing
- Internal binary counter/register with MICROWIRETM compatible serial 1/O
- General purpose and TRI-STATE® ${ }^{\circledR}$ outputs
- TTL/CMOS compatible in and out
- Software/hardware compatible with other members of COP400 family
- Compatible dual CPU device available

Block Diagram


## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Zero-Crossing Detect Pin

| Relative to GND | -1.2 V to +15 V |
| :--- | ---: |
| Voltage at Any Other Pin Relative to GND | -0.5 V to +7 V |
| Ambient Operating Temperature | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, 10 sec. ) | $300^{\circ} \mathrm{C}$ |

Power Dissipation
0.75 W at $25^{\circ} \mathrm{C}$
0.4 W at $70^{\circ} \mathrm{C}$

Total Source Current 150 mA

Total Sink Current 90 mA
Absolute Maximum Ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted

\begin{tabular}{|c|c|c|c|c|}
\hline Parameter \& Conditions \& Min \& Max \& Units \\
\hline Operating Voltage ( \(\mathrm{V}_{\mathrm{CC}}\) ) \& (Note 3) \& 4.5 \& 6.3 \& V \\
\hline Power Supply Ripple \& (Peak to Peak) \& \& 0.4 \& V \\
\hline Operating Supply Current \& \[
\begin{aligned}
\& \text { (All Inputs and Outputs Open) } \\
\& T_{A}=0^{\circ} \mathrm{C} \\
\& T_{A}=25^{\circ} \mathrm{C} \\
\& T_{A}=70^{\circ} \mathrm{C}
\end{aligned}
\] \& \& \[
\begin{aligned}
\& 44 \\
\& 37 \\
\& 30
\end{aligned}
\] \& \[
\begin{aligned}
\& \mathrm{mA} \\
\& \mathrm{~mA} \\
\& \mathrm{~mA} \\
\& \hline
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\mathrm{R}}\) RAM Power Supply Current \& \(\mathrm{V}_{\mathrm{R}}=3.3 \mathrm{~V}\) \& \& 3 \& mA \\
\hline ```
Input Voltage Levels
CKI Input Levels ( \(\div 16\) )
Logic High ( \(\mathrm{V}_{1 \mathrm{H}}\) )
Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) )
Logic Low (VIL)
RESET Input Levels
Logic High
Logic Low
Zero-Crossing Detect Input ( \(\mathrm{IN}_{1}\) )
Trip Point
Logic High ( \(\mathrm{V}_{\mathrm{IH}}\) ) Limit
Logic Low ( \(\mathrm{V}_{1 \mathrm{~L}}\) ) Limit
\(\mathrm{IN}_{1}\)
Logic High
Logic Low
All Other Inputs
Logic High
Logic High
Logic Low
``` \& \begin{tabular}{l}
\[
\begin{aligned}
\& V_{C C}=\operatorname{Max} ., \\
\& V_{C C}=5 \mathrm{~V} \pm 5 \%
\end{aligned}
\] \\
(Schmitt Trigger Input) \\
Zero-Crossing Interrupt Input; INIL Instruction \\
Interrupt Input; ININ Instruction; MICROBUS Input
\[
\begin{aligned}
\& V_{C C}=M a x . \\
\& V_{C C}=5 V \pm 5 \%
\end{aligned}
\]
\end{tabular} \& 2.5
2.0
-0.3
\(0.7 V_{C C}\)
-0.3
-0.15
-0.8

3.0
-0.3
2.5
2.0

-0.3 \& $$
\begin{gathered}
0.4 \\
0.6 \\
0.15 \\
12 \\
\\
0.8 \\
0.8 \\
\hline
\end{gathered}
$$ \& \[

$$
\begin{aligned}
& v \\
& v \\
& v \\
& v \\
& v \\
& v \\
& \\
& v \\
& V \\
& V
\end{aligned}
$$
\]

V

$$
\dot{v}
$$

V
V

$$
\mathrm{V}
$$ <br>

\hline $\mathrm{IN}_{1}$ Input Resistance to Ground \& $\mathrm{V}_{\mathrm{IH}}=1.0 \mathrm{~V}$ \& 1.5 \& 4.6 \& k $\Omega$ <br>
\hline Input Load Source Current \& $\mathrm{V}_{\mathrm{IH}}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ \& 14 \& 230 \& $\mu \mathrm{A}$ <br>
\hline Input Capacitance \& \& \& 7.0 \& pF <br>
\hline Hi-Z Input Leakage \& \& -1.0 \& +1.0 \& $\mu \mathrm{A}$ <br>

\hline | Output Voltage Levels Standard Output TTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOU) CMOS Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) |
| :--- |
| TRI-STATE Output TTL Operation Logic High ( $\mathrm{VOH}_{\mathrm{OH}}$ ) Logic Low (VOL) CMOS Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | \& \[

$$
\begin{aligned}
& \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\
& \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\
& \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\
& \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \\
& \\
& \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\
& \mathrm{IOL}_{\mathrm{L}}=1.6 \mathrm{~mA} \\
& 33 \mathrm{k} \Omega \geq \mathrm{R}_{\mathrm{L}} \geq 4.7 \mathrm{k} \Omega \\
& \mathrm{I}_{\mathrm{L}}=-10 \mu \mathrm{~A} \\
& \mathrm{IOH}^{2}=1.6 \mathrm{~mA} \\
& \hline
\end{aligned}
$$

\] \& \[

V_{C C}-0.4
\]

$$
2.4
$$

\[
V_{C C}-0.5

\] \& | 0.4 |
| :--- |
| 0.2 |
| 0.4 |
| 0.4 | \& \[

$$
\begin{aligned}
& V \\
& V \\
& v \\
& v \\
& \\
& v \\
& v \\
& v \\
& v \\
& \hline
\end{aligned}
$$
\] <br>

\hline Output Current Levels Standard Output Source Current TRI-STATE Output Leakage Current \& $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ \& \[
$$
\begin{aligned}
& -100 \\
& -2.5
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& -650 \\
& +2.5
\end{aligned}
$$

\] \& \[

\underset{\mu \mathrm{A}}{\mu \mathrm{~A}}
\] <br>

\hline
\end{tabular}

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq T_{A} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Total Sink Current Allowed |  |  | 90 |  |
| All IIO Combined |  | 20 | mA |  |
| Each L, R Port |  |  | 10 | mA |
| Each D, G, H Port |  |  | 2.5 | mA |
| SO, SK |  |  | 1.8 | mA |
| IP |  |  | 150 | mA |
| Total Source Current Allowed | (Note 4) | 70 | mA |  |
| All I/O Combined |  |  | 70 | mA |
| L Port |  | 23 | mA |  |
| L7-L4 |  | 1.6 | mA |  |
| Each L Pin |  |  | mA |  |
| All Other Output Pins |  |  |  |  |

Note 1: TRI-STATE configuration is excluded.
AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V} C \mathrm{C} \leq 6.3 \mathrm{~V}$ unless otherwise noted

| Parameter | Conditions | , Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time-te |  | 4.0 | 10 | $\mu \mathrm{s}$ |
| CKI Frequency Duty Cycle (Note 1) Rise Time Fall Time | $\begin{aligned} & \div 16 \mathrm{Mode} \\ & \mathrm{f}_{\mathrm{l}}=4 \mathrm{MHz} \\ & \mathrm{f}_{\mathrm{l}}=4 \mathrm{MHz} \\ & \mathrm{f}_{\mathrm{l}}=4 \mathrm{MHz} \end{aligned}$ | $\begin{aligned} & 1.6 \\ & 30 \end{aligned}$ | $\begin{aligned} & 4.0 \\ & 60 \\ & 60 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{MHz} \\ \% \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \hline \end{gathered}$ |
|  | From AD/DATA Rising Edge | $\begin{gathered} 0.3 \\ 300 \\ \\ 0.25 \\ 250 \\ 0 \\ \\ 1.7 \\ 300 \\ \hline \end{gathered}$ |  | $\mu \mathrm{s}$ ns $\mu \mathrm{s}$ ns ns $\mu \mathrm{S}$ ns |
| OUTPUT PROPAGATION DELAY IP <br> $t_{p d 1 A}, t_{p d 0 A}$ <br> $t_{\text {pd1B }}, t_{\text {pdOB }}$ <br> DCK <br> $t_{p d 1}, t_{p d 0}$ <br> AD/DATA <br> $t_{\text {pd1 }}, t_{\text {pdo }}$ <br> SO, SK <br> $t_{\text {pd1 }}, t_{\text {pd }} 0$ <br> All Other Outputs | Test Condition: $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{~V}_{\mathrm{OUT}}=1.5 \mathrm{~V}$ $\begin{aligned} & \mathrm{R}_{\mathrm{L}}=2.4 \mathrm{k} \Omega \\ & \mathrm{R}_{\mathrm{L}}=5.0 \mathrm{k} \Omega \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 1.94 \\ & 0.94 \\ & 375 \\ & 300 \\ & \\ & 1.0 \\ & 1.4 \\ & \hline \end{aligned}$ | $\mu \mathrm{S}$ $\mu \mathrm{S}$ <br> ns <br> ns <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{s}$ |
| MICROBUS TIMING <br> Read Operation <br> Chip Select Stable Before $\overline{\mathrm{RD}}-\mathrm{t}$ CSR <br> Chip Select Hold Time for RD- $\mathrm{t}_{\text {RCS }}$ <br> RD Pulse Width-trR <br> Data Delay from $\overline{R D}-t_{R D}$ <br> $\overline{R D}$ to Data Floating-t DF <br> Write Operation <br> Chip Select Stable Before $\overline{W R}-t_{\text {CSW }}$ <br> Chip Select Hold Time for WR-twCS <br> WR Pulse Width-tww <br> Data Set-Up Time for WR-tow <br> Data Hold Time for WR-twD <br> INTR Transition Time from WR- ${ }_{\text {WI }}$ | $C_{L}=100 \mathrm{pF}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ <br> TRI-STATE outputs | $\begin{gathered} 65 \\ 20 \\ 400 \\ \\ \\ 65 \\ 20 \\ 400 \\ 320 \\ 100 \end{gathered}$ | $700$ |  |

[^4]
## Connection Diagram



## Pin Descriptions

$\mathrm{H}_{3}-\mathrm{H}_{0}$
$\mathrm{R}_{7}-\mathrm{R}_{0}$
SI
SO
SK Logic-controlled clock (or general purpose output)
CKI System oscillator input
CKOI General purpose input
$V_{\text {RAM }}$
$\overline{\mathrm{MB}}$
DCK Clock output to latch D outputs and high order address bits
AD/DATA Address out/data in flag
$\mathrm{IP}_{1}-\mathrm{IP} 0 \quad 8$-bit bidirectional port for ROM address, ROM data and D outputs
RESET System reset input
VCC Power Supply
GND Ground

Top View
FIGURE 2
Order Number COP404N See NS Package Number N48A

## Timing Diagram



## Functional Description

The COP404 is a ROMless microcontroller for emulating the COP440 or for stand-alone applications. Please refer to the COP440 description for detail functional description. The following describes functions that are unique to the COP404 or are different from those in COP440. Figures 1 and 2 show the COP404 block diagram and pin-out.

## PROGRAM MEMORY

Program memory consists of 2048 bytes of external memory (on-chip in the COP440) that can be accessed through the IP port. See External Memory Interface below.

## D PORT

The D3-D0 outputs are missing from this 48-pin package, but may be recovered through the IP port (see External Memory Interface below). Note that the recovered signals have the same timing but different output drive capability as those from the COP440 (see D Port Characteristics below).

## MICROBUS AND ZERO-CROSSING DETECT INPUT OPTION

The MICROBUS compatible I/O, selected by a mask option on the COP440, is selected by tying the $\overline{\mathrm{MB}}$ pin directly to ground. When the MICROBUS compatible I/O is not desired, the $\overline{\mathrm{MB}}$ pin should be tied to $\mathrm{V}_{\mathrm{CC}}$. Note that none of the IN inputs are $\mathrm{Hi}-\mathrm{Z}$. Since zero-crossing detect input (used by INIL instruction and zero-crossing interrupt feature) is chosen for IN1, the IN1 input " 1 " level for ININ instruction, IN1 interrupt, and MICROBUS input is 3V. Even though the MICROBUS option and zero-crossing detector option appear on the COP404, they are mutually exclusive on the COP440.

## OSCILLATOR

CKI is an external clock input signal. The clock frequency is divided by 16 to give the execution frequency.

## CKO PIN OPTIONS

Two different CKO functions of the COP440 are available on the COP404. V ${ }_{\text {RAM }}$ supplies power to the lower four registers of RAM, and CKOI is an interrupt input or a general purpose input, reading into bit 2 of A (accumulator) through the INIL instruction.

## EXTERNAL MEMORY INTERFACE

The COP404 is designed for use with an external program memory. This memory may be implemented using any devices having the following characteristics:

1. Random addressing
2. TTL-compatible TRI-STATE outputs
3. TTL-compatible inputs
4. Access time $=450 \mathrm{~ns}$ maximum

Typically these requirements are met using bipolar or MOS PROMs.

Figure 3 shows the timings for IP port and the external memory interface clocks-DCK and AD/DATA. While DCK is low, the upper three address bits, P10-P8, of the next instruction to be executed appear at IP2-IPO respectively; D3-D0 appear at IP7-IP4 and IP3 contains the SKIP output used by the COPS Program Development System (PDS). The rising edge of DCK clocks these data into D flip-flops, e.g., 74 LS 374 . The timing of $D$ port data is then the same for COP404 and COP440. After DCK has risen to a " 1 " level, the remaining address bits (P7-P0) appear at IP7-IP0. The falling edge of AD/ $\overline{\text { DATA }}$ latches these data into flowthrough latches, e.g., 74LS373. The latched addresses provide the inputs to the external memory. When AD/DATA goes low, the $\mathbb{I P}$ outputs are disabled and the IP lines become program memory inputs from the external memory. Note that DCK has a duty cycle of about $50 \%$ and AD/ $\overline{\text { DATA }}$ has a duty cycle of about $75 \%$. Figure 4 shows how to emulate the COP440 using a COP404 and an EPROM as the external memory.

## I/O OPTIONS

All inputs except IN1 and CKI have on-chip depletion load devices to $\mathrm{V}_{\mathrm{CC}}$. IN1 has a resistive load to GND due to the zero-crossing input. CKI is a $\mathrm{Hi}-\mathrm{Z}$ input.
G and H ports have standard outputs. L and R ports have TRI-STATE outputs. IP port, DCK, AD/ $\overline{\mathrm{DATA}}$, SO and SK have push-pull outputs.

## LED DRIVE

The TRI-STATE outputs of L port may be used to drive the segments of an LED display. External current limiting resistors of $100 \Omega$ must be connected between the $L$ outputs and the LED segments.

## D PORT CHARACTERISTICS

Since the D port is recovered through an external latch, the output drive is that of the latch and not that of COP440. Using the set-up as shown in Figure 4, at an output " 0 " level of 0.4 V , the 74LS374 may sink 10 times as much current as the COP440. At an output " 1 " level of 2.4 V , the 74LS374 may source 10 times as much current as the COP440. On the other hand, the output " 1 " level of 74LS374 latch does not go to $V_{C C}$ without an external pull-up resistor. In order to better approximate the COP440 output characteristics, add a 74C906 buffer to the output of the 74LS374, thus emulating an open drain D output. A pull-up resistor of 10k should be added to the input of the buffer. To emulate the standard output, add a pull-up resistor between 2.7 k and 15 k to the output of the 74C906.

Functional Description (Continued)


TL/DD/6916-4
FIGURE 4. COP404 Used to Emulate a COP440

## Option Table

COP404 MASK OPTIONS
The following COP440 options have been implemented in the COP404．

| Option Value | Comment | Option Value |  | Comment |
| :---: | :---: | :---: | :---: | :---: |
| Option 1－2 $=3$ | L outputs are TRI－STATE | Option 22 | $=0$ | CKI is input clock divided by 16 |
| Option $3=0$ | SI has load to $\mathrm{V}_{\mathrm{CC}}$ | Option 23 | － 0 | $\overline{\text { RESET }}$ has load to VCC |
| Option $4=2$ | SO is push－pull output | Option 24－31 | $=3$ | R outputs are TRI－STATE |
| Option $5=2$ | SK is push－pull output | Option 32－35 | $=3$ | L outputs are TRI－STATE |
| Option $6=0$ | INO has load to $\mathrm{V}_{\mathrm{CC}}$ | Option 36 | $=2$ | IN1 is zero－crossing detect input |
| Option $7=0$ | IN3 has load to $\mathrm{V}_{\mathrm{CC}}$ | Option 37 | 0 | IN2 has load to $V_{\text {CC }}$ |
| Option $8-11=0$ | G outputs are standard | Option 38－39 | $=3$ | L outputs are TRI－STATE |
| Option 12－15 $=0$ | H outputs are standard | Option 40 | $=\mathrm{N} / \mathrm{A}$ | $V_{C C}-$ No option available |
| Option 16－19 $=$ N／A | D outputs are derived from external latch，see Figure 4 | Option 41 <br> Option 42－48 | $\begin{aligned} & =0,1 \\ & =0 \end{aligned}$ | MICROBUS option is pin selectable Inputs have standard TTL levels |
| Option $20=$ N／A | GND－No option | Option 49 | $=\mathrm{N} / \mathrm{A}$ | No option available |
| Option $21=1,2$ | CKO is replaced by $\mathrm{V}_{\text {RAM }}$ and CKOI | Option 50 | $=N / A$ | 48－pin package |



## COP404C ROMless CMOS Microcontrollers

## General Description

The COP404C ROMless Microcontroller is a member of the COPSTM family, fabricated using double-poly, silicon gate CMOS (microCMOS) technology. The COP404C contains CPU, RAM, I/O and is identical to a COP444C device except the ROM has been removed and pins have been added to output the ROM address and to input the ROM data. The COP404C can be configured, by means of external pins, to function as a COP444C, a COP424C, or a COP410C. Pins have been added to allow the user to select the various functional options that are available on the family of mask-programmed CMOS parts. The COP404C is primarily intended for use in the development and debug of a COP program for the COP444C/445C, COP424C/425C, and COP410C/411C devices prior to masking the final part. The COP404C is also appropriate in low volume applications or when the program might be changing.

## Features

- Accurate emulation of the COP444C, COP424C and COP410C
- Lowest Power Dissipation ( $50 \mu \mathrm{~W}$ typical)
- Fully static (can turn off the clock)
- Power saving IDLE state and HALT mode
- $4 \mu \mathrm{~s}$ instruction time, plus software selectable clocks
- $128 \times 4$ RAM, addresses $2 k \times 8$ ROM
- True vectored interrupt, plus restart

■ Three-level subroutine stack
■ Single supply operation ( 2.4 V to 5.5 V )

- Programmable read/write 8-bit timer/event counter
- Internal binary counter register with MICROWIRETM serial I/O capability
■ General purpose and TRI-STATE® outputs
- LSTTL/CMOS compatible
- MICROBUSTM compatible
- Software/hardware compatible with other members of the COP400 family

Block Diagram


TL/DD/5530-1
FIGURE 1. Block Diagram

## Absolute Maximum Ratings

| Supply Voltage | 6 V | Operating temperature range | $0^{\circ}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: | :--- | ---: |
| Voltage at any pin | -0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ | Storage temperature range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Total Allowable Source Current | 25 mA | Lead temperature (soldering, 10 sec.) | $300^{\circ} \mathrm{C}$ |
| Total Allowable Sink Current | 25 mA |  |  |

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{a}} \leq 70^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage Power Supply Ripple (Note 5) | peak to peak | 2.4 | $\begin{gathered} 5.5 \\ 0.1 V_{C C} \end{gathered}$ | $\begin{aligned} & v \\ & v \end{aligned}$ |
| Supply Current (Note 1) | $\begin{aligned} & V_{C C}=2.4 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=64 \mu \mathrm{~s} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{t}_{\mathrm{c}}=16 \mu \mathrm{~s} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{t}_{\mathrm{C}}=4 \mu \mathrm{~s} \end{aligned}$ <br> ( $T_{C}$ is instruction cycle time) |  | $\begin{gathered} 120 \\ 700 \\ 3000 \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| HALT Mode Current (Note 2) | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~F}_{I N}=0 \mathrm{kHz}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~F}_{I N}=0 \mathrm{kHz}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |  | $\begin{gathered} 20 \\ 6 \end{gathered}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Input Voltage Levels RESET, DO (clock input) CKI. <br> Logic High <br> Logic Low <br> All other inputs (Note 7) <br> Logic High <br> Logic Low |  | $\begin{aligned} & 0.9 V_{C C} \\ & 0.7 V_{C C} \end{aligned}$ | $\begin{aligned} & 0.1 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & V \\ & v \\ & v \\ & v \end{aligned}$ |
| Input Pull-up current | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {IN }}=0$ | 30 | 330 | $\mu \mathrm{A}$ |
| Hi -Z input leakage |  | -1 | +1 | $\mu \mathrm{A}$ |
| Input capacitance (Note 4) |  |  | 7 | pF |
| Output Voltage Levels LSTTL Operation Logic High Logic Low CMOS Operation Logic High Logic Low | Standard outputs $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=400 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.2$ | $0.4$ $0.2$ | $\begin{aligned} & V \\ & v \\ & v \\ & v \end{aligned}$ |
| Output current levels Sink (Note 6) <br> Source (Standard option) <br> Source (Low current option) | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ <br> $V_{C C}=2.4 \mathrm{~V}, V_{\text {OUT }}=V_{C C}$ <br> $V_{C C}=4.5 \mathrm{~V}, V_{\text {OUT }}=0 \mathrm{~V}$ <br> $V_{C C}=2.4 \mathrm{~V}, V_{\text {OUT }}=0 \mathrm{~V}$ <br> $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V}$ <br> $\mathrm{V}_{\mathrm{CC}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=0 \mathrm{~V}$ | $\begin{gathered} 1.2 \\ 0.2 \\ 0.5 \\ 0.1 \\ 30 \\ 6 \\ \hline \end{gathered}$ | $\begin{gathered} 330 \\ 80 \\ \hline \end{gathered}$ | mA <br> mA <br> mA <br> mA <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Allowable Sink/Source current per pin (Note 6) |  |  | 5 | mA |
| Allowable Loading on CKOH |  |  | 100 | pF |
| Current needed to over-ride HALT <br> (Note 3) <br> To continue <br> To halt | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=2 \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |  | $\begin{gathered} .7 \\ 1.6 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| TRI-STATE leakage current |  | -2.5 | +2.5 | $\mu \mathrm{A}$ |

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

## COP404C

AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle | $\mathrm{V}_{\mathrm{CC}} \geq 4.5 \mathrm{~V}$ | 4 | DC | $\mu \mathrm{s}$ |
| Time ( $\mathrm{t}_{\mathrm{c}}$ ) | $4.5 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 2.4 \mathrm{~V}$ | 16 | DC | $\mu \mathrm{s}$ |
| Operating CKI | $V_{C C} \geq 4.5 \mathrm{~V}$ | DC | 1.0 | MHz |
| Frequency | $4.5 \mathrm{~V}>\mathrm{V}_{C C} \geq 2.4 \mathrm{~V}$ | DC | 250 | kHz |
| Duty Cycle (Note 4) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ | 40 | 60 | \% |
| Rise Time (Note 4) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ external clock |  | 60 | ns |
| Fall Time (Note 4) | $\mathrm{f}_{1}=4 \mathrm{MHz}$ external clock |  | 40 | ns |
| Instruction Cycle | $\mathrm{R}=30 \mathrm{k}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |  |  |  |
| Time using D0 as a | $\mathrm{C}=82 \mathrm{pF}$ | 8 | 16 | $\mu \mathrm{S}$ |
| RC Oscillator Dual- |  |  |  |  |
| Clock Input (Note 4) |  |  |  |  |
| INPUTS: (See Fig. 3) tsetup <br> $t_{\text {Hold }}$ | G Inputs <br> SI Input <br> IP Input <br> All Others <br> $V_{C C} \geq 4.5 \mathrm{~V}$ <br> $4.5 \mathrm{~V}>\mathrm{V}_{\mathrm{CC}} \geq 2.4 \mathrm{~V}$$\quad \quad \mathrm{~V}_{\mathrm{CC}} \geq 4.5 \mathrm{~V}$ | $\begin{gathered} \mathrm{T}_{\mathrm{c}} / 4+.7 \\ 0.3 \\ 1.0 \\ 1.7 \\ 0.25 \\ 1.0 \\ \hline \end{gathered}$ |  |  |
| $\begin{aligned} & \text { OUTPUT } \\ & \text { PROPAGATION DELAY } \end{aligned}$ | $\mathrm{V}_{\text {OUT }}=1.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=5 \mathrm{~K}$ |  |  |  |
| $\begin{aligned} & \text { IP7-IPO, A10-A8, SKIP } \\ & \text { tPD1, tPD0 } \end{aligned}$ | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>V_{C C} \geq 2.4 \mathrm{~V} \\ & \hline \end{aligned}$ |  | $\begin{array}{r} 1.94 \\ 7.75 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~S} \end{aligned}$ |
| $\begin{aligned} & \text { AD/ } \overline{\text { DATA }} \\ & \text { tpD1 }^{2}, t_{P D O} \end{aligned}$ | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>V_{C C} \geq 2.4 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} 375 \\ 1.5 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \end{aligned}$ |
| ALL OTHER OUTPUTS tpD1, tpDO | $\begin{aligned} & V_{C C}>4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V}>V_{C C} \geq 2.4 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 1.0 \\ & 4.0 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~s} \end{aligned}$ |
| MICROBUS TIMING <br> Read Operation (Fig. 4) | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ |  |  |  |
| Chip select stable before $\overline{\mathrm{RD}}$ - $\mathrm{t}_{\text {CSR }}$ |  | 65 |  | ns |
| Chip select hold time for $\overline{\mathrm{RD}}-\mathrm{t}_{\text {RCS }}$ |  | 20 |  | ns |
| $\overline{\mathrm{RD}}$ pulse width $-\mathrm{t}_{\mathrm{RR}}$ |  | 400 |  | ns |
| Data delay from $\overline{\mathrm{RD}}-\mathrm{t}_{\mathrm{RD}}$ |  |  | 375 | ns |
| $\overline{\mathrm{RD}}$ to data floating $-t_{\text {DF }}$ (Note 4) |  |  | 250 | ns |
| Write Operation (Fig. 5) |  |  |  |  |
| Chip select stable before $\overline{\mathrm{WR}}$ - $\mathrm{t}_{\text {cSW }}$ |  | 65 |  | ns |
| Chip select hold time for $\overline{W R}$ - twCS |  | 20 |  | ñs |
| $\overline{\text { WR }}$ pulse width - ${ }^{\text {W }}$ WW |  | 400 |  | ns |
| Data set-up time for $\overline{W R}$ - $t_{\text {DW }}$ |  | 320 |  | ns |
| Data hold time for $\overline{W R}-t_{\text {WD }}$ |  | 100 |  | ns |
| INTR transition time from $\overline{W R}-t_{\text {WI }}$ |  |  | 700 | ns |

Note 1: Supply current is measured after running for 2000 cycle times with a square-wave clock on CKI and all other pins pulled up to $V_{C C}$ with 20 k resistors. See current drain equation on page 16.
Note 2: Test conditions: All inputs tied to $V_{C C}$; L lines in TRI-STATE mode and tied to Ground; all outputs tied to Ground.
Note 3: When forcing HALT, current is only needed for a short time (approx. 200 ns) to flip the HALT flip-flop.
Note 4: This parameter is only sampled and not $100 \%$ tested. Variation due to the device included.
Note 5: Voltage change must be less than 0.5 volts in a 1 ms period.
Note 6: SO output sink current must be limited to keep $V_{O L}$ less than $0.2 \mathrm{~V}_{\mathrm{CC}}$ to prevent entering test mode.
Note 7: $\overline{M B}, \overline{T I N}, \overline{D U A L}, \overline{S E L 10}, \overline{S E L 20}$, input levels at $V_{C C}$ or $V_{S S}$.

## Connection Diagram

| Dual-In-Line Package |  |  |  | Pin |
| :---: | :---: | :---: | :---: | :---: |
| A10- |  | 48 |  | $V_{\text {CC }}$ |
|  |  |  | - ${ }^{\text {Ag }}$ | $V_{\text {SS }}$ |
| CKOL- 2 |  | 47 | - | CKI |
| $\mathrm{V}_{5 s}-3$ |  | 46 | - $\overline{M B}$ | $\overline{\mathrm{RS}}$ |
| CKOH-3 |  | 45 | -01 |  |
| $\mathrm{CKOH}-$ |  | 44 | -02 | CKOI |
| \%s- 6 |  |  | -D3 | L0-L7 |
| 197 - 7 |  | 42 | -D0 | G0-G3 |
| IP6 |  | 41 | - AB | D1-D3 |
| $1 \mathrm{P5}$-9 |  | 40 | - $\overline{\text { DUAL }}$ | DO |
| $1 \mathrm{IP4}^{18} \mathrm{~S}=11$ |  | 39 | - AD/ $\overline{\text { DATA }}$ |  |
|  | COP404C | 38 | - $\overline{\text { SELIO }}$ | INO-IN3 |
| $\begin{aligned} & \mathbb{I P 2}-1 \\ & \mid P 1-1 \end{aligned}$ |  | 37 | - SEL20 | SO |
| $\begin{aligned} & 1 P 1=1 \\ & 1800 \end{aligned}$ |  | 35 | -SKIP | SI |
|  | 14 |  | - ${ }^{18}$ | SK |
| 17 - 15 | 15 | 34 | -62 |  |
| $16-16$ | 16 | 33 | ${ }^{61}$ | 1P0-IP7 |
| L5-17 |  | 32 | -60 | A8, A9, A10 |
| L4-18 |  | 31 | -in3 | SKIP |
| INT- 19 | 19 | 30 | - ino | AD/ $\overline{\text { DATA }}$ |
| $1 \mathrm{~N} 2=2$ |  | 29 | -sk | $\overline{\mathrm{MB}}$ |
| $\mathrm{VCC}=21$ |  | 28 | - UNUSED | CKOH |
| ${ }^{13}$ - 22 |  | 27 | -so | DUAL |
| $\begin{aligned} & \mathrm{L} 2-23 \\ & \mathrm{~L}-\mathrm{D}_{24} \end{aligned}$ |  | 25 | - ${ }_{-1}$ | TIN |
|  |  |  |  | SELT0 |
|  | TOP VIEW |  |  | SEL20 |
|  |  |  |  | UNUSED |

## Pin Descriptions

| PIn | Description |
| :---: | :---: |
| $V_{\text {CC }}$ | Most positive voltage |
| $V_{\text {SS }}$ | Ground |
| CKI | Clock input |
| $\overline{\text { RS }}$ | Reset input |
| CKOI | General purpose input |
| L0-L7 | 8 TRI-STATE I/O |
| G0-G3 | 4 general purpose I/O |
| D1-D3 | 3 general purpose outputs |
| DO | Either general purpose output or Dual-Clock RC input |
| INO-IN3 | 4 general purpose inputs |
| SO | Serial data output |
| SI | Serial data input |
| SK | Serial data clock output |
| IP0-IP7 | I/O for ROM address and data |
| A8, A9, A10 | 3 address outputs |
| SKIP | Skip status output |
| AD/ $\overline{\text { DATA }}$ | Clock output |
| $\overline{M B}$ | MICROBUS select input |
| CKOH | Halt l/O pin |
| $\overline{\text { DUAL }}$ | Dual-Clock select input |
| TIN | Timer input select pin |
| SEL10 | COP410C emulation select input |
| $\overline{\text { SEL20 }}$ | COP424C emulation select input |
| UNUSED | Ground |

The internal architecture is shown in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 ", when a bit is reset, it is a logic "0".

## PROGRAM MEMORY

Program Memory consists of a 2048-byte external memory (typically PROM). Words of this memory may be program instructions, constants or ROM addressing data.
ROM addressing is accomplished by a 11-bit PC register which selects one of the 8 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 11-bit binary count value.
Three levels of subroutine nesting are implemented by a three level deep stack. Each subroutine call or interrupt
pushes the next PC address into the stack. Each return pops the stack back into the PC register.

## DATA MEMORY

Data memory consists of a 512-bit RAM, organized as 8 data registers of $16 \times 4$-bit digits. RAM addressing is implemented by a 7 -bit $B$ register whose upper 3 bits ( $B_{r}$ ) select 1 of 8 data registers and lower 4 bits ( $B_{d}$ ) select 1 of 164 -bit digits in the selected data register. While the 4-bit contents of the selected RAM digit ( $M$ ) are usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the $Q$ latches or $T$ counter or loaded from the L ports. RAM addressing may also be performed directly by the LDD and XAD instructions based upon the immediate operand field of these instructions. The $\mathrm{B}_{\mathrm{d}}$ register also serves as a source register for 4-bit data sent directly to the D outputs.

Timing Diagrams


FIGURE 3. Input/Output Timing


FIGURE 4. MICROBUS Read Operation Timing


FIGURE 5. MICROBUS Write Operation Timing

## Functional Description <br> internal logic

The processor contains its own 4-bit A register (accumulator) which is the source and destination register for most I/O, arithmetic, logic, and data memory access operations. It can also be used to load the $B_{r}$ and $B_{d}$ portions of the $B$ register, to load and input 4 bits of the 8 -bit $Q$ latch or $T$ counter, L. I/O ports data, to input 4-bit G, or IN ports, and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions, storing the results in A. It also outputs a carry bit to the 1 -bit C register, most often employed to indicate arithmetic overflow. The C register in conjunction with the XAS instruction and the EN register, also serves to control the SK output.
The 8 -bit T counter is a binary up counter which can be loaded to and from $M$ and $A$ using CAMT and CTMA instructions. This counter may be operated in two modes: as a timer if TIN pin is tied to Ground or as an external event counter if TIN pin is tied to $\mathrm{V}_{\mathrm{CC}}$. When the T counter overflows, an overflow flag will be set (see SKT and IT instructions below). The T counter is cleared on reset. A functional block diagram of the timer/counter is illustrated in Figure $10 a$.
Four general-purpose inputs, IN3-INO, are provided. IN1, IN2 and IN3 may be selected (by pulling $\overline{\mathrm{MB}}$ pin low) as Read Strobe, Chip Select, and Write Strobe inputs, respectively, for use in MICROBUS application.
The $D$ register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of $\mathrm{B}_{\mathrm{d}}$. In the dual clock mode, DO latch controls the clock selection (see dual oscillator below).
The G register contents are outputs to a 4-bit general-purpose bidirectional I/O port. GO may be selected as an output for MICROBUS applications.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from M and A , as well as 8 -bit data from ROM. Its contents are outputted to the LI/O ports when the $L$ drivers are enabled under program control. With the MICROBUS option selected, Q can also be loaded with the 8 -bit contents of the LI/O ports upon the occurrence of a write strobe from the host CPU.
The 8 L drivers, when enabled, output the contents of latched Q data to the L I/O port. Also, the contents of L may be read directly into A and M . As explained above, the MICROBUS option allows L I/O port data to be latched into the $Q$ register.
The SIO register functions as a 4-bit serial-in/serial-out shift register for MICROWIRETM I/O and COPS peripherals, or as a binary counter (depending on the contents of the EN register). Its contents can be exchanged with $A$.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output SKL; in the shift register mode, SK outputs SKL ANDed with the clock.

EN is an internal 4-bit register loaded by the LEI instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register:
0 . The least significant bit of the enable register, ENO, selects the SIO register as either a 4-bit shift register or a 4bit binary counter. With ENO set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output equals the value of EN3. With ENO reset, SIO is a serial shift register left shifting 1 bit each instruction cycle time. The data present at SI goes into the least significant bit of SIO . SO can be enabled to output the most significant bit of SIO each cycle time. The SK outputs SKL ANDed with the instruction cycle clock.

1. With EN1 set, interrupt is enabled. Immediately following an interrupt, EN1 is reset to disable further interrupts.
2. With EN2 set, the L drivers are enabled to output the data in Q to the L I/O port. Resetting EN2 disables the L drivers, placing the LI/O port in a high-impedance input state.
3. EN3, in conjunction with ENO, affects the SO output. With ENO set (binary counter option selected) SO will output the value loaded into EN3. With ENO reset (serial shift register option selected), setting EN3 enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting EN3 with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with A via an XAS instruction but SO remains set to " 0 ".

## INTERRUPT

The following features are associated with interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once recognized as explained below, pushes the next sequential program counter address (PC+1) onto the stack. Any previous contents at the bottom of the stack are lost. The program counter is set to hex address OFF (the last word of page 3) and EN1 is reset.
b. An interrupt will be recognized only on the following conditions:

1. EN1 has been set.
2. A low-going pulse (" 1 " to " 0 ') at least two instruction cycles wide has occurred on the IN1 input.
3. A currently executing instruction has been completed.

| ENO | EN3 | SIO | SI | SO | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift | 0 | If $\mathrm{SKL}=1, \mathrm{SK}=$ clock |
|  |  |  | Register |  | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 0 | 1 | Shift Register | Input to Shift | Serial | If $S K L=1, S K=$ clock |
|  |  |  | Register | out | If $\mathrm{SKL}=0, \mathrm{SK}=0$ |
| 1 | 0 | Binary Counter | Input to Counter | 0 | SK = SKL |
| 1 | 1 | Binary Counter | Input to Counter | 1 | SK $=$ SKL |

## Functional Description (Continued)

4. All successive transfer of control instructions and successive LBIs have been completed (e.g. if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed).
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example, if an interrupt occurs during the execution of an ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at hex address OFF. At the end of the interrupt routine, a RET instruction is executed to pop the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines should not be nested within the interrupt service routine, since their popping of the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The instruction at hex address OFF must be a NOP.
e. An LEI instruction may be put immediately before the RET instruction to re-enable interrupts.

## MICROBUS INTERFACE

With $\overline{M B}$ pin tied to Ground, the COP404C can be used as a peripheral microprocessor device, inputting and outputting data from and to a host microprocessor ( $\mu \mathrm{P}$ ). IN1, IN2 and IN3 general purpose inputs become MICROBUS compatible read-strobe, chip-select, and write-strobe lines, respectively. IN1 becomes RD - a logic " 0 " on this input will cause $Q$ latch data to be enabled to the $L$ ports for input to the $\mu \mathrm{P}$. $\operatorname{IN} 2$ becomes $\overline{C S}-$ a logic " 0 " on this line selects the COP404C and the $\mu \mathrm{P}$ peripheral device by enabling the operation of the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ lines and allows for the selection of one of several peripheral components. IN3 becomes WR - a logic " 0 " on this line will write bus data from the L ports to the $Q$ latches for input to the COP404C. G0 becomes INTR a "ready" output, reset by a write pulse from the $\mu \mathrm{P}$ on the WR line, providing the "handshaking" capability necessary for asynchronous data transfer between the host CPU and the COP404C.
This option has been designed for compatibility with National's MICROBUS - a standard interconnect system for 8 -bit parallel data transfer between MOS/LSI CPUs and interfacing devices. (See MICROBUS National Publication). The


TL/DD/5530-7
FIGURE 6. MICROBUS Option Interconnect
functioning and timing relationships between the signal lines affected by this option are as specified for the MICROBUS interface, and are given in the AC electrical characteristics and shown in the timing diagrams (Figures 4 and 5). Connection of the COP404C to the MICROBUS is shown in Figure 6.

## INITIALIZATION

The external RC network shown in Figure 7 must be connected to the RESET pin for the internal reset logic to initialize the device upon power-up. The RESET pin is configured as a Schmitt trigger input. If not used, it should be connected to $V_{\text {cc. }}$. Initialization will occur whenever a logic " 0 " is applied to the RESET input, providing it stays low for at least three instruction cycle times.
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the $A, B, C, D, E N, I L, T$ and $G$ registers are cleared. The SKL latch is set, thus enabling SK as a clock output. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA (clear A register).


## TIMER

There are two modes selected by TIN pin:
a) Time-base counter (TIN pin low). In this mode, the instruction cycle frequency generated from CKI passes through a 2-bit divide-by-4 prescaler. The output of this prescaler increments the 8 -bit T counter thus providing a 10 -bit timer. The prescaler is cleared during execution of a CAMT instruction and on reset. For example, using a 1 MHz crystal, the instruction cycle frequency of 250 kHz (divide by 4 ) increments the 10 -bit timer every $4 \mu \mathrm{~S}$. By presetting the counter and detecting overflow, accurate timeouts between $16 \mu \mathrm{~S}$ ( 4 counts) and 4.096 mS (1024 counts) are possible. Longer timeouts can be achieved by accumulating, under software control, multiple overflows.
b) External event counter ( $\overline{T I N}$ pin high). In this mode, a lowgoing pulse (" 1 " to " 0 ") at least 2 instruction cycles wide on the IN2 input will increment the 8 -bit T counter.
Note: the IT instruction is not allowed in this mode.

## HALT MODE

The COP404C is a FULLY STATIC circuit; therefore, the user may stop the system oscillator at any time to halt the chip. The chip may also be halted by two other ways (see Figure 8):

- Software HALT: by using the HALT instruction.
- Hardware HALT: by using the HALT I/O port CKOH. It is an I/O flip-flop which is an indicator of the HALT status. An external signal can over-ride this pin to start and stop the chip. By forcing CKOH high the


## Functional Description (Continued)

chip will stop as soon as CKI is high and CKOH output will stay high to keep the chip stopped if the external driver returns to high impedance state.
Once in the HALT mode, the internal circuitry does not receive any clock signal and is therefore frozen in the exact state it was in when halted. All information is retained until continuing.
The chip may be awakened by one of two different methods:

- Continue function: by forcing CKOH low, the system clock will be re-enabled and the circuit will continue to operate from the point where it was stopped. CKOH will stay low.
— Restart: by forcing the $\overline{\text { RESET }}$ pin low (see Initialization)
The HALT mode is the minimum power dissipation state.
Note: if the user has selected dual-clock ( $\overline{\mathrm{DUAL}}$ pin tied to Ground) AND is forcing an external clock on DO pin AND the COP404C is running from the D0 clock, the HALT mode - either hardware or software - will NOT be entered. Thus, the user should switch to the CKI clock to HALT. Alternatively, the user may stop the D0 clock to minimize power.


## Oscillator Options

There are two basic clock oscillator configurations available as shown by Figure 9.

- CKI oscillator: CKI is configured as a LSTTL compatible input external clock signal. The external frequency is divided by 4 to give the instruction cycle time.
- Dual oscillator. By tying DUAL pin to Ground, pin DO is now a single pin RC controlled Schmitt trigger oscillator input. The user may software select between the

D0 oscillator (the instruction cycle time equals the D0 oscillation frequency divided by 4) by setting the D0 latch high or the CKI oscillator by resetting DO latch low.
Note that even in dual clock mode, the counter, if used as a time-base counter, is always connected to the CKI oscillator.
For example, the user may connect up to a 1 MHz RC circuit to DO for faster processing and a 32 kHz external clock to CKI for minimum current drain and time keeping.
Note: CTMA instruction is not allowed when the chip is running from D0 clock.
Figures $10 a$ and $10 b$ show the timer and clock diagrams with and without Dual-Clock.


Note: $15 k \leq R \leq 150 k$
$50 \mathrm{pF} \leq \mathrm{C} \leq 150 \mathrm{pF}$
FIGURE 9. Dual-Oscillator Component Values


TL/DD/5530-10
FIGURE 8. HALT Mode

Functional Description (Continued)


FIGURE 10a. Clock and Timer Block Diagram without Dual-Clock


Figure 10b. Clock and Timer Block Diagram with Dual-Clock

## External Memory Interface

The COP404C is designed for use with an external Program Memory.
This memory may be implemented using any devices having the following characteristics:

1. random addressing
2. LSTTL or CMOS-compatible TRI-STATE outputs
3. LSTTL or CMOS-compatible inputs
4. access time $=1.0 \mu \mathrm{~s}$ max.

Typically, these requirements are met using bipolar PROMs or MOS/CMOS PROMs, EPROMs or E2PROMs.
During operation, the address of the next instruction is sent out on A10, A9, A8 and IP7 through IP0 during the time that AD/ $\overline{\text { DATA }}$ is high (logic " 1 " = address mode). Address data on the IP lines is stored into an external latch on the high-tolow transition of the AD/DATA line; A10, A9 and A8 are dedicated address outputs, and do not need to be latched. When AD/DATA is low (logic " 0 "= data mode), the output of the memory is gated onto IP7 through IP0, forming the input bus. Note that AD/ $\overline{\text { DATA }}$ output has a period of one instruction time, a duty cycle of approximately $50 \%$, and specifies whether the IP lines are used for address output or data input. A simplified block diagram of the external memory interface is shown in Figure 11.


TL/DD/5530-13
FIGURE 11. External Memory Interface to COP404C

## COP404C Instruction Set

Table II is a symbol table providing internal architecture, instruction operand and operation symbols used in the instruction set table.
Table III provides the mnemonic, operand, machine code data flow, skip conditions and description of each instruction.

Table II. Instruction Set Table Symbols
Symbol
Definition
Internal Architecture Symbols
A 4-bit Accumulator
B $\quad$-bit RAM address register
$\mathrm{Br} \quad$ Upper 3 bits of B (register address)
Bd Lower 4 bits of $B$ (digit address)
C 1-bit Carry register
D 4-bit Data output port
EN 4-bit Enable register
G 4-bit General purpose I/O port
IL two 1-bit (INO and IN3) latches
IN 4-bit input port
L 8-bit TRI-STATE I/O port
M 4-bit contents of RAM addressed by B
PC 11-bit ROM address program counter
Q 8-bit latch for L port
SA 11-bit Subroutine Save Register A
SB 11-bit Subroutine Save Register B
SC 11-bit Subroutine Save Register C
SIO 4-bit Shift register and counter
SK Logic-controlled clock output
SKL 1-bit latch for SK output
T 8-bit timer

Instruction operand symbols
d 4-bit operand field, $0-15$ binary (RAM digit select)
r 3-bit operand field, 0-7 binary (RAM register select)
a 11-bit operand field, 0-2047
y 4-bit operand field, $0-15$ (immediate data)
RAM(x) RAM addressed by variable $x$
ROM(x) ROM addressed by variable $x$
Operational Symbols
$+\quad$ Plus

- Minus
-> Replaces
$<->$ is exchanged with
$=\quad$ is equal to
A one's complement of $A$
$\oplus \quad$ exclusive-or
: range of values

TABLE III. COP404C Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip <br> Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC INSTRUCTIONS |  |  |  |  |  |  |
| ASC |  | 30 | \|0011|0000| | $\begin{aligned} & A+C+R A M(B) \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Add with Carry, Skip on Carry |
| ADD |  | 31 | \|0011|0001| | $\mathrm{A}+\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{A}$ | None | Add RAM to A |
| ADT |  | 4A | \|0011|0001| | $A+10_{10} \rightarrow A$ | None | Add Ten to A |
| AISC | $y$ | $5-$ | \|0101| y | | $A+y \rightarrow A$ | Carry | Add Immediate. Skip on Carry ( $y \neq 0$ ) |
| CASC |  | 10 | \|0001|0000| | $\begin{aligned} & \bar{A}+R A M(B)+C \rightarrow A \\ & \text { Carry } \rightarrow C \end{aligned}$ | Carry | Compliment and Add with Carry, Skip on Carry |
| CLRA |  | 00 | \|0000|0000| | $0 \rightarrow A$ | None | Clear A |
| COMP |  | 40 | \|0100|0000| | $\bar{A} \rightarrow A$ | None | Ones complement of A to A |
| NOP |  | 44 | \|0100|0100| | None | None | No Operation |
| RC |  | 32 | \|0011|0010| | "0" $\rightarrow$ C | None | Reset C |
| SC |  | 22 | \|0010|0010| | "1" $\rightarrow$ C | None | Set C |
| XOR |  | 02 | \|0000|0010| | $A \oplus \operatorname{RAM}(\mathrm{~B}) \rightarrow \mathrm{A}$ | None | Exclusive-OR RAM with A |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111| | $\mathrm{ROM}\left(\mathrm{PC}_{10: 8} \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{PC}_{7: 0}$ | None | Jump Indirect (note 2) |
| JMP | a | 6- | $\begin{aligned} & \|0110\| 0\left\|a_{10: 8}\right\| \\ & a_{7: 0} \mid \end{aligned}$ | $\mathrm{a} \rightarrow \mathrm{PC}$ | None | Jump |
| JP | a | - - | \|1| $a_{6: 0}$ \| (pages 2,3 only) or |11| $a_{5: 0}$ \| (all other pages) | $\mathrm{a} \rightarrow \mathrm{PC}_{6: 0}$ $\mathrm{a} \rightarrow \mathrm{PC}_{5: 0}$ | None | Jump within Page (Note 3) |
| JSRP | a | - | \|10| $\mathrm{a}_{5: 0}$ \| | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & 00010 \rightarrow \mathrm{PC}_{10: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 4) |
| JSR | a | 6- | $\begin{aligned} & \|0110\| 1\left\|a_{10: 8}\right\| \\ & \left\|a_{7: 0}\right\| \end{aligned}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | \|0100|1000| | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | None | Return from Subroutine |
| RETSK |  | 49 | \|0100|1001| | $\mathrm{SC} \rightarrow \mathrm{SB} \rightarrow \mathrm{SA} \rightarrow \mathrm{PC}$ | Always Skip on Return | Return from Subroutine then Skip |
| HALT |  | 33 | \|0011|0011| |  | None | HALT processor |
|  |  | 38 | \|0011|1000| |  |  |  |
| IT |  | 33 | \|0011|0011| |  |  | IDLE till timer |
|  |  | 39 | \|0011|1001| |  | None | overflows then continues |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMT |  | 33 | \|0011|0011| | $A \rightarrow T_{7: 4}$ |  |  |
|  |  | 3 F | \|0011|1111| | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{T}_{3: 0}$ | None | Copy A, RAM to T |
| CTMA |  | 33 | \|0011|0011| | $\mathrm{T}_{7: 44} \rightarrow \mathrm{RAM}(\mathrm{B})$ |  |  |
|  |  | 2 F | \|0010|1111| | $\mathrm{T}_{3: 0} \rightarrow \mathrm{~A}$ | None | Copy $T$ to RAM, A |
| CAMQ |  | 33 | \|0011|0011| | $\mathrm{A} \rightarrow \mathrm{Q}_{7: 4}$ | None | Copy A, RAM to Q |
|  |  | 3 C | \|0011|1100| | $\operatorname{RAM}(\mathrm{B}) \rightarrow \mathrm{Q}_{3: 0}$ |  |  |
| CQMA |  | 33 | \|0011|0011| | $\mathrm{Q}_{7: 4} \rightarrow \mathrm{RAM}(\mathrm{B})$ | None | Copy Q to RAM, A |
|  |  | 2 C | \|0010|1100| | $\mathrm{Q}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| LD | $r$ | -5 | \|00| r |0101| | RAM $(\mathrm{B}) \rightarrow \mathrm{A}$ | None | Load RAM into A, |
|  |  |  | ( $\mathrm{r}=0: 3$ ) | $\mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br}$ |  | Exclusive-OR Br with r |
| LDD | r,d | 23 | $\begin{aligned} & \|0010\| 0011 \mid \\ & \|0\| \mathrm{r}\|\mathrm{~d}\| \end{aligned}$ | $\mathrm{RAM}(\mathrm{r}, \mathrm{d}) \rightarrow \mathrm{A}$ | None | Load A with RAM pointed to direct by r,d |
| LQID |  | BF | \|1011|1111| | $\begin{aligned} & \operatorname{ROM}\left(\mathrm{PC}_{10: B, A, M}\right) \rightarrow 0 \\ & \mathrm{SB} \rightarrow \mathrm{SC} \end{aligned}$ | None | Load Q Indirect (Note 2) |
| RMB | 0 | 4 C | \|0100|1100| | $0 \rightarrow$ RAM $(\mathrm{B})_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | \|0100|0101| | $0 \rightarrow$ RAM $(B)_{1}$ |  |  |
|  | 2 | 42 | \|0100|0010| | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{2}$ |  |  |
|  | 3 | 43 | \|0100|0011| | $0 \rightarrow \mathrm{RAM}(\mathrm{B})_{3}$ |  |  |



## Instruction Set (Continued)

TABLE III. COP404C Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Machine Language Code (Binary) | Data Flow | Skip <br> Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS |  |  |  |  |  |  |
| ING |  | 33 | \|0011|0011| | $G \rightarrow A$ | None | Input G Ports to A |
|  |  | 2A | \|0010|1010| |  |  |  |
| ININ |  | 33 | \|0011|0011| | $\mathrm{IN} \rightarrow \mathrm{A}$ | None | Input IN Inputs to A |
|  |  | 28 | \|0010|1000| |  |  |  |
| INIL |  | 33 | \|0011|0011| | $\mathrm{IL}_{3}, \mathrm{CKO},{ }^{\prime} \mathrm{O}$ ', $\mathrm{IL}_{0} \rightarrow \mathrm{~A}$ | None | Input IL Latches to A (Note 2) |
|  |  | 29 | \|0010|1001| |  |  |  |
| INL |  | 33 | \|0011|0011| | $\mathrm{L}_{7: 4} \rightarrow$ RAM $(\mathrm{B})$ | None | Input L Ports to RAM, A |
|  |  | 2 E | \|0010|1110| | $\mathrm{L}_{3: 0} \rightarrow \mathrm{~A}$ |  |  |
| OBD |  | 33 | \|0011|0011| | $\mathrm{Bd} \rightarrow \mathrm{D}$ | None | Output Bd to D Outputs |
|  |  | 3E | \|0011|1110| |  |  |  |
| OGI | $y$ | 33 | \|0011|0011| | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | 5- | \|0101| y | |  |  |  |
| OMG |  | 33 | \|0011|0011| | $\mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{G}$ | None | Output RAM to G Ports |
|  |  | 3A | \|0011|1010| |  |  |  |
| XAS |  | 4F | \|0100|1111| | $A \longleftrightarrow S$ SIO, C $\rightarrow$ SKL | None | Exchange A with SIO (Note 2) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered O to N where $O$ signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit A register.
Note 2: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 3: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.

Note 4: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRF may not jump to the last word in page 2.
Note 5: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ ' data minus 1 e.g., to load the lower four bits of $\mathrm{B}(\mathrm{Bd})$ with the value $9\left(1001_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(100 \mathrm{O}_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).
Note 6: Machine code for operand field y for LEl instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds with the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)
Note 7: If $\overline{\mathrm{SEL2O}}=1, \mathrm{~A} \longleftrightarrow \mathrm{Br}(0 \rightarrow \mathrm{~A} 3)$
If $\overline{\mathrm{SEL2O}}=0, A \longleftrightarrow \mathrm{Br}(0,0 \longrightarrow \mathrm{~A}, \mathrm{~A} 2)$.

## Description of Selected Instructions

## XAS INSTRUCTION

XAS (Exchange A with SIO ) copies C to the SKL latch and exchanges the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/seri-al-out shift register or binary counter data, depending on the value of the EN register. If SIO is selected as a shift register, an XAS instruction can be performed once every 4 instruction cycles to effect a continuous data stream.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit $Q$ register with the contents of ROM pointed to by the 11-bit word PC10: PC8, A, M. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack (PC + $1 \rightarrow$ SA $\rightarrow$ SB $\rightarrow S C$ ) and replaces the least significant 8 bits of the PC as follows: A $\rightarrow \mathrm{PC}(7: 4), \mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{PC}(3: 0)$, leaving $\mathrm{PC}(10), \mathrm{PC}(9)$ and $\mathrm{PC}(8)$ unchanged. The ROM data pointed to by the
new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" (SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow$ PC), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost.
Note: LQID uses 2 instruction cycles if executed, one if skipped.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by $A$ and $M$. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 11-bit word, PC10: 8, A, M. PC10, PC9 and PC8 are not affected by JID.
Note: JID uses 2 instruction cycles if executed, one if skipped.

Description of Selected Instructions (Continued)

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of the T counter overflow latch (see internal logic, above), executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction allow the processor to generate its own time-base for real-time processing, rather than relying on an external input signal
Note: If the most significant bit of the $T$ counter is a 1 when a CAMT instruction loads the counter, the overflow flag will be set. The following sample of codes should be used when loading the counter:

| CAMT | ; load T counter |
| :--- | :--- |
| SKT | ; skip if overflow flag is set and reset it |
| NOP |  |

## IT INSTRUCTION

The IT (idle till timer) instruction halts the processor and puts it in an idle state until the time-base counter overflows. This idle state reduces current drain since all logic (except the oscillator and time base counter) is stopped. IT instruction is not allowed if the T counter is used as an external event counter (TIN pin tied to $\mathrm{V}_{\mathrm{CC}}$ ).

## INIL INSTRUCTION

INIL (Input IL Latches to A) inputs 2 latches, IL3 and ILO, CKOI and 0 into A. The IL3 and ILO latches are set if a lowgoing pulse (" 1 " to " 0 ') has occurred on the IN3 and INO inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction cycles. Execution of an INIL inputs IL3 and ILO into A3 and AO respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the IN3 and INO lines. The state of CKOI is input into A2. A 0 is input into A1. IL latches are cleared on reset.

## Instruction Set Notes

a. The first word of a program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, they are still fetched from the program memory. Thus program paths take the same number of cycles whether instructions are skipped or executed except for JID, and LQID.
c. The ROM is organized into pages of 64 words each. The Program Counter is a 11-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID, or LQID is the last word of a page, it operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a JID or LQID located in the last word of every fourth page (i.e. hex address 0FF, 1FF, 2FF, 3FF, 4FF, etc.) will access data in the next group of four pages.

## Power Dissipation

The lowest power drain is when the clock is stopped. As the frequency increases so does current. Current is also lower at lower operating voltages. Therefore, for minimum power dissipation, the user should run at the lowest speed and voltage that his application will allow. The user should take care that all pins swing to full supply levels to insure that outputs are not loaded down and that inputs are not at some intermediate level which may draw current. Any input with a slow rise or fall time will draw additional current. For
example, an RC oscillator on DO will draw more current than a square wave clock input since it is a slow rising signal.
If using an external square wave oscillator, the following equation can be used to calculate the COP404C operating current drain:

$$
I_{c o}=I q+V \times 40 \times F_{i}+V \times 1400 \times F_{i} / 4
$$

where:
$I_{c o}=$ chip operating current drain in microamps
$\mathrm{I}_{\mathrm{q}}=$ quiescent leakage current (from curve)
$\mathrm{F}_{\mathrm{i}}=$ CKI frequency in MegaHertz
$V=$ chip $V_{C C}$ in volts
For example at 5 volts $\mathrm{V}_{\mathrm{CC}}$ and 400 kHz :
$\mathrm{I}_{\mathrm{CO}}=20+5 \times 40 \times .4+5 \times 1400 \times .4 / 4$
$\mathrm{I}_{\mathrm{co}}=20+80+700=800 \mu \mathrm{~A}$
at 2.4 volts $V_{\mathrm{CC}}$ and 30 kHz :

$$
\begin{aligned}
& I_{\mathrm{CO}}=6+2.4 \times 40 \times .03+2.4 \times 1400 \times .03 / 4 \\
& I_{\mathrm{CO}}=6+2.88+25.2=34.08 \mu \mathrm{~A}
\end{aligned}
$$

If an IT instruction is executed, the chip goes into the IDLE mode until the timer overflows. In IDLE mode, the current drain can be calculated from the following equation:

$$
\mathrm{I}_{\mathrm{ci}}=\mathrm{I}_{\mathrm{q}}+\mathrm{V} \times 40 \times \mathrm{F}_{\mathrm{i}}
$$

For example, at 5 volts $V_{C C}$ and 400 kHz

$$
\mathrm{I}_{\mathrm{ci}}=20+5 \times 40 \times .4=100 \mu \mathrm{~A}
$$

The total average current will then be the weighted average of the operating current and the idle current:

$$
I t a=I c o \times \frac{T o}{T o+T i}+I c i \times \frac{T i}{T o+T i}
$$

where:
$\mathrm{I}_{\mathrm{ta}}=$ total average current
$\mathrm{I}_{\mathrm{co}}=$ operating current
$\mathrm{I}_{\mathrm{ci}}=$ idle current
$\mathrm{T}_{0}=$ operating time
$\mathrm{T}_{\mathrm{i}}=$ idle time

## I/O OPTIONS

COP404C outputs have the following configurations, illustrated in Figure 12.
a. Standard - A CMOS push-pull buffer with an N-channel device to ground in conjunction with a P-channel device to $\mathrm{V}_{\mathrm{CC}}$, compatible with CMOS and LSTTL. (Used on SO, SK, AD/ $\overline{\text { DATA }}$, SKIP, A10:8 and D outputs.)
b. Low Current - This is the same configuration as a. above except that the sourcing current is much less. (Used on G outputs.)
c. Standard TRI-STATE L Output - A CMOS output buffer similar to $a$. which may be disabled by program control. (Used on L outputs.)
All inputs have the following configuration:
d. Input with on chip load device to $\mathrm{V}_{\mathrm{Cc}}$. (Used on CKOI.)
e. HI-Z input which must be driven by the users logic. (Used on CKI, $\overline{R E S E T}, \mathrm{IN}, \mathrm{SI}, \overline{\mathrm{DUAL}}, \overline{\mathrm{TIN}}, \overline{\mathrm{MB}}, \overline{\mathrm{SEL} 10}$ and SEL20 inputs.)
All output drivers use one or more of three common devices numbered 1 to 3 . Minimum and maximum current (lout and $V_{\text {Out }}$ ) curves are given in Figure 13 for each of these devices to allow the designer to effectively use these I/O configurations.

a. Standard Push-Pull Output

b. Low Current Push-Pull Output


Standard TRI-STATE "L" Output

d. Input with Load

e. Hi-Z Input
TL/DD/5530-15

FIGURE 12. Input/Output Configurations

## Typical Performance Characteristics



TL/DD/5530- 16
FIGURE 13. Input/Output Characteristics

## Emulation

The COP404C may be used to exactly emulate the COP444C/445C, COP424C/425C, and COP410C/411C. However, the Program Counter always addresses $2 k$ of external ROM whatever chip is being emulated. Figure 14 shows the interconnect to implement a hardware emulation. This connection uses a NMC27C16 EPROM as external
memory. Other memory can be used such as bipolar PROM or RAM.
Pins IP7-IP0 are bidirectional inputs and outputs. When the AD/ $\overline{\text { DATA }}$ clocking output turns on, the EPROM drivers are disabled and IP7-IPO output addresses. The 8-bit latch (MM74C373) latches the addresses to drive the memory.


FIGURE 14. COP404C Used To Emulate A COP444C

## Emulation (Continued)

When AD/ $\overline{D A T A}$ turns off, the EPROM is enabled and the IP7-IP0 pins will input the memory data. A10, A9 and A8 output the most significant address bits to the memory. (SKIP output may be used for program debug if needed.)

- CKI is divided by 4. Other divide-by are emulated by external divider.
- CKO can be emulated as a general purpose input by using CKOI or as a Halt I/O port by using CKOH.
- $\overline{M B}$ pin can be pulled low if the MICROBUS feature of the COP444C and COP424C is needed. Othewise it should be high.
- $\overline{\text { DUAL }}$ pin can be pulled low if the Dual-Clock feature of the COP444C and COP424C is needed. Otherwise it should be high.
- TIN pin controls the input of the 8-bit timer of the COP444C and COP424C (internal timer if TIN is low, external event counter if TIN is high).
- The $\overline{\text { SEL10 }}$ and $\overline{\text { SEL20 }}$ inputs are used to emulate the COP444C/445C, COP424C/425C, or COP410C/411C.
- When emulating the COP444C/445C, the user must configure $\overline{\mathrm{SEL2O}}=1$ and $\overline{\mathrm{SEL} 10}=1$.
- When emulating the COP424C/425C, the user must configure $\overline{\mathrm{SEL2O}}=0$ and $\overline{\mathrm{SEL10}}=1$. In this mode, the user RAM is physically halved. As in the COP424C/ 425 C , the user has 64 digits ( 256 bits) of RAM available. Pin A10 should not be connected to the program memory (most significant address bit of the program memory should be grounded if using a $2 \mathrm{k} \times 8$ memory).
- When emulating the COP410C/411C, the user must configure $\overline{\mathrm{SEL20}}=0$ and $\overline{\mathrm{SEL} 10}=0$. In this mode, the user has 32 digits ( 128 bits ) of RAM available organized


## Option Table

## COP404C MASK OPTIONS

The following COP444C options have been implemented in the COP404C:

| Option value | Comment |
| :--- | :--- |
| Option $1=0$ | Ground Pin - no option available |
| Option $2=1,2$ | CKO is replaced by CKOI and CKOH |
| Option $3=5$ | CKI is external clock input divided by 4 |
| Option $4=1$ | RESET is Hi-Z input |
| Option $5-8=0$ | Loutputs are standard TRI-STATE |
| Option $9=1$ | IN1 is a Hi-Z input |
| Option $10=1$ | IN2 is a Hi-Z input |
| Option $11=0$ | VCC pin - no option available |
| Option $12-15=0$ | L outputs are standard TRI-STATE |
| Option $16=0$ | Sl is a Hi-Z input |
| Option $17=0$ | SO is a standard output |
| Option $18=0$ | SK is a standard output |
| Option $19=1$ | INO is a Hi-Z input |
| Option $20=1$ | IN3 is a Hi-Z input |
| Option $21-24=1$ | G outputs are low-current |
| Option $25-28=0$ | D outputs are standard |
| Option $29=1$ | No internal initialization logic |
| Option $30=0,1$ | DUAL-CLOCK is pin selectable |
| Option $31=0,1$ | TIMER is pin selectable |
| Option $32=0,1$ | MICROBUS is pin selectable |
| Option $33=$ N/A | 48-pin package |

in the same way as the COP410C/411C - 4 registers of 8 digits each. Pins A10 and A9 should not be connected to the program memory (the 2 most significant address bits of the program memory should be grounded).
Furthermore, the subroutine stack is decreased from 3 levels to 2 levels.
The pins $\overline{\text { SEL10 }}$ and $\overline{\text { SEL20 }}$ change the internal logic of the device to accurately emulate the devices as indicated above. However, the user must remember that the COP424C/425C is a subset of the COP444C/COP445C with respect to memory size. The COP410C/411C is a subset both in memory size and in function. The user must take care not to use features and instructions which are not available on the COP410C/411C (see table IV. below) when using the COP404C to emulate the COP410C/411C.

## TABLE IV. FEATURES AND INSTRUCTIONS NOT AVAILABLE ON COP410C/411C.

| Timer | ADT |  |  |
| :--- | :--- | :--- | :--- |
| Dual-clock | CASC |  |  |
| Interrupt | CAMT |  |  |
| Microbus | CTMA |  |  |
|  | IT |  |  |
|  | LDD | r, d |  |
|  | XAD | r, d | (except 3, 15) |
|  | XABR |  |  |
|  | SKT |  |  |
|  | ININ |  |  |
|  | INIL |  |  |
|  | OGI | $y$ |  |

National Semiconductor Corporation

## COP404LSN-5 ROMIess N-Channel Microcontrollers

## General Description

The COP404LSN-5 ROMless Microcontroller is a member of the COPSTM family, fabricated using $N$-channel, silicon gate MOS technology. The COP404LSN-5 contains CPU, RAM, I/O and is identical to a COP444L device except the ROM has been removed and pins have been added to output the ROM address and to input the ROM data. In a system the COP404LSNN-5 will perform exactly as the COP444L. This important benefit facilitates development and debug of a COP program prior to masking the final part. The COP404LSN-5 is also appropriate in low volume applications, or when the program might be changing. The COP404LSN-5 may be used to emulate the COP444L, COP445L, COP420L, and the COP421L.
Use COP404LSN-5 in volume applications. For extended temperature range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right), \mathrm{COP} 304 \mathrm{~L}$ is available on a special order basis.

## Features

■ Exact circuit equivalent of COP444L

- Low cost
- Powerful instruction set

■ $128 \times 4$ RAM, addresses $2048 \times 8$ ROM
■ True vectored interrupt, plus restart

- Three-level subroutine stack
- $16 \mu \mathrm{~s}$ instruction time

■ Single supply operation ( $4.5 \mathrm{~V}-5.5 \mathrm{~V}$ )

- Low current drain ( 16 mA max)
- Internal time-base counter for real-time processing
- Internal binary counter register with MICROWIRETM compatible serial I/O
- General purpose outputs
- LSTTL/CMOS compatible in and out
- Direct drive of LED digit and segment lines
- Software/hardware compatible with other members of COP400 family


## Block Diagram



TL/DD/8817-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin Relative to GND
-0.5 V to +10 V
Ambient Operating Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Ambient Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering, 10 sec .) $300^{\circ} \mathrm{C}$
Power Dissipation
0.75 W at $25^{\circ} \mathrm{C}$ 0.4 W at $70^{\circ} \mathrm{C}$

$$
\begin{array}{lr}
\text { Total Source Current } & 120 \mathrm{~mA} \\
\text { Total Sink Current } & 140 \mathrm{~mA} \\
\text { Note: Absolute maximum ratings indicate limits beyond } \\
\text { which damage to the device may occur. DC and AC electri- } \\
\text { cal specifications are not ensured when operating the de- } \\
\text { vice at absolute maximum ratings. }
\end{array}
$$

## DC Electrical Characteristics

$4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V} ; 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 2) | 4.5 | 5.5 | V |
| Power Supply Ripple | Peak to Peak |  | 0.5 | V |
| Operating Supply Current | All Inputs and Outputs Open |  | 16 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Crystal Input <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> RESET Input Levels <br> Logic High <br> Logic Low <br> IP0-IP7, SI Input Levels <br> Logic High <br> Logic High <br> Logic Low <br> All Other Inputs Logic High Logic Low | Schmitt Trigger Input $\begin{aligned} & V_{C C}=5.5 \mathrm{~V} \\ & V_{C C}=5 \mathrm{~V} \pm 5 \% \end{aligned}$ <br> High Trip Level Options Selected | $\begin{gathered} 2.0 \\ -0.3 \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ \\ 2.4 \\ 2.0 \\ -0.3 \\ \\ 3.6 \\ -0.3 \end{gathered}$ | 0.4 <br> 0.6 <br> 0.8 <br> 1.2 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{v} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| Input Capacitance |  |  | 7 | pF |
| Output Voltage Levels <br> LSTTL Operation <br> Logic High $\left(\mathrm{V}_{\mathrm{OH}}\right)$ <br> Logic Low (VOL) <br> IP0-IP7, P8, P9, SKIP/P10 <br> Logic High <br> Logic Low | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% \\ & \mathrm{I}_{\mathrm{OH}}=-25 \mu \mathrm{~A} \\ & \mathrm{l}_{\mathrm{OL}}=0.36 \mathrm{~mA} \\ & \text { (Note 1) } \\ & \mathrm{l}_{\mathrm{OH}}=-80 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=720 \mu \mathrm{~A} \\ & \hline \end{aligned}$ | 2.7 <br> 2.4 | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ |
| Output Current Levels Output Sink Current SO and SK Outputs (loL) $L_{0}-L_{7}$ Outputs $G_{0}-G_{3}$ and $D_{0}-D_{3}$ Outputs CKO | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 0.9 \\ & 0.4 \\ & 15 \\ & 0.2 \end{aligned}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Output Source Current $D_{0}-D_{3}, G_{0}-G_{3}$ Outputs (IOH) SO and SK Outputs (IOH) $L_{0}-L_{7}$ Outputs | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=1.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -30 \\ & -1.2 \\ & -1.4 \end{aligned}$ | $\begin{aligned} & -250 \\ & -25 \end{aligned}$ | $\mu \mathrm{A}$ <br> mA <br> mA |


| DC Electrical Characteristics (Continued) $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise noted |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Parameter | Conditions | Min | Max | Units |
| Input Load Source Current (l\|L) | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {IL }}=0 \mathrm{~V}$ | -10 | -140 | $\mu \mathrm{A}$ |
| Total Sink Current Allowed All Outputs Combined D, G Ports $L_{7}-L_{4}$ $\mathrm{L}_{3}-\mathrm{L}_{0}$ All Other Pins |  |  | $\begin{gathered} 140 \\ 120 \\ 4 \\ 4 \\ 1.8 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Total Source Current Allowed All I/O Combined $\begin{aligned} & L_{7}-L_{4} \\ & L_{3}-L_{0} \end{aligned}$ <br> Each L Pin <br> All Other Pins |  |  | $\begin{aligned} & 120 \\ & 60 \\ & 60 \\ & 30 \\ & 1.5 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |

AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{C C} \leq 5.5 \mathrm{~V}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time |  | 16 | 40 | $\mu \mathrm{S}$ |
| CKI <br> Input Frequency, f <br> Duty Cycle <br> Rise Time <br> Fall Time | $\begin{aligned} & (\div 32 \text { Mode) } \\ & f_{I}=2.0 \mathrm{MHz} \end{aligned}$ | $\begin{aligned} & 0.8 \\ & 30 \end{aligned}$ | $\begin{gathered} 2 \\ 60 \\ 120 \\ 80 \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{MHz} \\ \% \\ \mathrm{~ns} \\ \mathrm{~ns} \\ \hline \end{gathered}$ |
| INPUTS: ```SI, IP7-IP0 IsETUP thold IN N-IN N,GG}-\mp@subsup{G}{0}{\prime},\mp@subsup{L}{7}{\prime}-\mp@subsup{L}{0}{ tsetup thold``` |  | $\begin{aligned} & 2.0 \\ & 1.0 \\ & 8.0 \\ & 1.3 \end{aligned}$ |  | $\mu \mathrm{s}$ <br> $\mu \mathrm{s}$ $\mu \mathrm{s}$ |
| OUTPUT PROPAGATION DELAY $\begin{aligned} & \text { SO, SK Outputs } \\ & t_{p d 1}, t_{p d 0} \\ & D_{3}-D_{0}, G_{3}-G_{0}, L_{7}-L_{0} \\ & t_{\text {pd1 }}, t_{\text {pd0 }} \\ & \text { IP7-IP0, P8, P9, SKIP } \\ & t_{p d 1}, t_{p d 0} \\ & \text { P10 } \\ & t_{p d 1}, t_{\text {pd0 }} \end{aligned}$ | $\begin{aligned} & \text { Test Condition: } \\ & C_{L}=50 \mathrm{pF}, \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V} \\ & \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega \\ & \mathrm{R}_{\mathrm{L}}=20 \mathrm{k} \Omega \\ & R_{\mathrm{L}}=5 \mathrm{k} \Omega \\ & R_{\mathrm{L}}=5 \mathrm{k} \Omega \end{aligned}$ |  | 4.0 <br> 5.6 <br> 7.2 <br> 6.0 | $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{s}$ |

Note 1: COP404LSN-5 has Push-Pull drivers on these outputs.
Note 2: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.

## Connection Diagram



TL/DD/8817-2
Top View
FIGURE 2
Order Number COP404LSN-5 See NS Package Number N40A

## Pin Descriptions

| Pin | $\quad$Description |
| :--- | :--- |
| $L_{7}-L_{0}$ | 8 bidirecitonal I/O ports with TRI-STATE ${ }^{\circledR}$ |
| $\mathrm{G}_{3}-\mathrm{G}_{0}$ | 4 bidirectional I/O ports |
| $\mathrm{D}_{3}-\mathrm{D}_{0}$ | 4 general purpose outputs |
| $\mathrm{IN}_{3}-\mathrm{IN}_{0}$ | 4 general purpose outputs |
| SI | Serial input (or counter input |
| SO | Serial output (or general purpose output) |
| SK | Logic-controlled clock (or general purpose out- |
|  | put) |
| AD/DATA | Address out/data in flag |
| CKI | System oscillator input |
| CKO | System oscillator output (COP404LSN-5) |
| RESET | System reset input |
| VCC | Power supply |
| GND | Ground |
| IP7-IPO | 8 bidirectional ROM address and data ports |
| P8, P9 | 2 ROM address outputs |
| SKIP/P10 | Instruction skip output and most significant |
|  | ROM address bit output |

## Timing Diagram



TL/DD/8817-3
FIGURE 3. Input/Output

## Functional Description

A block diagram of the COP404LSN-5 is given in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device. Positive logic is used. When a bit is set, it is a logic " 1 " (greater than 2 V ). When a bit is reset, it is a logic " 0 " (less than 0.8 V ).

## PROGRAM MEMORY

Program Memory consists of a 2048 byte external memory. As can be seen by an examination of the COP404LSN-5 instruction set, these words may be program instructions, program data or ROM addressing data. Because of the special characteristics associated with the JP, JSRP, JID and LQID instructions, ROM must often be thought of as being organized into 32 pages of 64 words each.
ROM addressing is accomplished by an 11-bit PC register. Its binary value selects one of the 20488 -bit words contained in ROM. A new address is loaded into the PC register during each instruction cycle. Unless the instruction is a transfer of control instruction, the PC register is loaded with the next sequential 11-bit binary count value. Three levels of subroutine nesting are implemented by the 11-bit subroutine saves registers, SA, SB, and SC, providing a last-in, first-out (LIFO) hardware subroutine stack.
ROM instruction words are fetched, decoded and executed by the Instruction Decode, Control and Skip Logic circuitry.

## DATA MEMORY

Data memory consists of a 512-bit RAM, organized as 8 data registers of 164 -bit digits. RAM addressing is implemented by a 7 -bit B register whose upper 3 bits ( Br ) select 1 of 8 data registers and lower 4 bits (Bd) select 1 of 164 -bit digits in the selected data register. While the 4-bit contents of the selected RAM digit (M) is usually loaded into or from, or exchanged with, the A register (accumulator), it may also be loaded into or from the $Q$ latches or loaded from the $L$ ports. RAM addressing may also be performed directly by the LDD and XAD instructions based upon the 7-bit contents of the operand field of these instructions. The Bd register also serves as a source register for 4-bit data sent directly to the D outputs.

## INTERNAL LOGIC

The 4-bit A register (accumulator) is the source and destination register for most I/O, arithmetic, logic and data memory access operations. It can also be used to load the Br and Bd portions of the $B$ register, to load and input 4 bits of the 8 -bit Q latch data, to input 4 bits of the 8 -bit LI/O port data and to perform data exchanges with the SIO register.
A 4-bit adder performs the arithmetic and logic functions, storing its results in A. It also outputs a carry bit to the 1-bit C register, most often employed to indicate arithmetic overflow. The C register, in conjunction with the XAS instruction and the EN register, also serves to control the SK output. C can be outputted directly to SK or can enable SK to be a sync clock each instruction cycle time. (See XAS instruction and EN register description, below).

Four general-purpose inputs, $\mathbb{N}_{3}-\mathbb{I N}_{0}$, are provided.
The $D$ register provides 4 general-purpose outputs and is used as the destination register for the 4-bit contents of Bd. The D outputs can be directly connected to the digits of a multiplexed LED display.
The G register contents are outputs to 4 general-purpose bidirectional I/O ports. G I/O ports can be directly connected to the digits of a multiplexed LED display.
The $Q$ register is an internal, latched, 8 -bit register, used to hold data loaded to or from $M$ and $A$, as well as 8 -bit data from ROM. Its contents are output to the LI/O ports when the $L$ drivers are enabled under program control. (See LEI instruction.)
The 8 L drivers, when enabled, output the contents of latched $Q$ data to the LI/O ports. Also, the contents of $L$ may be read directly into $A$ and M. L I/O ports can be directly connected to the segments of a multiplexed LED display (using the LED Direct Drive output configuration option) with Q data being outputted to the $\mathrm{Sa}-\mathrm{Sg}$ and decimal point segments of the display.
The SIO register functions as a 4-bit serial-in/serial-out shift register or as a binary counter depending on the contents of the EN register. (See EN register description, below.) Its contents can be exchanged with $A$, allowing it to input or output a continuous serial data stream. SIO may also be used to provide additional parallel I/O by connecting SO to external serial-in/parallel-out shift registers.
The XAS instruction copies C into the SKL latch. In the counter mode, SK is the output of SKL; in the shift register mode, SK outputs SKL ANDed with the clock.
The EN register is an internal 4-bit register loaded under program control by the LEl instruction. The state of each bit of this register selects or deselects the particular feature associated with each bit of the EN register ( $\left.E N_{3}-E N_{0}\right)$.

1. The least significant bit of the enable register, $E N_{0}$, selects the SIO register as either a 4-bit shift register or a 4bit binary counter. With $E N_{0}$ set, SIO is an asynchronous binary counter, decrementing its value by one upon each low-going pulse (" 1 " to " 0 ") occurring on the SI input. Each pulse must be at least two instruction cycles wide. SK outputs the value of SKL. The SO output is equal to the value of $E N_{3}$. With $E N_{0}$ reset, SIO is a serial shift register shifting left each instruction cycle time. The data present at SI goes into the least significant bit of SIO. SO can be enabled to output the most significant bit of SIO each cycle time. (See 4 below.) The SK output becomes a logic-controlled clock.
2. With $E N_{1}$ set the $I N_{1}$ input is enabled as an interrupt input. Immediately following an interrupt, $\mathrm{EN}_{1}$ is reset to disable further interrupts.
3. With $E N_{2}$ set, the $L$ drivers are enabled to output the data in $Q$ to the L I/O ports. Resetting $\mathrm{EN}_{2}$ disables the L drivers, placing the LI/O ports in a high-impedance input state.

## Functional Description (Continued)

4. $\mathrm{EN}_{3}$, in conjunction with $E N_{0}$, affects the SO output. With $E N_{0}$ set (binary counter option selected) SO will output the value loaded into $E N_{3}$. With $E N_{0}$ reset (serial shift register option selected), setting $\mathrm{EN}_{3}$ enables SO as the output of the SIO shift register, outputting serial shifted data each instruction time. Resetting $\mathrm{EN}_{3}$ with the serial shift register option selected disables SO as the shift register output; data continues to be shifted through SIO and can be exchanged with $A$ via an XAS instruction but SO remains reset to " 0 ." The table below provides a summary of the modes associated with $\mathrm{EN}_{3}$ and $\mathrm{EN}_{\mathrm{O}}$.

## INTERRUPT

The following features are associated with the $\mathrm{IN}_{1}$ interrupt procedure and protocol and must be considered by the programmer when utilizing interrupts.
a. The interrupt, once acknowledged as explained below, pushes the next sequential program counter address (PC+1) onto the stack, pushing in turn the contents of the other subroutine-save registers to the next lower level (PC+1 $\rightarrow$ SA $\rightarrow$ SB $\rightarrow$ SC). Any previous contents of SC are lost. The program counter is set to hex address OFF (the last word of page 3) and $E N_{1}$ is reset.
b. An interrupt will be acknowledged only after the following conditions are met:

1. $E N_{1}$ has been set.
2. A low-going pulse (" 1 " to " 0 ") at least two instruction cycles wide occurs on the $\mathrm{IN}_{1}$ input.
3. A currently executing instruction has been completed.
4. All successive transfer of control instructions and successive LBls have been completed (e.g., if the main program is executing a JP instruction which transfers program control to another JP instruction, the interrupt will not be acknowledged until the second JP instruction has been executed.
c. Upon acknowledgement of an interrupt, the skip logic status is saved and later restored upon popping of the stack. For example, if an interrupt occurs during the execution of ASC (Add with Carry, Skip on Carry) instruction which results in carry, the skip logic status is saved and program control is transferred to the interrupt servicing routine at hex address OFF. At the end of the interrupt routine, a RET instruction is executed to "pop" the stack and return program control to the instruction following the original ASC. At this time, the skip logic is enabled and skips this instruction because of the previous ASC carry. Subroutines and LQID instructions should not be nested within the interrupt service routine, since their popping the stack will enable any previously saved main program skips, interfering with the orderly execution of the interrupt routine.
d. The first instruction of the interrupt routine at hex address OFF must be a NOP.
e. A LEI instruction can be put immediately before the RET to re-enable interrupts.

## INITIALIZATION

The Reset Logic will initialize (clear) the device upon powerup if the power supply rise time is less than 1 ms and greater than $1 \mu \mathrm{~s}$. If the power supply rise time is greater than 1 ms , the user must provide an external RC network and diode to the RESET pin as shown below. The RESET pin is configured as a Schmitt trigger input. If the RC network is not used, the RESET pin should be left open. Initialization will occur whenever a logic " 0 " is applied to the RESET input, provided it stays low for at least three instruction cycle times.


TL/DD/8817-4
RC $\geq 5 \times$ Power Supply Rise Time ( $\mathrm{R}>40 \mathrm{k}$ )
Upon initialization, the PC register is cleared to 0 (ROM address 0 ) and the A, B, C, D, EN, and G registers are cleared. The SK output is enabled as a SYNC output, providing a pulse each instruction cycle time. Data Memory (RAM) is not cleared upon initialization. The first instruction at address 0 must be a CLRA.

## EXTERNAL MEMORY INTERFACE

The COP404LSN-5 is designed for use with an external Program Memory. This memory may be implemented using any devices having the following characteristics:

1. random addressing
2. TTL-compatible TRI-STATE outputs
3. TTL-compatible inputs
4. access time $=5 \mu \mathrm{~s}$ max.

Typically these requirements are met using bipolar or MOS PROMs.
During operation, the address of the next instruction is sent out on P10, P9, P8, and IP7 through IP0 during the time that AD/ $\overline{\text { DATA }}$ is high (logic " 1 " = address mode). Address data on the IP lines is stored into an external latch on the high-to-low transition of the AD/DATA line; P9 and P8 are

Enable Register Modes - Blts $\mathrm{EN}_{3}$ and $\mathrm{EN}_{0}$

| $\mathrm{EN}_{3}$ | $\mathrm{EN}_{0}$ | SIO | SI | So | SK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Shift Register | Input to Shift Register | 0 | $\begin{aligned} & \text { If } S K L=1, S K=C L O C K \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 1 | 0 | Shift Register | Input to Shift Register | Serial Out | $\begin{aligned} & \text { If } S K L=1, S K=C L O C K \\ & \text { If } S K L=0, S K=0 \end{aligned}$ |
| 0 | 1 | Binary Counter | Input to Binary Counter | 0 | If $S K L=1, S K=1$ |
| 1 | 1 | Binary Counter | Input to Binary Counter | 1 | $\begin{aligned} & \text { If } \mathrm{SKL}=0, \mathrm{SK}=0 \\ & \text { If } \mathrm{SKL}=1, \mathrm{SK}=1 \\ & \text { If } \mathrm{SKL}=0, S K=0 \end{aligned}$ |

## Functional Description (Continued)

dedicated address outputs, and do not need to be latched. SKIP/P10 outputs address data when AD/ $\overline{\mathrm{DATA}}$ is low. When AD/ $\overline{D A T A}$ is low (logic " 0 " = data mode), the output of the memory is gated onto IP7 through IPO, forming the input bus. Note that the AD/ $\overline{\text { DATA }}$ output has a period of one instruction time, a duty cycle of approximately $50 \%$, and specifies whether the IP lines are used for address output or instruction input.

## OSCILLATOR

The basic clock oscillator configurations is shown in Figure 4.

Crystal Controlled Osclllator-CKI and CKO are connected to an external crystal. The instruction cycle time equals the crystal frequency divided by 32.


TL/DD/8817-5
FIGURE 4. Oscillator

## INPUT/OUTPUT CONFIGURATIONS

COP404LSN-5 outputs have the following configurations, illustrated in Figure 5:
a. Standard-an enhancement mode device to ground in conjunction with a depletion-mode device to $\mathrm{V}_{\mathrm{CC}}$, compatible with LSTTL and CMOS input requirements. (Used on D and G outputs.)
b. Open-Drain-an enhancement-mode device to ground only, allowing external pull-up as required by the user's application.
c. Push-Pull-an enhancement-mode device to ground in conjunction with a depletion-mode device paralleled by an enhancement-mode device to $\mathrm{V}_{\mathrm{Cc}}$. This configuration has been provided to allow for fast rise and fall times when driving capacitive loads.
d. LED Direct Drive-an enhancement-mode device to ground and to $V_{C C}$, meeting the typical current sourcing requirements of the segments of an LED display. The sourcing device is clamped to limit current flow. These devices may be turned off under program control (see Functional Description, EN Register), placing the outputs in a high-impedance state to provide required LED segment blanking for a multiplexed display. (Used on L outputs.)
COP404LSN-5 inputs have an on-chip depletion load device to $\mathrm{V}_{\mathrm{CC}}$.
The above input and output configurations share common enhancement-mode and depletion-mode devices. Specifically, all configurations use one or more of six devices (numbered 1-6, respectively). Minimum and maximum current (lout and VOUT) curves are given in Figure 6 for each of these devices to allow the designer to effectively use these 1/O configurations in designing a system.
An important point to remember is that even when the $L$ drivers are disabled, the depletion load device will source a small amount of current (see Figure 6, device 2); however; when the L-lines are used as inputs, the disabled depletion device can not be relied on to source sufficient current to pull an input to a logic " 1 ".


c. Push-Pull Output



TL/DD/8817-10
e. Input with Load
d. L Output (LED)

## Typical Performance Characteristics



## COP404LSN-5 Instruction Set

Table $I$ is a symbol table providing internal architecture, instruction operand and operational symbols used in the instruction set table.

Table II provides the mnemonic, operand, machine code, data flow, skip conditions, and description associated with each instruction in the COP404LSN-5 instruction set.

| Symbol | Definition |
| :--- | :--- |
| INTERNAL ARCHITECTURE SYMBOLS |  |
| A | 4-bit Accumulator |
| B | 10-bit RAM Address Register |
| Br | Upper 3 bits of B (register address) |
| Bd | Lower 4 bits of B (digit address) |
| C | 1-bit Carry Register |
| D | 4-bit Data Output Port |
| EN | 4-bit Enable Register |
| G | 4-bit Register to latch data for G I/O Port |
| IL | Two 1-bit latches associated with the IN ${ }_{3}$ or IN ${ }_{0}$ |
|  | inputs |
| IN | 4-bit Input Port |
| IP | 8-bit bidirectional ROM address and Data Port |
| L | 8-bit TRI-STATE I/O Port |
| M | 4-bit contents of RAM Memory pointed to by B |
|  | Register |
| P | 3-bit ROM Address Register Port |
| PC | 11-bit ROM Address Register (program counter) |
| Q | 8-bit Register to latch data for L I/O Port |
| SA | 11-bit Subroutine Save Register A |
| SB | 11-bit Subroutine Save Register B |
| SC | 11-bit Subroutine Save Register C |
| SIO | 4-bit Shift Register and Counter |
| SK | Logic-Controlled Clock Output |

Symbol Definition

## INSTRUCTION OPERAND SYMBOLS

d 4-bit Operand Field, 0-15 binary (RAM Digit Select)
r 3-bit Operand Field, 0-7 binary (RAM Register Select) 11-bit Operand Field, 0-2047 binary (ROM Address)
y 4-bit Operand Field, 0-15 binary (Immediate Data)
RAM(s) Contents of RAM location addressed by s
ROM(t) Contents of ROM location addressed by $t$

OPERATIONAL SYMBOLS
$+\quad$ Plus

- Minus
$\rightarrow \quad$ Replaces
$\longleftrightarrow$ Is exchanged with
$=\quad$ Is equal to
$\bar{A} \quad$ The one's complement of $A$
$\oplus \quad$ Exclusive-OR
: Range of values

TABLE II. COP404LSN-5 Instruction Set

| Mnemonic | Operand | Hex <br> Code | Machine <br> Language Code <br> (Binary) | Data Flow | Skip Conditions |
| :---: | :---: | :---: | :---: | :--- | :--- |


| TABLE II. COP404LSN-5 Instruction Set (Continued) |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Operand | Hex Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| TRANSFER OF CONTROL INSTRUCTIONS |  |  |  |  |  |  |
| JID |  | FF | \|1111|1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \\ & \mathrm{PC}_{7: 0} \end{aligned}$ | None | Jump Indirect (Note 2) |
| JMP |  | $\begin{aligned} & 6- \\ & -- \end{aligned}$ | $\frac{0110\|0\| a_{10: 8} \mid}{L a_{7: 0}}$ | $a \rightarrow P C$ | None | Jump |
| JP | a |  | $\begin{gathered} \begin{array}{\|c\|} \hline 1 \mid \\ \text { (pages } 2,3 \\ \text { or only } \end{array} \\ \quad \text { or } \\ \text { (all other pages) } \end{gathered}$ | $a \rightarrow P C_{6: 0}$ $a \rightarrow P C_{5: 0}$ | None | Jump within Page (Note 4) |
| JSRP | a | -- | 10 ${ }^{10}$ a ${ }^{\text {5:0 }}$ | $\begin{aligned} & \mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \\ & \rightarrow \mathrm{SC} \\ & 00010 \rightarrow \mathrm{PC}_{10: 6} \\ & \mathrm{a} \rightarrow \mathrm{PC}_{5: 0} \end{aligned}$ | None | Jump to Subroutine Page (Note 5) |
| JSR | a | 6- | $\frac{\|0110\| 1\left\|a_{10: 8}\right\|}{L a_{7: 0}}$ | $\begin{aligned} & P C+1 \rightarrow S A \rightarrow S B \\ & \rightarrow \mathrm{SC} \\ & \mathrm{a} \rightarrow \mathrm{PC} \end{aligned}$ | None | Jump to Subroutine |
| RET |  | 48 | -0100\|1000 | SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow$ PC | None | Return from Subroutine |
| RETSK |  | 49 | \|0100|1001| | $S C \rightarrow S B \rightarrow S A \rightarrow P C$ | Always Skip on Return | Return from Subroutine then Skip |
| MEMORY REFERENCE INSTRUCTIONS |  |  |  |  |  |  |
| CAMQ |  | $\begin{aligned} & 33 \\ & 3 \mathrm{C} \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline 0011 & 0011 \\ \hline 0011 & 1100 \\ \hline \end{array}$ | $\begin{aligned} & A \rightarrow Q_{7: 4} \\ & R A M(B) \end{aligned} Q_{3: 0}$ | None | Copy A, RAM to Q |
| CQMA |  | $\begin{aligned} & 33 \\ & 2 \mathrm{C} \end{aligned}$ | 0011 0011 <br> 0010 1100 | $\begin{aligned} & Q_{7: 4} \rightarrow \text { RAM(B) } \\ & Q_{3: 0} \rightarrow A \end{aligned}$ | None | Copy Q to RAM, A |
| LD | $r$ | -5 | $\frac{00\|\mathrm{r}\| 0101 \mid}{(\mathrm{r}=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \rightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | None | Load RAM into A, Exclusive-OR Br with r |
| LDD | r,d | 23 | 0010 0011  <br> 0010 0 d <br> 0 r d | $\mathrm{RAM}(\mathrm{r}, \mathrm{d}) \rightarrow \mathrm{A}$ | None | Load A with RAM pointed to directly by $\mathrm{r}, \mathrm{d}$ |
| LQID |  | BF | \|1011 1111 | $\begin{aligned} & \mathrm{ROM}\left(\mathrm{PC}_{10 ; 8}, \mathrm{~A}, \mathrm{M}\right) \rightarrow \mathrm{Q} \\ & \mathrm{SB} \rightarrow \mathrm{SC} \end{aligned}$ | None | Load Q Indirect (Note 3) |
| RMB | 0 | 4 C | 0100 $1100 \mid$ <br> $0\|0\|$  | $0 \rightarrow$ RAM $(\mathrm{B})_{0}$ | None | Reset RAM Bit |
|  | 1 | 45 | 01000101 | $0 \rightarrow$ RAM $(\mathrm{B})_{1}$ |  |  |
|  | 2 | 42 | 0100 0010 | $0 \rightarrow$ RAM $(\mathrm{B})_{2}$ |  |  |
|  | 3 | 43 | 0100 0011 | $0 \rightarrow$ RAM $(\mathrm{B})_{3}$ |  |  |
| SMB | 0 | 4D | 0100\|1101| | $1 \rightarrow \mathrm{RAM}(\mathrm{B})_{0}$ | None | Set RAM Bit |
|  | 1 | 47 | 0100 0111 | $1 \rightarrow \mathrm{RAM}(\mathrm{B})_{1}$ |  |  |
|  | 2 | 46 | 01000110 | $1 \rightarrow \operatorname{RAM}(\mathrm{~B})_{2}$ |  |  |
|  | 3 | 4B | 0100 1011 | $1 \rightarrow \mathrm{RAM}(\mathrm{B})_{3}$ |  |  |
| STII | $y$ | 7- | 0111) y | $\begin{aligned} & y \rightarrow \text { RAM(B) } \\ & B d+1 \rightarrow B d \end{aligned}$ | None | Store Memory Immediate and Increment Bd |
| X | r | -6 | $\frac{\|00\| r\|0110\|}{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Br} \oplus \mathrm{r} \longrightarrow \mathrm{Br} \end{aligned}$ | None | Exchange RAM with A, Exclusive-OR Br with r |
| XAD | r,d | 23 | 0010 0011  <br> $1 \mid$ r d | RAM $(\mathrm{r}, \mathrm{d}) \longleftrightarrow \mathrm{A}$ | None | Exchange A with RAM pointed to directly by $(r, d)$ |
| XDS | r | -7 | $\frac{\|00\| r\|0111\|}{(r=0: 3)}$ | $\begin{aligned} & \mathrm{RAM}(\mathrm{~B}) \longleftrightarrow \mathrm{A} \\ & \mathrm{Bd}-1 \rightarrow \mathrm{Bd} \\ & \mathrm{Br} \oplus \mathrm{r} \rightarrow \mathrm{Br} \end{aligned}$ | Bd decrements past 0 | Exchange RAM with A and Decrement Bd, Exclusive-OR Br with r |



TABLE II. COP404LSN-5 Instruction Set (Continued)

| Mnemonic | Operand | Hex Code | Machine <br> Language Code (Binary) | Data Flow | Skip Conditions | Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT/OUTPUT INSTRUCTIONS (Continued) |  |  |  |  |  |  |
| OGI | $y$ | 33 | 001110011 | $y \rightarrow G$ | None | Output to G Ports Immediate |
|  |  | 5- | 0101] y |  |  |  |
| OMG |  | 33 | 0011 10011 | $R A M(B) \rightarrow G$ | None | Output RAM to G Ports |
|  |  | 3A | 0011 1010 |  |  |  |
| XAS |  | 4F | $0100 / 1111$ | $\mathrm{A} \longleftrightarrow \mathrm{SIO}, \mathrm{C} \rightarrow$ SKL | None | Exchange A with SIO (Note 2) |

Note 1: All subscripts for alphabetical symbols indicate bit numbers unless explicitly defined (e.g., Br and Bd are explicitly defined). Bits are numbered 0 to N where 0 signifies the least significant bit (low-order, right-most bit). For example, $A_{3}$ indicates the most significant (left-most) bit of the 4 -bit A register.
Note 2: For additional information on the operation of the XAS, JID, LQID, INIL, and SKT instructions, see below.
Note 3: The JP instruction allows a jump, while in subroutine pages 2 or 3, to any ROM location within the two-page boundary of pages 2 or 3 . The JP instruction, otherwise, permits a jump to a ROM location within the current 64 -word page. JP may not jump to the last word of a page.
Note 4: A JSRP transfers program control to subroutine page 2 ( 0010 is loaded into the upper 4 bits of P). A JSRP may not be used when in pages 2 or 3 . JSRP may not jump to the last word in page 2.
Note 5: LBI is a single-byte instruction if $d=0,9,10,11,12,13,14$, or 15 . The machine code for the lower 4 bits equals the binary value of the " $d$ " data minus 1 , e.g., to load the lower four bits of $B(B d)$ with the value $\left.9(1001)_{2}\right)$, the lower 4 bits of the LBI instruction equal $8\left(1000_{2}\right)$. To load 0 , the lower 4 bits of the LBI instruction should equal 15 (11112).
Note 6: Machine code for operand field y for LEI instruction should equal the binary value to be latched into EN, where a " 1 " or " 0 " in each bit of EN corresponds to the selection or deselection of a particular function associated with each bit. (See Functional Description, EN Register.)

## Description of Selection Instructions

The following information is provided to assist the user in understanding the operation of several unique instructions and to provide notes useful to programmers in writing COP404LSN-5 programs.

## XAS INSTRUCTIONS

XAS (Exchange A with SIO) exchanges the 4-bit contents of the accumulator with the 4-bit contents of the SIO register. The contents of SIO will contain serial-in/serial-out shift register or binary counter data, depending on the value of the EN register. An XAS instruction will also affect the SK output. (See Functional Description, EN Register.) If SIO is selected as a shift register, an XAS instruction must be performed once every 4 instruction cycles to effect a continuous data stream.

## JID INSTRUCTION

JID (Jump Indirect) is an indirect addressing instruction, transferring program control to a new ROM location pointed to indirectly by A and M. It loads the lower 8 bits of the ROM address register PC with the contents of ROM addressed by the 11-bit word, $\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{M} . \mathrm{PC}_{10}, \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ are not affected by this instruction.
Note: JID requires 2 instruction cycles to execute.

## INIL INSTRUCTION

INIL (Input IL Latches to A) inputs 2 latches, $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ (see Figure 7 ) and CKO into A . The $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ latches are set if a low-going pulse (" 1 " to " 0 ") has occurred on the $\mathrm{IN}_{3}$ and $\mathrm{IN}_{0}$ inputs since the last INIL instruction, provided the input pulse stays low for at least two instruction times. Execution of an INIL inputs $\mathrm{IL}_{3}$ and $\mathrm{IL}_{0}$ into A 3 and A 0 respectively, and resets these latches to allow them to respond to subsequent low-going pulses on the $\mathrm{N}_{3}$ and $\mathrm{IN}_{0}$ lines. INIL will input " 1 " into A2 on the COP404LSN-5. A " 0 " is always placed in A1 upon the execution of an INIL. The general purpose inputs $I N_{3}-I N_{0}$ are input to $A$ upon execution of an ININ instruction. (See Table II, ININ instruction.) INIL is use-
ful in recognizing pulses of short duration or pulses which occur too often to be read conveniently by an ININ instruction.
Note: IL latches are not cleared on reset.

## LQID INSTRUCTION

LQID (Load Q Indirect) loads the 8-bit Q register with the contents of ROM pointed to by the 11-bit word $\mathrm{PC}_{10}, \mathrm{PC}_{9}$, $\mathrm{PC}_{8}, \mathrm{~A}, \mathrm{M}$. LQID can be used for table lookup or code conversion such as BCD to seven-segment. The LQID instruction "pushes" the stack ( $\mathrm{PC}+1 \rightarrow \mathrm{SA} \rightarrow \mathrm{SB} \rightarrow \mathrm{SC}$ ) and replaces the least significant 8 bits of PC as follows: $\mathrm{A} \rightarrow \mathrm{PC}_{7: 4}, \mathrm{RAM}(\mathrm{B}) \rightarrow \mathrm{PC}_{3: 0}$, leaving $\mathrm{PC}_{10}, \mathrm{PC}_{9}$ and $\mathrm{PC}_{8}$ unchanged. The ROM data pointed to by the new address is fetched and loaded into the $Q$ latches. Next, the stack is "popped" (SC $\rightarrow$ SB $\rightarrow$ SA $\rightarrow$ PC), restoring the saved value of PC to continue sequential program execution. Since LQID pushes SB $\rightarrow$ SC, the previous contents of SC are lost. Also, when LQID pops the stack, the previously pushed contents of SB are left in SC. The net result is that the contents of SB are placed in SC (SB $\rightarrow$ SC).
Note: LOID takes two instruction cycle times to execute.


FIGURE 7. INIL. Hardware Implementation

## Description of Selected Instructions (Continued)

## SKT INSTRUCTION

The SKT (Skip On Timer) instruction tests the state of an internal 10-bit time-base counter. This counter divides the instruction cycle clock frequency by 1024 and provides a latched indication of counter overflow. The SKT instruction tests this latch, executing the next program instruction if the latch is not set. If the latch has been set since the previous test, the next program instruction is skipped and the latch is reset. The features associated with this instruction, therefore, allow the COP404LSN-5 to generate its own time-base for real-time processing rather than relying on an external input signal.
For example, using a 2.097 MHz oscillator as the time-base to the clock generator, the instruction cycle clock frequency will be 65 kHz (crystal frequency $\div 32$ ) and the binary counter output pulse frequency will be 64 Hz . For time-of-day or similar real-time processing, the SKT instruction can call a routine which increments a "seconds" counter every 64 ticks.

## INSTRUCTION SET NOTES

a. The first word of a COP404LSN-5 program (ROM address 0 ) must be a CLRA (Clear A) instruction.
b. Although skipped instructions are not executed, one instruction cycle time is devoted to skipping each byte of the skipped instruction. Thus all program paths except JID and LQID take the same number of cycle times whether instructions are skipped or executed. JID and LQID instructions take 2 cycles if executed and 1 cycle if skipped.
c. The ROM is organized into 32 pages of 64 words each. The Program Counter is an 11-bit binary counter, and will count through page boundaries. If a JP, JSRP, JID or LQID instruction is located in the last word of a page, the instruction operates as if it were in the next page. For example: a JP located in the last word of a page will jump to a location in the next page. Also, a LQID or JID located in the last word of page $3,7,11,15,19,23$ or 27 will access data in the next group of four pages.

## Typical Applications

## PROM-BASED SYSTEM

The COP404LSN-5 may be used to exactly emulate the COP444L. Figure 8 shows the interconnect to implement a COP444L hardware emulation. This connection uses a MM2716 EPROM as external memory. Other memory can be used such as bipolar PROM or RAM.
Pins IP7-IPO are bidirectional inputs and outputs. When the AD/DATA clocking output turns on, the EPROM drivers are disabled and IP7-IPO output addresses. The 8-bit latch (MM74LS373) latches the addresses to drive the memory. When AD/ $\overline{\text { DATA }}$ turns off, the EPROM is enabled and the IP7-IPO pins will input the memory data. P8, P9 and SKIP/ P10 output the most significant address bits to the memory. (SKIP output may be used for program debug if needed.)
The other 28 pins of the COP404LSN- 5 may be configured exactly the same as a COP444L. The COP404LSN-5 VCC can vary from 4.5 V to 5.5 V . However, 5 V is used for the memory.
For In-Circuit emulation, see also COP444LP.

## COP404LSN-5 Mask Options

The following COP444L options have been implemented on the COP404LSN-5.

| Option Value | Comment |
| :---: | :---: |
| Option $1=0$ | Ground, no option available |
| Option $2=0$ | CKO is clock generator output to crystal/resonator |
| Option 3 $=0$ | CKI is oscillator input (divide by 32) |
| Option $4=0$ | RESET pin has load device to $\mathrm{V}_{\mathrm{CC}}$ |
| Option $5=2$ | $L_{7}$ |
| Option $6=2$ | $\mathrm{L}_{6}$ have LED direct-drive |
| Option $7=2$ | $L_{5}$ output |
| Option $8=2$ | $\mathrm{L}_{4}$ |
| Option $9=0$ | IN1 has load device to $\mathrm{V}_{\mathrm{CC}}$ |
| Option $10=0$ | IN2 has load device to $V_{\text {cc }}$ |
| Option $11=1$ | $\mathrm{V}_{\text {cc }} 4.5 \mathrm{~V}$ to 5.5 V operation |
| Option $12=2$ | $\mathrm{L}_{3}$ |
| Option $13=2$ | $\mathrm{L}_{2}$ have LED direct-drive |
| Option $14=2$ | $L_{1}$ output |
| Option $15=2$ | $\mathrm{L}_{0}$ |
| Option $16=0$ | SI has load to $\mathrm{V}_{\mathrm{CC}}$ |
| Option $17=2$ | SO has push-pull output |


| Option Value | Comment |
| :---: | :---: |
| Option $18=2$ | SK has push-pull output |
| Option $19=0$ | INO has load device to $V_{\text {CC }}$ |
| Option $20=0$ | IN3 has load device to $V_{\text {CC }}$ |
| Option $21=0$ | $\mathrm{G}_{0}$ |
| Option $22=0$ | $\mathrm{G}_{1}$ have high current |
| Option $23=0$ | $\mathrm{G}_{2}$ standard output |
| Option $24=0$ | $\mathrm{G}_{3}$ |
| Option $25=0$ | $\mathrm{D}_{3}$ |
| Option $26=0$ | $\mathrm{D}_{2}$ \} have high current |
| Option $27=0$ | $\mathrm{D}_{1}$ standard output |
| Option $28=0$ | $\mathrm{D}_{0}$ |
| Option $29=1$ | L) |
| Option $30=1$ | IN $\}$ have higher voltage |
| Option $31=1$ | G input levels |
| Option $32=0$ | SI has standard input level |
| Option $33=0$ | RESET has Schmitt trigger input |
| Option $34=0$ | CKO has standard input levels |
| Option $35=\mathrm{N} / \mathrm{A}$ | 40-pin package |

Typical Applications (Continued)


FIGURE 8. COP404LSN-5 System Diagram

Section 2 COP800 Family

## Section 2 Contents

COP800C ..... 2-3
COP820C/COP821C/COP822C Single-Chip microCMOS Microcontroller ..... 2-4
COP840C $2 k$ Single-Chip 8-Bit Low Cost Microcontroller ..... 2-20
COP8620C 1k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Data Memory ..... 2-21
COP8640C 2 k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Data Memory ..... 2-22
COP8720C 1k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Program and Data Memory ..... 2-23
COP8740C $2 k$ Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Program and Data Memory ..... 2-24

## COP800C

The COP800 Family of Products combines the powerful COPS Instruction Set philosophy with a memory mapped core architecture to offer the lowest cost $\mathrm{M}^{2} \mathrm{CMOS}$ microcontroller available today.
These chips are complete microcomputers on a single chip. All system timing, internal logic, ROM, RAM, and I/O are provided on the chip to produce a cost effective system solution.
The M2CMOS process results in very low current drain and enables the user to select the optimum speed/power product for his system.
These devices are available in various DIP and SO package configurations.

## Features

- Fully static $\mathrm{M}^{2} \mathrm{CMOS}$
- 2.5 V to 6.0 V operating voltage

■ $1 \mu \mathrm{~s}$ instruction cycle time

- Low current drain
- Ultra low current static halt mode
- Single supply operation

■ MICROWIRE PLUSTM serial I/O

- 20 through 44 pin packages
- Software selectable I/O options
- Fully supported by National's PC biased MoleTM Development System
- E2PROM program space
- E2PROM data space
- Hi-I/O and LCD drive

COP800 Roadmap

| Part \# | ROM | RAM | EEPROM (ROM) | EEPROM <br> (RAM) | Supply Voltage | INTERRUPT | Time Count | $1 / 0$ | Plns | Features |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| COP820C | 1k | $64 \times 8$ |  |  | $2.5 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 24 | 28 | STANDARD PART |
| COP821C | 1k | $64 \times 8$ |  |  | $2.5 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 20 | 24 | STANDARD PART |
| COP822C | 1k | $64 \times 8$ |  |  | $2.5 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 16 | 20 | STANDARD PART |
| COP8620C | 1k | $64 \times 8$ |  | $64 \times 8$ | $2.7 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 24 | 28 | STANDARD PART |
| COP8621C | 1k | $64 \times 8$ |  | $64 \times 8$ | 2.7V-6.0V | YES | YES | 20 | 24 | STANDARD PART |
| COP8622C | 1k | $64 \times 8$ |  | $64 \times 8$ | $2.7 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 16 | 20 | STANDARD PART |
| COP8720C |  | $64 \times 8$ | 1k | $64 \times 8$ | 2.7V-6.0V | YES | YES | 24 | 28 | STANDARD PART |
| COP8721C |  | $64 \times 8$ | 1k | $64 \times 8$ | 2.7V-6.0V | YES | YES | 20 | 24 | STANDARD PART |
| COP8722C |  | $64 \times 8$ | 1k | $64 \times 8$ | $2.7 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 16 | 20 | STANDARD PART |
| COP840C | 2k | $128 \times 8$ |  |  | $2.5 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 24 | 28 | STANDARD PART |
| COP8640C | 2k | $128 \times 8$ |  | $128 \times 8$ | $2.7 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 24 | 28 | STANDARD PART |
| COP8740C |  | $128 \times 8$ | 2k | $128 \times 8$ | 2.7V-6.0V | YES | YES | 24 | 28 | STANDARD PART |
| COP848C | 2k | $128 \times 8$ |  |  | $2.5 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 36/40 | 40/44 | $24 \times 4$ LCD or I/O |
| COP888C | 4k | $128 \times 8$ |  |  | $2.5 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 36/40 | 40/44 | UART <br> $24 \times 4$ LCD or I/O |
| COP8788 |  | $128 \times 8$ | 4k | $128 \times 8$ | $2.7 \mathrm{~V}-6.0 \mathrm{~V}$ | YES | YES | 36/40 | 40/44 | UART <br> $24 \times 4$ LCD or I/O |

The COP800C is the low cost CMOS system solution.

National Semiconductor Corporation

## PRELIMINARY

## COP820C/COP821C/COP822C Single Chip microCMOS Microcontrollers

## General Description

The COP820C is a member of the COPSTM microcontroller family. It is a fully static part, fabricated using double-metal silicon gate microCMOS technology. This low cost microcontroller is a complete microcomputer containing all system timing, interrupt logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include an 8-bit memory mapped architecture, MICROWIRE serial I/O, a 16-bit timer/counter with capture register and a multi-sourced interrupt. Each I/O pin has software selectable options to adapt the COP820C to the specific application. The part operates over a voltage range of 2.5 to 6.0 V . High throughput is achieved with an efficient, regular instruction set operating at a 1 microsecond per instruction rate. The part may be operated in the ROMless mode to provide for accurate emulation and for applications requiring external program memory.

## Features

- Low Cost 8-bit microcontroller
- Fully static CMOS
- $1 \mu \mathrm{~s}$ instruction time ( 20 MHz clock)
- Low current drain ( 3.5 mA at $3 \mu \mathrm{~s}$ instruction rate)

Extra-low current static HALT mode (Typically $<1 \mu \mathrm{~A}$ )

- Single supply operation: 2.5 to 6.0 V
- 1024 bytes on-chip ROM
- Expandable to 32k bytes in ROMless mode
- 64 bytes on-chip RAM
- 16-bit read/write timer operates in a variety of modes
- Timer with 16-bit auto reload register
- 16-bit external event counter
- Timer with 16 -bit capture register (selectable edge)
- Multi-source interrupt
- Reset master clear
- External interrupt with selectable edge
- Timer interrupt or capture interrupt
- Software/"watch-dog" interrupt
- 8-bit stack pointer (stack in RAM)
- Powerful instruction set, most instruction single byte
- BCD arithmetic instructions
- MICROWIRE PLUSTM serial I/O
- 28 pin package (optionally 24 or 20 pin package)
- 24 input/output pins
- Software selectable I/O options (TRI-STATE ${ }^{\oplus}$, pushpull, weak pull-up)
- Schmitt trigger inputs on Port G
- Extended temperature ranges: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ to be available)
- ROMless mode for accurate emulation and external program capability
- Form, fit and function EEPROM emulation device (COP8720C)
■ Fully supported by National's MOLETM development system


## Block Diagram



FIGURE 1

## Absolute Maximum Ratings

Specifications for Milltary/Aerospace products are not contalned in this datasheet. Refer to the assoclated rellability electrical test specificatlons document.
Supply Voltage ( $\mathrm{V}_{\mathrm{Cc}}$ ) $7 V$
Voltage at any Pin
-0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$
ESD Susceptibility (Note 4)
Total Current into $\mathrm{V}_{\mathrm{CC}}$ Pin (Source)
2000V
50 mA

Total Current out of GND Pin (Sink)
60 mA Storage Temperature Range
Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $-40^{\circ} \mathrm{C}<\mathrm{T}_{\mathrm{A}}<+85^{\circ} \mathrm{C}$ unless otherwise specified


Note 1: Rate of voltage change must be less than $0.5 \mathrm{~V} / \mathrm{ms}$.
Note 2: Supply current is measured after running 2000 cycles with a square wave CKI input, CKO open, inputs at rails and outputs open.
Note 3: The HALT mode will stop CKI from oscillating in the RC and the Crystal configurations. Test conditions: All inputs tied to $V_{C C}$, L and G ports TRI-STATED and tied to ground, all outputs low and tied to ground.
Note 4: Human body mode, 100 pF through $1500 \Omega$.

AC Electrical Characteristics $-40^{\circ} \mathrm{C}<\mathrm{T}_{\mathrm{A}}<+85^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Condition | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time (tc) <br> High Speed Mode <br> (Div-by 20) <br> Normal Mode <br> (Div-by 10) <br> R/C Oscillator Mode <br> (Div-by 10) <br> (See Page 16) | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V} \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & \\ & 2.5 \mathrm{~V}<V_{C C}<4.5 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 1 \\ 2.5 \\ 2 \\ 5 \\ 3 \\ \\ 7.5 \end{gathered}$ |  | DC <br> DC <br> DC <br> DC <br> DC <br> DC | $\mu \mathrm{S}$ $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{S}$ $\mu \mathrm{S}$ $\mu \mathrm{s}$ |
| CKI Clock Duty Cycle (Note 5) Rise Time (Note 5) Fall Time (Note 5) | $\begin{aligned} \mathrm{fr} & =\mathrm{Max} \\ \mathrm{fr} & =20 \mathrm{MHz} \text { Ext Clock } \\ \mathrm{fr} & =20 \mathrm{MHz} \text { Ext Clock } \end{aligned}$ | 33 |  | $\begin{gathered} 66 \\ \\ 12 \\ 8 \\ \hline \end{gathered}$ | \% <br> ns ns |
| Inputs tsetup thold $^{\text {then }}$ | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<\mathrm{V}_{C C}<4.5 \mathrm{~V} \\ & \mathrm{~V}_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<\mathrm{V}_{C C}<4.5 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 200 \\ 500 \\ 60 \\ 150 \end{gathered}$ |  |  | ns <br> ns <br> ns <br> ns |
| Output Propagation Delay tpD1, tpD0 SO, SK <br> All Others | $\begin{aligned} & R_{L}=2.2 \mathrm{k}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} \\ & \mathrm{~V}_{\mathrm{CC}} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V} \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V} \end{aligned}$ |  |  | $\begin{gathered} 0.7 \\ 1.75 \\ 1 \\ 2.5 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~S} \\ & \mu \mathrm{~S} \\ & \mu \mathrm{~S} \\ & \hline \end{aligned}$ |
| Input Pulse Width Interrupt Input High Time Interrupt Input Low Time Timer Input High Time Timer Input Low Time |  | $\begin{aligned} & \text { TBD } \\ & \text { TBD } \\ & \text { TBD } \\ & \text { TBD } \end{aligned}$ |  |  | ns |
| Reset Pulse Width |  | TBD |  |  | ns |

Note 5: Parameter sampled but not $\mathbf{1 0 0 \%}$ tested.
AC Electrical Characteristics in ROMless Mode $-40^{\circ} \mathrm{C}<\mathrm{T}_{\mathrm{A}}<85^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Condition | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Instruction Cycle Time (tc) High Speed Mode (Div-by 20) Normal Mode (Div-by 10) R/C Oscillator Mode (See Page 8) | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<V_{C C}<4.5 \mathrm{~V} \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<V_{C C}<4.5 \mathrm{~V} \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<V_{C C}<4.5 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 2 \\ 5 \\ 4 \\ 10 \\ 6 \\ 15 \end{gathered}$ | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| CKI Clock Duty Clock Rise Time Fall Time | $\begin{aligned} \mathrm{fr} & =\mathrm{Max} \\ \mathrm{fr} & =10 \mathrm{MHz} \text { Ext Clock } \\ \mathrm{fr} & =10 \mathrm{MHz} \text { Ext Clock } \end{aligned}$ | 40 | $\begin{aligned} & 24 \\ & 16 \end{aligned}$ | 60 | $\begin{aligned} & \% \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |
| Inputs tsetup $t_{\text {HOLD }}$ | $\begin{aligned} & V_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<V_{C C}<4.5 \mathrm{~V} \\ & V_{C C} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<V_{C C}<4.5 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 400 \\ & 800 \\ & 120 \\ & 300 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \end{aligned}$ |
| Output Propagation Delay tpD1, tpDO SO, SK <br> All Others | $\begin{aligned} & \mathrm{RL}=2.2 \mathrm{k}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} \\ & \mathrm{~V}_{\mathrm{CC}} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}} \geq 4.5 \mathrm{~V} \\ & 2.5 \mathrm{~V}<\mathrm{V}_{\mathrm{CC}}<4.5 \mathrm{~V} \\ & \hline \end{aligned}$ |  | $\begin{gathered} 1.4 \\ 3.5 \\ 2 \\ 5 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Minimum Pulse Width Interrupt Input Timer Input |  |  | $\begin{aligned} & \text { TBD } \\ & \text { TBD } \end{aligned}$ |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| Reset Pulse Width |  |  |  |  | ns |



FIGURE 2．AC Timing Diagrams in ROMless Mode

## Connection Diagrams



Order Number COP822C－XXXN See NS Package Number N20A


TL／DD／9103－4
Order Number COP821C－XXXN
See NS Package Number N24A
Order Number COP821C－XXXN
See NS Package Number N24A


FIGURE 3


COP820C


TL／DD／9103－5
Order Number COP820C－XXXN
See NS Package Number N28B



## Pin Descriptions

$V_{C C}$ and GND are the power supply pins.
CKI is the clock input. This can come from an external source, a R/C generated oscillator or a crystal (in conjunction with CKO). See Oscillator description.
RESET is the master reset input. See Reset description.
PORT I is a four bit $\mathrm{Hi}-\mathrm{Z}$ input port.
PORT L is an 8-bit I/O port.
There are two registers associated with each L I/O port: a data register and a configuration register. Therefore, each L I/O bit can be individually configured under software control as shown below:

| Port L <br> Config. | Port L <br> Data | Port L <br> Setup |
| :---: | :---: | :--- |
| 0 | 0 | Hi-Z Input (TRI-STATE) |
| 0 | 1 | Input With Weak Pull-Up |
| 1 | 0 | Push-Pull "0" Output |
| 1 | 1 | Push-Pull "1" Output |

Three data memory address locations are allocated for these ports, one for data register, one for configuration register and one for the input pins.
PORT G is an 8-bit port with 6 I/O pins (G0-G5) and 2 input pins (G6, G7). All eight G-pins have Schmitt Triggers on the inputs. The G7 pin functions as an input pin under normal operation and as the continue pin to exit the HALT mode. There are two registers with each I/O port: a data register and a configuration register. Therefore, each I/O bit can be individually configured under software control as shown before.

| Port G <br> Config. | Port G <br> Data | Port G <br> Setup |
| :---: | :---: | :--- |
| 0 | 0 | Hi-Z Input (TRI-STATE) |
| 0 | 1 | Input With Weak Pull-Up |
| 1 | 0 | Push-Pull "0" Output |
| 1 | 1 | Push-Pull "1" Output |

Three data memory address locations are allocated for these ports, one for data register, one for configuration register and one for the input pins. Since G6 and G7 are input only pins, any attempt by the user to set them up as outputs by writing a one to the configuration register will be disregarded. Reading the G6 and G7 configuration bits will return zeros. Note that the chip will be placed in the HALT mode by setting the G7 data bit.
Six bits of Port $G$ have alternate features:
GO INTR (an external interrupt)
G3 TIO (timer/counter input/output)
G4 SO (MICROWIRE serial data output)
G5 SK (MICROWIRE clock I/O)
G6 SI (MICROWIRE serial data input)
G7 CKO crystal oscillator output (selected by mask option) or HALT restart input (general purpose input)
Pins G1 and G2 currently do not have any alternate functions.
PORT $D$ is a four bit output port that is set high when $\overline{R E}$ $\overline{\text { SET }}$ goes low. The user can Wire-OR the D-ports in order to get a higher drive.
The D2 pin is sampled at reset. If it is held low at reset the COP820C enters the ROMless mode of operation.

## Functional Description

Figure 1 shows the block diagram of the internal architecture. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other in implementing the instruction set of the device.

## ALU AND CPU REGISTERS

The ALU can do an 8-bit addition, subtraction, logical or shift operation in one cycle time.
There are five CPU registers:
A is the 15-bit Program Counter register
PU is the upper 7 bits of the program counter (PC)
PL is the lower 8 bits of the program counter (PC)
$B$ is the 8 -bit address register, can be auto incremented or decremented.
X is the 8-bit alternate address register, can be incremented or decremented.
SP is the 8-bit stack pointer, points to subroutine stack (in RAM).
$\mathrm{B}, \mathrm{X}$ and SP registers are mapped into the on chip RAM. The $B$ and $X$ registers are used to address the on chip RAM. The SP register is used to address the program counter stack in RAM during subroutine calls and returns.

## PROGRAM MEMORY

Program memory for the COP820C consists of 1024 bytes of ROM. These bytes may hold program instructions or constant data. The program memory is addressed by the 15-bit program counter (PC). ROM can be indirectly read by the LAID instruction for table lookup.

## DATA MEMORY

The data memory address space includes on chip RAM, I/O and registers. Data memory is addressed directly by the instruction or indirectly by the $\mathrm{B}, \mathrm{X}$ and SP registers.
The COP820C has 64 bytes of RAM. Sixteen bytes of RAM are mapped as "registers" that can be loaded immediately, decremented or tested. Three specific registers: B, X and SP are mapped into this space, the other bytes are available for general usage.
The instruction set of the COP820C permits any bit in memory to be set, reset or tested. All I/O and registers on the COP820C (except the A \& PC) are memory mapped; therefore, I/O bits and register bits can be directly and individually set, reset and tested.

## RESET

The RESET input when pulled low initializes the microcontroller. Initialization will occur whenever the RESET input is pulled low. Upon initialization, the ports $L$ and $G$ are placed in the TRI-STATE mode and the Port $D$ is set high. The PC, PSW and CNTRL registers are cleared. The data and configuration registers for Ports L \& G are cleared.
The external RC network shown in Figure 4 should be used to ensure that the RESET pin is held low until the power supply to the chip stabilizes. It is recommended that the components of the RC network be selected to provide a RESET delay of at least five times the power supply rise time or the minimum RESET pulse width, whichever is greater.

## Functional Description (Continued)



TL/DD/9103-9
FIGURE 4. Recommended Reset Circuit

## OSCILLATOR CIRCUITS

Figure 5 shows the three clock oscillator configurations available for the COP820C.

## A. CRYSTAL OSCILLATOR

The COP820C can be driven by a crystal clock. The crystal network is connected between the pins CKI and CKO.
Table I shows the component values required for various standard crystal values.

## B. EXTERNAL OSCILLATOR

CKI can be driven by an external clock signal. CKO is available as a general purpose input and/or HALT restart control.

## C. R/C OSCILLATOR

CKI is configured as a single pin RC controlled Schmitt trigger oscillator. CKO is available as a general purpose input and/or HALT restart control.

Table Il shows the variation in the oscillator frequencies as functions of the component ( R and C ) values.


TL/DD/9103-10
FIGURE 5. Crystal and R-C Connection Diagrams MASK OPTIONS

The COP820C can be driven by clock inputs between DC and 20 MHz . For low input clock frequencies ( $<5 \mathrm{MHz}$ ) the instruction cycle frequency can be selected to be the input clock frequency divided by 10 . This mode is known as the Normal Mode.
For oscillator frequencies that are greater than 5 MHz the chip must run with a divide by 20 . This is known as the High Speed mode.

TABLE I. Crystal Oscillator Configuration, $\mathrm{T}_{\mathbf{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$

| $\begin{gathered} R 1 \\ (k \Omega) \end{gathered}$ | $\begin{gathered} \text { R2 } \\ (k \Omega) \end{gathered}$ | $\begin{gathered} \mathrm{C1} \\ (\mathrm{pF}) \end{gathered}$ | $\begin{gathered} \mathrm{C} 2 \\ (\mathrm{pF}) \end{gathered}$ | CKI Freq (MHz) | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TBD | TBD | TBD | TBD | 20 | $V_{C C}=5 \mathrm{~V}$ |
| TBD | TBD | TBD | TBD | 10 | $V_{C C}=5 \mathrm{~V}$ |
| TBD | TBD | TBD | TBD | 4 | $V_{C C}=3 V$ |
| TBD | TBD | TBD | TBD | 0.455 | $V_{C C}=3 V$ |

TABLE II. RC Oscillator Configuration, $\mathrm{T}_{\mathrm{A}}=\mathbf{2 5 ^ { \circ }} \mathbf{C}$

| $\mathbf{R}$ <br> $\mathbf{( k \Omega})$ | $\mathbf{C}$ <br> $(\mathbf{p F})$ | CKI Freq. <br> $(\mathbf{M H z})$ | Instr. Cycle <br> $(\mu \mathbf{s})$ | Conditions |
| :---: | :---: | :---: | :---: | :---: |
| TBD | 82 | 3.3 to 1.1 | 3 to 9 | 10 to 20 |
| TBD | 100 | 1 to 0.5 | $V_{C C}=5 \mathrm{~V}$ |  |
| TBD | 100 | 1.33 to 0.57 | 7.5 to 17.5 | $V_{C C}=5 \mathrm{~V}$ |

## Functional Description (Continued)

The COP820C microcontroller provides five mask options for configuring the clock input. The CKI and CKO pins are automatically configured upon selecting a particular option.

- High Speed Crystal (CKI/20) CKO for crystal configuration
- Normal Mode Crystal (CKI/10) CKO for crystal configuration
- High Speed External (CKI/20) CKO available as G7 input
- Normal Mode External (CKI/10) CKO available as G7 input
- R/C
(CKI/10) CKO available as G7 input
Where, G7 can be used either as a general purpose input or as a control input to continue from the HALT mode.


## CURRENT DRAIN

The total current drain of the chip depends on:

1) Oscillator operating mode-11
2) Internal switching current-12
3) Internal leakage current-13
4) Output source current-14
5) DC current caused by external input not at $V_{C C}$ or GND15
Thus the total current drain, It is given as

$$
\mathrm{It}=\mathrm{I} 1+\mathrm{I} 2+13+14+15
$$

To reduce the total current drain, each of the above components must be minimum.
The chip will draw the least current when in the normal mode. The high speed mode will draw additional current. The R/C mode will draw the most. Operating with a crystal network will draw more current than an external squarewave. Switching current, governed by the equation below, can be reduced by lowering voltage and frequency. Leakage current can be reduced by lowering voltage and temperature. The other two items can be reduced by carefully designing the end-user's system.
$\mathrm{I} 2=\mathrm{C} \times \mathrm{V} \times \mathrm{f}$
Where
$C=$ equivalent capacitance of the chip. (TBD)
$\mathrm{V}=$ operating voltage
$f=$ CKI frequency
The typical capacitance for the COP820C is TBD pF.
Some sample current drain values at $\mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V}$ are:

| CKI (MHz) | Inst. Cycle $(\mu \mathbf{S})$ | It (mA) |
| :---: | :---: | :---: |
| 20 | 1 | 15 |
| 3.58 | 3 | 3.6 |
| 2 | 5 | 2 |
| 0.3 | 3 | 0.3 |
| 0 (HALT) | - | $<0.0001$ |

## HALT MODE

The COP820C supports a power saving mode of operation: HALT. The COP820C is placed in the HALT mode by setting the G7 data bit, alternatively the user can stop the clock input. In the HALT mode all internal processor activities including the clock oscillator are stopped. The fully static ar-
chitecture of the COP820C freezes the state of the controller and retains all information until continuing. In the HALT mode, the COP820C power requirements are minimal as it draws only leakage currents and output current. The applied voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) may be decreased down to Vr (minimum RAM retention voltage) without altering the state of the machine. There are two ways to exit the HALT mode: via the RESET or by the CKO pin. A low on the RESET line reinitializes the microcontroller and start executing from the address 0000 H . A low to high transition on the CKO pin causes the microcontroller to continue with no reinitialization from the address following the HALT instruction.

## INTERRUPTS

The COP820C provides a sophisticated interrupt structure to allow easy interface to the real word. There are three possible interrupt sources, as shown below.
A maskable interrupt on external G0 input (positive or negative edge sensitive under software control)
A maskable interrupt on timer carry or timer capture
A non-maskable software/error interrupt on opcode zero

## INTERRUPT CONTROL

The GIE (global interrupt enable) bit enables the interrupt function. This is used in conjunction with ENI and ENTI to select one or both of the interrupt sources. This bit is reset when interrupt is acknowledged.
ENI and ENTI bits select external and timer interrupt respectively. Thus the user can select either or both sources to interrupt the microcontroller when GIE is enabled.
IEDG selects the external interrupt edge ( $0=$ rising edge, 1
$=$ falling edge). The user can get an interrupt on both rising and falling edges by toggling the state of IEDG bit after each interrupt.
IPND and TPND bits signal which interrupt is pending. After interrupt is acknowledged, the user can check these two bits to determine which interrupt is pending. This permits the interrupts to be prioritized under software. The pending flags have to be cleared by the user. Setting the GIE bit high inside the interrupt subroutine allows nested interrupts.
The software interrupt does not reset the GIE bit. This means that the COP820C can be interrupted by other interrupt sources while servicing the software interrupt.

## INTERRUPT PROCESSING

The interrupt, once acknowledged, pushes the program counter (PC) onto the stack and the stack pointer (SP) is decremented twice. The Global Interrupt Enable (GIE) bit is reset to disable further interrupts. The microcontroller then vectors to the address 00FFH and continues from that address. At the end of the interrupt subroutine, any of the following three instructions return the processor back to the main program: RET, RETSK or RETI. Either one of the three instructions will pop the stack into the program counter (PC). The stack pointer is then incremented twice. The RETI instruction additionally sets the GIE bit to re-enable further interrupts.
Either of the three instructions can be used to return from a hardware interrupt subroutine. The RETSK instruction should be used when returning from a software interrupt subroutine to avoid entering an infinite loop.

Functional Description (Continued)


TL/DD/9103-11
FIGURE 6. Interrupt Block Diagram

## DETECTION OF ILLEGAL CONDITIONS

The COP820C incorporates a hardware mechanism that allows it to detect illegal conditions which may occur from coding errors, noise and 'brown out' voltage drop situations. Specifically it detects cases of executing out of undefined ROM area and unbalanced stack situations.
Reading an undefined ROM location returns 00 (hexadecimal) as its contents. The opcode for a software interrupt is also '00'. Thus a program accessing undefined ROM will cause a software interrupt.
Reading an undefined RAM location returns a FF (hexadecimal). The subroutine stack on the COP820C grows down for each subroutine call. By initializing the stack pointer to 02FH the first unbalanced return instruction will cause the stack pointer to address undefined RAM. As a result the program will attempt to execute from FFFF (hexadecimal), which is an undefined ROM location and will trigger a software interrupt.

## MICROWIRE/PLUSTM

MICROWIRE/PLUS is a serial synchronous communications interface. The MICROWIRE/PLUS capability enables the COP820C to interface with any of National Semiconductor's Microwire peripherals (i.e. A/D converters, display drivers, EEPROMS, etc.) and with other microcontrollers which support the Microwire interface. It consists of an 8 -bit serial shift register (SIO) with serial data input (SI), serial data output (SO) and serial shift clock (SK). Figure 7 shows the block diagram of the MICROWIRE/PLUS interface.
The shift clock can be selected from either an internal source or an external source. Operating the Microwire arrangement with the internal clock source is called the Master mode of operation. Similarly, operating the Microwire arrangement with an external shift clock is called the Slave mode of operation.
The CNTRL register is used to configure and control the MICROWIRE mode. To use the MICROWIRE, the MSEL bit in the CNTRL register is set to one. The SK clock rate is selected by the two bits, S0 and S1, in the CNTRL register. Table III details the different clock rates that may be selected.

TABLE III

| S1 | S0 | SK Rate |
| :---: | :---: | :---: |
| 0 | 0 | $2 x t_{C}$ |
| 0 | 1 | $4 x \mathrm{c}_{\mathrm{C}}$ |
| 1 | x | $8 \times \mathrm{c}_{\mathrm{C}}$ |

where,
$\mathrm{t}_{\mathrm{C}}$ is the instruction cycle clock.

## MICROWIRE PLUS OPERATION

Setting the BUSY bit in the PSW register causes the Microwire arrangement to start shifting the data. It gets reset when eight data bits have been shifted. The user may reset the BUSY bit by software to allow less than 8 bits to shift. The COP820C may enter the MICROWIRE PLUS mode either as a Master or as a Slave. Figure 8 shows how two COP820C microcontrollers and several peripherals may be interconnected using the MICROWIRE/PLUS arrangement.

## Master MICROWIRE PLUS Operation

In the MICROWIRE PLUS Master mode of operation the shift clock (SK) is generated internally by the COP820C. The Microwire Master always initiates all data exchanges. (See Figure 8). The MSEL bit in the CNTRL register must be set to enable the SO and SK functions onto the G Port. The SO and SK pins must also be selected as outputs by setting appropriate bits in the Port G configuration register. Table IV summaries the bit settings required for Master mode of operation.

## SLAVE MICROWIRE PLUS OPERATION

In the Microwire Plus Slave mode of operation the SK clock is generated by an external source. Setting the MSEL bit in the CNTRL register enables the SO and SK functions onto the G Port. The SK pin must be selected as an input and the SO pin is selected as an output pin by setting and resetting the appropriate bit in the Port $G$ configuration register. Table IV summarizes the settings required to enter the Slave mode of operation.
The user must set the BUSY flag immediately upon entering the Slave mode. This will ensure that all data bits sent by the Master will be shifted properly. After eight clock pulses the BUSY flag will be cleared and the sequence may be repeated. (See Figure 8.)

Functional Description (Continued)
TABLE IV

| G4 <br> Config. <br> Bit | G5 <br> Config. <br> Bit | G4 <br> Fun. | G5 <br> Fun. | G6 <br> Fun. | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | S0 | Int. SK | SI | MICROWIRE Master |
| 0 | 1 | TRI-STATE | Int. SK | SI | MICROWIRE Master |
| 1 | 0 | S0 | Ext. SK | SI | MICROWIRE Slave |
| 0 | 0 | TRI-STATE | Ext. SK | SI | MICROWIRE Slave |

## TIMER/COUNTER

The COP820C has a powerful 16 -bit timer with an associated 16 -bit register enabling it to perform extensive timer functions. The timer T1 and its register R1 are each organized as two 8 -bit read/write registers. Control bits in the register CNTRL allow the timer to be started and stopped under software control. The timer-register pair can be operated in one of three possible modes.


TL/DD/9103-12
FIGURE 7. MICROWIRE Block Diagram


FIGURE 8. Microwire Application

Functional Description（Continued）
TABLE V．Timer Operating Modes

| CNTRL <br> BIts <br> 765 | Operation Mode | Timer <br> Counts <br> On |  |
| :---: | :--- | :--- | :--- |
| 000 | External Counter W／Auto－Load Reg． | TInterrupt | Timer Carry |
| 001 | External Counter W／Auto－Load Reg． | Timer Carry | TIO Pos．Edge |
| 010 | Not Allowed | Not Allowed | TIONeg．Edge |
| 011 | Not Allowed | Not Allowed | Not Allowed |
| 100 | Timer W／Auto－Load Reg． | Timer Carry | tc |
| 101 | Timer W／Auto－Load Reg．／Toggle TIO Out | Timer Carry | tc |
| 110 | Timer W／Capture Register | TIO Pos．Edge | tc |
| 111 | Timer W／Capture Register | TIO Neg．Edge | tc |



FIGURE 9．Timer／Counter Auto Reload Mode Block Dlagram


TL／DD／9103－14

## TIMER PWM APPLICATION

Figure 11 shows how a minimal component D／A converter can be built out of the Timer－Register pair in the Auto－Re－ load mode．The timer is placed in the＂Timer with auto re－ load＂mode and the TIO pin is selected as the timer output． At the outset the TIO pin is set high，the timer T1 holds the on time and the register R1 holds the signal off time．Setting TRUN bit starts the timer which counts down at the instruc－ tion cycle rate．The underflow toggles the TIO output and copies the off time into the timer，which continues to run．By alternately loading in the on time and the off time at each successive interrupt a PWM frequency can be easily gener－ ated．


TL／DD／9103－16
FIGURE 11．Timer Application

## Control Registers

## CNTRL REGISTER (ADDRESS X'OOEE)

The Timer and MICROWIRE control register contains the following bits:
St \& SO Select the MICROWIRE clock divide-by
IEDG External interrupt edge polarity select
( $0=$ rising edge, $1=$ falling edge)
MSEL Enable MICROWIRE functions SO and SK
TRUN Start/Stop the Timer/Counter (1 = run, $0=$ stop)
TEDG Timer input edge polarity select ( $0=$ rising edge, 1 = falling edge)
CSEL Selects the capture mode
TSEL Selects the timer mode

| TSEL | CSEL | TEDG | TRUN | MSEL | IEDG | S1 | S0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BIT 7 |  |  |  |  |  |  | BIT 0 |

PSW REGISTER (ADDRESS $\times$ '00EF)
The PSW register contains the following select bits:
GIE Global interrupt enable
ENI External interrupt enable
BUSY MICROWIRE busy shifting
IPND External interrupt pending
ENTI Timer interrupt enable
TPND Timer interrupt pending
C Carry Flag
HC Half carry Flag


Bit 7
Bit 0

## Operating Modes

The COP820C offers the user two operating modes: Single Chip mode and the ROMless mode. The operating mode is determined by the state of the D2 pin at power on reset.

## SINGLE CHIP MODE

In the Single Chip mode, the COP820C functions as a self contained microcontroller. It can address internal memory consisting of 64 bytes of RAM and 1024 bytes of ROM. All ports configured as memory mapped I/O ports.

## ROMLESS MODE

The COP820C enters the ROMless mode of operation if the D2 pin is held at logical " 0 " at reset. In this case the internal ROM is disabled and the COP820C can now address up to 32 kbytes of external program memory. It continues to use the on board 64 bytes of RAM. The ports D and I are used to access the external program memory. By providing a serial interface to external program memory the COP820C manages a large address space without the penalty of losing a large number of I/O pins in the process. Figure 12 shows in schematic form the logic required for the ROMless mode operation and all support logic required to recreate the I/O.

## Memory Map

All RAM, ports and registers (except A and PC) are mapped into data memory address space.

| Address | Contents |
| :---: | :--- |
| 00 to 2F | On Chip RAM Bytes |
| 30 to 7F | Unused RAM Address Space (Reads as all Ones) |
| 80 to BF | Expansion Space for on Chip EERAM |
| C0 to CF | Expansion Space for I/O and Registers |
| D0 to DF | On Chip I/O and Registers |
| D0 | Port L Data Register |
| D1 | Port L Configuration Register |
| D2 | Port L Input Pins (Read Only) |
| D3 | Reserved for Port L |
| D4 | Port G Data Register |
| D5 | Port G Configuration Register |
| D6 | Port G Input Pins (Read Only) |
| D7 | Port I Input Pins (Read Only) |
| D8-DB | Reserved for Port C |
| DC-DF | Port D |
| E0 to EF | On Chip Functions and Registers |
| E0-E7 | Reserved for Future Parts |
| E8 | Reserved |
| E9 | MICROWIRE Shift Register |
| EA | Timer Lower Byte |
| EB | Timer Upper Byte |
| EC | Timer Autoload Register Lower Byte |
| ED | Timer Autoload Register Upper Byte |
| EE | CNTRL Control Register |
| EF | PSW Register |
| F0 to FF | On Chip RAM Mapped as Registers |
| FC | X Register |
| FD | SP Register |
| FE | B Register |

Reading memory locations $30 \mathrm{H}-7 \mathrm{FH}$ will return all ones. Reading other unused memory locations will return undefined data.

## Addressing Modes

## REGISTER INDIRECT

This is the "normal" mode of addressing for COP820C. The operand is the memory addressed by the B register or X register.

## DIRECT

The instruction contains an 8-bit address field that directly points to the data memory for the operand.

## IMMEDIATE

The instruction contains an 8 -bit immediate field as the operand.

## REGISTER INDIRECT (AUTO INCREMENT AND DECREMENT)

This is a register indirect mode that automatically increments or decrements the B or X register after executing the instruction.


## Addressing Modes (Continued)

## RELATIVE

This mode is used for the JP instruction, the instruction field is added to the program counter to get the new program location. JP has a range of from -31 to +32 to allow a one byte relative jump (JP +1 is implemented by a NOP instruction). There are no 'pages' when using JP, all 15 bits of PC are used.

## Instruction Set

REGISTER AND SYMBOL DEFINITIONS
Registers

| A | 8-bit Accumulator register |
| :--- | :--- |
| B | 8-bit Address register |
| X | 8-bit Address register |
| SP | 8-bit Stack pointer register |

PC 15-bit Program counter register
PU upper 7 bits of PC
PL lower 8 bits of PC
C 1-bit of PSW register for carry
HC Half Carry
GIE 1-bit of PSW register for global interrupt enable

## Symbols

[B] Memory indirectly addressed by B register
[X] Memory indirectly addressed by X register
Mem Direct address memory or [B]
Meml Direct address memory or $[B]$ or Immediate data
Imm 8-bit Immediate data
Reg Register memory: addresses F0 to FF (Includes B, X and SP)
Bit Bit number (0 to 7)
$\leftarrow \quad$ Loaded with
$\longleftrightarrow$ Exchanged with

Instruction Set

| ADD <br> ADC <br> SUBC <br> AND <br> OR <br> XOR <br> IFEQ <br> IFGT <br> IFBNE <br> DRSZ <br> SBIT <br> RBIT <br> IFBIT | add <br> add with carry <br> subtract with carry <br> Logical AND <br> Logical OR <br> Logical Exclusive-OR <br> IF equal <br> IF greater than <br> IF $B$ not equal <br> Decrement Reg. ,skip if zero <br> Set bit <br> Reset bit <br> If bit | $A \leftarrow A+M e m l$ <br> A $\leftarrow+$ Meml $+\mathrm{C}, \mathrm{C} \leftarrow$ Carry <br> HC $\leftarrow$ Half Carry <br> $A \leftarrow A+\overline{M e m I}+C, C \leftarrow$ Carry <br> HC $\leftarrow$ Half Carry <br> $A \leftarrow A$ and Meml <br> $A \leftarrow A$ or Meml <br> $A \leftarrow A$ xor Meml <br> Compare $A$ and Meml, Do next if $A=$ Meml <br> Compare A and Meml, Do next if A > Meml <br> Do next if lower 4 bits of $\mathrm{B} \neq \mathrm{imm}$ <br> Reg $\leftarrow \operatorname{Reg}-1$, skip if Reg goes to 0 <br> 1 to bit, <br> Mem (bit $=0$ to 7 immediate) <br> 0 to bit, <br> Mem <br> If bit, <br> Mem is true, do next instr. |
| :---: | :---: | :---: |
| X <br> LD A <br> LD mem <br> LD Reg | Exchange A with memory <br> Load A with memory <br> Load Direct memory Immed. <br> Load Register memory Immed. | $A \longleftrightarrow$ Mem <br> $A \leftarrow M e m l$ <br> Mem $\leftarrow \mathrm{Imm}$ <br> Reg $\leftarrow \mathrm{Imm}$ |
| x <br> X <br> LD A <br> LDA <br> LD M | Exchange $A$ with memory [B] Exchange A with memory [X] Load A with memory [B] Load A with memory [ X ] Load Memory Immediate | $A \longleftrightarrow[B] \quad(B \leftarrow B \pm 1)$ $A \leftarrow[X] \quad(X \leftarrow X \pm 1)$ $A \leftarrow[B] \quad(B \leftarrow B \pm 1)$ $A \leftarrow[X] \quad(X \leftarrow X \pm 1)$ $[B] \leftarrow \operatorname{lmm}(B \leftarrow B \pm 1)$ |
| CLRA <br> INCA <br> DECA <br> LAID <br> DCORA <br> RRCA <br> SWAPA <br> SC <br> RC <br> IFC <br> IFNC | Clear A <br> Increment A <br> Decrement A <br> Load A indirect from ROM <br> DECIMAL CORRECT A <br> ROTATE A RIGHT THRU C <br> Swap nibbles of $A$ <br> Set C <br> Reset C <br> If C <br> If not $C$ | $A \leftarrow 0$ <br> $A \leftarrow A+1$ <br> $A \leftarrow A-1$ <br> $A \leftarrow \operatorname{ROM}(P U, A)$ <br> $A \leftarrow B C D$ correction (follows ADC, SUBC) <br> $\mathrm{C} \rightarrow \mathrm{A} 7 \rightarrow \ldots \rightarrow \mathrm{AO} \rightarrow \mathrm{C}$ <br> $A 7 \ldots A 4 \longleftrightarrow A 3 \ldots A O$ <br> $C \leftarrow 1, H C \leftarrow 1$ <br> $C \leftarrow 0, H C \leftarrow 0$ <br> If C is true, do next instruction <br> If C is not true, do next instruction |
| JMPL <br> JMP <br> JP <br> JSRL <br> JSR <br> JID <br> RET <br> RETSK <br> RETI <br> INTR <br> NOP | Jump absolute long <br> Jump absolute <br> Jump relative short <br> Jump subroutine long <br> Jump subroutine <br> Jump indirect <br> Return from subroutine <br> Return and Skip <br> Return from Interrupt <br> Generate an interrupt <br> No operation |  |



## Instruction Execution Time

Most instructions are single byte (with immediate addressing mode instruction taking two bytes).
Most single instructions take one cycle time ( $1 \mu \mathrm{~s}$ at 20 MHz ) to execute.
See the BYTES and CYCLES per INSTRUCTION table for details.

## BYTES and CYCLES per INSTRUCTION

The following table shows the number of bytes and cycles for each instruction in the format of byte/cycle (a cycle is $1 \mu \mathrm{~s}$ at 20 MHz ).

|  | [B] | Direct | Immed. |
| :--- | :---: | :---: | :---: |
| ADD | $1 / 1$ | $3 / 4$ | $2 / 2$ |
| ADC | $1 / 1$ | $3 / 4$ | $2 / 2$ |
| SUBC | $1 / 1$ | $3 / 4$ | $2 / 2$ |
| AND | $1 / 1$ | $3 / 4$ | $2 / 2$ |
| OR | $1 / 1$ | $3 / 4$ | $2 / 2$ |
| XOR | $1 / 1$ | $3 / 4$ | $2 / 2$ |
| IFEQ | $1 / 1$ | $3 / 4$ | $2 / 2$ |
| IFGT | $1 / 1$ | $3 / 4$ | $2 / 2$ |
| IFBNE | $1 / 1$ |  |  |
| DRSZ |  | $1 / 3$ |  |
| SBIT | $1 / 1$ | $3 / 4$ |  |
| RBIT | $1 / 1$ | $3 / 4$ |  |
| IFBIT | $1 / 1$ | $3 / 4$ |  |


|  | Memory Transfer Instructions |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Register Indirect [B] [X] | Direct | Immed. | $\begin{array}{r} \text { Regis } \\ \text { Auto l } \\ {[\mathrm{B}+, \mathrm{B}} \end{array}$ | direct <br> \& Decr $x+, x-1$ |
| X A,* | 1/1 1/3 | 2/3 |  | 1/2 | 1/3 |
| LD A,* | $1 / 11 / 3$ | $2 / 3$ | 2/2 | 1/2 | 1/3 |
| LD B,Imm |  |  | 1/1 |  |  |
| LD B,Imm |  |  | 2/3 |  |  |
| LD Mem, Imm | $2 / 2$ | 3/3 |  | $2 / 2$ |  |
| LD Reg, Imm |  |  | 2/3 |  |  |

* = > Memory location addressed by B or X or directly.

| Instructions Using A \& C |  | Transfer of Control Instructions |  |
| :--- | :---: | :---: | :---: |
| CLRA $1 / 1$ JMPL $3 / 4$ <br> INCA $1 / 1$ JMP $2 / 3$ <br> DECA $1 / 1$ JP $1 / 3$ <br> LAID $1 / 3$ JSRL $3 / 5$ <br> DCORA $1 / 1$ JSR $2 / 5$ <br> RRCA $1 / 1$ JID $1 / 3$ <br> SWAPA $1 / 1$ RET $1 / 5$ <br> SC $1 / 1$ RETSK $1 / 5$ <br> RC $1 / 1$ RETI $1 / 5$ <br> IFC $1 / 1$ INTR $1 / 7$ <br> IFNC $1 / 1$ NOP $1 / 1$ |  |  |  |

The following table shows the instructions assigned to unused opcodes.

| Unused <br> Opcode | Instruction | Unused <br> Opcode | Instruction |
| :---: | :---: | :---: | :---: |
| 60 | NOP | A9 | NOP |
| 61 | NOP | AF | LD A, [B] |
| 62 | NOP | B1 | NOP |
| 63 | NOP | B4 | NOP |
| 67 | NOP | B5 | NOP |
| 8C | RET | B7 | XA, [X] |
| 99 | NOP | B9 | NOP |
| $9 F$ | LD [B], \#i | BF | LD A, [X] |
| A7 | XA, [B] |  |  |
| A8 | NOP |  |  |

## Development Support

The MOLE (Microcomputer On Line Emulator) is a low cost development system and emulator for all microcontroller products. These include COPs, TMP, 8050U and the HPC family of products. The MOLE consists of a BRAIN Board, Personality Board and optional host software.
The purpose of the MOLE is to provide the user with a tool to write and assemble code, emulate code for the target microcontroller and assist in both software and hardware debugging of the system.
It is a self contained computer with its own firmware which provides for all system operation, emulation control, communication, PROM programming and diagnostic operations. It contains three serial ports to optionally connect to a terminal, a host system, a printer or a modem, or to connect to other MOLEs in a multi-MOLE environment.
MOLE can be used in either a stand alone mode or in conjunction with a selected host system ie those using CP/M or PC-DOS communicating via a RS-232 port.

Dial-A-Helper is a service provided by the MOLE applications group. If a user is having difficulty in getting a MOLE to operate in a particular mode or it is acting peculiar, he can contact the Microcontroller Group, NSC via his system and a modem. He can leave messages on the Dial-A-Helper Bulletin Board System.
The Dial-A-Helper also maintains an accurate and up to date software library that the user can access freely. Software subroutines, math packages and assemblers are examples of the variety offered over the Dial-A-Helper.

## Single Chip Emulator Device

The COP820C is fully supported by a form, fit and function emulator device, the COP8720C.

## Option List

The COP820C/COP821C/COP822C mask programmable options are listed out below. The options are programmed at the same time as the ROM pattern to provide the user with hardware flexibility to use a variety of osciliator configuration.
OPTION 1: CKI INPUT
$=1$ Normal Mode Crystal (CKI/10) CKO for crystal configuration
$=2$ Normal Mode External (CKI/10) CKO available as G7 input
$=3$ R/C $\quad($ CKI/10) CKO available as G7 input
$=4$ High Speed Crystal
(CKI/20) CKO for crystal configuration
$=5$ High Speed External (CKI/20) CKO available as G7 input

## OPTION 2: COP820C BONDING

$=128$ pin package
$=224$ pin package
$=320$ pin package

## COP840C 2k Single-Chip 8-Bit Low Cost Microcontroller

## General Description

The COP840C is a member of the COPSTM microcontroller family. It is a fully static part, fabricated using double-metal silicon gate microCMOS technology. This low cost microcontroller is a complete microcomputer containing all system timing, interrupt logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a variety of applications. Features include an 8 -bit memory mapped architecture, MICROWIRETM serial I/O, a 16-bit timer/counter, and a multi-sourced interrupt. Each I/O pin has software selectable options to adapt the COP840 to the specific application. The part operates over a voltage range of 2.5 V to 6.0 V . High throughput is achieved with an efficient, regular instruction set operating at a $1 \mu \mathrm{~s}$ per instruction rate. The part may be operated in the ROMless mode to provide for accurate emulation and for applications requiring external program memory.

## Features

- Low cost 8 -bit microController
- Fully static CMOS
- $1 \mu \mathrm{~s}$ instruction time ( 20 MHz clock)
- Low current drain ( 2 mA at $4 \mu \mathrm{~s}$ instruction rate)
- Extra-low current static HALT mode ( $5 \mu \mathrm{~A}$ )

■ Single supply operation: 2.5 V to 6.0 V

- $2048 \times 8$ ROM, $128 \times 8$ RAM

■ 16-bit read/write timer operates in a variety of modes - Timer with 16 -bit auto reload register

- 16-bit external event counter
- Timer with 16-bit capture register (selectable edge)
- Multi-source vectored interrupt
- Reset master clear
- External interrupt with selectable edge
- Timer interrupt or capture interrupt
- Software/"wătch-dog" interrupt
- Idle timer with interrupt
- Power saving IDLE and HALT modes
- On chip comparator
- 8-bit stack pointer (stack in RAM)
- Powerful instruction set, most instructions single byte
- MICROWIRE/PLUSTM serial I/O
- 28 pin package
- 24 input/output pins

■ Software selectable I/O options (TRI-STATE ${ }^{@}$, pushpull, weak pull-up)

- I/O ports and function compatible with the COP400 family
■ Extended temperature ranges: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ to be available)
- ROMless mode to get accurate emulation and external program capability
- Fully supported by National's MOLETM development system


## Block Diagram



TL/DD/9106-1

National
Semiconductor Corporation

## COP8620C 1k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Data Memory

## General Description

The COP8620C is a member of the COPSTM microcontroller family. It is a fully static part, fabricated using double-metal silicon gate microCMOS technology. This low cost microcontroller is a complete microcomputer containing all system timing, interrupt logic, ROM, RAM, EEPROM and I/O necessary to implement dedicated control functions in a variety of applications. Features include an 8-bit memory mapped architecture, MICROWIRETM serial I/O, a 16 -bit timer/counter, and a multi-sourced interrupt. Each 1/O pin has software selectable options to adapt the COP8620 to the specific application. The part operates over a voltage range of 2.7 V to 6.0 V . High throughput is achieved with an efficient, regular instruction set operating at a $1 \mu \mathrm{~s}$ per instruction rate. The part may be operated in the ROMless mode to provide for accurate emulation and for applications requiring external program memory.

## Features

- Low cost 8-bit microController
- Fully static CMOS
- $1 \mu \mathrm{~s}$ instruction time ( 20 MHz clock)

■ Low current drain ( 2 mA at $4 \mu \mathrm{~s}$ instruction rate)

- Extra-low current static HALT mode ( $5 \mu \mathrm{~A}$ )

■ Single supply operation: 2.7 V to 6.0 V

- $1024 \times 8$ ROM, $64 \times 8$ RAM, $64 \times 8$ EEPROM
- 16-bit read/write timer operates in a variety of modes
- Timer with 16 -bit auto reload register
- 16-bit external event counter
- Timer with 16-bit capture register (selectable edge)
- Multi-source interrupt
- Reset master clear
- External interrupt $\$$ ith selectable edge
- Timer interrupt or capture interrupt
- Software/"watch-dog" interrupt
- 8-bit stack pointer (stack in RAM)
- Powerful instruction set, most instructions single byte
- MICROWIRE/PLUSTM serial I/O
- 28 pin package (optionally 24 or 20 pin package)
- 24 input/output pins
- Software selectable I/O options (TRI-STATE ${ }^{(1)}$, pushpull, weak pull-up)
■ I/O ports and function compatible with the COP400 family
- Extended temperature ranges: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ to be available)
- ROMless mode to get accurate emulation and external program capability
- Fully supported by National's MOLETM development system


## Block Diagram



TL/DD/9104-1

National

## COP8640C 2k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Data Memory

## General Description

The COP8640C is a member of the COPSTM microcontroller family. It is a fully static part, fabricated using double-metal silicon gate microCMOS technology. This low cost microcontroller is a complete microcomputer containing all system timing, interrupt logic, ROM, RAM, EEPROM and I/O necessary to implement dedicated control functions in a variety of applications. Features include an 8-bit memory mapped architecture, MICROWIRETM serial I/O, a 16 -bit timer/counter, and a multi-sourced interrupt. Each I/O pin has software selectable options to adapt the COP8640 to the specific application. The part operates over a voltage range of 2.7 V to 6.0 V . High throughput is achieved with an efficient, regular instruction set operating at a $1 \mu$ s per instruction rate. The part may be operated in the ROMless mode to provide for accurate emulation and for applications requiring external program memory.

## Features

■ Low cost 8-bit microController

- Fully static CMOS
- $1 \mu \mathrm{~s}$ instruction time ( 20 MHz clock)
- Low current drain ( 2 mA at $4 \mu \mathrm{~s}$ instruction rate)
- Extra-low current static HALT mode ( $5 \mu \mathrm{~A}$ )

■ Single supply operation: 2.7 V to 6.0 V

- $2048 \times 8$ ROM, $128 \times 8$ RAM, $128 \times 8$ EEPROM
- 16-bit read/write timer operates in a variety of modes - Timer with 16-bit auto reload register
- 16-bit external event counter
- Timer with 16-bit capture register (selectable edge)
- Multi-source vectored interrupt
- Reset master clear
- External intelupt with selectable edge
- Timer interrupt or capture interrupt
- Software/"watch-dog" interrupt
- Idle timer with interrupt
- Power saving IDLE and HALT modes
- On-chip comparator
- 8-bit stack pointer (stack in RAM)

■ Powerful instruction set, most instructions single byte

- MICROWIRE/PLUSTM serial I/O
- 28 pin package
- 24 input/output pins
- Software selectable I/O options (TRI-STATE ${ }^{\circledR}$, pushpull, weak pull-up)
- I/O ports and function compatible with the COP400 family
- Extended temperature ranges: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ to be available)
- ROMless mode to get accurate emulation and external program capability
- Fully supported by National's MOLETM development system

Block Diagram


TL/DD/9105-1

National Semiconductor Corporation

## COP8720C 1k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Program and Data Memory

## General Description

The COP8720C is a member of the COPSTM microcontroller family. It is a fully static part, fabricated using double-metal silicon gate microCMOS technology. This low cost microcontroller is a complete microcomputer containing all system timing, interrupt logic, EEPROM in ROM address space, RAM, EEPROM and I/O necessary to implement dedicated control functions in a variety of applications. Features include an 8 -bit memory mapped architecture, MICROWIRETM serial I/O, a 16 -bit timer/counter, and a multisourced interrupt. Each I/O pin has software selectable options to adapt the COP800 to the specific application. The part operates over a voltage range of 2.7 V to 6.0 V . High throughput is achieved with an efficient, regular instruction set operating at a $1 \mu \mathrm{~s}$ per instruction rate. This part is the $E^{2}$ full form, fit, function emulator for the COP820C and COP8620C family parts.

## Features

■ Low cost 8-bit microController

- Fully static CMOS
- $1 \mu$ s instruction time ( 20 MHz clock)
- Low current drain ( 2 mA at $4 \mu \mathrm{~s}$ instruction rate)

■ Extra-low current static HALT mode ( $5 \mu \mathrm{~A}$ )
■ Single supply operation: 2.7 V to 6.0 V

- $1024 \times 8$ EEPROM, $64 \times 8$ RAM, $64 \times 8$ EEPROM
- 16-bit read/write timer operates in a variety of modes - Timer with 16 -bit auto reload register
- 16-bit external event counter
- Timer with 16-bit capture register (selectable edge)
- Multi-source interrupt
- Reset master cleab
- External interrupt with selectable edge
- Timer interrupt or capture interrupt
- Software/"watch-dog"' interrupt
- 8-bit stack pointer (stack in RAM)
- Powerful instruction set, most instructions single byte
- MICROWIRE/PLUSTM serial I/O
- 28 pin package (optionally 24 or 20 pin package)
- 24 input/output pins
- Software selectable I/O options (TRI-STATE ${ }^{\circledR}$, pushpull, weak pull-up)
- I/O ports and function compatible with the COP400 family
■ Extended temperature ranges: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ to be available)
- Fully supported by National's MOLETM development system


## Block Diagram



## COP8740C 2k Single-Chip 8-Bit Low Cost Microcontroller with E2PROM Program and Data Memory

## General Description

The COP8740C is a member of the COPSTM microcontroller family. It is a fully static part, fabricated using double-metal silicon gate microCMOS technology. This low cost microcontroller is a complete microcomputer containing all system timing, interrupt logic, EEPROM on ROM address space, RAM, EEPROM and I/O necessary to implement dedicated control functions in a variety of applications. Features include an 8 -bit memory mapped architecture, MICROWIRETM serial I/O, a 16 -bit timer/counter, and a multi-sourced interrupt. Each I/O pin has software selectable options to adapt the COP8740C to the specific application. The part operates over a voltage range of 2.7 V to 6.0 V . High throughput is achieved with an efficient, regular instruction set operating at a $1 \mu \mathrm{~s}$ per instruction rate. This part is the $E^{2}$ full form, function emulator for the COP840C and COP8640C Family Parts.

## Features

- Low cost 8 -bit microController
- Fully static CMOS
- $1 \mu \mathrm{~s}$ instruction time ( 20 MHz clock)
- Low current drain ( 2 mA at $4 \mu \mathrm{~s}$ instruction rate)
- Extra-low current static HALT mode ( $5 \mu \mathrm{~A}$ )
- Single supply operation: 2.7 V to 6.0 V
- $2048 \times 8$ EEPROM, $128 \times$ RAM, $128 \times 8$ EEPROM
- 16-bit read/write timer operates in a variety of modes - Timer with 16 -bit auto reload register
- 16-bit external event counter
- Timer with 16 -bit capture register (selectable edge)
- Multi-source vectored interrupt
- Reset master clear
- External interiupt with selectable edge
- Timer interrupt or capture interrupt
- Software/"watch-dog" interrupt
- Idle timer with interrupt
- Power saving IDLE and HALT modes
- On-chip Comparator
- 8-bit stack pointer (stack in RAM)
- Powerful instruction set, most instructions single byte

■ MICROWIRE/PLUSTM serial I/O

- 28 pin package
- 24 input/output pins
- Software selectable I/O options (TRI-STATE ${ }^{\circledR}$, pushpull, weak pull-up)
- I/O ports and function compatible with the COP400 family
- Extended temperature ranges: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ $\left(-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}$ to be available)
- Fully supported by National's MOLETM development system


## Block Diagram



Section 3
COPS Peripherals

## Section 3 Contents

COP431/COP432/COP434/COP438/ADC0831/ADC0832/ADC0834/ADC0838 8-Bit Serial I/O A/D Converters with Multiplexer Options ..... 3-3
COP452L/COP352L Frequency Generator and Counter ..... 3-27
COP470/COP370 V.F. Display Driver ..... 3-57
COP472-3 Liquid Crystal Display Controller ..... 3-64
COP494/NMC9306 256-Bit Serial Electrically Erasable Programmable Memory ..... 3-71
COP495/NMC9345 1024-Bit Serial Electrically Erasable Programmable Memory (5V Only) ..... 3-76
COP498/COP398 Low Power CMOS RAM and Timer (RAT) COP499/COP399 Low Power CMOS Memory ..... 3-81
DS8906 AM/FM Digital Phase-Locked Loop Synthesizer ..... 3-93
DS8907 AM/FM Digital Phase-Locked Loop Frequency Synthesizer ..... 3-100
DS8908 AM/FM Digital Phase-Locked Loop Frequency Synthesizer ..... 3-106
DS8911/DS8912 AM/FM/TV Sound Up-Conversion Frequency Synthesizers ..... 3-114
MM5450/MM5451 LED Display Drivers ..... 3-123
MM5452/MM5453 Liquid Crystal Display Drivers ..... 3-129
MM5483 Liquid Crystal Display Driver ..... 3-136
MM5484 16-Segment LED Display Driver ..... 3-139
MM5486 LED Display Driver ..... 3-142
MM58201 Multiplexed LCD Driver ..... 3-147
MM58248 High Voltage Display Driver ..... 3-153
MM58241 High Voltage Display Driver ..... 3-158
MM58242 High Voltage Display Driver ..... 3-163
MM58342 High Voltage Display Driver ..... 3-168
MM58348 High Voltage Display Driver ..... 3-173
MM58341 High Voltage Display Driver ..... 3-178
AN-440 New CMOS Vacuum Fluorescent Drivers Enable Three Chip System to Provide Intelligent Control of Dot Matrix VF Display ..... 3-183
NMC27C32B 32,768-Bit (4095 x 8) UV Erasable CMOS PROM ..... 3-193
NMC27C64 65,536-Bit ( $8 \mathrm{k} \times 8$ ) UV Erasable CMOS PROM ..... 3-201
NMC27C256 262,144-Bit (32k x 8) UV Erasable CMOS PROM ..... 3-209
NMC27C512 524,288-Bit (64k x 8) UV Erasable CMOS PROM ..... 3-218
NMC27C1024 1,048,576-Bit (64k x 16) UV Erasable CMOS PROM ..... 3-226
DM54LS373/DM74LS373, DM54LS374/DM74LS374 TRI-STATE Octal D-Type Transparent Latches and Edge-Triggered Flip-Flops ..... 3-234
MM54HC373/MM74HC373 TRI-STATE Octal D-Type Latch ..... 3-239
MM57409 Super Number Cruncher ..... 3-242

National Semiconductor Corporation

## ADC0831/ADC0832/ADC0834 and ADC0838 (COP431/COP432/COP434 and COP438) 8-Bit Serial I/O A/D Converters with Multiplexer Options

## General Description

The ADC0831 series are 8 -bit successive approximation A/D converters with a serial I/O and configurable input multiplexers with up to 8 channels. The serial I/O is configured to comply with the NSC MICROWIRETM serial data exchange standard for easy interface to the COPSTM family of processors, and can interface with standard shift registers or $\mu \mathrm{Ps}$.
The 2-, 4- or 8-channel multiplexers are software configured for single-ended or differential inputs as well as channel assignment.
The differential analog voltage input allows increasing the common-mode rejection and offsetting the analog zero input voltage value. In addition, the voltage reference input can be adjusted to allow encoding any smaller analog voltage span to the full 8 bits of resolution.

## Features

- NSC MICROWIRE compatible-direct interface to COPS family processors
- Easy interface to all microprocessors, or operates "stand-alone"
- Operates ratiometrically or with $5 \mathrm{~V}_{D C}$ voltage reference
- No zero or full-scale adjust required
- 2-, 4- or 8-channel multiplexer options with address logic
- Shunt regulator allows operation with high voltage supplies
- 0 V to 5 V input range with single 5 V power supply

■ Remote operation with serial digital data link

- T2L/MOS input/output compatible

■ $0.3^{\prime \prime}$ standard width, 8 -, 14- or 20-pin DIP package

## Key Specifications

| ■ Resolution | 8 Bits |
| :--- | ---: |
| ■ Total Unadjusted Error | $\pm 1 / 2$ LSB and $\pm 1 \mathrm{LSB}$ |
| ■ Single Supply | 5 VDC |
| - Low Power | 15 mW |
| - Conversion Time | $32 \mu \mathrm{~s}$ |

## Typical Application



TL/H/5583-1

```
Absolute Maximum Ratings (Notes 1 \& 2)
Current into \(\mathrm{V}^{+}\)(Note 3)
                            15 mA
Supply Voltage, \(\mathrm{V}_{\mathrm{CC}}\) (Note 3)
Voltage
    Logic Inputs
    -0.3 V to +15 V
-0.3 V to \(\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}\)
    \(\pm 5 \mathrm{~mA}\)
    \(\pm 20 \mathrm{~mA}\)
                                    Package
Storage Temperature
Package Dissipation
    at \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) (Board Mount)
                                0.8W
Lead Temp. (Soldering, 10 seconds) \(300^{\circ} \mathrm{C}\)
```

Absolute Maximum Ratings (Notes 1 \& 2)
Current into $\mathrm{V}^{+}$(Note 3)
15 mA
Supply Voltage, $\mathrm{V}_{\mathrm{CC}}$ (Note 3)
Voltage
Logic Inputs
Analog Inputs
Input Current per Pin
Package
Storage Temperature
at $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ (Board Mount) $300^{\circ} \mathrm{C}$

Operating Ratings (Notes 1 \& 2)

| Supply Voltage, $\mathrm{V}_{\mathrm{CC}}$ | $4.5 \mathrm{~V}_{D C}$ to $6.3 \mathrm{~V}_{\mathrm{DC}}$ |
| :---: | ---: |
| Temperature Range | $\mathrm{T}_{\text {MIN }} \leq \mathrm{T}_{\mathrm{A}} \leq \mathrm{T}_{\text {MAX }}$ |
| ADC0831/2/4/8BJ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| ADC0831/2/4/8CJ |  |
| ADC0831/2/4/8BCJ | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| ADC0831/2/4/8CCJ |  |
| ADC0831/2/4/8BCN | $-0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| ADC0831/2/4/8CCN |  |

## Converter and Multiplexer Electrical Characteristics

The following specifications apply for $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}+=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{j}}=25^{\circ} \mathrm{C}$, and $\mathrm{f}_{\mathrm{CLK}}=250 \mathrm{kHz}$ unless otherwise specified. Boldface limits apply from $T_{\text {MIN }}$ to $T_{\text {MAX }}$.

| Parameter | BCJ and <br> CCJ Devices | BCN and <br> CCN Devices |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Typ <br> (Note 9) |  |  | Tested <br> Limit <br> (Note 10) | Design <br> Limit <br> (Note 11) | Typ <br> (Note 9) | Tested <br> Limit <br> (Note 10) |
|  |  |  |  |  |  |  |  |  |

## CCNVERTER AND MULTIPLEXER CHARACTERISTICS

| Total Unadjusted Error <br> ADC0831/2/4/8ECN <br> ADC0831/2/4/8BJ <br> ADC0831/2/4/8BCJ <br> ADC0831/2/4/8CCN <br> ADC0831/2/4/8CJ <br> ADC0831/2/4/8CCJ | $\begin{aligned} & V_{\text {REF }}=5.00 \mathrm{~V} \\ & \text { (Note 4) } \end{aligned}$ |  | $\begin{aligned} & +1 / 2 \\ & \pm 1 / 2 \\ & \pm 1 / 2 \\ & \pm 1 \\ & \pm 1 \end{aligned}$ |  |  | $\begin{aligned} & \pm 1 / 2 \\ & \pm 1 / 2 \\ & \pm 1 \end{aligned}$ | $\begin{aligned} & \pm 1 / 2 \\ & \pm 1 \end{aligned}$ | LSB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Minimum Reference Input Resistance |  | 2.4 | 1.3 |  | 2.4 | 1.3 | 1.3 | k $\Omega$ |
| Maximum Reference Input Resistance |  | 2.4 | 5.9 |  | 2.4 | 5.4 | 5.4 | k $\Omega$ |
| Maximum Common-Mode Input Range (Note 5) |  |  | $\mathrm{V}_{\mathrm{Cc}}+0.05$ |  |  | $\mathrm{V}_{\mathrm{CC}}+0.05$ | $\mathrm{V}_{\mathrm{CC}}+0.05$ | V |
| Minimum Common-Mode Input Range (Note 5) |  |  | GND - 0.05 |  |  | GND -0.05 | GND-0.05 | V |
| DC Common-Mode Error |  | $\pm 1 / 16$ | $\pm 1 / 4$ | $\pm 1 / 4$ | $\pm 1 / 16$ | $\pm 1 / 4$ | $\pm 1 / 4$ | LSB |
| Change in zero error from $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ to internal zener operation (Note 3) | $\begin{aligned} & 15 \mathrm{~mA} \text { into } \mathrm{V}+ \\ & \mathrm{V}_{\mathrm{CC}}=\mathrm{N} . \mathrm{C} . \\ & \mathrm{V}_{\mathrm{REF}}=5 \mathrm{~V} \end{aligned}$ |  | 1 |  |  | 1 | 1 | LSB |
| $\mathrm{V}_{\mathrm{Z}}$, internal MIN <br> diode breakdown MAX <br> (at $\mathrm{V}_{+}$) (Note 3)  | 15 mA into $\mathrm{V}+$ |  | $\begin{aligned} & 6.3 \\ & 8.5 \end{aligned}$ |  |  | $\begin{aligned} & 6.3 \\ & 8.5 \end{aligned}$ | $\begin{aligned} & 6.3 \\ & 8.5 \end{aligned}$ | V |
| Power Supply Sensitivity | $V_{C C}=5 \mathrm{~V} \pm 5 \%$ | $\pm 1 / 16$ | $\pm 1 / 4$ | $\pm 1 / 4$ | $\pm 1 / 16$ | $\pm 1 / 4$ | $\pm 1 / 4$ | LSB |
| IOFF, Off Channel Leakage Current (Note 6) | On Channel $=5 \mathrm{~V}$ <br> Off Channel $=0 \mathrm{~V}$ |  | -1 |  |  | -1 | -1 | $\mu \mathrm{A}$ |
|  | On Channel $=0 \mathrm{~V}$ <br> Off Channel $=5 \mathrm{~V}$ |  | +1 |  |  | +1 | + 1 | $\mu \mathrm{A}$ |
| ION, On Channel Leakage Current (Note 6) | On Channel = OV <br> Off Channel $=5 \mathrm{~V}$ |  | -1 |  |  | -1 | -1 | $\mu \mathrm{A}$ |
|  | On Channel $=5 \mathrm{~V}$ <br> Off Channel = 0V |  | +1 |  |  | +1 | +1 | $\mu \mathrm{A}$ |

Note 1: Absolute Maximum Ratings are those values beyond which the life of the device may be impaired.
Note 2: All voltages are measured with respect to ground.
Note 3: Internal zener diodes ( 6.3 to 8.5 V ) are connected from $V+$ to GND and $V_{C C}$ to $G N D$. The zener at $V+$ can operate as a shunt regulator and is connected to $V_{C C}$ via a conventional diode. Since the zener voltage equals the $A / D$ 's breakdown voltage, the diode insures that $V_{C C}$ will be below breakdown when the device is powered from $V+$. Functionality is therefore guaranteed for $V+$ operation even though the resultant voltage at $V_{C C}$ may exceed the specified $A b s o l u t e ~ M a x ~ o f ~$ 6.5 V . It is recommended that a resistor be used to limit the max current into $\mathrm{V}+$. (See Figure 3)

Note 4: Total unadjusted error includes offset, full-scale, linearity, and multiplexer errors.

Converter and Multiplexer Electrical Characteristics (Continued)
The following specifications apply for $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}+=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{j}}=25^{\circ} \mathrm{C}$, and $\mathrm{f}_{\mathrm{CLK}}=250 \mathrm{kHz}$ unless otherwise specified. Boldface limits apply from $T_{\text {MIN }}$ to $T_{\text {MAX }}$.

| Parameter | Conditions | BCJ and CCJ Devices |  |  | BCN and CCN Devices |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Typ (Note 9) | Tested Limit (Note 10) | Design Limit (Note 11) | $\begin{gathered} \text { Typ } \\ \text { (Note 9) } \end{gathered}$ | Tested Limit (Note 10) | Design Limit (Note 11) |  |
| DIGITAL AND DC CHARACTERISTICS |  |  |  |  |  |  |  |  |
| $\mathrm{V}_{\text {IN(1) }}$, Logical "1" Input Voltage (Min) | $V_{C C}=5.25 \mathrm{~V}$ |  | 2.0 |  |  | 2.0 | 2.0 | V |
| Vin(0), Logical "0" Input Voltage (Max) | $V_{C C}=4.75 \mathrm{~V}$ |  | 0.8 |  |  | 0.8 | 0.8 | V |
| $\operatorname{IIN}^{(1)}$, Logical "1" Input Current (Max) | $\mathrm{V}_{1 \mathrm{~N}}=5.0 \mathrm{~V}$ | 0.005 | 1 |  | 0.005 | 1 | 1 | $\mu \mathrm{A}$ |
| ${ }^{\text {IN }(0)}$, Logical " 0 " Input Current (Max) | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ | -0.005 | -1 |  | -0.005 | -1 | -1 | $\mu \mathrm{A}$ |
| Vout(1), Logical "1" Output Voltage (Min) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \text { lout }=-360 \mu \mathrm{~A} \\ & \text { loUT }=-10 \mu \mathrm{~A} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 2.4 \\ & 4.5 \\ & \hline \end{aligned}$ |  |  | $\begin{array}{r} 2.4 \\ 4.5 \\ \hline \end{array}$ | $\begin{aligned} & 2.8 \\ & 4.6 \\ & \hline \end{aligned}$ | $\begin{aligned} & V \\ & V \end{aligned}$ |
| Vout(0), Logical "0" Output Voltage (Max) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OUT}}=1.6 \mathrm{~mA} \end{aligned}$ |  | 0.4 |  |  | 0.4 | 0.34 | V |
| lout, TRI-STATE Output Current (Max) | $\begin{aligned} & V_{\text {OUT }}=0 \mathrm{~V} \\ & V_{\text {OUT }}=5 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{gathered} -0.01 \\ 0.01 \\ \hline \end{gathered}$ | $\begin{gathered} -3 \\ 3 \\ \hline \end{gathered}$ |  | $\begin{gathered} -0.01 \\ 0.01 \end{gathered}$ | $\begin{array}{r} -3 \\ +3 \\ \hline \end{array}$ | $\begin{array}{r} -3 \\ +3 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| ISOURCE, Output Source Current (Min) | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | -14 | -6.5 |  | -14 | -6.5 | -7.5 | mA |
| ISINK, Output Sink Current (Min) | $V_{\text {OUT }}=V_{\text {CC }}$ | 16 | 8.0 |  | 16 | 8.0 | 9.0 | mA |
| $\begin{aligned} & \text { ICC, Supply Current (Max) } \\ & \text { ADC0831, ADC0834, } \\ & \text { ADC0838 } \\ & \hline \end{aligned}$ |  | 1 | 2.5 |  | 1 | 2.5 | 2.5 | mA |
| ADC0832 | Includes Ladder Current | 3 | 7.2 |  | 3 | 7.2 | 7.2 | mA |

AC Characteristics The following specifications apply for $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}$ and $25^{\circ} \mathrm{C}$ unless otherwise specified.

| Parameter |  | Conditions | Typ (Note 4) | Tested Limit (Note 5) | Design Limit (Note 6) | Limit Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| fclk, Clock Frequency | Min <br> Max |  |  | 10 | 400 | $\begin{aligned} & \mathrm{kHz} \\ & \mathrm{kHz} \\ & \hline \end{aligned}$ |
| $\mathrm{t}_{\mathrm{c}}$, Conversion Time |  | Not including MUX Addressing Time |  | 8 |  | 1/ficlk |
| Clock Duty Cycle (Note 7) | Min Max |  |  |  | $\begin{aligned} & 40 \\ & 60 \end{aligned}$ | $\begin{aligned} & \% \\ & \% \end{aligned}$ |
| tSET-UP, CS Falling Edge or Data Input Valid to CLK Rising Edge |  |  |  |  | 250 | ns |
| $t_{\text {HOLD }}$, Data Input Valid after CLK Rising Edge |  |  |  |  | 90 | ns |
| $\mathrm{t}_{\mathrm{pd} 1}, \mathrm{t}_{\mathrm{pd}}$-CLK Falling Edge to Output Data Valid (Note 8) |  | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} \\ & \text { Data MSB First } \\ & \text { Data LSB First } \end{aligned}$ | $\begin{aligned} & 650 \\ & 250 \end{aligned}$ |  | $\begin{gathered} 1500 \\ 600 \end{gathered}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| $\mathrm{t}_{1 \mathrm{H},} \mathrm{t}_{\mathrm{OH}}$,-Rising Edge of CS to Data Output and SARS Hi-Z |  | $\begin{aligned} & C_{L}=10 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=10 \mathrm{k} \\ & \text { (see TRI-STATE }{ }^{\oplus} \text { Test Circuits) } \end{aligned}$ | 125 |  | 250 | ns |
|  |  | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pf}, \mathrm{R}_{\mathrm{L}}=2 \mathrm{k}$ |  | 500 |  | ns |
| $\mathrm{C}_{\mathrm{IN}}$, Capacitance of Logic Input |  |  | 5 |  |  | pF |
| Cout, Capacitance of Logic Outputs |  |  | 5 |  |  | pF |

Note 5: For $\mathrm{V}_{\mathbb{N}}(-) \geq \mathrm{V}_{\mathbb{N}}(+)$ the digital output code will be 00000000 . Two on-chip diodes are tied to each analog input (see Block Diagram) which will forward conduct for analog input voltages one diode drop below ground or one diode drop greater then the $\mathrm{V}_{\mathrm{CC}}$ supply. Be careful, during testing at low $\mathrm{V}_{\mathrm{CC}}$ levels ( 4.5 V ), as high level analog inputs ( 5 V ) can cause this input diode to conduct-especially at elevated temperatures, and cause errors for analog inputs near full-scale. The spec allows 50 mV forward bias of either diode. This means that as long as the analog $V_{I N}$ does not exceed the supply voltage by more than 50 mV , the output code will be correct. To achieve an absolute $0 \mathrm{~V}_{D C}$ to $5 \mathrm{~V}_{D C}$ input voltage range will therefore require a minimum supply voltage of $4.950 \mathrm{~V}_{\mathrm{DC}}$ over temperature variations, initial tolerance and loading.
Note 6: Leakage current is measured with the clock not switching.
Note 7: A $40 \%$ to $60 \%$ clock duty cycle range insures proper operation at all clock frequencies. In the case that an available clock has a duty cycle outside of these limits, the minimum, time the clock is high or the minimum time the clock is low must be at least $1 \mu \mathrm{~s}$.
Note 8: Since data, MSB first, is the output of the comparator used in the successive approximation loop, an additional delay is built in (see Block Diagram) to allow for comparator response time.
Note 9: Typicals are at $25^{\circ} \mathrm{C}$ and represent most likely parametric values.
Note 10: Guaranteed and $100 \%$ production tested.
Note 11: Guaranteed but not $100 \%$ production tested. These limits are not used to calculate outgoing quality levels.

## Typical Performance Characteristics



Leakage Current Test Circuit


TL/H/5583-3

## TRI-STATE Test Circuits and Waveforms





TL/H/5583-4

## Timing Diagrams





## Timing Diagrams (Continued)



TL/H/5583-27



* Make sure clock edge \# 18 clocks in the LSB before $\overline{\text { SE }}$ is taken low



## Connection Diagrams




COM internally connected to A GND


COM internally connected to GND.
REF internally connected to $\mathrm{V}_{\mathrm{CC}}$.

ADC0831 Single Differential Input


TL/H/5583-8

## Functional Description

### 1.0 MULTIPLEXER ADDRESSING

The design of these converters utilizes a sample-data comparator structure which provides for a differential analog input to be converted by a successive approximation routine.
The actual voltage converted is always the difference between an assigned " + " input terminal and a " - " input terminal. The polarity of each input terminal of the pair being converted indicates which line the converter expects to be the most positive. If the assigned " + " input is less than the "-" input the converter responds with an all zeros output code.
A unique input multiplexing scheme has been utilized to provide multiple analog channels with software-configurable single-ended, differential, or a new pseudo-differential option which will convert the difference between the voltage at any analog input and a common terminal. The analog signal conditioning required in transducer-based data acquisition systems is significantly simplified with this type of input flexibility. One converter package can now handle ground referenced inputs and true differential inputs as well as signals with some arbitrary reference voltage.
A particular input configuration is assigned during the MUX addressing sequence, prior to the start of a conversion. The MUX address selects which of the analog inputs are to be enabled and whether this input is single-ended or differen-
tial. In the differential case, it also assigns the polarity of the channels. Differential inputs are restricted to adjacent channel pairs. For example channel 0 and channel 1 may be selected as a different pair but channel 0 or 1 cannot act differentially with any other channel. In addition to selecting differential mode the sign may also be selected. Channel 0 may be selected as the positive input and channel 1 as the negative input or vice versa. This programmability is best illustrated by the MUX addressing codes shown in the following tables for the various product options.
The MUX address is shifted into the converter via the DI line. Because the ADC0831 contains only one differential input channel with a fixed polarity assignment, it does not require addressing.
The common input line on the ADC0838 can be used as a pseudo-differential input. In this mode, the voltage on this pin is treated as the "-" input for any of the other input channels. This voltage does not have to be analog ground; it can be any reference potential which is common to all of the inputs. This feature is most useful in single-supply application where the analog circuitry may be biased up to a potential other than ground and the output signals are all referred to this potential.

TABLE I. Multiplexer/Package Options

| Part <br> Number | Alternate <br> Part Number | Number of Analog Channels |  | Number of <br> Package Pins |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Single-Ended | Differential |  |
| ADC0832 | COP432 | 2 | 1 | 8 |
| ADC0834 | COP434 | 4 | 1 | 8 |
| ADC0838 | COP438 | 8 | 2 | 14 |

Functional Description (Continued)
TABLE II. MUX Addressing: ADC0838
Single-Ended MUX Mode

| MUX Address |  |  |  | Analog Single-Ended Channel \# |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{SGL} /}$ | $\begin{aligned} & \text { ODD/ } \\ & \text { SIGN } \end{aligned}$ |  | T 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | COM |
| 1 | 0 | 0 | 0 | + |  |  |  |  |  |  |  | - |
| 1 | 0 | 0 | 1 |  |  | + |  |  |  |  |  | - |
| 1 | 0 | 1 | 0 |  |  |  |  | + |  |  |  | - |
| 1 | 0 | 1 | 1 |  |  |  |  |  |  | + |  | - |
| 1 | 1 | 0 | 0 |  | + |  |  |  |  |  |  | - |
| 1 | 1 | 0 | 1 |  |  |  | + |  |  |  |  | - |
| 1 | 1 | 1 | 0 |  |  |  |  |  | + |  |  | - |
| 1 | 1 | 1 | 1 |  |  |  |  |  |  |  | + | - |

## Differential MUX Mode

| MUX Address |  |  |  | Analog Differential Channel-Pair \# |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{SGL} / \\ & \overline{\mathrm{DIF}} \end{aligned}$ | ODD/ SIGN | SELECT |  | 0 |  | 1 |  | 2 |  | 3 |  |
|  |  | 1 | 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0 | 0 | 0 | 0 | + | - |  |  |  |  |  |  |
| 0 | 0 | 0 | 1 |  |  | + | - |  |  |  |  |
| 0 | 0 | 1 | 0 |  |  |  |  | + | - |  |  |
| 0 | 0 | 1 | 1 |  |  |  |  |  |  | + | - |
| 0 | 1 | 0 | 0 | - | + |  |  |  |  |  |  |
| 0 | 1 | 0 | 1 |  |  | - | + |  |  |  |  |
| 0 | 1 | 1 | 0 |  |  |  |  | - | + |  |  |
| 0 | 1 | 1 | 1 |  |  |  |  |  |  | - | + |

TABLE III. MUX Addressing: ADC0834
Single-Ended MUX Mode

| MUX Address |  |  | Channel \# |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SGL// <br> DIF | ODD/ <br> SIGN | SELECT | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ |
|  | $\mathbf{1}$ | 0 |  |  |  |  |
| 1 | 0 | 0 |  |  | + |  |
| 1 | 0 | 1 |  | + |  |  |
| 1 | 1 | 0 |  |  |  | + |
| 1 | 1 | 1 |  |  |  |  |

COM is internally tied to A GND
Differential MUX Mode

| MUX Address |  |  | Channel \# |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \hline \text { SGL// } \\ \text { DIF } \end{gathered}$ | ODD/ SIGN | SELECT | 0 | 1 | 2 | 3 |
|  |  | 1 |  |  |  |  |
| 0 | 0 | 0 | $+$ | - |  |  |
| 0 | 0 | 1 |  |  | + | - |
| 0 | 1 | 0 | - | + |  |  |
| 0 | 1 | 1 |  |  | - | $+$ |

TABLE IV. MUX Addressing: ADC0832

Single-Ended MUX PMode

| MUX Address |  | Channel \# |  |
| :---: | :---: | :---: | :---: |
| SGL/ <br> $\overline{\mathrm{DIF}}$ | ODD/ <br> SIGN | 0 | 1 |
| 1 | 0 | + |  |
| 1 | 1 |  | + |

COM is internally tied to A GND
Differential MUX Mode

| MUX Address |  | Channel \# |  |
| :---: | :---: | :---: | :---: |
| SGL/ <br> $\overline{\text { DIF }}$ | ODD/ <br> SIGN | 0 | 1 |
| 0 | 0 | + | - |
| 0 | 1 | - | + |

## Functional Description (Continued)

Since the input configuration is under software control, it can be modified, as required, at each conversion. A channel can be treated as a single-ended, ground referenced input for one conversion; then it can be reconfigured as part of a differential channel for another conversion. Figure 1 illustrates the input flexibility which can be achieved.
The analog input voltages for each channel can range from 50 mV below ground to 50 mV above $\mathrm{V}_{\mathrm{CC}}$ (typically 5 V ) without degrading conversion accuracy.

### 2.0 THE DIGITAL INTERFACE

A most important characteristic of these converters is their serial data link with the controlling processor. Using a serial communication format offers two very significant system improvements; it allows more function to be included in the converter package with no increase in package size and it can eliminate the transmission of low level analog signals by locating the converter right at the analog sensor; transmitting highly noise immune digital data back to the host processor.


To understand the operation of these converters it is best to refer to the Timing Diagrams and Functional Block Diagram and to follow a complete conversion sequence. For clarity a separate diagram is shown of each device.

1. A conversion is initiated by first pulling the $\overline{\mathrm{CS}}$ (chip select) line low. This line must be held low for the entire conversion. The converter is now waiting for a start bit and its MUX assignment word.
2. A clock is then generated by the processor (if not provided continuously) and output to the A/D clock input.
3. On each rising edge of the clock the status of the data in (DI) line is clocked into the MUX address shift register. The start bit is the first logic " 1 " that appears on this line (all leading zeros are ignored). Following the start bit the converter expects the next 2 to 4 bits to be the MUX assignment word.

FIGURE 1. Analog Input Multiplexer Options for the ADC0838

## Functional Description (Continued)

4. When the start bit has been shifted into the start location of the MUX register, the input channel has been assigned and a conversion is about to begin. An interval of $1 / 2$ clock period (where nothing happens) is automatically inserted to allow the selected MUX channel to settle. The SAR status line goes high at this time to signal that a conversion is now in progress and the DI line is disabled (it no longer accepts data).
5. The data out (DO) line now comes out of TRI-STATE and provides a leading zero for this one clock period of MUX settling time.
6. When the conversion begins, the output of the SAR comparator, which indicates whether the analog input is greater than (high) or less than (low) each successive voltage from the internal resistor ladder, appears at the DO line on each falling edge of the clock. This data is the result of the conversion being shifted out (with the MSB coming first) and can be read by the processor immediately.
7. After 8 clock periods the conversion is completed. The SAR status line returns low to indicate this $1 / 2$ clock cycle later.
8. If the programmer prefers, the data can be provided in an LSB first format [this makes use of the shift enable ( $\overline{\mathrm{SE}}$ ) control line]. All 8 bits of the result are stored in an output shift register. On devices which do not include the SE control line, the data, LSB first, is automatically shifted out the DO line, after the MSB first data stream. The DO line then goes low and stays low until $\overline{\mathrm{CS}}$ is returned high. On the ADC0838 the $\overline{\text { SE }}$ line is brought out and if held high, the value of the LSB remains valid on the DO line. When $\overline{S E}$ is forced low, the data is then clocked out LSB first. The ADC0831 is an exception in that its data is only output in MSB first format.
9. All internal registers are cleared when the $\overline{\mathrm{CS}}$ line is high. If another conversion is desired, $\overline{\mathrm{CS}}$ must make a high to low transition followed by address information.

a) Ratiometric

The DI and DO lines can be tied together and controlled through a bidirectional processor I/O bit with one wire. This is possible because the DI input is only "looked-at" during the MUX addressing interval while the DO line is still in a high impedance state.
All of the logic inputs can be taken to 15 V independent of the magnitude of the supply voltage, $\mathrm{V}_{\mathrm{CC}}$.

### 3.0 REFERENCE CONSIDERATIONS

The voltage applied to the reference input to these converters defines the voltage span of the analog input (the difference between $\mathrm{V}_{\operatorname{IN}(\mathrm{MAX})}$ and $\left.\mathrm{V}_{\operatorname{IN}(\mathrm{MIN})}\right)$ over which the 256 possible output codes apply. The devices can be used in either ratiometric applications or in systems requiring absolute accuracy. The reference pin must be connected to a voltage source capable of driving the reference input resistance of typically $2.4 \mathrm{k} \Omega$. This pin is the top of a resistor divider string used for the successive approximation conversion.
In a ratiometric system, the analog input voltage is proportional to the voltage used for the A/D reference. This voltage is typically the system power supply, so the $\mathrm{V}_{\text {REF }}$ pin can be tied to $\mathrm{V}_{\mathrm{CC}}$ (done internally on the ADC0832). This technique relaxes the stability requirements of the system reference as the analog input and A/D reference move together maintaining the same output code for a given input condition.
For absolute accuracy, where the analog input varies between very specific voltage limits, the reference pin can be biased with a time and temperature stable voltage source. The LM385 and LM336 reference diodes are good low current devices to use with these converters.
The maximum value of the reference is limited to the $V_{C C}$ supply voltage. The minimum value, however, can be quite small (see Typical Performance Characteristics) to allow direct conversions of transducer outputs providing less than a 5 V output span. Particular care must be taken with regard to noise pickup, circuit layout and system error voltage sources when operating with a reduced span due to the increased sensitivity of the converter ( 1 LSB equals $\mathrm{V}_{\mathrm{REF}}$ / 256).


TL/H/5583-10
b) Absolute with a Reduced Span

FIGURE 2. Reference Examples

## Functional Description (Continued)

### 4.0 THE ANALOG INPUTS

The most important feature of these converters is that they can be located right at the analog signal source and through just a few wires can communicate with a controlling processor with a highly noise immune serial bit stream. This in itself greatly minimizes circuitry to maintain analog signal accuracy which otherwise is most susceptible to noise pickup. However, a few words are in order with regard to the analog inputs should the input be noisy to begin with or possibly riding on a large common-mode voltage.
The differential input of these converters actually reduces the effects of common-mode input noise, a signal common to both selected " + " and "-" inputs for a conversion (60 Hz is most typical). The time interval between sampling the " + " input and then the " - " input is $1 / 2$ of a clock period. The change in the common-mode voltage during this short time interval can cause conversion errors. For a sinusoidal common-mode signal this error is:

$$
\mathrm{V}_{\text {error }}(\max )=\mathrm{V}_{\text {peak }}\left(2 \pi \mathrm{f}_{\mathrm{CM}}\right)\left(\frac{0.5}{\mathrm{f}_{\mathrm{CLK}}}\right)
$$

where $\mathrm{f}_{\mathrm{CM}}$ is the frequency of the common-mode signal,
$V_{\text {peak }}$ is its peak voltage value
and $\mathrm{f}_{\mathrm{CLK}}$, is the $\mathrm{A} / \mathrm{D}$ clock frequency.
For a 60 Hz common-mode signal to generate a $1 / 4$ LSB error ( $\approx 5 \mathrm{mV}$ ) with the converter running at 250 kHz , its peak value would have to be 6.63 V which would be larger than allowed as it exceeds the maximum analog input limits.
Due to the sampling nature of the analog inputs short spikes of current enter the " + " input and exit the "- -" input at the clock edges during the actual conversion. These currents decay rapidly and do not cause errors as the internal comparator is strobed at the end of a clock period. Bypass capacitors at the inputs will average these currents and cause an effective DC current to flow through the output resistance of the analog signal source. Bypass capacitors should not be used if the source resistance is greater than $1 \mathrm{k} \Omega$.
This source resistance limitation is important with regard to the DC leakage currents of input multiplexer as well. The worst-case leakage current of $\pm 1 \mu \mathrm{~A}$ over temperature will create a 1 mV input error with a $1 \mathrm{k} \Omega$ source resistance. An op amp RC active low pass filter can provide both impedance buffering and noise filtering should a high impedance signal source be required.

### 5.0 OPTIONAL ADJUSTMENTS

### 5.1 Zero Error

The zero of the A/D does not require adjustment. If the minimum analog input voltage value, $\mathrm{V}_{\mathbb{I N}(\mathrm{MIN})}$, is not ground, a zero offset can be done. The converter can be made to output 00000000 digital code for this minimum input voltage by biasing any $\mathrm{V}_{\mathbb{I N}}(-)$ input at this $\mathrm{V}_{\mathbb{I N}(\mathrm{MIN})}$ value. This utilizes the differential mode operation of the A/D.
The zero error of the A/D converter relates to the location of the first riser of the transfer function and can be measured by grounding the $\mathrm{V}_{\mathrm{IN}}(-)$ input and applying a small magnitude positive voltage to the $\mathrm{V}_{\mathrm{IN}}(+)$ input. Zero error is the difference between the actual DC input voltage which is necessary to just cause an output digital code transition from 00000000 to 00000001 and the ideal $1 / 2$ LSB value $\left(1 / 2 \mathrm{LSB}=9.8 \mathrm{mV}\right.$ for $\left.\mathrm{V}_{\mathrm{REF}}=5.000 \mathrm{~V}_{\mathrm{DC}}\right)$.

### 5.2 Full-Scale

The full-scale adjustment can be made by applying a differential input voltage which is $11 / 2$ LS3 down from the desired analog full-scale voltage range and then adjusting the magnitude of the $V_{\text {REF }}$ input or $V_{C C}$ for a digital output code which is just changing from 11111110 to 11111111.

### 5.3 Adjusting for an Arbitrary Analog Input Voltage Range

If the analog zero voltage of the A/D is shifted away from ground (for example, to accommodate an analog input signal which does not go to ground), this new zero reference should be properly adjusted first. A $\mathrm{V}_{\text {IN }}(+)$ voltage which equals this desired zero reference plus $1 / 2$ LSB (where the LSB is calculated for the desired analog span, 1 LSB = ana$\log$ span/256) is applied to selected " + " input and the zero reference voltage at the corresponding "-" input should then be adjusted to just obtain the 00 HEX to $0^{01} \mathrm{HEX}$ code transition.
The full-scale adjustment should be made [with the proper $\mathrm{V}_{\mathbb{N}}(-)$ voltage applied] by forcing a voltage to the $\mathrm{V}_{\operatorname{IN}}(+)$ input which is given by:

$$
V_{\mathrm{IN}}(+) \text { fs adj }=\mathrm{V}_{\mathrm{MAX}}-1.5\left[\frac{\left(\mathrm{~V}_{\mathrm{MAX}}-\mathrm{V}_{\mathrm{MIN}}\right)}{256}\right]
$$

where:
$V_{\text {MAX }}=$ the high end of the analog input range and
$\mathrm{V}_{\text {MIN }}=$ the low end (the offset zero) of the analog range.
(Both are ground referenced.)
The $V_{\text {REF }}$ (or $V_{C C}$ ) voltage is then adjusted to provide a code change from FE HEX to FF HEX. This completes the ad- $^{\text {d }}$ justment procedure.

### 6.0 POWER SUPPLY

A unique feature of the ADC0838 and ADC0834 is the inclusion of a zener diode connected from the $\mathrm{V}+$ terminal to ground which also connects to the $V_{C C}$ terminal (which is the actual converter supply) through a silicon diode, as shown in Figure 3. (See Note 3)


TL/H/5583-11
FIGURE 3. An On-Chip Shunt Regulator Diode

## Functional Description (Continued)

This zener is intended for use as a shunt voltage regulator to eliminate the need for any additional regulating components. This is most desirable if the converter is to be remotely located from the system power source. Figures 4 and 5 illustrate two useful applications of this on-board zener when an external transistor can be afforded.
An important use of the interconnecting diode between $\mathrm{V}^{+}$ and $\mathrm{V}_{\mathrm{CC}}$ is shown in Figures 6 and 7. Here, this diode is used as a rectifier to allow the $\mathrm{V}_{\mathrm{CC}}$ supply for the converter

## Applications



FIGURE 4. Operating with a Temperature Compensated Reference


FIGURE 6. Generating $\mathbf{V}_{\mathbf{C C}}$ from the Converter Clock
to be derived from the clock. The low current requirements of the A/D and the relatively high clock frequencies used (typically in the range of $10 \mathrm{k}-400 \mathrm{kHz}$ ) allows using the small value filter capacitor shown to keep the ripple on the $V_{C C}$ line to well under $1 / 4$ of an LSB. The shunt zener regulator can also be used in this mode. This requires a clock voltage swing which is in excess of $\mathrm{V}_{\mathrm{Z}}$. A current limit for the zener is needed, either built into the clock generator or a resistor can be used from the CLK pin to the $\mathrm{V}+$ pin.


FIGURE 5. Using the A/D as the System Supply Regulator


FIGURE 7. Remote Sensing-Clock and Power on 1 Wire

Applications (Continued)
Digital Link and Sample Controlling Software for the Serially Oriented COP420 and the Bit Programmable I/O INS8048


COP CODING EXAMPLE
Mnemonic Instruction
LEI
SC
OGI
CLRA CLEARS ACCUMULATOR
AISC 1 LOADS ACCUMULATOR WITH 1
XAS EXCHANGES SIO WITH ACCUMULATOR AND STARTS SK CLOCK
LDD
NOP
XAS
$\uparrow$ $\uparrow$ 8 INSTRUCTIONS $\downarrow$
XAS READS HIGH ORDER NIBBLE (4 BITS) INTO ACCUMULATOR
XIS PUTS HIGH ORDER NIBBLE INTO RAM
CLRA CLEARS ACCUMULATOR
RC $\quad C=0$
XAS READS LOW ORDER NIBBLE INTO ACCUMULATOR AND STOPS SK
XIS PUTS LOW ORDER NIBBLE INTO RAM
$\mathrm{OGI} \quad \mathrm{GO}=1(\overline{\mathrm{CS}}=1)$
LEI DISABLES SIO'S INPUT AND OUTPUT


TL/H/5583-13

## 8048 CODING EXAMPLE

## Mnemonic

Instruction
START: ANL P1, \#0F7H ;SELECT A/D ( $\overline{\mathrm{CS}}=0$ )
MOV
MOV A, \#ADDR
LOOP 1: RRC
JC ONE
;TEST BIT
; $\mathrm{BIT}=0$
ZERO: ANL P1, \#OFEH ;DI $\leftarrow 0$
JMP CONT ;CONTINUE
; BIT=1
ONE: ORL P1,\#1 ;DI $\leftarrow 1$
CONT: CALL PULSE ;PULSE SK $0 \rightarrow 1 \rightarrow 0$
DJNZ B, LOOP 1 ;CONTINUE UNTIL DONE
CALL PULSE ;EXTRA CLOCK FOR SYNC
MOV B, \#8 ;BIT COUNTER $\leftarrow 8$
LOOP 2:
IN
IN A, P1
RRC A
RRC A
MOV A, C $\quad$; $\leftarrow$ RESULT
RLC $A \quad ; A(0) \leftarrow$ BIT AND SHIFT
MOV C, A ; C $\leftarrow$ RESULT
DJNZ B, LOOP 2
RETR

PULSE:

| ORL | P1, \#04 | ;SK $\leftarrow 1$ |
| :--- | :--- | :--- |
| NOP |  | ;DELAY |
| ANL | P1, \#0FBH | $;$ SK $\leftarrow 0$ |
| RET |  |  |

Applications (Continued)

*Pinouts shown for ADC0838.
For all other products tie to
pin functions as shown.


## Digitizing a Current Flow



Operating with Ratiometric Transducers


TL/H/5583-15
$* V_{I N}(-)=0.15 V_{C C}$
$15 \%$ of $V_{C C} \leq V_{X D R} \leq 85 \%$ of $V_{C C}$

Applications (Continued)

Span Adjust: $\mathrm{OV} \leq \mathrm{V}_{\text {IN }} \leq 3 \mathrm{~V}$


Zero-Shift and Span Adjust: $\mathbf{2 V} \leq \mathbf{V}_{\mathbf{I N}} \leq 5 \mathrm{~V}$


Applications (Continued)
Obtaining Higher Resolution


Controller performs a routine to determine which input polarity (9-bit example) or which channel pair (10-bit example) provides a non-zero output code. This information provides the extra bits.
a) 9-Bit A/D
b) $10-$ Bit A/D

Protecting the Input


High Accuracy Comparators


## Applications (Continued)

Convert 8 Thermocouples with only One Cold-Junction Compensator


Uses the pseudo-differential mode to keep the differential inputs constant with changes in reference temperature ( $T_{\text {REF }}$ ).


TL/H/5583-19

[^5]
-1500V isolation


- No additional connections

- Timing arranged for 40 kHz , could be changed up or down by component change
- 10\% CLK frequency change without component change OK

Applications (Continued)
Two Wire 1-Channel Interface


- Simpler version of 8 -channel
- $\overline{\text { CS }}$ derived from long CLK pulse

TL/H/5583-22
Ordering Information

| Part Number | Analog Input Channels | Total Unadjusted Error | Package | Temperature Range |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { ADC0831BJ } \\ & \text { ADC0831BCJ } \\ & \text { ADC0831BCN (COP431BN) } \end{aligned}$ | 1 | $\pm 1 / 2$ | Hermetic (J) <br> Hermetic (J) <br> Molded ( N ) | $\begin{gathered} -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ -0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ \hline \end{gathered}$ |
| $\begin{aligned} & \text { ADC0831CCJ } \\ & \text { ADC0831CCN (COP431CN) } \end{aligned}$ |  | $\pm 1$ | Hermetic (J) <br> Molded (N) | $\begin{aligned} & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & -0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \end{aligned}$ |
| ADC0832BJ <br> ADC0832BCJ <br> ADC0832BCN (COP432BN) | 2 | $\pm 1 / 2$ | Hermetic (J) <br> Hermetic (J) <br> Molded (N) | $\begin{gathered} -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ -0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ \hline \end{gathered}$ |
| ADC0832CCJ <br> ADC0832CCN (COP432CN) |  | $\pm 1$ | Hermetic (J) <br> Molded (N) | $\begin{aligned} & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & -0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \end{aligned}$ |
| $\begin{aligned} & \text { ADC0834BJ } \\ & \text { ADC0834BCJ } \\ & \text { ADC0834BCN (COP434BN) } \end{aligned}$ | 4 | $\pm 1 / 2$ | Hermetic (J) <br> Hermetic (J) <br> Molded ( N ) | $\begin{gathered} -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ -0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \end{gathered}$ |
| ADC0834CCJ ADC0834CCN (COP434CN) |  | $\pm 1$ | Hermetic (J) <br> Molded (N) | $\begin{aligned} & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & -0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \end{aligned}$ |
| ADC0838BJ <br> ADC0838BCJ <br> ADC0838BCN (COP438BN) | 8 | $\pm 1 / 2$ | Hermetic (J) <br> Hermetic (J) <br> Molded (N) | $\begin{aligned} & -55^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & -0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |
| ADC0838CCJ <br> ADC0838CCN (COP438CN) |  | $\pm 1$ | Hermetic (J) <br> Molded (N) | $\begin{aligned} & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & -0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \end{aligned}$ |

## COP452L/COP352L Frequency Generator and Counter

## General Description

The COP452L and COP352L are peripheral members of the COPSTM family fabricated using N -channel silicon gate MOS technology. Containing two independent 16 -bit counter/register pairs, they are well suited to a wide variety of tasks involving the measurement and/or generation of times and/or frequencies. Included in the features are multiple tone generation, precise duty cycle generation, event counting, waveform measurement, frequency bursts, delays, and "white noise" generation. An on-chip zero crossing detector can trigger a pulse with a programmed delay and duration. The COP352L is the extended temperature version of the COP452L. The COP352L is the functional equivalent of the COP452L.
The COP452L series peripheral devices can perform numerous functions that a microcontroller alone cannot perform. They can execute one or more complex tasks, attaining higher accuracies over a broader frequency range than a microcontroller alone. These devices remove repetitive yet demanding counting, timing, and frequency related functions from the microcontroller, thereby freeing it to perform other tasks or allowing the use of a simpler microcontroller in the system.

Features
■ Unburdens microcontroller by performing "mundane" tasks

- Wider range and greater accuracy than microcontroller alone
- Generates frequencies, frequency bursts, and complex waveforms
- Measures waveform duty cycle
- Two independent pulse/event counters
- True zero crossing detector triggers output pulse
- White noise generator
- Compatible with all COP400 microcontrollers
- MICROWIRETM compatible serial I/O
- 14-pin package
m Single supply operation (4.5V-6.3V, COP452L; 4.5V-5.5V, COP352L)
- Low cost
- Crystal or external clock
( 25 kHz to 2.1 MHz , COP452L)
( 64 kHz to $2.1 \mathrm{MHz}, \mathrm{COP} 352 \mathrm{~L}$ )
- TTL compatible


## Block Diagram



TL/DD/6155-1

## COP452L

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin (except ZI)
relative to GND

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+7.0 \mathrm{~V} \\
-0.8 \text { to }+10 \mathrm{~V}
\end{array}
$$

Voltage at Pin ZI relative to GND
Sink Current, Output OA
Sink Current, All Other Outputs 5 mA
Total Sink Current 35 mA
Source Current, Outputs OA, OB 5 mA
Source Current, All Other Outputs 1 mA

Total Source Current
10 mA
Ambient Operating Temperature
Ambient Storage Temperature
Lead Temperature (Soldering, 10 sec .)
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
$300^{\circ} \mathrm{C}$
Power Dissipation
0.5 W at $25^{\circ} \mathrm{C}$ 0.2 W at $70^{\circ} \mathrm{C}$

Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}}+70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ (COP452L), unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 | 6.3 | V |
| Operating Supply Current | All Outputs Open |  | 14 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> DI, INB, ENB, SK, $\overline{C S}$ <br> Logic High <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low (VIL) <br> ZI Input Voltage | $\begin{aligned} & V_{C C}=\operatorname{Max} \\ & V_{C C}=5.0 V \pm 5 \% \\ & V_{C C}=\operatorname{Max} . \\ & V_{C C}=5.0 V \pm 5 \% \end{aligned}$ | $\begin{array}{r} 3.0 \\ 2.0 \\ \\ 3.0 \\ 2.0 \\ \\ -0.8 \\ \hline \end{array}$ | $\begin{gathered} 0.4 \\ \\ \\ 0.8 \\ +10 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| Impedance to GND at ZI |  | -1.6 | 7.8 | $\mathrm{k} \Omega$ |
| ZI Offset Voltage | (Note 1) |  | 150 | mV |
| Output Voltage Levels <br> TTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \pm 5 \% \\ & \mathrm{I}_{\mathrm{OH}}=100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=-1.6 \mathrm{~mA} \\ & \hline \end{aligned}$ | 2.4 | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Maximum Allowable Output Current Levels <br> Sink Current <br> OA <br> All Other Outputs Total Sink Current Source Current OA, OB All Other Outputs Total Source Current | (Note 2) <br> (Note 2) <br> (Note 3) <br> (Note 2) <br> (Note 2) <br> (Note 3) |  | $\begin{array}{r} 15 \\ 5.0 \\ 35 \\ \\ -5.0 \\ -1.0 \\ -10 \end{array}$ | mA <br> mA <br> mA <br> mA <br> mA <br> mA |

Note 1: Zl offset voltage is the absolute value of the difference between the voltage at Zl and ground (pin 9 ) that will cause the zero detect circuit output to change state. This is the maximum value which takes into account the worst case effects of process, temperature, voltage, and gain variation.
Note 2: The maximum current for the specified pin must be limited to this value or less.
Note 3: The total current in the device must be limited to this value or less.

## COP452L

AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| CKI Input Frequency (fiN) | $\begin{aligned} & \div 4 \text { Mode } \\ & \div 1 \text { Mode } \end{aligned}$ | $\begin{aligned} & 100 \\ & 25 \end{aligned}$ | $\begin{gathered} 2100 \\ 525 \end{gathered}$ | $\begin{aligned} & \mathrm{kHz} \\ & \mathrm{kHz} \end{aligned}$ |
| Duty Cycle $\div 1$ | $\begin{aligned} & \div 4 \\ & \div 1 \end{aligned}$ | $\begin{aligned} & 30 \\ & 45 \end{aligned}$ | $\begin{aligned} & 55 \\ & 55 \end{aligned}$ | $\begin{aligned} & \% \\ & \% \end{aligned}$ |
| Rise Time ( $\mathrm{t}_{\mathrm{r}}$ ) | $\mathrm{fiN}^{\mathrm{N}}=2.1 \mathrm{MHz}$ |  | 50 | ns |
| Fall Time ( $\mathrm{t}_{\mathrm{f}}$ ) | $\mathrm{fiN}^{\mathrm{N}}=2.1 \mathrm{MHz}$ |  | 40 | ns |
| SK Input Frequency |  | 25 | 250 | kHz |
| SK Duty Cycle |  | 30 | 70 | \% |
| Internal Clock Frequency ( $\mathrm{f}_{\mathrm{l}}$ ) |  | 25 | 525 | kHz |
| Internal Count Rate |  | 0 | $\mathrm{f}_{\mathrm{I}} / 2$ | Hz |
| Output Frequency |  | $\mathrm{f}_{\mathrm{l}} / 131072$ | $\mathrm{f}_{\mathrm{I}} / 2$ | Hz |
| Inputs <br> DI tsetup thold |  | $\begin{gathered} 800 \\ 1.0 \end{gathered}$ |  | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Outputs CKO $\begin{array}{ll}t_{\mathrm{pd} 1} \\ & \mathrm{t}_{\mathrm{pdO}}\end{array}$ | $C_{L}=50 \mathrm{pF}$ |  | 0.2 0.2 | $\mu s$ $\mu s$ |
| ZO $\begin{aligned} & t_{\text {pd1 }} \\ & \\ & t_{\text {pd0 }}\end{aligned}$ | $\mathrm{ZI}=$ Sine Wave (Figure 4) |  | 0.7 0.6 | $\mu \mathrm{s}$ |
| $\begin{array}{ll} \mathrm{DO} & \mathrm{t}_{\mathrm{pd} 1} \\ & t_{\mathrm{pd}} \end{array}$ | $C_{L}=50 \mathrm{pF}$ |  | 1.0 0.6 | $\mu \mathrm{s}$ |
| $\mathrm{OA} \quad t_{p d 1}$ | $\begin{aligned} & C_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V} \end{aligned}$ |  | 0.7 0.8 | $\mu \mathrm{s}$ |
|   <br> OB $\mathrm{t}_{\text {PDO }}$ <br> $\mathrm{t}_{\text {pd1 }}$ <br>  <br> $\mathrm{t}_{\text {pd0 }}$ |  |  | 0.8 1.0 0.4 | $\begin{gathered} \mu \mathrm{S} \\ \mu \mathrm{~S} \\ \mu \mathrm{~S} \end{gathered}$ |

## COP352L

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin (except ZI)
relative to GND

$$
\begin{array}{r}
-0.5 \mathrm{~V} \text { to }+7.0 \mathrm{~V} \\
-0.8 \mathrm{~V} \text { to }+10 \mathrm{~V} \\
15 \mathrm{~mA} \\
5 \mathrm{~mA} \\
35 \mathrm{~mA} \\
5 \mathrm{~mA} \\
1 \mathrm{~mA}
\end{array}
$$

| Total Source Current | 10 mA |
| :--- | ---: |
| Ambient Operating Temperature | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Ambient Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, 10 sec.) | $300^{\circ} \mathrm{C}$ |
| Power Dissipation | 0.5 W at $25^{\circ} \mathrm{C}$ |
|  | 0.125 W at $85^{\circ} \mathrm{C}$ |
| Note: Absolute maximum ratings indicate limits beyond |  |
| which damage to the device may occur. DC and AC electri- |  |
| cal specifications are not ensured when operating the de- |  |
| vice at absolute maximum ratings. |  |

## DC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 | 5.5 | V |
| Operating Supply Current | All Outputs Open |  | 16 | mA |
| Input Voltage Levels <br> CKI Input Levels <br> Logic High ( $\mathrm{V}_{\mathrm{H}}$ ) <br> Logic Low ( $\mathrm{V}_{\mathrm{IL}}$ ) <br> DI, INB, ENB, SK, CS <br> Logic High <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low (VIL) <br> Zl Input Voltage | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{Max} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% \\ & V_{\mathrm{CC}}=\operatorname{Max} . \\ & V_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% \end{aligned}$ | $\begin{aligned} & 3.0 \\ & 2.2 \end{aligned}$ <br> 3.0 <br> 2.2 $-0.8$ | $\begin{gathered} 0.3 \\ \\ \\ 0.6 \\ +10 \\ \hline \end{gathered}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ |
| Impedance to GND at ZI |  | 1.6 | 7.8 | k $\Omega$ |
| ZI Offset Voltage | (Note 1) |  | 150 | mV |
| Output Voltage Levels TTL Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% \\ & \mathrm{I}_{\mathrm{OH}}=100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=-1.6 \mathrm{~mA} \\ & \hline \end{aligned}$ | 2.4 | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Maximum Allowable Output <br> Current Levels <br> Sink Current <br> OA <br> All Other Outputs <br> Total Sink Current <br> Source Current <br> OA, OB <br> All Other Outputs <br> Total Source Current | (Note 2) <br> (Note 2) <br> (Note 3) <br> (Note 2) <br> (Note 2) <br> (Note 3) |  | $\begin{array}{r} 15 \\ 5.0 \\ 35 \\ \\ -5.0 \\ -1.0 \\ -10 \\ \hline \end{array}$ | mA <br> mA <br> mA <br> mA <br> mA <br> mA |

Note 1: Zl offset voltage is the absolute value of the difference between the voltage at ZI and ground (pin 9 ) that will cause the zero detect circuit output to change state. This is the maximum value which takes into account the worst case effects of process, temperature, voltage, and gain variation.
Note 2: The maximum current for the specified pin must be limited to this value or less.
Note 3: The total current in the device must be limited to this value or less.

## COP325L

AC Electrical Characteristics $-40^{\circ} \mathrm{C} \leq T_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}$ unless otherwise specified

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| CKI Input Frequency ( f (N) | $\begin{aligned} & \div 4 \text { Mode } \\ & \div 1 \text { Mode } \end{aligned}$ | $\begin{gathered} 256 \\ 64 \end{gathered}$ | $\begin{gathered} 2100 \\ 525 \end{gathered}$ | $\begin{aligned} & \mathrm{kHz} \\ & \mathrm{kHz} \end{aligned}$ |
| Duty Cycle | $\begin{aligned} & \div 4 \\ & \div 1 \end{aligned}$ | $\begin{aligned} & 35 \\ & 50 \end{aligned}$ | $\begin{aligned} & 55 \\ & 55 \end{aligned}$ | $\begin{aligned} & \% \\ & \% \end{aligned}$ |
| Rise Time ( $\mathrm{t}_{\mathrm{r}}$ ) | $\mathrm{f}_{\mathrm{IN}}=2.1 \mathrm{MHz}$ |  | 50 | ns |
| Fall Time ( $\mathrm{t}_{\mathrm{f}}$ ) | $\mathrm{fiN}^{\mathrm{N}}=2.1 \mathrm{MHz}$ |  | 40 | ns |
| SK Input Frequency |  | 25 | 250 | kHz |
| SK Duty Cycle |  | 30 | 70 | \% |
| Internal Clock Frequency ( $\mathrm{f}_{\mathrm{l}}$ ) |  | 64 | 525 | kHz |
| Internal Count Rate |  | 0 | $\mathrm{f}_{1} / 2$ | Hz |
| Output Frequency |  | $\mathrm{f}_{\mathrm{l}} / 131072$ | $\mathrm{f}_{1} / 2$ | Hz |
| Inputs <br> DI t SETUP <br>  <br> $t_{\text {HOLD }}$ |  | $\begin{array}{r} 800 \\ 1.0 \\ \hline \end{array}$ |  | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Outputs  <br> CKO  <br>  $t_{\text {pd1 }}$ <br> ZO $\mathrm{t}_{\text {pd0 }}$ <br>  $\mathrm{t}_{\text {pd1 }}$ <br> DO $\mathrm{t}_{\text {pd0 }}$ <br>  $\mathrm{t}_{\text {pd1 }}$ <br> OA $\mathrm{t}_{\text {pd0 }}$ <br>  $\mathrm{t}_{\text {pd1 }}$ <br>   <br> OB $\mathrm{t}_{\text {pd0 }}$ <br>  $\mathrm{t}_{\text {pd1 }}$ <br>  $\mathrm{t}_{\text {pdo }}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{ZI}=\text { sine wave (Figure 4) } \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V} \end{aligned}$ |  | $\begin{gathered} 0.25 \\ 0.25 \\ 0.8 \\ 0.7 \\ 1.1 \\ 0.7 \\ 0.7 \\ \\ 0.8 \\ 1.0 \\ 0.4 \end{gathered}$ | $\mu \mathrm{s}$ $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{S}$ $\mu \mathrm{s}$ $\mu \mathrm{s}$ $\mu \mathrm{s}$ <br> $\mu \mathrm{s}$ $\mu \mathrm{S}$ $\mu \mathrm{s}$ |

## Timing Diagrams



TL/DD/6155-2
FIGURE 2a. CKO Output Timing


TL/DD/6155-3
FIGURE 2b. OA and OB Output Timing

## Timing Diagrams (Continued)



TL/DD/6155-4
FIGURE 3a. Synchronous Data Timing


TL/DD/6155-5
FIGURE 3b. Instruction Timing (Except Read/Write)


TL/DD/6155-6
FIGURE 3c. Write Instruction Timing


FIGURE 3d. Read Instruction Timing

Timing Diagrams (Continued)


TL/DD/6155-8
FIGURE 4a. ZO Timing, $V_{\text {OFFSET }}>0 V$


FIGURE 4b. ZO Timing, VOFFSET $^{<} \mathbf{O V}$

## Pin Descriptions

| Pin | Description | Pin | Description |
| :--- | :--- | :--- | :--- |
| ZO | Zero Cross Output Signal | CKI | Crystal Oscillator Input |
| OA | Counter A, Logic Controlled Output | GND | Ground |
| INB | Counter B, External Input | CS | Chip Select |
| ENB | Enable for INB | SK | Serial Data I/O Clock Input |
| OB | Counter B Output | DI | Serial Data Input |
| VCC | Power Supply | DO | Serial Data Output |
| CKO | Crystal Oscillator Output | ZI | AC Waveform Input, Counter A External Input |

## Connection Diagram

## Dual-In-Line Package



TL/DD/6155-10
FIGURE 5. Pin Connection Diagram
Order Number COP452D, COP352D, COP452N or COP352N
See NS Package Number D14D or N14A

Typical Performance Characteristics


FIGURE 7. COP352L

## Functional Description

The COP452L and COP352L are functionally identical devices. They differ only in $\mathrm{V}_{\mathrm{CC}}$ range and/or operating temperature range, and certain electrical parameters associated with those temperature and voltage ranges. The following information will refer only to the COP452L. All the information, however, applies equally to the COP452L and COP352L.

## INSTRUCTION SET AND OPERATING MODES

The COP452L has ten instructions and eleven operating modes as indicated in Figure 8. The information for the instruction or mode is sent to the COP452L via the serial interface. The MSB is always a " 1 " and is properly viewed as a start bit. The second MSB identifies the communication as an instruction or a mode. The lower four bits contain the command for the device.

| Instruction | $\begin{aligned} & \text { Opcode } \\ & \text { MSB LSB } \end{aligned}$ | Comments |
| :---: | :---: | :---: |
| LDRB | 100000 | Load register B from DI |
| LDRA | 100001 | Load register A from DI |
| RDRB | 100010 | Read register B to DO |
| RDRA | 100011 | Read register A to DO |
| TRCB | 100100 | Transfer register B to counter B |
| TRCA | 100101 | Transfer register A to counter A |
| TCRB | 100110 | Transfer counter B to register B |
| TCRA | 100111 | Transfer counter A to register A |
| CK1 | 101000 | CKI divide by one |
| CK4 | 101001 | CKI divide by four |
| LDM | 11xxxx | Load mode latches |

FIGURE 8a. COP452L Instruction Set

| Operating Mode | Opcode <br> MSB LSB |
| :--- | :---: |
| Reset | 111111 |
| Dual Frequency | 110000 |
| Frequency and Count | 110100 |
| Dual Count | 110101 |
| Number of Pulses | 110010 |
| Duty Cycle | 110011 |
| Waveform Measurement | 110110 |
| Triggered Pulse | 110001 |
| Triggered Pulse and Count | 110111 |
| White Noise and Frequency | 111000 |
| Gated White Noise | 111001 |

FIGURE 8b. COP452L Operating Modes
A block diagram of the COP452L is given in Figure 1. Positive logic is used. The COP452L can execute ten instructions as indicated in Figure 8a, and has eleven operating modes. The operating mode is under user software control. The device basically consists of two sixteen bit shift registers and two sixteen bit binary down counters organized as two register-counter pairs. In most operating modes, the two register-counter pairs are completely independent of one another. For frequency generation, both the register and counter of a given pair are utilized. The counter counts down to zero where a toggle flip-flop is toggled. Then the data in the register is loaded, automatically, to the counter
and the process continues. A similar procedure is used in the duty cycle mode and number of pulses modes. For counting, the counters count the pulses at their respective inputs. There is no automatic counter-register transfer in the count modes. The counters wraparound from 0 to FFFF in the count modes. Data I/O is via the serial port and the registers. The counters are not involved in the input/output process at all.
The device requires a low chip select signal. When the device is selected ( $\overline{\mathrm{CS}}$ low) the driver on the DO pin is enabled and the device will accept data at DI on each SK pulse. When the device is deselected ( $\overline{\mathrm{CS}}$ high) the DO driver is TRI-STATE ${ }^{\circledR}$ and the I register is reset to 0 . Note that chip select does not affect any other portion of the device. The mode latches are not affected. The COP452L will continue to operate in the mode specified by the user until the mode is changed by the user.
The COP452L contains a clock generator. The user may connect a crystal network to CKI and CKO or he may drive CKI from an external oscillator. Certain RC and LC networks may also be used. See the applications for further information.
The user also has control over whether the clock generator divides the CKI signal by 4 or 1 . This allows the user to quickly get a 4 to 1 change in frequency output or input count rates. Alternatively, it allows the user to use a higher speed crystal or clock generator. The internal clock frequency (the frequency after the divider) must remain between the specified limits to guarantee proper operation. The state of the divider is not affected by $\overline{\mathrm{CS}}$.
There is an internal power-on reset circuit which places the device in the Reset mode (mode latches all set to 1) and sets the clock divider to divide by four. If the CKI frequency is less than four times the minimum internal frequency the first access of the COP452L must be the command to set the divider to divide by 1 . This command will be accepted and will be processed. Proper operation of the COP452L is not guaranteed if the internal frequency is less than the specified minimum. The power-on reset circuit does not affect the counter and registers of the COP452L.
When the COP452L is subjected to rapid power supply cycling, the internal power on reset will not function. Power must be removed for at least 20 seconds to allow restoration of internal reset circuitry. If the application requires power on-off cycles more frequently than once each 20 seconds the software reset with proper CKI divide by must be used to establish the initial state of the COP452L.

## INSTRUCTION DESCRIPTION

1. Load Register (LDRA/LDRB)-The selected register (A/B) is loaded with 16 bits of data shifted in on DI and clocked in by SK.
2. Read Register (RDRA/RDRB)-The data in the selected register $(A / B)$ is shifted out serially onto DO. At the same time the data is recirculated back to the register.
3. Load Counter (TRCA/TRCB)-The contents of the selected register are transferred to its associated counter. (Counter $A$ is loaded from register $A$; counter $B$ is loaded from register B.) The contents of the register are unaffected.
4. Copy Counter (TCRA/TCRB)-The contents of the selected counter are transferred to its associated register. (Counter A loads register A; counter B loads register B.) The contents of the counter are unaffected.

## Functional Description (Continued)

5. CKI Divide by One-The oscillator divider at the CKI input is set to divide by one. The internal frequency is therefore equal to the CKI frequency. This instruction should not be used if the CKI frequency is greater than the maximum internal frequency.
6. CKI Divide by Four-The oscillator divider at the CKI input is set to divide by four. The internal frequency is therefore equal to one-fourth of the CKI frequency. This instruction should not be used if the CKI frequency is less than four times the minimum internal frequency.
7. Load Mode Latches-The four mode latches are loaded with the lower four bits of the instruction.

## MODE DESCRIPTION

1. Reset Mode-This mode sets OA and OB to " 0 ". The mode latches are all set to "1". No counting occurs; the COP452L is in an idle condition. The registers and counters are not altered in any way.
2. Dual Frequency-Two frequencies are generated-one at output OA and one at output OB. The period of the square wave at $O A$ is determined by the contents of register $A$. The period of the square wave at $O B$ is determined by the contents of register B. In frequency generation modes, the counters count down until they reach zero. At that point the output toggles and the counters are automatically loaded from the respective registers. The counters are only loaded when they count down to zero. Therefore it may be necessary to initially load the counters. The frequency outputs at OA and OB are completely independent of one another. The respective counter inputs (INB, ZI) have no effect on the counters in this mode.

$t_{A}=(A+1) t$
$t_{B}=(B+1) t$
$0 \leq A \leq 65535 ; 0 \leq B \leq 65535$
Where: $\quad A=$ Contents of register $A$
$B=$ Contents of register B
$t=$ Period of internal clock
$=$ Period of CKI oscillator ( $\div$ mode)
$=4 \times$ period of CKI oscillator ( $\div 4$ mode $)$
Period of output square wave $=2(N+1) t$
Where $t$ is devined above
$N=$ Contents of register
$0 \leq N \leq 65535\left(0 \leq N \leq\right.$ FFFF $\left._{16}\right)$
3. Frequency and Count-A single frequency is output at OA. Counter B counts external pulses on INB (when ENB $=1$ ). There is no automatic clear of the counter. Since counter B counts down from whatever state it is in it is usually desirable to preload the counter. Preloading the counter with all zeroes will give the two's complement of the count. Preloading the counter with all ones will give the one's complement of the count.

$t_{A}=(A+1) t$
Where: $\quad A=$ Contents of register $A$
$t=$ Period of internal clock (as previously defined)
$0 \leq A \leq 65535\left(0 \leq A \leq\right.$ FFFF $\left._{16}\right)$
$O B$ toggles each time counter $B$ counts through zero.
Maximum count rate at $\operatorname{INB}=\hat{f}_{1} / 2$
Where: $\quad f_{\mathrm{I}}=$ Internal Clock frequency
$=$ CKI input frequency ( $\div 1$ mode)
$=$ CKI input frequency $\div 4(\div 4$ mode $)$
Minimum pulse width required for reliable counting $=\mathbf{t}$ where $t=$ period of internal clock.
4. Dual Count-In this mode counter A and counter B are enabled as external event or pulse counters. Counter $A$ counts pulses at Zl and counter B counts pulses at INB (when ENB $=1$ ). There is no automatic clear of either counter. Each counter counts down from whatever state it starts in. Thus, to ease reading the information, the counters should be preloaded. Preloading the counters with all zeroes will give the two's complement of the count. Preloading the counters with all ones will give the one's complement of the count. The circuitry which decrements the counters is enabled by the high to low transition at the count input. There is no interaction between the two register counter pairs.
OA toggles every time counter A counts through " 0 ".
OB toggles every time counter B counts through " 0 ".
The counters, when counting, count down and wrap around from 0 to FFFF and continue counting down.
Maximum count rate $=f_{l} / 2$
where: $f_{j}=$ internal clock frequency
Minimum pulse width $=t$
where: $\mathbf{t}=$ period of internal clock
(as previously defined).
There is no requirement that the count signal be symmetrical. The pulse width low must be at least equal to $t$. The pulse width high must also be at least equal to $t$.
5. Number of Pulses Mode-This mode outputs at OA a specified number of pulses of a specified width. The number of pulses is specified by the contents of register B. The pulse width is specified by the contents of register $A$.
[^6]
## Functional Description (Continued)

OB toggles each time a pulse train is generated at OA. The pulse is generated each time the COP452L is selected and an instruction is set to the device. Counter $B$ is automatically loaded from register B after the N pulses are generated. Counter $A$ is automatically loaded from register $A$ at each transition of OA. Therefore simply reloading the number of pulses mode will repeat the previous sequence.
6. Duty Cycle Mode-This mode generates a rectangular waveform at OA. The pulse width high is specified by the contents of register $A$. The pulse width low is specified by the contents of register B . A combination square wave signal is generated at $O B$.


08


$$
\begin{gathered}
t_{A}=A t \\
t_{B}=B t \\
t_{A}+B=(A+B) t \\
\text { Where: } \quad A=\text { Contents of register } A \\
B=\text { Contents of register } B \\
t=\text { period of internal clock } \\
\\
\\
\\
\\
1 \leq A \leq 65535, A \neq 0\left(1 \leq A \leq \text { FFFF }_{16}\right) \\
0 \leq B \leq 65535, B \neq 0\left(1 \leq B \leq F F F F_{16}\right)
\end{gathered}
$$

7. Waveform Measurement Mode-This mode measures the high and low times of an external waveform at INB (with ENB $=1$ ). Counter A counts the pulse width high and counter B counts the pulse width low. On the high to low transition counter A is transferred to register A and then cleared. On the low to high transition counter B is transferred to register B and then cleared. The counters, therefore, count down from zero. Therefore the value read from the registers is a two's complement value. The transfer from the counter to register is inhibited during a read instruction.
The outputs $O A$ and $O B$ toggle each time the respective counter counts through zero.
The minimum pulse width, either high or low, that can be measured, is the period of the internal frequency. The maximum pulse width that can be measured is the maximum count (65535) multiplied by the period of the internal frequency.

INB

8. Triggered Pulse Mode-This mode outputs a pulse triggered by the zero crossing of a signal at ZI . The delay from the zero crossing is specified by the contents of register $A$. The pulse width is specified by the contents of register $B$. Input INB is ignored. See applications section for further information.

9. Triggered Pulse and Count Mode-This mode outputs a pulse at OA triggered by the zero crossing of a signal at ZI . The contents of register A specify the delay from the zero crossing. The pulse remains high until the next zero crossing of the signal at Zl .
Independently of the zero detection, counter B counts external events at INB (when ENB $=1$ ). The conditions on the counter as described previously apply here.


## Functional Description (Continued)

10. White Noise and Frequency Mode-Register $A$ is converted to a 17 -stage shift register generator for the generation of pseudo-random noise at output OA. OB outputs a square wave whose period is specified by the contents of register B . The shift register generator is shifted at the internal frequency ( $=$ CKI frequency or $1 / 4$ CKI frequency depending on the oscillator divider). See the applications section for more information on the white noise generator.
OA


TL/DD/6155-24
Where: $\quad \mathrm{B}=$ Contents of register B
$t=$ period of internal clock
(as previously defined)
$0 \leq \mathrm{B} \leq 65535 \quad\left(0 \leq \mathrm{B} \leq \mathrm{FFFF}_{16}\right)$
11. Gated White Noise Mode-This mode generates pseu-do-random noise ANDed with a square wave. OA outputs this combined signal. OB outputs a square wave frequency. Register $A$ is converted into a 17 -stage shift register generator which is shifted at the internal frequency rate. Counter $A$ is not used. Counter $B$ and register $B$ are used in the frequency generation. See the applications section for further information on the white noise generation.


## GENERAL NOTES

The master timing reference in the COP452L is the internal frequency. This is the CKI frequency after it has passed through the divider. This frequency must remain within its specified limits. The maximum count rate at either input is this frequency divided by 2 . The minimum pulse width that can be measured is the period of this frequency.
$\overline{\mathrm{CS}}$, other than removing DO from the TRI-STATE condition and allowing data to come into the I register via DI, does not affect the operation of the device. $\overline{\mathrm{CS}}$ must go high between accesses in order to clear the I register. Since the I register is cleared when $\overline{C S}$ goes high, the user must insure that $\overline{\mathrm{CS}}$ does not go high before the COP452L has accepted the
information in the I register. See the software interface section for further explanation on this point. CS does not affect the mode latches.
In those modes where there is an automatic transfer from the register to the counter (frequency generation, duty cycle, number of pulses, triggered pulse), care must be exercised when reading or writing the register. To insure proper, "glitch-free" operation, one of the two procedures below must be followed:

1. Place the COP452L in the RESET mode.
2. Read or write the appropriate register.
3. Place the COP452L back in the original mode.

Alternatively:

1. Read or write the appropriate register.
2. Send the instruction to copy the appropriate register to its counter.
WARNING: Failure to observe one or the other of these procedures can cause some faulty output conditions.
The COP452L powers up in the RESET mode and with oscillator divide by 4 . If the CKI input frequency is less than 4 times the minimum internal clock frequency the user must set the oscillator divider to divide by 1 before attempting any operation with the COP452L. The instruction setting the oscillator divider will be accepted regardless of the value of the internal clock frequency.
Caution: Failure to observe this requirement will result in the improper operation of the COP452L.

## Applications Information <br> \section*{ZERO CROSS}

The ZI input normally requires a resistor and diode external to the device as indicated in Figure 9a. The resistor is part of a voltage divider used to ensure that the voltage at pin Zl does not exceed 10 V peak and to protect the diode which is required to clamp the negative voltage swing at the input to less than -0.8 V . Figure $9 b$ is the recommended input circuit if logic level pulses are input to ZI for counting.
As indicated above, the input voltage at ZI must not exceed 10 V peak. For inputs less than 10 V peak, the resistor in Figure $9 a$ is required only to protect the diode. Otherwise, the resistor should be selected to guarantee that the voltage at pin Zl does not exceed 10 V peak. Figure 10 shows this resistor ( $\mathrm{R}_{\mathrm{S}}$ ) and the impedance ( $\mathrm{R}_{\mathrm{IN}}$ ) which forms the first part of the input circuit at ZI . The absolute value of $\mathrm{RIN}_{\mathrm{IN}}$ can vary widely with process variation. The user should compute the divider with $\mathrm{R}_{\mathrm{S}}$ and the worst case maximum of $R_{I N}$ so that the voltage at pin Zl is 10 V or less. The following relationship should be used when the input voltage is greater than 10 V peak:

$$
\frac{R_{\operatorname{IN}(M A X .)}}{R_{S}+R_{\operatorname{IN}(M A X .)}} \times V_{\mathbb{I N}} \leq 10 \mathrm{~V} \text { peak }
$$

Substituting the maximum value for $R_{I N}$ and solving for $R_{S}$ gives:

$$
\mathrm{R}_{\mathrm{S}} \leq \frac{\mathrm{V}_{\mathrm{IN}}}{10} \times 7.8 \mathrm{k}-7.8 \mathrm{k}
$$

where: $\mathrm{V}_{\mathrm{IN}}=$ peak input voltage.
Note that this equation is not valid for $V_{I N}$ less than 10 V . In this case, the value of $R_{S}$ is chosen primarily for protection of the diode and not to divide the voltage down to acceptable values.

## Applications Information (Continued) zero cross offset

As the electrical characteristics indicate, the Zl input has a worst case offset of 150 mV in the zero crossing detection. Therefore, the output of the zero cross detection circuit will change state within $\pm 150 \mathrm{mV}$ of zero volts. There are no directional characteristics to this, i.e., approaching zero from the positive or negative direction has no effect on where the output of the zero cross detection circuit will change state (see Figure 4). The offset further indicates that the voltage at pin ZI must exceed 150 mV peak in order to guarantee that the zero crossings will be detected and the appropriate signals generated.

## TRIGGERED PULSE MODES

The delays from the zero crossing in the triggered pulse modes are measured from the point where the output of the zero crossing detection circuit changes state-the trip point of this circuit. As stated before, the delay time from this trip point is:

$$
T=(A+1.5) t
$$

where: $T=$ delay time from trip point
$A=$ contents of register $A$
$t=$ period of internal clock
The delay from the true zero crossing of the input waveform has other parameters that must be considered. The equation is of the form:

$$
T=(A+1.5) t \pm\left|X_{1}\right|+X_{2}+X_{3}
$$

where: $T, A, t$ are as defined previously
$X_{1}=$ time for input waveform to reach the trip point of the zero cross detection circuit
$X_{2}=$ propagation delay through the zero cross detection circuit
$X_{3}=$ input synchronization delay
Parameter $X_{1}$ is dependent on the peak voltage at pin ZI and on the frequency of the input signal. The peak voltage at $Z I$ is in turn dependent on the $R_{S}-R_{I N}$ voltage divider and the input voltage. The $X_{1}$ time is added or subtracted because the trip point of the zero cross detection circuit may be either above or below zero. In the worst case, the trip point is the maximum offset of 150 mV . For a sine wave signal, $X_{1}$ is determined as follows:

$$
\begin{aligned}
& V_{\text {OFFSET }}=V_{p} \sin \left[2 \pi f\left(X_{1}\right)\right] \\
& X_{1}=\frac{1}{2 \pi f} \arcsin \frac{V_{\text {OFFSET }}}{V_{P}}
\end{aligned}
$$

and

$$
V_{P}=V_{I N} \frac{R_{I N}}{R_{S}+R_{O N}}
$$

substituting we have

$$
X_{1}=\frac{1}{2 \pi f} \arcsin \left(V_{\text {OFFSET }} \frac{R_{S}+R_{I N}}{V_{I N} R_{I N}}\right)
$$

where: $V_{\text {OFFSET }}=$ zero crossing offset or trip point
$V_{P}=$ peak input voltage at pin ZI
$f=$ frequency of input signal
$\mathrm{R}_{\mathbb{N}}=$ internal impedance to ground at pin ZI
$R_{S}=$ external series resistance at ZI
Both $V_{\text {OFFSET }}$ and $R_{\text {IN }}$ vary from device to device. It is clear from the equation above that the maximum value of $\left|X_{1}\right|$ is
obtained when $V_{\text {OFFSET }}$ is at its maximum of 150 mV and $R_{I N}$ is at its minimum of $2.6 \mathrm{k} \Omega$. The minimum value of $\left|X_{1}\right|$ is obtained if $V_{\text {OFFSET }}$ is 0 . Using this information, the following range of $\left|X_{1}\right|$ is obtained:

$$
0 \leq\left|X_{1}\right| \leq \frac{1}{2 \pi f} \arcsin 0.15 \frac{R_{\mathrm{S}}+2.6 k}{V_{I N} \times 2.6 k}
$$

Parameter $X_{2}$ is the propagation delay through the zero crossing detection circuit and its range is given by:

$$
0.3 \mu \mathrm{~s} \leq \mathrm{X}_{2} \leq 0.6 \mu \mathrm{~s}
$$

Parameter $X_{3}$ is the internal synchronization delay and is dependent upon when the zero crossing occurs relative to the internal timing which reads the output of the zero crossing detection circuit. The range for $X_{3}$ is:

$$
0 \leq x_{3} \leq \frac{t}{2}
$$

where: $t=$ period of internal clock
With the preceding information, minimum and maximum values of the delay from true zero can be derived by simply substituting into the original equation.

$$
\begin{aligned}
T_{\mathrm{MIN}}= & (A+1.5) t-\frac{1}{2 \pi \mathrm{f}} \arcsin \left(0.15 \frac{R_{\mathrm{S}}+2.6 \mathrm{k}}{\mathrm{~V}_{I N} \times 2.6 \mathrm{k}}\right)+0.3 \mu \mathrm{~s} \\
\mathrm{~T}_{\mathrm{MAX}}= & (\mathrm{A}+1.50) \mathrm{t}+\frac{1}{2 \pi \mathrm{f}} \arcsin \left(0.15 \frac{R_{\mathrm{S}}+2.6 \mathrm{k}}{V_{I N} \times 2.6 \mathrm{k}}\right) \\
& +0.6 \mu \mathrm{~s}+\frac{\mathrm{t}}{2}
\end{aligned}
$$

The preceding information should enable the user to determine more closely the actual delay from zero of output OA of the COP452L. This analysis applies to both of the triggered pulse modes. The three parameters, $\mathrm{X}_{1}, \mathrm{X}_{2}, \mathrm{X}_{3}$, also apply in the same way in the triggered pulse and count mode when OA returns to 0 since it is the zero cross detection circuit that causes the output to return to zero in that mode.


FIGURE 9a


TL/DD/6155-28
FIGURE 10

## Applications Information (Continued) TRIGGERED PULSE MODES: INTERVENING ZERO CROSSINGS

In the triggered pulse modes, it is possible to specify a delay from the zero crossing which will extend beyond the next zero crossing. In the triggered pulse and count mode, the intervening zero crossing is ignored and therefore lost. The device will still continue to operate properly. The situation is somewhat different in the "pure" triggered pulse mode where both a delay and a pulse width are specified. Any zero crossing which occurs during the programmed delay time is ignored and therefore lost. However, if the delay time is counted out and the zero crossing occurs during the pulse width high time, the zero crossing will be recognized and the delay time will start counting again while the pulse width high time is being counted. This can result in a variety of possible conditions at the output-ranging from the apparent loss of that zero crossing to an effective very short delay from the zero crossing. What will occur depends on the values of the two counters and on their relationship to the times between zero crossings. Some interesting output waveforms can be produced, but their utility is questionable. Therefore, the user should exercise extreme caution in this mode and make sure that the times are such that all zero crossings occur at the "right" times. Otherwise, the user must be prepared to accept the bizarre effects that this situation can produce.

## COUNT MODES

As stated before, the counters are 16 -bit down counters. Preloading them when they are enabled as external event counters with ones or zeroes will give the one's or two's complement of the count. To read the counters it is necessary to first copy the counter to its respective register and then read the register.
The user can utilize the fact that the outputs toggle when the counter counts through zero. The counter can be preloaded with a value that represents the number of events the user wishes to count. When the output corresponding to that counter toggles, the specified number of events have occurred. Thus, the user can know that the required number of events have occurred without having to actually read the counter.
The counters require a pulse width greater than or equal to the period of the internal frequency in order to be reliably decremented. It is possible for a narrower pulse to decrement the counter, but it is not guaranteed. A narrower pulse will decrement the counter if it appears at the count input at the right time relative to the internal timing of the device. Since the user does not have access to this internal timing, it is impossible for him to synchronize the count input to this timing and effectively reduce the required width of the count pulse. Therefore, applying pulses at the count input of less than one period of the internal frequency in width may cause erratic counting in the sense that some of the pulses may be recognized and some may not be recognized. Reliable counting is assured only if the width of the count pulse is greater than or equal to one period of the internal frequency.

The counters decrement on a low-going pulse at the input. As stated above, the pulse must remain low at least one internal frequency period to give reliable counting. Similarly, the count signal must go high and remain high at least one internal frequency period before it goes low again. However, the count signal does not have to be symmetrical.

## COP452L OSCILLATOR

The COP452L will operate over a wide range of oscillator input frequencies. The input frequency may be supplied from an external source or CKI and CKO can be used with a crystal or resonator to generate the oscillator frequency. Figure 11 indicates some crystal networks for some typical crystal values.
RC and LC networks can also be connected between CKI and CKO to produce the oscillation frequency. Figure 12 indicates some examples of such networks. Figure 12a is the recommended RC network for use in this manner. With $\mathrm{C}_{1}=0.005 \mu \mathrm{~F}, \mathrm{R}=1.5 \mathrm{k} \Omega$, and $\mathrm{C}_{2}$ between 10 pF and 400 pF oscillation frequencies between about 1 MHz and 3 MHz should be obtainable. The oscillation frequency decreases with increasing values of $\mathrm{C}_{2}$. The user should feel free to experiment with the R and C values, and with the network configuration, to produce the oscillation frequency desired.
Figures $12 b$ and $12 c$ indicate LC networks that can be used to produce the COP452L oscillation frequency. In Figure 12 b , with $\mathrm{L}=100 \mu \mathrm{H}$ and $\mathrm{C}=100 \mathrm{pF}$, a frequency of about 2 MHz should be produced. In Figure 12c, with $\mathrm{L}=$ $56 \mu \mathrm{H}, \mathrm{C}_{2}=27 \mathrm{pF}$, and $\mathrm{C}_{1}$ between 25 pF and $0.01 \mu \mathrm{~F}$, frequencies between about 1.5 MHz and 3 MHz can be produced.
There is, in effect, an inverter between CKI and CKO. This inverter was designed for use with a crystal and its associated network. It was not designed for use with the RC and LC networks previously described. However, these networks will work and are usable. The user should be prepared to experiment with the networks to determine component values, stability, oscillation frequency, etc. These networks should be viewed as the starting point for a user who wishes to use networks of this type to generate the COP452L oscillation frequency.
The RC networks provide an inexpensive way to generate the oscillation frequency. It is foolish, however, to expect any significant degree of frequency stability or accuracy over temperature and voltage with a simple RC networkespecially if inexpensive, uncompensated components are used. LC and RLC networks can produce very stable and accurate frequencies. Regardless of the network used, the user must consider the variation of the external components in his design if accuracy and stability are important considerations in his application.
The crystal networks of Figure 11 provide frequency stability and accuracy and are easy to use. If the application requires oscillation frequency accuracy and stability the crystal networks are recommended as the best solution.

## Applications Information (Continued)



FIGURE 11. COP452 Crystal Oscillator


| Crystal <br> Value | Component Values |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ | $\mathbf{C}$ |  |
| 2.0 MHz | 1 k | 1 M | 56 pF |  |
| 1.0 MHz | 1 k | 1 M | 56 pF |  |

FIGURE 12. RC and LC Networks to Produce COP452 Oscillator Frequency

## WHITE NOISE GENERATION MODES

In the two white noise modes register $A$ is converted into a 17 -stage shift register, or polynomial, generator. With feedback taps at stages 17 and 14, as indicated in Figure 13, a maximal length sequence is generated. With these feedback taps the characteristic polynomial of the sequence is:

$$
x^{17}+x^{3}+1
$$

The output of this generator is a pseudo-random sequence. Since the register is shifted at the internal frequency rate, the sequence repeats after a period equal to $\left(2^{17}-1\right) t$, where $t$ is the period of the internal frequency.
The first 16 stages of the shift register are the 16 bits of register $A$ that the user may read or write. Entering either
white noise mode presets the 16th stage to a 1 and connects the 17th stage to the shift register. If the user wishes, he can write register $A$ and then enter the white noise and frequency mode. The output at OA will then be " 1 ", and the lower 15 bits of the data user had written to register A. Following that, the polynomial sequence dictates the output. This injection of a 1 into the 16th stage prevents the lockup condition that occurs if all the stages are 0.
WARNING: To insure proper operation, the white noise must be entered from the Reset mode. The COP452 must be in the Reset mode before the desired white noise mode and there may be no intervening modes between Reset and the desired white noise mode. (The state of 17th stage is don't care (unknown).)

## Applications Information (Continued)



Note: Setting the Register A to all 1's will result in a predictable pattern each time this mode is activated.
TL/DD/6155-34
FIGURE 13. COP452L White Noise Generator

## INTERFACE TO COPS MICROCONTROLLERS

Figure 14 indicates the typical interface between the COP452L and a COPS microcontroller. As is obvious from the figure, the interface is the standard MICROWIRE. $\mathrm{G}_{2}$ is indicated as the chip select line because it is available on all COPS microcontrollers. Obviously, any convenient output of the microcontroller may be used as the chip select for the COP452L.


TL/DD/6155-35
FIGURE 14
The $\overline{C S}$ pin of the COP452L must be toggled between successive communications with the device. The internal I register (instruction register) is held reset (all zero) when $\overline{\mathrm{CS}}$ is high. Since this is the only way in which the I register is cleared, failure to take $\overline{\mathrm{CS}}$ high between accesses will result in improper operation.
The COP452L contains an internal power-on reset circuit which sets the mode latches to one, i.e., places the COP452L in the RESET mode, and sets the oscillator divider to divide by 4. The counters and registers are not affected by this reset circuit and are therefore undefined at power up.

## INTERFACE SOFTWARE FOR THE COP452L

Sample software for interfacing COPS microcontroliers to the COP452L is given below. The code is completely general and will work in any COPS microcontroller. The following assumptions are made:

1. Pin $\mathrm{G}_{2}$ is used as the chip select for the COP452L (because $\mathrm{G}_{2}$ is available on all COPS microcontrollers).
2. $G_{2}$ is assumed high on entry to the routines.
3. The SK clock is off ( 0 ) on entry to the routines.
4. Register 0 of the microcontroller is arbitrarily chosen as the I/O register.
5. The leading digit sent out is of the form 001X where 1 is a start bit; X is 1 or 0 , depending on the operation.
6. The next lower digit contains the remaining 4 bits of the command.
7. If data is being sent, it is in the next 16 bits of information sent.
8. Location GSTATE chosen as RAM address 0,15 .
9. SK frequency is less than or equal to the internal frequency.
Since the COP452L is an I/O device, the code takes precautions to insure that SO is 0 prior to enabling the SK clock. (This is a wise precaution to take in any system with I/O peripherals on the serial port.)
Two versions of the WRITE routine are provided. The destructive WRITE routine destroys the information in the microcontroller as the data is being sent out to the COP452L. The nondestructive WRITE routine preserves the data in the microcontroller as that data is being sent out to the COP452L. The destructive routine is a little more code efficient than the nondestructive routine.

## Applications Information (Continued)



## Applications Information (Continued)

The code below is the code to read COP452L. It is written so that the command to the COP452L is sent out nondestructively, i.e., the data in the microcontroller is preserved. A routine which sends out the data destructively could be
easily generated but is not shown here. The user is referred to the techniques in the WRITE routines to determine how to modify this READ routine to send the command out destructively.

| READ: | CLRA |  | ; READ INSTRUCTION IN 0, 1 AND 0, 0 AND IS |
| :---: | :---: | :---: | :---: |
|  | AISC | 1 | ; OF THE FORM 00100010 OR 00100011 IF READ |
|  | LBI | GSTATE | ; RA OR RB |
|  | RMB | 2 |  |
|  | OMG |  | ; SELECT THE COP452L |
|  | CAB |  |  |
|  | SC |  |  |
|  | CLRA |  | ; SO THAT ZEROES GO OUT FIRST |
|  | LEI | 8 |  |
| SEND2: | XAS |  |  |
|  | LD |  |  |
|  | XDS |  |  |
|  | JP | SEND2 | ; NONDESTRUCTIVE SENDING OF READ INSTRUCTION |
|  | XAS |  |  |
|  | CLRA |  | SET UP TO READ |
|  | AISC | 2 |  |
|  | CAB |  |  |
|  | NOP |  | ; NOW WAIT FOR THE DATA |
|  | NOP |  |  |
|  | NOP |  |  |
| RDLOOP: | CLRA |  |  |
|  | XAS |  |  |
|  | XDS |  |  |
|  | JP | RDLOOP |  |
|  | RC |  | ; TURN OFF THE CLOCK |
|  | XAS |  | ; READ LAST 4 BITS |
|  | JP | DONE | ; COMMON EXIT WITH WRITE ROUTINE |
|  |  |  | ; EXITS WITH DATA IN LOWER 3 DIGITS OF RO |
|  |  |  | ; AND IN THE ACCUMULATOR |
| SAMPLE CODE TO READ THE COP452L |  |  |  |
| WRCMND: | CLRA |  | SET UP POINTER FOR COMMAND ONLY WRITE |
|  | AISC | 1 |  |
|  | JP | WRITE |  |
| WRDATA: | CLRA |  | ; SET UP POINTER FOR COMMAND AND DATA WRITE |
|  | AISC | 5 |  |
| WRITE: | LBI | GSTATE |  |
|  | RMB | 2 |  |
|  | OMG |  | ; SELECT THE COP452L - G2 LOW |
|  | CAB |  | ; LOAD THE POINTER |
|  | RC |  |  |
|  | CLRA |  |  |
|  | LEI | 8 | ENABLE SHIFT REGISTER MODE |
|  | XAS |  | ; SEND OUT ZEROES |
|  | SC |  |  |
|  | CLRA |  |  |
| SEND: | XAS |  | FIRST TIME THROUGH, TURNS ON CLOCK |
|  | LD |  | ; THEN SENDS DATA |
|  | XDS |  |  |
|  | JP | SEND |  |
|  | XAS |  | ; SEND LAST 4 BITS |
|  | CLRA |  |  |
|  | NOP |  |  |
| FINISH: | RC |  |  |
|  | XAS |  | ; ALL DONE, SK OFF |
| DONE: | LBI | GSTATE |  |
|  | SMB | 2 | ; DESELECT THE COP452 |
|  | OMG |  |  |
|  | LEI | 0 | ; SEND SO LOW |
|  | RET |  |  |

CODE TO WRITE COP452L - DATA PRESERVED IN MICROCONTROLLER

## Applications Information (Continued)

The software interface routines provided above are general purpose routines written to work in the general case for all COPS microcontrollers. They are written as subroutines to be called by the main program. There is no question that other routines can be written to perform the required function. It is also clear that these routines can be reduced in specific applications. These routines should be viewed as providing a framework from which the user can develop routines which are optimal to a specific application.
Assumption 9 mentioned prior to the code itself presents an important requirement for the interface software. There must be a time delay greater than 3 periods of the internal frequency between the time the SK clock is turned off and the time the COP452L is deselected. This is required because the COP452L reads the instruction register with timing based on its internal frequency. When the microcontroller deselects the COP452L, CS goes high and the instruction register is automatically cleared. Therefore, depending on the relative speeds of SK and the internal frequency, it is possible that the instruction register may be cleared before the COP452L has accepted the information. The sample code provided automatically satisfies the requirement mentioned above whenever the SK frequency is less than or equal to the counter clock frequency. When SK is faster than the internal frequency, some delay may be required between the time SK is turned off and the time the COP452L is deselected. The time delay is not required when reading or writing the COP452L registers or when changing the oscillator divider.
Caution: Failure to observe this time delay will result in improper operation of the COP452L.

## APPLICATION \# 1—GENERATION OF

## MULTIPLE TONES

The COP452L makes the generation of two independent frequencies a simple task. This application indicates how to generate frequencies with the COP452L and also indicates other aspects of control of the device.
The requirement is to generate the following two DTMF frequencies:

$$
\begin{aligned}
& f 1=941 \mathrm{~Hz} \\
& \mathrm{f} 2=1336 \mathrm{~Hz}
\end{aligned}
$$

We will select the CKI frequency of the COP452L as 1 MHz primarily for ease in computation. Therefore, in divide by 1
mode, the internal frequency is 1 MHz . Since the registers in the COP452L are loaded with a number related to the period of the frequency, we need the periods of f 1 and $\mathfrak{f} 2$.

$$
\begin{aligned}
& \frac{1}{\mathrm{f} 1}=\mathrm{t} 1=1062.7 \mu \mathrm{~s} ; \quad \frac{\mathrm{t} 1}{2}=531.35 \mu \mathrm{~s} \\
& \frac{1}{\mathrm{f} 2}=\mathrm{t} 2=748.5 \mu \mathrm{~s} ; \quad \frac{\mathrm{t} 2}{2}=374.25 \mu \mathrm{~s}
\end{aligned}
$$

As stated earlier, the period of an output frequency in the COP452L in the frequency generation mode is given by:

$$
\begin{aligned}
& T=2(N+1) t \\
& t=\text { period of inter } \\
& N=\text { register value }
\end{aligned}
$$

where: $\quad t=$ period of internal clock

Solving for $N$, the equation becomes

$$
N=\frac{T}{2 t}-1
$$

With the internal frequency at 1 MHz , the value of $t$ is $1 \mu \mathrm{~s}$. Therefore, the N values with which the registers must be loaded to generate the frequencies specified above are 530 ( 212 hex) and 373 (175 hex). Note that the fractional parts of the numbers are lost since the COP452L cannot be loaded with fractional numbers. Note that the fractionial parts may be reduced or eliminated by judicious choice of the CKI frequency. With the numbers here, the COP452L will generate a frequency with a period of $1062 \mu \mathrm{~s}(941.62 \mathrm{~Hz})$ and a frequency with a period of $748 \mu \mathrm{~s}(1336.9 \mathrm{~Hz})$. Note that these values are accurate to within $0.7 \%$ of the desired output frequencies.
Figure 15 indicates a connection diagram for this application. The software to accomplish this task is indicated below. The software indicates several aspects of the usage of the COP452L. The code first resets the COP452L, then loads the registers with the proper values, transfers the registers to the counters, puts the COP452L in the CKI divide by 1 state, and then loads the dual frequency mode. The output frequency generation begins when the dual frequency mode is loaded. The code as written is independent of the COP microcontroller used. The code uses the WRITE routines as described in the software interface section and assumes that these routines are located in the subroutine page.
In this, $\mathrm{CKI}($ Max. $)=525 \mathrm{kHz} \div 1$ Mode

## Applications Information (Continued)

; THE COP452L IS NOW RESET, NOW SET UP TO WRITE REGISTER A TO ; GENERATE OUTPUT FREQUENCY OF 941 HZ AT OA

| LBI | 0,0 |  |
| :--- | :--- | :--- |
| STII | 2 | 0212 HEX $=530$, GIVE PERIOD OF $1062 \mu \mathrm{~S}$ |
| STII | 1 |  |
| STII | 2 |  |
| STII | 0 |  |
| STII | 1 |  |
| STII | 2 | START BIT PLUS CODE TO WRITE RA |
| JSRP | WRDATA |  |

; REGISTER A IS NOW LOADED. NEXT TRANSFER REGISTER A TO COUNTER A

| LBI | 0,0 |  |
| :--- | :--- | :--- |
| STII | 5 |  |
| STII | 2 |  |
| JSRP | WRCMND |  |

: ALL DONE WITH REGISTER AND COUNTER A, NEXT WORK ON REGISTER B

| LBI | 0,0 |  |
| :--- | :--- | :--- |
| STII | 5 | ; WRITE REGISTER B WITH 0175 HEX (373) |
| STII | 7 | ; TO GIVE FREQUENCY OF 1336 HZ |
| STII | 1 |  |
| STII | 0 |  |
| STII | 0 | ; INSTRUCTION TO WRITE RB |
| STII | 2 |  |
| JSRP | WRDATA |  |

; REGISTER B IS NOW LOADED. NEXT TRANSFER RB TO CB

| LBI | 0,0 |  |
| :--- | :--- | :--- |
| STII | 4 |  |
| STII | 2 |  |
| JSRP | WRCMND |  |

; NOW LOAD CKI DIVIDE BY 1

| LIB | 0,0 |
| :--- | :--- |
| STII | 8 |
| STII | 2 |
| JSRP | WRCMND |

; NOW PUT THE COP452 IN DUAL FREQUENCY MODE

| LBI | 0,0 |
| :--- | :--- |
| STII | 0 |
| STII | 3 |
| JSRP | WRCMND |

; NOW THE CODE MAY PROCEED TO DO WHATEVER ELSE IS REQUIRED IN
; THE APPLICATION.
; THE SUBROUTINES USED IN THIS APPLICATION ARE CLEAR AND THE
; WRITE ROUTINES. THE ADD ROUTINE IS USED IN THE EXAMPLE BELOW

## CLEAR:

 CLRA XISJP CLEAR

ADD:
ADD1:
LBI 2.9 ; ROUTINE ADDS 1 TO COUNTER

CLRA ASC NOP XIS JP ADD1 RET
;
WRCMND: ; SEE SOFTWARE INTERFACE FOR THIS ROUTINE

WRDATA: ; SEE SOFTWARE INTERFACE FOR THIS ROUTINE

## Applications Information (Continued)

The preceding has done a lot with the COP452L. It is clear that the code can be reduced and specialized. The purpose here was to illustrate the various communications with the device.
An interesting effect can now be produced by making use of the 4 to 1 CKI divider. With the CKI frequency at 1 MHz , the internal frequency is well within the specified limits in either the divide by 1 or divide by 4 condition. Therefore, this characteristic of the device can be used to quickly multiply or divide the output frequency by 4 . An interesting siren effect
can thus be created. Sample code to do this is given below. This code assumes that the registers have been loaded and that the COP452 is in dual frequency mode. Again, the code is written to be independent of the COPS microcontroller used.
As is obvious from this code, it is a simple matter to create this effect. As was mentioned earlier, the code here is general purpose. This necessarily means that it can be reduced in specific applications. The user should view this code as representative of the techniques involved and then optimize or rewrite the routines to suit his particular application.

| SIREN: | LBI | 2,9 | ; USE REGISTER 2 AS COUNTER FOR DELAY TIME |
| :--- | :--- | :--- | :--- |
|  | JSRP | CLEAR |  |
|  | LBI | 0,0 |  |
|  | STII | 8 | ; CKI DIVIDE BY 1 |
|  | STII | 2 |  |
|  | JSRP | WRCMND |  |
|  | JSRP | ADD | ; INCREMENT COUNTER FOR DELAY |
|  | SKC |  |  |
|  | JP | PLUS1 | ; EXIST DELAY LOOP WHEN COUNTER OVERFLOWS |
|  | LBI | 0,0 |  |
|  | STII | 9 | CKI DIVIDE BY 4 |
|  | STII | 2 |  |
|  | JSRP | WRCMND |  |
|  | LBI | 2,9 |  |
|  | JSRP | CLEAR |  |
|  | JSRP | ADD |  |
|  | SKC |  |  |
|  | JP | PLUS1A | AGAIN, TIME OUT VIA THE COUNTER |
|  | JP | SIREN | ; DONE, START OVER AGAIN |



## Applications Information (Continued)

## APPLICATION \#2

This application makes use of the number of pulses mode of the COP452L to control a stepping motor. The technique is equally applicable in any situation where a number of pulses must be generated based upon the state of the system. Figure 16 indicates the system interconnect. Since the oscillator frequency is 2.1 MHz max. and the CKO pin of the COP452L is being used to drive the CKI of the microcontroller, a COP420 is specified as the microcontroller. If a separate oscillator were provided, any COPS microcontroller could be used. The software is completely general and will work in any COPS microcontroller.
The application has the following specifications:

1. The pulse width required for the stepping motor is 5 ms $\pm 5 \%$.
2. The system has 4 return lines which indicate 4 possible variations in the number of output pulses required. These four conditions are:
a. 10 pulses required
b. 100 pulses required
c. Repeat the last number of pulses sent
d. Send one more than the last number of pulses
3. The system has a signal available indicating that the return lines contain valid information.
4. One pulse is required at power up.

A flowchart to implement this system is indicated in Figure 17. Figure 16 is the interconnect used in this application. As the figure indicates, we will use a 2.1 MHz crystal as the
time base for the COP452L. With the oscillator divide by 4 selection, this gives an internal frequency period of $1.11745 \mu \mathrm{~s}$. With this information we can determine the number that needs to be loaded to register A to give a pulse width of 5 ms . From application \#1 we have the following equation which is valid here:

$$
T=(N+1) t
$$

where: $T=$ pulse width
$N=$ contents of register $A$
$t=$ period of internal clock

Solving for $N$ we have;

$$
\begin{aligned}
\mathrm{N} & =(\mathrm{T} / \mathrm{t})-1 \\
& =(5 \mathrm{~ms} / 1.11746 \mu \mathrm{~s})-1 \\
& =4474.34-1 \\
& =4473.34
\end{aligned}
$$

The fractional part is discarded, so register A must be loaded with 4473 (1179 hex) to give a 5 ms pulse. The error created by the truncation of the number is $0.5 \mu \mathrm{~s}$. There is an error of $0.01 \%$-well within the tolerance limits required. The code to operate this system is given below. The interconnect of Figure 16 is assumed. The code uses the READ and WRITE subroutines as given in the software interface section of this data sheet. The code further assumes that those routines are located in the subroutine page.


FIGURE 16. COP452 in Stepping Motor Control

## Applications Information (Continued)



|  | . PAGE | 0 |  |
| :---: | :---: | :---: | :---: |
| GSTATE POWRON: | $=$ | 0, 15 |  |
|  | CLRA |  |  |
|  | XAS |  | ; TURN OFF SK CLOCK |
|  | LBI | GSTATE |  |
|  | STII | 15 |  |
|  | LBI | GSTATE |  |
|  | OMG |  | ; DESELECT THE COP452L - G2 HIGH |
|  | LD |  |  |
|  | CAMQ |  | ; DRIVE THE L LINES HIGH FOR READING |
|  | LEI | 4 | ; ENABLE THE L OUTPUTS |
|  | LBI | 0, 0 |  |
|  | STII | 9 |  |
|  | STII | 7 |  |
|  | STII | 1 |  |
|  | STII | 1 |  |
|  | STII | 1 |  |
|  | STII | 2 | ; WRITE RA OF COP452L WITH 1179 HEX TO GET |
|  | JSRP | WRDATA | ; 5MS PULSE |

## Applications Information (Continued)

|  | LBI | 0, 0 |  |
| :---: | :---: | :---: | :---: |
|  | STII | 5 | ; transfer ra to counter a |
|  | STII | 2 |  |
|  | JSRP | WRCMND |  |
|  | LBI | 0, 0 | ; NOW WRITE RB WITH THE NUMBER OF PULSES |
|  | STII | 1 |  |
| RBWRT: | STII | 0 | ; ONE PULSE REQUIRED AT POWER UP |
| RBWRT2: | STII | 0 |  |
|  | STII | 0 |  |
| RBWRT3: | STII | 0 |  |
|  | STII | 2 |  |
|  | JSRP | WRDATA |  |
|  | LBI | 0, 0 | ; NOW TRANSFER RB TO COUNTER B |
|  | STII | 4 |  |
|  | STII | 2 |  |
|  | JSRP | WRCMND |  |
| PULSE: | LBI | 0, 0 |  |
|  | STII | 2 | ; SET NUMBER OF PULSES MODE |
|  | STII | 3 |  |
|  | JSRP | WRCMND |  |
| ; AT THIS POINT THE COP452L IS IN NUMBER OF PULSES MODE, ONE ; PULSE IS OUTPUT AT OA. NOW MUST READ THE RETURN LINES, MAKE ; THE APPROPRIATE DETERMINATION OF THE STATE OF THE SYSTEM ; AND UPDATE THE COP452L ACCORDINGLY, ALSO AT THIE POINT, THE ; COP452L IS SET UP TO AGAIN GENERATE A SINGLE PULSE 5 ms WIDE ; IF THE DEVICE IS ACCESSED AGAIN. |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
| ; |  |  |  |
| STATE: | LBI | gState |  |
|  | LD |  | ; CONTENTS OF GSTATE $=15$ HERE |
|  | CAMQ |  | ; MAKE SURE L LINES ARE HIGH AND |
|  | LEI | 4 | ; ENABLED |
|  | LBI | 0,0 |  |
|  | INL |  | ; READ THE L LINES TO A AND M(0, 0 ) |
|  | SKMBZ | 0 | ; TEST DATA - RETURN LINES - VALID |
|  | JMP | STATE | ; DATA NOT VALID, WAIT FOR IT TO BE VALID |
|  | AISC | 8 | ; DATA IS VALID, DECODE A |
|  | JMP | TEST2 |  |
| STATE1: | STII | 15 | ; POINTING AT 0, 0 <br> ; RESET THE COP452L FOR STATE 1 |
|  | STII | 3 |  |
|  | JSRP | WRCMND | ; RESET THE COP452L FOR STATE 1 |
|  | LBI | 0, 0 | ; NOW SET UP TO SEND 10 PULSES |
|  | STII | 10 |  |
|  | JMP | RBWRIT | ; SHARE COMMON CODE |
| TEST2: | AISC | 4 |  |
|  | JMP | TEST3 |  |
| STATE2: | STII | 15 | ; IN STATE2, MUST SEND 100 PULSES <br> ; FIRST RESET THE COP452L |
|  | STII | 3 |  |
|  | JSRP | WRCMND |  |
|  | LBI | 0,0 | ; WRITE 100 (0064 HEX) TO RB OF COP452L |
|  | STII | 4 |  |
|  | STII | 6 |  |
|  | JMP | RBWRT2 |  |
| TEST3: | AISC | 2 |  |
|  | JMP | TEST4 |  |
| STATE3: | JMP | PULSE | $\begin{aligned} & \text {; STATE } 3 \text { MERELY SENDS THE SAME NUMBER OF PULSES AGAIN. } \\ & \text {; THEREFORE, MERELY SEND THE NUMBER OF PULSES MODE COMMAND } \\ & \text {; AGAIN } \end{aligned}$ |

## Applications Information (Continued)

| TEST4: | AISC | 1 |  |
| :---: | :---: | :---: | :---: |
|  | JMP | STATE | ; ALL L LINES WERE 0, JUMP BACK TO MAIN |
| STATE4: | STII | 15 | ; RESET THE COP452L. |
|  | STII | 3 |  |
|  | JSRP | WRCMND |  |
|  | LBI | 0, 0 | ; NOW READ THE COP452L |
|  | STII | 2 |  |
|  | STII | 2 | COMMAND TO READ RB |
|  | JSRP | READ |  |
|  | LBI | 0, 0 | MOVE DATA TO LAST 4 DIGITS OF RO |
|  | XIS |  |  |
|  | XIS |  |  |
|  | XIS |  |  |
|  | XIS |  |  |
|  | LBI | 0, 0 | NOW INCREMENT THE VALUE BY 1 |
|  | SC |  |  |
| PLUS1: | CLRA |  |  |
|  | ASC |  |  |
|  | NOP |  |  |
|  | XIS |  |  |
|  | CBA |  |  |
|  | AISC | 12 |  |
|  | JP | . PLUSI |  |
|  | JMP | RBWRT3 | ; HAVE INCREMENTED THE VALUE, SEND IT OUT |
| ; |  |  |  |
| READ: |  |  |  |
|  |  |  | ; SEE SOFTWARE INTERFACE SECTION FOR THESE |
| WRDATA: |  |  | ; ROUTINES |

These are general routines and can be reduced in specific applications. The application itself was kept general so that it can be easily adapted to particular applications. The user should view this code as the basis from which to work to optimize the code for a specific application.

## APPLICATION \# 3

An application such as a tachometer requires the counting of external pulses that occur within a given time period. The COP452L can be used both to perform the counting and to establish the "viewing window," or time period, during which to count the pulses. By using the frequency and count mode of the COP452L, a frequency can be generated which will establish this viewing time. The other counter can then be used to count the pulses. Figure 18 provides a diagram of the interconnect in this application.
As Figure 18 indicates, the oscillator frequency for the COP452L has been selected as 250 kHz . With the oscillator divider set at divide by 1 , the internal frequency is also 250 kHz . At this frequency, the minimum pulse width that can be reliably expected to decrement the counter is $4 \mu \mathrm{~s}$ the period of the internal frequency.
A viewing time of 250 ms is arbitrarily selected. This means that the period of the output frequency is $500 \mathrm{~ms}-\mathrm{a}$ frequency of 2 Hz . Using the equation developed earlier for determining the counter values we have:

$$
\begin{aligned}
& N=\frac{T}{2 t}-1 \\
&=(500 \mathrm{~ms} / 8 \mu \mathrm{~s}) \\
&-1 \\
&=62500-1 \\
& N=62499=F 423 \\
& h e x
\end{aligned}
$$

Therefore, register A must be loaded with the hex value F423 to generate a frequency of 2 Hz at OA. Counter B will count pulses when OA is high by virtue of the ENB input. When OA is low, the microcontroller will read and reset the counter and peform any necessary operations.
With the values above for the internal frequency and the viewing window, the tachometer range is 240 RPM to 62,500 RPM. By making use of the divide by 1 /divide by 4 features of the oscillator divider, the range can be extended down to 60 RPM. The range when the oscillator is divided by 4 is 60 RPM to 15,625 RPM. However, a penalty is paid for this range extension. The viewing window goes from 250 ms to 1 second. The minimum reliable pulse width also increases from $4 \mu$ s to $16 \mu \mathrm{~s}$. The added time spent counting may or may not be acceptable. It can be reduced somewhat by changing the value of RA to give a faster frequency at the reduced counter clock frequency. However, as the OA frequency increases, the low end of the range increases.
A flow chart for this application is provided in Figure 19. Sample code is given below. Note that the sample code includes only the COP452L interface and control. Other system requirements, e.g., display interface, arithmetic, etc., are not included here. Other data sheets and application notes provide sufficient information to fill in those details.
The hardware interface indicated in Figure 18 and the code below, are completely general and valid of any COPS microcontroller. In specific applications both the hardware and software may be optimized to a greater extent than that shown here.

Applications Information (Continued)


FIGURE 18. COP452 in Wide Range Tachometer Application


## Applications Information (Continued)

|  | . PAGE | 0 |  |  |
| :---: | :---: | :---: | :---: | :---: |
| gstate | $=$ | 0, 15 |  |  |
| POWRON: | CLRA |  |  |  |
|  | XAS |  | ; TURN OFF THE SK CLOCK-C = 0 AT POWER UP |  |
|  | LBI | gState |  |  |
|  | OBD |  | ; DRIVE D LINES HIGH TO DESELECT DISPLAY |  |
|  | STII | 15 |  |  |
|  | LBI | GSTATE |  |  |
|  | OMG |  | ; DESELECT THE COP452L |  |
|  | LD |  |  |  |
|  | CAMQ |  | ; SET THE Q REGISTER TO ALL 1'S FOR INPUT |  |
|  | LBI | 0,0 |  |  |
|  | STII | 3 | ; NOW SET UP TO WRITE RA OF COP452L |  |
|  | STII | 2 |  |  |
|  | STII | 4 |  |  |
|  | $\begin{aligned} & \text { STII } \\ & \text { STII } \end{aligned}$ | 15 1 | ; WRIte RA WITH F423 HEX | TL/DD/6155-49 |
|  | STII | 2 | ; REMEMBER COP452L IS RESET AT POWER UP |  |
|  | JSRP | WRDATA |  |  |
|  | LBI | 0, 0 |  |  |
|  | STII | 5 | ; TRANSFER RA TO CA |  |
|  | STII | 2 |  |  |
|  | JSRP | WRCMND |  |  |
|  | JSR | RSTRB | ; RESET RB AND COUNTER B WITH FFFF |  |
|  | JSR | RANGE | ; TEST RANGE AND SET OSCILLATOR DIVIDER |  |
|  | LEI | 4 | ; ENABLE Q TO L-DRIVE L LINES HIGH |  |
|  | LBI | 0,0 | ; LOOK FOR OA $=0$ |  |
| TSTOAO: | INL |  |  |  |
|  | SKMBZ | 3 |  |  |
|  | JP | tstoan |  |  |
|  | LBI | 0, 0 | ; OA IS 0, READ COUNTER |  |
|  | STII | 6 | ; FIRST TRANSFER CB TO RB |  |
|  | STII | 2 |  |  |
|  | JSRP | WRCMND |  |  |
|  | LBI | 0, 0 | ; THEN READ RB |  |
|  | STII | 2 |  |  |
|  | STII | 2 |  |  |
|  | JSRP | READ |  |  |
|  | LBI | 0.0 | ; NOW TAKE THE 1'S COMPLEMENT |  |
| ONECMP: | COMP |  |  |  |
|  | XIS |  |  |  |
|  | COMP |  |  |  |
|  | XIS |  |  |  |
|  | COMP |  |  |  |
|  | XIS |  |  |  |
|  | COMP |  |  |  |
|  | X |  |  |  |
|  | LBI | 0, 0 | ; Now save value in R1 |  |
| XFER1: | LD | 1 |  |  |
|  | XIS | 1 |  |  |
|  | JP | XFER1 |  |  |
|  | JSR | RSTRB | ; RESET RB AND CB WITH FFFF FOR NEXT TIME |  |
| ; AT THIS POINT INSERT THE APPROPRIATE CODE FOR ANY NECESSARY |  |  |  |  |
|  |  |  |  |  |
| ; ARITHMETIC, BINARY/BCD CONVERSION, DISPLAY OUTPUT, AND ANY OTHER |  |  |  |  |
| ; SYSTEM REQUIREMENTS. AFTER THESE ARE COMPLETE, JUMP TO LABEL |  |  |  |  |
| ; TSTRNG WHICH HAS BEEN ARBITRARILY PLACED IN PAGE 4. |  |  |  |  |
| . PAGE | 2 |  |  |  |
| WRDATA: |  |  |  |  |
| WRCMND: |  | ; SEE SOF <br> ; THREE R | ARE INTERFACE SECTION FOR THESE TINES |  |
| READ: |  |  |  |  |
|  | . PAGE | 4 |  |  |
| TSTRNG: | JSR | RANGE | ; CHECK THE RANGE |  |
|  | LEI | 4 | ; BE SURE Q IS ENABLED TO L |  |
|  | LBI | 0, 0 | ; LOOK FOR OA = 1 |  |
| TSTOA1: | INL |  |  |  |
|  | SKMBZ | 3 |  |  |
|  | JMP | tstoan |  |  |
|  | JP | tStoal |  |  |
| ; the subroutines range and rstrb are inserted here |  |  |  |  |
|  |  |  |  |  |
| ; RANGE : |  |  |  |  |
|  | LEI | 4 | ; MAKE SURE L ENABLED |  |
|  | LBI | 3, 15 | ; WILL SAVE RANGE STATUS $\operatorname{IN} 3,15$ |  |
|  | INL |  |  |  |
|  | X |  |  |  |
|  | CLRA |  | ; NOW PREPARE TO SET OSCILLATOR DIVIDER | TL/DD/6155-50 |

## Applications Information (Continued)

|  | AISC | 8 | ; AN 8 MEANS DIVIDE BY 1 |
| :---: | :---: | :---: | :---: |
|  | SKMBZ | 3 |  |
|  | JP | HILOW |  |
| LOW: | AISC | 1 | ; IF DIVIDE BY 4, WANT A 9 IN A |
| HILOW: | LBI | 0, 0 |  |
|  | XIS |  |  |
|  | STII | 2 |  |
|  | JMP | WRCMND |  |
| ; |  |  |  |
| ; THE FOLLOWING SUBROUTINE USES A SUBROUTINE LEVEL. IT RESETS BOTH |  |  |  |
| ; REGISTER B AND COUNTER B OF THE COP452L TO FFFF |  |  |  |
| ; |  |  |  |
| RSTRB: | LBI | 0,0 |  |
|  | STII | 15 |  |
|  | STII | 15 |  |
|  | STII | 15 |  |
|  | STII | 15 |  |
|  | STII | 0 |  |
|  | STII | 2 |  |
|  | JSRP | WRDATA | ; WRITE FFFF TO RB |
|  | LBI | 0, 0 |  |
|  | STII | 4 | ; TRANSFER RB TO CB |
|  | STII | 2 |  |
|  | JMP | WRCMND |  |

TL/DD/6155-51

## APPLICATION \# 4

The triggered pulse mode of the COP452L provides the capability of generating the appropriate signals for triac control. Figure 20 is a general diagram of such an application. Assume the requirement is to switch on the triac 45 degrees into the waveform. With a 60 Hz sine wave signal, the 45 degree delay is 2.0833 ms from the zero crossing. Assume also that the triac requires a gate pulse width of $150 \mu \mathrm{~s}$. As the diagram indicates, a 2.097 MHz crystal provides the oscillator input to the COP452L. With the above information the two values that must be loaded in the COP452L can be determined. With CKI at 2.097 MHz and the oscillator divider at divide by 4 , the period of the internal frequency is $1.9075 \mu \mathrm{~s}$. From the description of the triggered pulse mode, the pulse width is given by:

$$
\mathrm{T}=\mathrm{Bt}
$$

where: $T=$ desired pulse width
$B=$ contents of register $B$
$t=$ period of internal clock
Solving for B is trivial and gives:

$$
\begin{aligned}
\mathrm{B} & =\mathrm{T} / \mathrm{t} \\
& =150 \mu \mathrm{~s} / 1.9075 \mu \mathrm{~s} \\
& =78.64
\end{aligned}
$$

Since the register and counter can be loaded with whole numbers only, register $B$ and counter $B$ must be initialized with 79 (002F hex) to give a pulse width of $150 \mu \mathrm{~s}$.
The delay from the zero cross trip point is given by:

$$
T=(A+1.5) t
$$

where: $T=$ delay from zero cross trip point
$A=$ contents of register $A$
$t=$ period of internal clock
Solving for $A$ we have:

$$
\begin{aligned}
A & =(T / t)-1.5 \\
& =(2.0833 \mathrm{~ms} / 1.9075 \mu \mathrm{~s})-1.5 \\
\mathrm{~A} & =1090.66 \text { rounded up to } 1091
\end{aligned}
$$

Therefore register A and counter A must be initialized with 1091 ( 0443 hex) to delay 2.0833 ms ( 45 degrees at 60 Hz ) from zero cross.
Once the data has been given to the COP452L and the device placed in the triggered pulse mode, no further attention is required. The COP452L will generate the pulses with the appropriate delay as long as the power is applied and the input sine wave is available. It is a trivial matter to change any of the information. Merely write the appropriate register/counter pair. Thus very easy control is available over the firing angle of triacs.
Sample code to accomplish this function is given below. The code is general purpose and is written to work in any COPS microcontroller.

## Applications Information (Continued)



FIGURE 20. COP452L as Triac Controller

|  | . PAGE | 0 |  |
| :---: | :---: | :---: | :---: |
| GSTATE POWRON: | $=$ | 0,15 |  |
|  | CLRA |  |  |
|  | XAS |  | ; TURN OFF THE SK CLOCK |
|  | LBI | GSTATE |  |
|  | STII | 15 |  |
|  | LBI | GSTATE |  |
|  | OMG |  | ; DESELECT THE COP452L - G2 HIGH |
|  | LBI | 0,0 | ; NOW WRITE RB/CB WITH 002F HEX TO GIVE |
|  | STII | 15 | ; $150 \mu$ S PULSE WIDTH |
|  | STII | 2 |  |
|  | STII | 0 |  |
|  | STII | 0 |  |
|  | STII | 0 |  |
|  | STII | 2 |  |
|  | JSRP | WRDATA |  |
|  | LBI | 0, 0 |  |
|  | STII | 4 | ; TRANSFER RB TO CB |
|  | STII | 2 |  |
|  | JSRP | WRCMND |  |
|  | LBI | 0, 0 | ; NOW WRITE RAICA WITH 0443 HEX FOR THE DELAY |
|  | STII | 3 |  |
|  | STII | 4 |  |
|  | STII | 4 |  |
|  | STII | 0 |  |
|  | STII | 1 |  |
|  | STII | 2 |  |
|  | JSRP | WRDATA |  |
|  | LBI | 0,0 |  |
|  | STII | 5 |  |
|  | STII | 2 |  |
|  | JSRP | WRCMND | ; TRANSFER RA TO CA |
|  | LBI | 0,0 |  |
|  | STII | 9 |  |


| STII | 2 | ; SET OSCILLATOR DIVIDER TO DIVIDE BY 4 |
| :--- | :--- | :--- |
| JSRP | WRCMND |  |
| LBI | 0,0 |  |
| STII | 1 |  |
| STII | 3 |  |
| JSRP | WRCMND TRIGGERED PULSE MODE |  |

; ALL COMPLETE AT THIS POINT. ROUTINES WRCMND AND WRDATA ASSUMED
; IN PAGE 2 AND ARE THE SAME AS GIVEN IN SOFTWARE INTERFACE SECTION.
; THE COP452L WILL NOW GENERATE THE $150 \mu$ S PULSE DELAYED BY 2.0833 ms
; FROM EVERY ZERO CROSSING. THE USER CAN NOW IGNORE THE TRIAC CONTROL.
; AND DO WHATEVER ELSE IS REQUIRED IN THE SYSTEM. FURTHER ATTENTION
; IS REQUIRED ONLY WHEN THE DATA IN THE COP452 MUST BE CHANGED.

## Applications Information (Continued)

Let us now compute the minimum and maximum delays from the true zero crossing in this application. As indicated earlier, the period of the internal frequency here is $1.9075 \mu \mathrm{~s}$. Counter A contains 0443 hex (decimal 1091). R ${ }_{\text {S }}$ is 150 k and the peak input voltage is 180 V . A 60 Hz sine wave is assumed. As given earlier, the minimum time is:
$\mathrm{T}_{\mathrm{MIN}}=(\mathrm{A}+1.5) \mathrm{t}-\frac{1}{2 \pi \mathrm{f}} \arcsin \left(0.15 \frac{\mathrm{R}_{\mathrm{S}}+2.6 \mathrm{k}}{\mathrm{V}_{\mathrm{IN}} \times 2.6 \mathrm{k}}\right)+0.3 \mu \mathrm{~s}$
Substituting we have:

$$
\begin{aligned}
\mathrm{T}_{\text {MIN }} & =1092.5 \mathrm{t}-\frac{1}{120 \pi} \arcsin \left(0.15 \frac{152.6 \mathrm{k}}{180 \times 2.6 \mathrm{k}}\right)+0.3 \mu \mathrm{~s} \\
& =2093.9 \mu \mathrm{~s}-129.7 \mu \mathrm{~s}+0.3 \mu \mathrm{~s} \\
\mathrm{~T}_{\text {MIN }} & =1954.5 \mu \mathrm{~s}
\end{aligned}
$$

Similarly, the maximum time is given as:

$$
\begin{aligned}
\mathrm{T}_{\mathrm{MAX}}= & (\mathrm{A}+1.5) \mathrm{t}+\frac{1}{2 \pi \mathrm{f}} \arcsin \left(0.15 \frac{\mathrm{R}_{\mathrm{S}}+2.6 \mathrm{k}}{\mathrm{~V}_{\mathrm{IN}} \times 2.6 \mathrm{k}}\right)+ \\
& 0.6 \mu \mathrm{~s}+\frac{\mathrm{t}}{2}
\end{aligned}
$$

Substituting, we have:

$$
\begin{aligned}
\mathrm{T}_{\mathrm{MAX}}= & 1092.5 \mathrm{t}+\frac{1}{120 \pi} \arcsin \left(0.15 \frac{152.6 \mathrm{k}}{180 \times 2.6 \mathrm{k}}\right)+ \\
& 0.6 \mu \mathrm{~s}+\frac{1.9075 \mu \mathrm{~s}}{2} \\
= & 2083.9 \mu \mathrm{~s}+129.7 \mu \mathrm{~s}+0.6 \mu \mathrm{~s}+0.9538 \mu \mathrm{~s} \\
\mathrm{~T}_{\mathrm{MAX}}= & 2215.15 \mu \mathrm{~s}
\end{aligned}
$$

As is obvious from the preceding analysis, the parameter previously defined as $X_{1}$ is the most significant of the additional factors that define the time delay from true zero. This factor can be minimized by using as small a series resistance as possible. The frequency and input voltage will be governed by the application. The user must also remember that the minimum and maximum times calculated in this manner are absolute worst case values derived using the worst case condition.

## 7 <br> National <br> Semiconductor Corporation

## COP470/COP370 V.F. Display Driver

## General Description

The COP470 is a peripheral member of National's COPSTM Microcontroller family. It is designed to directly drive a multiplexed Vacuum Fluorescent display. Data is loaded serially and held in internal latches. The COP470 has an on-chip oscillator to multiplex four digits of eight segment display and may be cascaded and/or stacked to drive more digits, more segments, or both.
With the addition of external drivers, the COP470 also provides a convenient means of interfacing to a large-digit LED display. The COP370 is the extended temperature range version of the COP470.

## Features

- Directly interfaces to multiplexed 4 digit by 8 segment Vacuum Fluorescent displays
- Expandable to drive 8 digits and/or 16 segments
m Compatible with all COP400 processors
- Needs no refresh from processor
- Internal or external oscillator
- No "glitches" on outputs when loading data
- Drives large and small displays
- Programmable display brightness
- Small (20-pin) dual-in-line package
- Operates from 4.5 V to 9.5 V
- Outputs switch 35 V and require no external resistors
- Static latches
- MICROWIRETM compatible serial I/O
- Extended temperature device COP370 $\left(-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}$ )


## Connection and Block Diagrams

## Dual-In-Line Package



TL/DD/6154-1
Top View
FIGURE 1. COP470
Order Number COP470D, COP370D, COP470N or COP370N
See NS Package Number D20A or N20A


FIGURE 2. COP470

## Absolute Maximum Ratings ${\text { ( } \mathrm{v}_{s \mathrm{~s}}=0}$ )

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
$\begin{array}{ll}\text { Voltage at Display Outputs } & +0.3 \mathrm{~V} \text { to }-35 \mathrm{~V} \\ \text { Voltage at All Other Pins } & +0.3 \mathrm{~V} \text { to }-20 \mathrm{~V}\end{array}$

| Operating Temperature |  |
| :--- | ---: |
| COP470 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| COP370 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, 10 sec.$)$ | $300^{\circ} \mathrm{C}$ |
| Package Power Dissipation | 400 mW at $25^{\circ} \mathrm{C}$ |
|  | 200 mW at $70^{\circ} \mathrm{C}$ |
|  | 125 mW at $85^{\circ} \mathrm{C}$ |

DC Electrical Characteristics $V_{S S}=0, V_{D D}=-4.5 \mathrm{~V}$ to $-9.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{GG}}=-30 \mathrm{~V}$ to $-35 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to
$+70^{\circ} \mathrm{C}$ for COP 470 and $\mathrm{T}_{\mathrm{A}}=40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ for COP 370 unless otherwise specified.

| Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| ```Power Supply Voltage VDD VGG (COP470) VGG (COP370)``` | $\begin{aligned} & -9.5 \\ & -35 \\ & -32 \\ & \hline \end{aligned}$ | $\begin{aligned} & -4.5 \\ & V_{D D} \\ & V_{D D} \\ & \hline \end{aligned}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ |
| ```Power Supply Current IDD IGG (Displayed Blanked)``` |  | $\begin{aligned} & 5 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Input Levels $V_{I H}$ $V_{\mathrm{IL}}$ | $\begin{array}{r} -1.5 \\ -10.0 \\ \hline \end{array}$ | $\begin{array}{r} +0.3 \\ -4.0 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| Output Drive Digits and Segments $\begin{aligned} & \mathrm{IOH}_{\mathrm{OH}} @ V_{\mathrm{OH}}=\mathrm{V}_{\mathrm{SS}}-3 \mathrm{~V} \\ & \mathrm{IOH}_{\mathrm{OH}} @ V_{\mathrm{OH}}=\mathrm{V}_{\mathrm{SS}}-2 \mathrm{~V} \\ & \mathrm{IOL}_{\mathrm{OL}} @ \mathrm{~V}_{\mathrm{OL}}=\mathrm{V}_{\mathrm{GG}}+2 \mathrm{~V}^{(1)} \end{aligned}$ | $\begin{gathered} 10 \\ 7 \\ 10 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \end{aligned}$ |
| $\begin{aligned} & \text { Output Drive @ } V_{G G}=V_{D D}=V_{S S}-5 V \\ & I_{O H} @ V_{O H}=V_{S S}-2 V \end{aligned}$ | 1 |  | mA |
| Allowable Source Current Per Pin Total for Segments |  | $\begin{array}{r} 20 \\ 60 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Input Capacitance |  | 7 | pF |
| Input Leakage |  | 1 | $\mu \mathrm{A}$ |

AC Electrical Characteristics $V_{S S}=0, V_{D D}=-4.5 \mathrm{~V}$ to $-9.5 \mathrm{~V}, \mathrm{~V}_{G G}=-30 \mathrm{~V}$ to $-35 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ for COP470 and $\mathrm{T}_{\mathrm{A}}=40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ for COP370 unless otherwise specified.

| Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| OSC Period (internal or external) | 4 | 20 | $\mu \mathrm{S}$ |
| OSC Pulse Width | 1.5 |  | $\mu \mathrm{s}$ |
| Clock Period T (twice Osc. period) | 8 | 40 | $\mu \mathrm{s}$ |
| Display Frequency <br> 4 digits $=1 / 64 \mathrm{~T}$ <br> 8 digits $=1 / 128 T$ | $\begin{aligned} & 390 \\ & 190 \end{aligned}$ | $\begin{aligned} & 2000 \\ & 1000 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{Hz} \\ & \mathrm{~Hz} \end{aligned}$ |
| SK Clock Frequency | 0 | 250 | kHz |
| SK Clock Width | 1.5 |  | $\mu \mathrm{s}$ |
| Data Set-up and Hold Time tsetup $t_{\text {HOLD }}$ | $\begin{aligned} & 1.0 \\ & 50 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |
| CS Set-up and Hold Time tsetup <br> thOLD | $\begin{aligned} & 1.0 \\ & 1.0 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Duty Cycle 4 digits 8 digits | $\begin{gathered} 1 / 64 \\ 1 / 128 \\ \hline \end{gathered}$ | $\begin{gathered} 15 / 64 \\ 15 / 128 \end{gathered}$ |  |

Note 1: IOL current is to $V_{G G}$ with the chip running. Current is measured just after the output makes a high-to-low transition.

## Timing Diagram



## Performance Characteristic



TL/DD/6154-4

## Functional Description

SEGMENT DATA BITS
Data is loaded in serially in sets. Each set of segment data is in the following format:

| $S A$ | $S B$ | $S C$ | $S D$ | $S E$ | $S F$ | $S G$ | $S H$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Data is shifted into an eight bit shift register. The first bit of the data is for segment H , digit 1 . The eighth bit is segment A, digit 1.
A set of eight bits is shifted in and then loaded into the digit one latches. The second set of 8 bits is loaded into digit two latches. The third set into digit three latches and the fourth set is loaded into digit four latches.

## DISPLAY ON TIME AND CONTROL BITS

The fifth set of 8 data bits contains blank time data and control data in the following format:

> Display Digits

Sync


The first four bits shifted in contain the on time. This is used to control display brightness. The brightness is a function of the on time of each segment divided by the total time (duty cycle). The on time is programmable from 0 to 15 and the total time is 64 . For example, if the on time is 15 , the duty cycle is $15 / 64$ which is maximum brightness. If on time is 8 , the duty cycle is $8 / 64$, about $1 / 2$ brightness. There are 16 levels of brightness from 15/64 to 0/64 (off).

The fifth and sixth bits control the multiplex digits. To enable the COP470 to drive a 4 digit multiplex display, set both bits to one. If two COP470s are used to drive an 8 digit display, bit five is set on the left COP470 and bit six is set on the right COP470 (see Figure 6). In the eight digit mode, the display duty cycle is on time/128.


TL/DD/6154-5
FIGURE 4. System Diagram—4 Digit Display

## Functional Description (Continued)



TL/DD/6154-6
FIGURE 5. Segment and Digit Output Timing Diagram

The seventh bit selects internal or external oscillator. The OSC pin of the COP470 is either an output of the internal oscillator (bit $7=0$ ) or is an input allowing the COP470 to run from an external oscillator (bit $7=1$ ).
The eighth bit is set to synchronize two COP470s. For example, to set the COP470 to internal osc, 4 digits, and maximum brightness, send out six ones and two zeros.

## LOADING SEQUENCE

Step

1. Turn $\overline{C S}$ Low.
2. Clock in 8 bits of data for digit 1.
3. Clock in 8 bits of data for digit 2.
4. Clock in 8 bits of data for digit 3.
5. Clock in 8 bits of data for digit 4.
6. Clock in 8 bits of data for on time and control bits.
7. Turn $\overline{\mathrm{CS}}$ high.

Note: $\overline{C S}$ may be turned high after any step. For example, to load only 2 digits of data do steps $1,2,3$, and 7 . $\overline{\mathrm{CS}}$ must make a high to low transition before loading data in order to reset internal counters.

## 8 DIGIT Displays

Two COP470s may be tied together in order to drive an eight digit multiplexed display. This is shown in Figure 6. The following is the loading sequence to drive an eight digit display using two COP470s.

1. Turn $\overline{\mathrm{CS}}$ Iwo on both COP470s.
2. Shift in 32 bits of data for the right 4 digits.
3. Shift in 4 bits of on time, a zero and three ones. This synchronizes both chips, sets to external oscillator, and to right four of eight digits. Thus both chips are synchronized and the oscillator is stopped.
4. Turn $\overline{\mathrm{CS}}$ high to both chips.
5. Turn $\overline{\mathrm{CS}}$ low to the left COP470.
6. Shift in 32 bits of data for the left 4 digits.
7. Shift in 4 bits of on time, a one and three zeros. This sets this COP470 to internal oscillator and to left four of eight digits. Now both chips start and run off the same oscillator.
8. Turn $\overline{C S}$ high.

The chips are now synchronized and driving eight digits of display. To load new data simply load each chip separately in the normal manner.

## 16 SEGMENT DISPLAY

Two COP470s may be tied together in order to drive a sixteen segment display. This is shown in Figure 8. To do this, both chips must be synchronized, one must run off external oscillator while the other runs off its internal oscillator outputting to the other. Similarly, four COP470s could be tied together to drive eight digits of sixteen segments.

## Functional Description (Continued)



FIGURE 6. System Diagram 8 Diglt Display


FIGURE 7. Segment and Digit Output Timing Diagram for 8 Digits


FIGURE 8. System Diagram for 16 Segment Display

## Functional Description (Continued)

## LED DISPLAY

The COP470 may be used to drive LED displays. The COP470 can drive the segments directly on small, low current LED displays as shown in Figure 9. By adding display drivers, large, high current LED displays can be driven as shown in Figure 10.

Example:
COP420 Code to Load COP470
(Display Data is in Memory 0, 12-0, 15)

|  | LBI 0,12 | ; Point to first display data |
| :---: | :---: | :---: |
|  | OBD | ; Turn CS low (DO) |
| LOOP: | CLRA |  |
|  | LQID | ; Look up segment data |
|  | CQMA | ; Copy data from Q to M \& A |
|  | SC | ; Set C to turn on SK |
|  | XAS | ; Output lower 4 bits of data |
|  | NOP | ; Delay |
|  | NOP | ; Delay |
|  | LD | ; Load A with upper 4 bits |
|  | XAS | ; Output 4 bits of data |
|  | NOP | ; Delay |
|  | NOP | ; Delay |
|  | RC | ; Reset C |
|  | XAS | ; Turn off SK clock |
|  | XIS | ; Increment B for next data |
|  | JP LOOP | ; Skip this jump after last digit |
|  | SC | ; Set C |
|  | CLRA | ; |
|  | AISC 15 | ; 15 to A |
|  | XAS | ; Output on time (max brightness) |
|  | NOP | ; |
|  | CLRA | ; |
|  | AISC 12 | ; 12 to A |
|  | XAS | ; Output control bits |
|  | NOP | ; |
|  | LBI 0,15 | ; 15 to B |
|  | RC | ; Reset C |
|  | XAS | ; Turn off SK |
|  | OBD | ; Turn CS high (DO) |

## Functional Description (Continued)



FIGURE 9. LED Display


FIGURE 10. Large LED Display


TL/DD/6154-12
FIGURE 11. Sample V.F. System

## COP472-3 Liquid Crystal Display Controller

## General Description

The COP472-3 Liquid Crystal Display (LCD) Controller is a peripheral member of the COPSTM family, fabricated using CMOS technology. The COP472-3 drives a multiplexed liquid crystal display directly. Data is loaded serially and is held in internal latches. The COP472-3 contains an on-chip oscillator and generates all the multi-level waveforms for backplanes and segment outputs on a triplex display. One COP472-3 can drive 36 segments multiplexed as $3 \times 12$ ( $41 / 2$ digit display). Two COP472-3 devices can be used together to drive 72 segments $(3 \times 24)$ which could be an $81 / 2$ digit display.

## Features

- Direct interface to TRIPLEX LCD
- Low power dissipation ( $100 \mu \mathrm{~W}$ typ.)

■ Low cost

- Compatible with all COP400 processors
- Needs no refresh from processor
- On-chip oscillator and latches
- Expandable to longer displays
- Software compatible with COP470 V.F. Display Driver chip
- Operates from display voltage
- MICROWIRETM compatible serial I/O
- 20-pin Dual-In-Line package


## Block Diagram



TL/DD/6932-1

Absolute Maximum Ratings
Voltage at CS, DI, SK pins
Voltage at all other Pins
Operating Temperature Range

$$
\begin{array}{r}
-0.3 \mathrm{~V} \text { to }+9.5 \mathrm{~V} \\
-0.3 \mathrm{~V} \text { to } \mathrm{V}_{D D}+0.3 \mathrm{~V} \\
0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}
\end{array}
$$

Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temp. (Soldering, 10 Seconds)

## DC Electrical Characteristics

$\mathrm{GND}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=3.0 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (depends on display characteristics)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Power Supply Voltage, V $\mathrm{VD}^{\text {d }}$ |  | 3.0 | 5.5 | Volts |
| Power Supply Current, IDD (Note 1) | $V_{D D}=5.5 \mathrm{~V}$ |  | 250 | $\mu \mathrm{A}$ |
|  | $V_{D D}=3 V$ |  | 100 | $\mu \mathrm{A}$ |
| $\begin{gathered} \text { Input Levels } \\ \text { DI, SK, CS } \\ V_{\mathrm{VI}} \\ \mathrm{~V}_{\mathrm{IH}} \end{gathered}$ |  | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | $\begin{aligned} & 0.8 \\ & 9.5 \end{aligned}$ | Volts Volts |
| $\begin{gathered} \text { BPA (as Osc. in) } \\ V_{\mathrm{IL}} \\ V_{\mathrm{IH}} \\ \hline \end{gathered}$ |  | $V_{D D}-0.6$ | $\begin{gathered} 0.6 \\ V_{D D} \\ \hline \end{gathered}$ | Volts <br> Volts |
| ```Output Levels, BPC (as Osc. Out) \(\mathrm{V}_{\mathrm{OL}}\) \(\mathrm{V}_{\mathrm{OH}}\)``` |  | $V_{D D}-0.4$ | $\begin{gathered} 0.4 \\ V_{D D} \\ \hline \end{gathered}$ | Volts <br> Volts |
| Backplane Outputs (BPA, BPB, BPC) <br> $V_{B P A, ~ B P B, B P C} O N$ <br> $V_{B P A, ~ B P B, ~ B P C ~}$ OFF | During $\mathrm{BP}+\text { Time }$ | $\begin{gathered} V_{D D}-\Delta V \\ 1 / 3 V_{D D}-\Delta V \end{gathered}$ | $\begin{gathered} V_{D D} \\ 1 / 3 V_{D D}+\Delta V \end{gathered}$ | Volts <br> Volts |
| $V_{B P A, B P B, B P C} O N$ <br> $V_{B P A, ~ B P B, ~ B P C ~ O F F ~}^{\text {O }}$ | During BP-Time | $\begin{gathered} 0 \\ 2 / 3 V_{D D}-\Delta V \end{gathered}$ | $\begin{gathered} \Delta V \\ 2 / 3 V_{D D}+\Delta V \end{gathered}$ | Volts <br> Volts |
| $\begin{aligned} & \text { Segment Outputs }\left(\mathrm{SA}_{1} \sim \mathrm{SA}_{4}\right) \\ & \mathrm{V}_{\text {SEG }} \text { ON } \\ & \mathrm{V}_{\mathrm{SEG}} \text { OFF } \end{aligned}$ | During BP+ Time | $\begin{gathered} 0 \\ 2 / 3 V_{D D}-\Delta V \end{gathered}$ | $\begin{gathered} \Delta V \\ 2 / 3 V_{D D}+\Delta V \end{gathered}$ | Volts <br> Volts |
| $\begin{aligned} & \mathrm{v}_{\text {SEG }} O N \\ & \mathrm{~V}_{\text {SEG }} \mathrm{OFF} \end{aligned}$ | During BP- Time | $\begin{gathered} V_{D D}-\Delta V \\ 1 / 3 V_{D D}-\Delta V \\ \hline \end{gathered}$ | $\begin{gathered} V_{D D} \\ 1 / 3 V_{D D}+\Delta V \end{gathered}$ | Volts Volts |
| Internal Oscillator Frequency |  | 15 | 80 | kHz |
| Frame Time (Int. Osc. $\div$ 192) |  | 2.4 | 12.8 | ms |
| Scan Frequency ( $1 / T_{\text {SCAN }}$ ) |  | 39 | 208 | Hz |
| SK Clock Frequency |  | 4 | 250 | kHz |
| SK Width |  | 1.7 |  | $\mu \mathrm{S}$ |
| DI Data Setup, tsetup Data Hold, thOLD |  | $\begin{aligned} & 1.0 \\ & 100 \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mathrm{~ns} \end{aligned}$ |
| $\begin{aligned} & \hline \overline{\mathrm{CS}} \\ & \text { t }_{\text {SETUP }} \\ & \mathrm{t}_{\text {HOLD }} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 1.0 \\ & 1.0 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Output Loading Capacitance |  |  | 100 | pF |

Note 1: Power supply current is measured in stand-alone mode with all outputs open and all inputs at VDD-
Note 2: $\Delta \mathrm{V}=0.05 \mathrm{~V}_{\mathrm{DD}}$.


Top View
Order Number COP472N-3 See NS Package N20A

| Pin | Description |
| :--- | :--- |
| CS | Chip select |
| $V_{D D}$ | Power supply (display voltage) |
| GND | Ground |
| DI | Serial data input |
| SK | Serial clock input |
| $\mathrm{BP}_{\mathrm{A}}$ | Display backplane A (or oscillator in) |
| $\mathrm{BP}_{\mathrm{B}}$ | Display backplane B |
| $\mathrm{BP}_{\mathrm{C}}$ | Display backplane C (or oscillator out) |
| SA1~SC4 | 12 multiplexed outputs |

FIGURE 2. Connection Dlagram


FIGURE 3. Serial Load TIming Dlagram


FIGURE 4. Backplane and Segment Waveforms


FIGURE 5. Typical Display Internal Connections
Epson LD-370

## Functional Description

The COP472-3 drives 36 bits of display information organized as twelve segments and three backplanes. The COP472-3 requires 40 information bits: 36 data and 4 control. The function of each control bit is described below. Display information format is a function of the LCD interconnections. A typical segment/backplane configuration is illustrated in Figure 5, with this configuration the COP472-3 will drive 4 digits of 9 segments.
To adapt the COP472-3 to any LCD display configuration, the segment/backplane multiplex scheme is illustrated in Table I.
Two or more COP472-3 chips can be cascaded to drive additional segments. There is no limit to the number of COP472-3's that can be used as long as the output loading capacitance does not exceed specification.

TABLE I. COP472-3 Segment/Backplane Multiplex Scheme

| Multiplex Scheme |  |  |  |
| :---: | :---: | :---: | :---: |
| Blt Number | Segment, Backplane | Data to Numeric Display |  |
| 1 | SA1, BPC | SH |  |
| 2 | SB1, BPB | SG |  |
| 3 | SC1, BPA | SF |  |
| 4 | SC1, BPB | SE |  |
| 5 | SB1, BPC | SD | Digit 1 |
| 6 | SA1, BPB | SC |  |
| 7 | SA1, BPA | SB |  |
| 8 | SB1, BPA | SA |  |
| 9 | SA2, BPC | SH |  |
| 10 | SB2, BPB | SG |  |
| 11 | SC2, BPA | SF |  |
| 12 | SC2, BPB | SE |  |
| 13 | SB2, BPC | SD | Digit 2 |
| 14 | SA2, BPB | SC |  |
| 15 | SA2, BPA | SB |  |
| 16 | SB2, BPA | SA |  |
| 17 | SA3, BPC | SH |  |
| 18 | SB3, BPB | SG |  |
| 19 | SC3, BPA | SF |  |
| 20 | SC3, BPB | SE |  |
| 21 | SB3, BPC | SD | Digit 3 |
| 22 | SA3, BPB | SC |  |
| 23 | SАЗ, BPA | SB |  |
| 24 | SB3, BPA | SA |  |
| 25 | SA4, BPC | SH |  |
| 26 | SB4, BPB | SG |  |
| 27 | SC4, BPA | SF |  |
| 28 | SC4, BPB | SE |  |
| 29 | SB4, BPC | SD | Digit 4 |
| 30 | SA4, BPB | SC |  |
| 31 | SA4, BPA | SB |  |
| 32 | SB4, BPA | SA |  |
| 33 | SC1, BPC | SPA | Digit 1 |
| 34 | SC2, BPC | SP2 | Digit 2 |
| 35 | SC3, BPC | SP3 | Digit 3 |
| 36 | SC4, BPC | SP4 | Digit 4 |
| 37 | not used |  |  |
| 38 | Q6 |  |  |
| 39 | Q7 |  |  |
| 40 | SYNC |  |  |

## SEGMENT DATA BITS

Data is loaded in serially, in sets of eight bits. Each set of segment data is in the following format:


Data is shifted into an eight bit shift register. The first bit of the data is for segment H , digit 1 . The eighth bit is segment A, digit 1. A set of eight bits is shifted in and then loaded into the digit one latches. The second set of 8 bits is loaded into digit two latches. The third set into digit three latches, and the fourth set is loaded into digit four latches.

## CONTROL BITS

The fifth set of 8 data bits contains special segment data and control data in the following format:

| SYNC | Q7 | Q6 | X | SP4 | SP3 | SP2 | SP1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The first four, bits shifted in contain the special character segment data. The fifth bit is not used. The sixth and seventh bits program the COP472-3 as a stand alone LCD driver or as a master or slave for cascading COP472-3's. BPC of the master is connected to BPA of each slave. The following table summarizes the function of bits six and seven:

| Q7 | Q6 | Function | BPC Output | BPA Output |
| :---: | :---: | :--- | :--- | :--- |
| 1 | 1 | Slave | Backplane | Oscillator |
| 0 | 1 | Stand Alone | Output <br> Backplane | Input |
| Backplane |  |  |  |  |
| 1 | 0 | Not Used | Output <br> Internal | Output |
| Oscillator |  |  |  |  |
| 0 | 0 | Master | Osc. Output <br> Internal <br> Osc. Output | Backplane |

The eighth bit is used to synchronize two COP472-3's to drive an $81 / 2$-digit display.

## LOADING SEQUENCE TO DRIVE A 4½-DIGIT DISPLAY

Steps:

1. Turn $\overline{C E}$ low.
2. Clock in 8 bits of data for digit 1.
3. Clock in 8 bits of data for digit 2 .
4. Clock in 8 bits of data for digit 3 .
5. Clock in 8 bits of data for digit 4.
6. Clock in 8 bits of data for special segment and control function of BPC and BPA.

| 0 | 0 | 1 | 1 | SP 4 | SP 3 | SP 2 | SP 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

7. Turn $\overline{\mathrm{CS}}$ high.

Note: $\overline{C S}$ may be turned high after any step. For example to load only 2 digits of data, do steps $1,2,3$, and 7.
$\overline{\mathrm{CS}}$ must make a high to low transition before loading data in order to reset internal counters.

## LOADING SEQUENCE TO DRIVE AN 81/2-DIGIT DISPLAY

Two or more COP472-3's may be connected together to drive additional segments. An eight digit multiplexed display is shown in Figure 7. The following is the loading sequence to drive an eight digit display using two COP472-3's. The right chip is the master and the left the slave.
Steps:

1. Turn $\overline{\mathrm{CS}}$ low on both COP472-3's.
2. Shift in 32 bits of data for the slave's four digits.
3. Shift in 4 bits of special segment data: a zero and three ones.


This synchronizes both the chips and BPA is oscillator input. Both chips are now stopped.
4. Turn CS high to both chips.
5. Turn CS low to master COP472-3.
6. Shift in 32 bits of data for the master's 4 digits.
7. Shift in four bits of special segment data, a one and three zeros.

| 0 | 0 | 0 | 1 | SP 4 | SP 3 | SP 2 | SP 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

This sets the master COP472-3 to BPA as a normal backplane output and BPC as oscillator output. Now both the chips start and run off the same oscillator.
8. Turn $\overline{C S}$ high.

The chips are now synchronized and driving 8 digits of display. To load new data simply load each chip separately in the normal manner, keeping the correct status bits to each COP472-3 (0110 or 0001).


FIGURE 6. System Diagram - 41⁄2 Digit Display


FIGURE 7. System Diagram - 81⁄2 Digit Display

## Example Software

Example 1
COP420 Code to load a COP472-3 [Display data is in $M(0,12)-M(0,15)$, special segment data is in $M(0,0)$ ]

| LBI 0, 12 | ; POINT TO FIRST DISPLAY DATA |
| :---: | :---: |
| OBD | ; TURN $\overline{C S}$ LOW (DO) |
| CLRA |  |
| LQID | ; LOOK UP SEGMENT DATA |
| CQMA | ; COPY DATA FROM Q TO M \& A |
| SC | ; SET C TO TURN ON SK |
| XAS | ; OUTPUT LOWER 4 BITS OF DATA |
| NOP | ; DELAY |
| NOP | ; DELAY |
| LD | ; LOAD A WITH UPPER 4 BITS |
| XAS | ; OUTPUT 4 BITS OF DATA |
| NOP | ; DELAY |
| NOP | ; DELAY |
| RC | ; RESET C |
| XAS | ; TURN OFF SK CLOCK |
| XIS | ; INCREMENT B FOR NEXT DATA |
| JP LOOP | ; SKIP THIS JUMP AFTER LAST DIGIT |
| SC | ; SETC |
| LBI 0, 0 | ; ADDRESS SPECIAL SEGMENTS |
| LD | ; LOAD INTO A |
| XAS | ; OUTPUT SPECIAL SEGMENTS |
| NOP | ; |
| CLRA | ; |
| AISC 12 | ; 12 to A |
| XAS | ; OUTPUT CONTROL BITS |
| NOP | ; |
| LBI 0, 15 | ; 15 to B |
| RC | ; RESET C |
| XAS | ; TURN OFF SK |
| OBD | ; TURN $\overline{C S} \mathrm{HIGH}$ (DO) |

## Example Software (Continued)

## Example 2

COP420 Code to load two COP472-3 parts [Display data is in $M(0,12)-M(0,15)$ and $M(1,12)-M(1,15)$, special segment data is in $M(0,0)$ and $M(1,0)$ ]

| INIT: | LBI | 0,15 |  |
| :---: | :---: | :---: | :---: |
|  | OBD |  | ; TURN BOTH CS'S HIGH |
|  | LEI | 8 | ; ENABLE SO OUT OF S. R. |
|  | RC |  |  |
|  | XAS |  | ; TURN OFF SK CLOCK |
|  | LBI | 3,15 | ; USE M $(3,15)$ FOR CONTROL BITS |
|  | STII | 7 | ; STORE 7 TO SYNC BOTH CHIPS |
|  | LBI | 0,12 | ; SET B TO TURN BOTH CS'S LOW |
|  | JSR | OUT | ; CALL OUTPUT SUBROUTINE |
| MAIN DISPLAY SEQUENCE |  |  |  |
| DISPLAY | LBI | 3,15 |  |
|  | STII | 8 | ; SET CONTROL BITS FOR SLAVE |
|  | LBI | 0,13 | ; SET B TO TURN SLAVE CS LOW |
|  | JSR | OUT | ; OUTPUT DATA FROM REG. 0 |
|  | LBI | 3,15 |  |
|  | STII | 6 | ; SET CONTROL BITS FOR MASTER |
|  | LBI | 1,14 | ; SET B TO TURN MASTER CS LOW |
|  | JSR | OUT | ; OUTPUT DATA FROM REG. 1 |
| OUTPUT SUBROUTINE |  |  |  |
| OUT: | OBD |  | ; OUTPUT B TO CS'S |
|  | CLRA |  |  |
|  | AISC | 12 | ; 12 TO A |
|  | CAB |  | ; POINT TO DISPLAY DIGIT (BD=12) |
| LOOP | CLRA |  |  |
|  | LQID |  | ; LOOK UP SEGMENT DATA |
|  | CQMA |  | : COPY DATA FROM Q TOM \& A |
|  | SC |  |  |
|  | XAS |  | ; OUTPUT LOWER 4 BITS OF DATA |
|  | NOP |  | ; DELAY |
|  | NOP |  | ; DELAY |
|  | LD |  | ; LOAD A WITH UPPER 4 BITS |
|  | XAS |  | ; OUTPUT 4 BITS OF DATA |
|  | NOP |  | ; DELAY |
|  | NOP |  | ; DELAY |
|  | RC |  | ; RESET C |
|  | XAS |  | ; TURN OFF SK |
|  | XIS |  | ; INCREMENT B FOR NEXT DISPLAY DIGIT |
|  | JP | LOOP | ; SKIP THIS JUMP AFTER LAST DIGIT |
|  | SC |  | ; SET C |
|  | NOP |  |  |
|  | LD |  | ; LOAD SPECIAL SEGS. TO A (BD=0) |
|  | XAS |  | ; OUTPUT SPECIAL SEGMENTS |
|  | NOP |  |  |
|  | LBI | 3,15 |  |
|  | LD |  | ; LOAD A |
|  | XAS |  | ; OUTPUT CONTROL BITS |
|  | NOP |  |  |
|  | NOP |  |  |
|  | RC |  |  |
|  | XAS |  | ; TURN OFF SK |
|  | OBD |  | ; TURN CS'S HIGH (BD=15) |
|  | RET |  |  |

# NMC9306/COP494 256-Bit Serial Electrically Erasable Programmable Memory 

## General Description

The NMC9306/COP494 is a 256 -bit non-volatile sequential access memory fabricated using advanced floating gate N -channel $\mathrm{E}^{2} \mathrm{PROM}$ technology. It is a peripheral memory designed for data storage and/or timing and is accessed via the simple MICROWIRETM serial interface. The device contains 256 bits of read/write memory divided into 16 registers of 16 bits each. Each register can be serially read or written by a COP400 series controller. Written information is stored in a floating gate cell with at least 10 years data retention and can be updated by an erase-write cycle. The NMC9306/COP494 has been designed to meet applications requiring up to $1 \times 10^{4}$ erase/write cycles per register. A power down mode reduces power consumption by 70 percent.

Features

- Low cost
- Single supply operation ( $5 \mathrm{~V} \pm 10 \%$ )
- TTL compatible
- $16 \times 16$ serial read/write memory
- MICROWIRE compatible serial I/O
- Compatible with COP400 processors
- Low standby power
- Non-volatile erase and write
- Reliable floating gate technology

Block and Connection Diagrams


Dual-In-Line Package


TL/D/5029-10
Top View


TL/D/5029-2
Top View
Order Number NMC9306N, NMC9306 or COP494N
See NS Package N08E or M14B

## Pin Names

| CS | Chip Select |
| :--- | :--- |
| SK | Serial Data Clock |
| DI | Serial Data Input |
| DO | Serial Data Output |
| VCC | Power Supply |
| GND | Ground |

## Absolute Maximum Ratings

Voltage Relative to GND +6 V to -0.3 V
Ambient Operating Temperature
NMC9306/COP494
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Ambient Storage Temperature
with Data Retention
$-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Lead Temperature (Soldering, 10 seconds) $300^{\circ} \mathrm{C}$

Note: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## Electrical Characteristics $0^{\circ} \mathrm{C} \leq T A \leq 70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ unless otherwise specified

| Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 4.5 |  | 5.5 | V |
| Operating Current ( $\mathrm{lCC1}^{\text {) }}$ | $V_{C C}=5.5 \mathrm{~V}, \mathrm{CS}=1$ |  |  | 10 | mA |
| Standby Current (lcc2) | $V_{C C}=5.5 \mathrm{~V}, \mathrm{CS}=0$ |  |  | 3 | mA |
| Input Voltage Levels $V_{\mathrm{IL}}$ $\mathrm{V}_{\mathrm{IH}}$ |  | $\begin{gathered} -0.1 \\ 2.0 \end{gathered}$ |  | $\begin{gathered} 0.8 \\ v_{C C}+1 \end{gathered}$ | $\begin{aligned} & V \\ & V \end{aligned}$ |
| Output Voltage Levels $V_{O L}$ $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \end{aligned}$ | 2.4 |  | 0.4 | $\begin{aligned} & V \\ & V \end{aligned}$ |
| Input Leakage Current | $\mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |  |  | 10 | $\mu \mathrm{A}$ |
| Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}, \mathrm{CS}=0$ |  |  | 10 | $\mu \mathrm{A}$ |
| SK Frequency <br> SK HIGH TIME tskH (Note 2) <br> SK LOW TIME tskL (Note 2) |  | $\begin{aligned} & 0 \\ & 1 \\ & 1 \end{aligned}$ |  | 250 | $\begin{gathered} \mathrm{kHz} \\ \mu \mathrm{~s} \\ \mu \mathrm{~s} \\ \hline \end{gathered}$ |
| Input Set-Up and Hold Times  <br> CS t CSS <br>  t $_{\text {CSH }}$ <br> DI t DIS $^{2}$ <br>  t DIH |  | $\begin{gathered} 0.2 \\ 0 \\ 0.4 \\ 0.4 \end{gathered}$ |  |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Output Delay  <br> DO tPD1 <br>  tpDO $^{2}$ | $\begin{aligned} & \mathrm{CL}=100 \mathrm{pF} \\ & \mathrm{~V}_{\mathrm{OL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}}=0.45 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}=2.40 \mathrm{~V} \end{aligned}$ |  |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| Erase/Write Pulse Width ( $\mathrm{t}_{\mathrm{E} / \mathrm{W}}$ ) (Note 1) |  | 10 |  | 30 | ms |
| CS Low Time (tcs) (Note 3) |  | 1 |  |  | $\mu \mathrm{s}$ |

Note 1: $\mathrm{t}_{\mathrm{E} / \mathrm{w}}$ measured to rising edge of SK or CS, whichever occurs last.
Note 2: The SK frequency spec. specifies a minimum SK clock period of $4 \mu \mathrm{~s}$, therefore in an SK clock cycle, $\mathrm{t}_{\mathrm{SKH}}+{ }^{\text {tskL }}$ must be greater than or equal to $4 \mu \mathrm{~s}$. e.g. if $\mathrm{t}_{\mathrm{SKL}}=1 \mu \mathrm{~s}$ then the minimum $\mathrm{t}_{\mathrm{SKH}}=3 \mu \mathrm{~s}$ in order to meet the SK frequency specification.

Note 3: CS must be brought low for a minimum of $1 \mu \mathrm{~s}$ (tcs) between consecutive instruction cycles.

## Instruction Set

| Instruction | SB | Op Code | Address | Data | Comments |
| :--- | :---: | :---: | :--- | :--- | :--- |
| READ | 1 | $10 x x$ | A3A2A1AO |  | Read register A3A2A1A0 |
| WRITE | 1 | $01 x x$ | A3A2A1A0 | D15-D0 | Write register A3A2A1A0 |
| ERASE | 1 | $11 x x$ | A3A2A1A0 |  | Erase register A3A2A1A0 |
| EWEN | 1 | 0011 | xxxx |  | Erase/write enable |
| EWDS | 1 | 0000 | xxxx |  | Erase/write disable |
| ERAL | 1 | 0010 | xxxx |  | Erase all registers |
| WRAL | 1 | 0001 | xxxx | D15-D0 | Write all registers |

NMC9306/COP494 has 7 instructions as shown. Note that MSB of any given instruction is a " 1 " and is viewed as a start bit in the interface sequence. The next 8 bits carry the op code and the 4 -bit address for 1 of 16,16 -bit registers.
X is a don't care state.

## Functional Description

The NMC9306/COP494 is a small peripheral memory intended for use with COPSTM controllers and other non-volatile memory applications. Its organization is sixteen registers and each register is sixteen bits wide. The input and output pins are controlled by separate serial formats. Seven 9 -bit instructions can be executed. The instruction format has a logical ' 1 ' as a start bit, four bits as an op code, and four bits of address. SK clock cycle is necessary after CS equals logical " 1 " before the instruction can be loaded. The onchip programming-voltage generator allows the user to use a single power supply ( $V_{\mathrm{CC}}$ ). Only during the read mode is the serial output (DO) pin valid. During all other modes the DO pin is in TRI-STATE ${ }^{\oplus}$, eliminating bus contention.

## READ

The read instruction is the only instruction which outputs serial data on the DO pin. after a READ instruction is received, the instruction and address are decoded, followed by data transfer from the memory register into a 16 -bit seri-al-out shift register. A dummy bit (logical ' 0 ') precedes the 16-bit data output string. Output data changes are initiated by a low to high transition of the SK clock.

## ERASE/WRITE ENABLE AND DISABLE

Programming must be preceded once by a programming enable (EWEN) instruction. Programming remains enabled until a programming disable (EWDS) instruction is executed. The programming disable instruction is provided to protect against accidental data disturb. Execution of a READ instruction is independent of both EWEN and EWDS instructions.

## ERASE (Note 4)

Like most E2PROMS, the register must first be erased (all bits set to 1s) before the register can be written (certain bits
set to Os). After an ERASE instruction is input, CS is dropped low. This falling edge of CS determines the start of programming. The register at the address specified in the instruction is then set entirely to 1 s . When the erase/write programming time ( $\mathrm{E}_{\mathrm{E} / \mathrm{W}}$ ) constraint has been satisfied, CS is brought up for at least one SK period. A new instruction may then be input, or a low-power standby state may be achieved by dropping CS low.

## WRITE (Note 4)

The WRITE instruction is followed by 16 bits of data which are written into the specified address. This register must have been previously erased. Like any programming mode, erase/write time is determined by the low state of CS following the instruction. The on-chip high voltage section only generates high voltage during these programming modes, which prevents spurious programming during other modes. When CS rises to $\mathrm{V}_{I H}$, the programming cycle ends. All programming modes should be ended with CS high for one SK period, or followed by another instruction.

## CHIP ERASE (Note 4)

Entire chip erasing is provided for ease of programming. Erasing the chip means that all registers in the memory array have each bit set to a 1 . Each register is then ready for a WRITE instruction.

## CHIP WRITE (Note 4)

All registers must be erased before a chip write operation. The chip write cycle is identical to the write cycle, except for the different op code. All registers are simultaneously written with the data pattern specified in the instruction.
Note 4: During a programming mode (write, erase, chip erase, chip write), SK clock is only needed while the actual instruction, i.e., start bit, op code, address and data, is being input. It can remain deactivated during the Erase/ Write pulse width ( $\mathrm{t}_{\mathrm{E} / \mathrm{W}}$ ).


Synchronous Data Timing


TL/D/5029-4

TL/D/5029-5


TL/D/5029-6


## NMC9345/COP495 1024-Bit Serial Electrically Erasable Programmable Memory (5V Only)

## General Description

The NMC9345/COP495 is a 1024-bit non-volatile, sequential E2PROM, fabricated using advanced N -channel E2PROM technology. It is an external memory with the 1024 bits of read/write memory divided into 64 registers of 16 bits each. Each register can be serially read or written by a COP400 controller, or a standard microprocessor. Written information is stored in a floating gate cell until updated by an erase and write cycle. The NMC9345 has been designed for applications requiring up to $10^{4}$ erase/write cycles per register. A power-down mode is provided by CS to reduce power consumption by 75 percent.

## Features

■ Low cost
■ Single supply read/write/erase operations ( $5 \mathrm{~V} \pm 10 \%$ )

- TTL compatible
- $64 \times 16$ serial read/write memory
- MICROWIRETM compatible serial I/O
- Simple interfacing
- Low standby power
- Non-volatile erase and write
- Reliable floating gate technology
- Self-timed programming cycle
- Device status signal during programming

Block and Connection Diagrams
Serial E2PROM


Dual-In-Line Package


TL/D/7616-2
Top View

SO Package


TL/D/7616-10
Top View
Order Number NMC9345N, NMC9345 or COP495N See NS Package Number N08E or M14B

## Pin Names

CS Chip Select
SK Serial Data Clock
DI Serial Data Input
DO Serial Data Output
VCC Power Supply
GND Ground
NC Not Connected

Absolute Maximum Ratings (Note 1)

Voltage Relative to GND
Ambient Operating Temperature
+6 V to -0.3 V
Ambient Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Lead Temp. (Soldering, 10 seconds)
$300^{\circ} \mathrm{C}$

DC and AC Electrical Characteristics $\operatorname{NMC9345:~} 0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$ unless specified

| Symbol | Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | Operating Voltage |  | 4.5 | 5.5 | $\checkmark$ |
| ${ }^{\text {c }}$ C1 | Operating Current Erase/Write Operating Current | $\begin{aligned} & V_{C C}=5.5 \mathrm{~V}, \mathrm{CS}=1, \mathrm{SK}=1 \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 12 \\ & 12 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |
| ${ }^{1} \mathrm{CC} 2$ | Standby Current | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{CS}=0$ |  | 3 | mA |
| $\begin{aligned} & \mathrm{V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | Input Voltage Levels |  | $\begin{array}{r} -0.1 \\ 2.0 \end{array}$ | $\begin{gathered} 0.8 \\ v_{C C}+1 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ |
| $V_{\text {OL }}$ $\mathrm{VOH}_{\mathrm{OH}}$ | Output Voltage Levels | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \\ & \mathrm{IOH}^{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \hline \end{aligned}$ | 2.4 | 0.4 | $\begin{aligned} & v \\ & v \end{aligned}$ |
| LI | Input Leakage Current | $\mathrm{V}_{1 \mathrm{~N}}=5.5 \mathrm{~V}$ |  | 10 | $\mu \mathrm{A}$ |
| LLO | Output Leakage Current | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}, \mathrm{CS}=0$ |  | 10 | $\mu \mathrm{A}$ |
| $\begin{array}{r} \text { tsKH } \\ t_{\text {SKL }} \\ \hline \end{array}$ | SK Frequency SK High Time SK Low Time |  | $\begin{aligned} & 0 \\ & 2 \\ & 1 \end{aligned}$ | 250 | $\begin{aligned} & \mathrm{kHz} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| tcss <br> $\mathrm{t}_{\mathrm{CSH}}$ <br> tDIS <br> $t_{D I H}$ | Inputs CS DI |  | $\begin{gathered} 0.2 \\ 0 \\ 0.4 \\ 0.4 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~S} \\ & \mu \mathrm{~S} \\ & \mu \mathrm{~S} \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \mathrm{t}_{\mathrm{pd}} 1 \\ & \mathrm{t}_{\mathrm{pd} 0} 0 \end{aligned}$ | $\begin{aligned} & \text { Output } \\ & \text { DO } \end{aligned}$ | $\begin{aligned} & C_{\mathrm{L}}=100 \mathrm{pF} \\ & \mathrm{~V}_{\mathrm{OL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}}=0.45 \mathrm{~V}, \mathrm{~V}_{\mathrm{HH}}=2.40 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 2 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~S} \end{aligned}$ |
| $\mathrm{t}_{\mathrm{E} / \mathrm{W}}$ | Self-Timed Program Cycle |  |  | 10 | ms |
| $\mathrm{t}_{\mathrm{CS}}$ | Min CS Low Time (Note 3) |  | 1 |  | $\mu \mathrm{S}$ |
| tsv | Rising Edge of CS to Status Valid | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |  | 1 | $\mu \mathrm{S}$ |
| $\mathrm{ton}_{\mathrm{H}, \mathrm{t}_{1 \mathrm{H}}}$ | Falling Edge of CS to DO TRI-STATE® |  |  | 0.4 | $\mu \mathrm{S}$ |

Note 1: Stress above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: The SK frequency spec. specifies a minimum SK clock period of $4 \mu \mathrm{~s}$, therefore in an SK clock cycle tSKH $+\mathrm{t}_{\text {SKL }}$ must be greater than or equal to $4 \mu \mathrm{~s}$. e.g. if $\mathrm{t}_{\mathrm{SKL}}=1 \mu \mathrm{~s}$ then the minimum $\mathrm{t}_{\mathrm{SKH}}=3 \mu \mathrm{~s}$ in order to meet the SK frequency specification.

Note 3: CS must be brought low for a minimum of $1 \mu \mathrm{~S}(\mathrm{t} \mathrm{CS})$ between consecutive instruction cycles.

## Functional Description

The NMC9345/COP495 is a small peripheral memory intended for use with COPSTM controllers and other non-volatile memory applications. Its organization is sixty-four registers and each register is sixteen bits wide. The input and output pins are controlled by separate serial formats. Seven 9 -bit instructions can be executed. The instruction format has a logical ' 1 ' as a start bit, two bits as an op code, and six bits of address. The programming cycle is self-timed, with the data out (DO) pin indicating the read/busy status of the chip.

The on-chip programming voltage generator allows the user to use a single power supply ( $\mathrm{V}_{\mathrm{CC}}$ ). It only generates high voltage during the programming modes (write, erase, chip erase, chip write) to prevent spurious programming during other modes. The DO pin is valid as data out during the read mode, and if initiated, as a ready/busy status indicator during a programming cycle. During all other modes the DO pin is in TRI-STATE, eliminating bus contention.

## Functional Description (Continued)

## READ

The read instruction is the only instruction which outputs serial data on the DO pin. After a read instruction is received, the instruction and address are decoded, followed by data transfer from the memory register into a 16 -bit seri-al-out shift register. A dummy bit (logical ' 0 ') precedes the 16 -bit data output string. Output data changes are initiated by a low to high transition of the SK clock.

## ERASE/WRITE ENABLE AND DISABLE

When $V_{C C}$ is applied to the part it powers up in the programming disable (EWDS) state, programming must be preceded by a programming enable (EWEN) instruction. Programming remains enabled until a programming disable (EWDS) instruction is executed or $V_{C C}$ is removed from the part. The programming disable instruction is provided to protect against accidental data disturb. Execution of a read instruction is independent of both EWEN and EWDS instructions.

## ERASE (Note 4)

Like most $E^{2}$ PROMs, the register must first be erased (all bits set to logical '1') before the register can be written (certain bits set to logical ' 0 '). After an erase instruction is input, CS is dropped low. This falling edge of CS determines the start of the self-timed programming cycle. If CS is brought high subsequently (after observing the tcs specification), the DO pin will indicate the ready/busy status of the chip. The DO pin will go low if the chip is still programming. The DO pin will go high when all bits of the register at the address specified in the instruction have been set to a logical ' 1 '. The part is now ready for the next instruction sequence.

## WRITE (Note 4)

The write instruction is followed by 16 bits of data to be written into the specified address. After the last bit of data (D0) is put on the data in (DI) pin CS must be brought low before the next rising edge of the SK clock. This falling edge of CS initiates the self-timed programming cycle. Like all programming modes, DO indicates the ready/busy status of the chip if CS is brought high after a minimum of $1 \mu \mathrm{~S}\left(\mathrm{t}_{\mathrm{CS}}\right)$. $\mathrm{DO}=$ logical ' 0 ' indicates that programming is still in progress. $\mathrm{DO}=$ logical ' 1 ' indicates that the register at the address specified in the instruction has been written with the data pattern specified in the instruction and the part is ready for another instruction. The register to be written into must have been previously erased.

## CHIP ERASE (Note 4)

Entire chip erasing is provided for ease of programming. Erasing the chip means that all registers in the memory array have each bit set to a logical ' 1 '. Each register is then ready for a write instruction. The chip erase cycle is identical to the erase cycle except for the different op code.

## CHIP WRITE (Note 4)

All registers must be erased before a chip write operation. The chip write cycle is identical to the write cycle except for the different op code. All registers are simultaneously written with the data pattern specified in the instruction.
Note 4: During a programming mode (write, erase, chip erase, chip write), SK clock is only needed while the actual instruction, i.e., start bit, op code, address and data, is being input. It can remain deactivated during the selftimed programming cycle and status check.

IC INSTRUCTION SET FOR NMC9345/COP495

| Instruction | SB | Opcode | Address | Data | Comments |
| :--- | :---: | :---: | :---: | :---: | :--- |
| READ | 1 | 10 | A5A4A3A2A1A0 |  | Read register A5A4A3A2AA1A0 |
| WRITE | 1 | 01 | A5A4A3A2A1A0 | D15-D0 | Write register A5A4A3A2A1A0 |
| ERASE | 1 | 11 | A5A4A3A2A1A0 |  | Erase register A5A4A3A2A1A0 |
| EWEN | 1 | 00 | $11 x x x x$ |  | Erase/Write enable |
| EWDS | 1 | 00 | $00 x x x x$ |  | Erase/Write disable |
| ERAL | 1 | 00 | $10 x x x x$ |  | Erase all registers |
| WRAL | 1 | 00 | $01 x x x x$ | D15-D0 | Write all registers |

NMC9345/COP495 has 7 instructions as shown. Note that the MSB of any given instruction is a " 1 " and is viewed as a start bit in the interface sequence. The next 8 bits carry the op code and the 6 -bit address for 1 of 64,16 -bit registers.

## Timing Diagrams




Instruction Timing


TL/D/7616-7


TL/D/7616-8


## COP498/COP398 Low Power CMOS RAM and Timer (RAT ${ }^{\text {TM }}$ ) <br> COP499/COP399 Low Power CMOS Memory

## General Description

The COP498/398 Low Power CMOS RAM and Timer (RAT) and the COP499/399 Memory are peripheral members of the COPSTM family, fabricated using low power CMOS technology. These devices provide external data storage and/or timing, and are accessed via the simple MICROWIRETM serial interface. Each device contains 256 bits of read/write memory organized into 4 registers of 64 bits each; each register can be serially loaded or read by a COPS controller.
The COP498/398 also contain a crystal-based timer for timekeeping purposes, and can provide a "wake-up" signal to turn on a COPS controller. Hence, these devices are ideal for applications requiring very low power drain in a standby mode, while maintaining a real-time clock (e.g., electronically-tuned automobile radio). Power is minimized by cycling controller power off for periods of time when no processing is required.
The COP499/399 contain circuitry that enables the user to turn a controller on and off while maintaining the integrity of the memory.
A COP400 series N -channel microcontroller coupled with a COP498 (or 499) RAM/Timer offers a user the low-power advantages of an all CMOS system and the low-cost advantage of an NMOS system. This type of system is ideally suited to a wide variety of automotive and instrumentation applications.

## Features

■ Low power dissipation

- Quiescent current $=40 \mathrm{nA}$ typical $\left(25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=3.0 \mathrm{~V}\right)$
- Low cost
- Single supply operation ( $2.4 \mathrm{~V}-5.5 \mathrm{~V}$ )
- CMOS-compatible I/O
- $4 \times 64$ serial read/write memory
- Crystal-based selectable timer-2.097152 MHz or 32.768 kHz (COP498/398)
- Software selectable 1 Hz or 16 Hz "wake-up" signal for COPS controller (COP498/398)
- External override to "wake-up" controller
- Compatible with all COP400 processors (processor $\mathrm{V}_{\mathrm{CC}} \leq 9.5 \mathrm{~V}$ )
- MICROWIRE-compatible serial I/O
- Memory protection with write enable and write disable instructions
- 14-pin Dual-In-Line package (COP498/398) or 8-pin Dual-In-Line package (COP499/399)


## Block Diagram



FIGURE 1

## Absolute Maximum Ratings

Voltage relative to GND

At XSEL, $1 \mathrm{~Hz}, \mathrm{X}_{\text {IN }}, X_{\text {OUT }}, D O$
At all other pins
Maximum VCC Voltage
Total Sink Current Allowed
Total Source Current Allowed
Ambient Operating Temperature

```
COP398/COP399
COP498/COP499
\[
\begin{array}{r}
-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\
0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}
\end{array}
\]
```

-0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ -0.3 V to 10 V
6.5 V 15 mA 10 mA

Ambient Storage Temperature $\quad-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Lead Temp. (Soldering, 10 seconds) $300^{\circ} \mathrm{C}$ Power Dissipation 50 mW Note: "Absolute maximum ratings" indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not insured when operating the device at absolute maximum ratings.

## DC Electrical Characteristics

COP398/COP399: $-40^{\circ} \mathrm{C} \leq T_{A} \leq+85^{\circ} \mathrm{C}$ unless otherwise specified.
COP498/COP499: $0^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+70^{\circ} \mathrm{C}$ unless other wise specified.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage | COP498/COP499 COP398/COP399 | $\begin{aligned} & 2.4 \\ & 3.0 \end{aligned}$ | $\begin{aligned} & 5.5 \\ & 5.5 \end{aligned}$ | $\begin{aligned} & v \\ & v \end{aligned}$ |
| Quiescent Current (COP398/COP399 only) | All inputs at GND $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=3.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=5.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=5.5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=3.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=5.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=5.5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=85^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=3.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=85^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=5.0 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=85^{\circ} \mathrm{C}, \mathrm{~V}_{C C}=5.5 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 1.0 \\ & 3.0 \\ & 6.0 \\ & 4.0 \\ & 10 \\ & 20 \\ & 8.0 \\ & 16 \\ & 30 \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| COP498/COP398 <br> Standby Current (sleep mode) (running with crystal <br> Operating Current | $\mathrm{V}_{\mathrm{CC}}=$ Min., Osc. $=2.097 \mathrm{MHz}$ <br> $V_{C C}=$ Max., Osc. $=2.097 \mathrm{MHz}$ <br> $V_{C C}=$ Min., Osc. $=32.768 \mathrm{kHz}$ <br> $\mathrm{V}_{\mathrm{CC}}=$ Max., Osc. $=32.768 \mathrm{kHz}$ <br> $\mathrm{SK}=250 \mathrm{kHz}$ square wave <br> $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$., Osc. $=2.097 \mathrm{MHz}$ <br> $V_{C C}=$ Max., Osc. $=2.097 \mathrm{MHz}$ <br> $V_{C C}=$ Min., Osc. $=32.768 \mathrm{kHz}$ <br> $V_{\mathrm{CC}}=$ Max., Osc. $=32.768 \mathrm{kHz}$ |  | $\begin{gathered} 200 \\ 700 \\ 20 \\ 100 \\ \\ 300 \\ 920 \\ 120 \\ 320 \end{gathered}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| COP499/COP399 Operating Current | $\begin{aligned} & S K=250 \mathrm{kHz} \text { square wave } \\ & V_{C C}=2.4 \mathrm{~V} \text { for COP } 498 / \mathrm{COP} 499 \\ & V_{C C}=3.0 \mathrm{~V} \text { for COP398/COP399 } \\ & V_{C C}=M a x . \end{aligned}$ |  | $\begin{array}{r} 100 \\ 140 \\ 250 \\ \hline \end{array}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ |
| Input Voltage Levels CE Input <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) Logic Low (VIL.) OVR Input Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) Logic Low (VIL) <br> All Other Inputs Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) Logic Low (VIL) | (Schmitt Trigger Input) <br> (Schmitt Trigger Input) | $\begin{aligned} & 0.8 \mathrm{~V}_{\mathrm{CC}} \\ & 0.8 \mathrm{~V}_{\mathrm{CC}} \\ & 0.7 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & 0.4 \mathrm{~V}_{\mathrm{CC}} \\ & 0.2 \mathrm{~V}_{\mathrm{CC}} \\ & 0.3 \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | $\begin{aligned} & V \\ & V \\ & v \\ & v \\ & v \\ & V \end{aligned}$ |
| Output Voltage Levels-DO, 1 Hz CMOS Operation Logic High ( $\mathrm{V}_{\mathrm{OH}}$ ) Logic Low (VOL) | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.1$ | 0.1 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |

DC Electrical Characteristics (Continued)

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Input Leakage Current | COP498/COP499, $\mathrm{V}_{\text {IH }}=\mathrm{V}_{\text {CC }}, \mathrm{V}_{\text {IL }}=0 \mathrm{~V}$ | -1.0 | +1.0 | $\mu \mathrm{A}$ |
|  | COP398/COP399, $V_{\text {IH }}=V_{C C}, V_{\text {IL }}=O V$ | -2.0 | +2.0 | $\mu \mathrm{A}$ |
| TRI-STATE®, Open Drain | COP498/COP499, $V_{H}=V_{C C}, V_{L}=0 \mathrm{~V}$ | -2.5 | +2.5 | $\mu \mathrm{A}$ |
| Leakage Current | COP398/COP399, $V_{H}=V_{C C}, V_{L}=0 \mathrm{~V}$ | -5.0 | +5.0 | $\mu \mathrm{A}$ |
| Output Current Levels | $V_{C C}=4.5 \mathrm{~V}$ |  |  |  |
| Sink Current |  |  |  |  |
| OSC | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ | 0.5 |  | mA |
| $\overline{O N}$ | $\mathrm{V}_{\mathrm{OL}}=1.5 \mathrm{~V}$ | 1.5 | 7.5 | mA |
| X OUT | $X S E L=1, X_{\text {IN }}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OL }}=1.0 \mathrm{~V}$ | 0.25 |  | mA |
| X OUT | $\mathrm{XSEL}=0, \mathrm{X}_{\text {IN }}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {OL }}=2.0 \mathrm{~V}$ | 8.0 |  | $\mu \mathrm{A}$ |
| 1 Hz , DO | $\mathrm{V}_{\mathrm{OL}}=0.8 \mathrm{~V}$ | 0.8 |  | mA |
| Source Current |  |  |  |  |
| $\overline{\mathrm{ON}}$ | $\mathrm{V}_{\mathrm{OH}}=1.0 \mathrm{~V}$ | 60 |  | $\mu \mathrm{A}$ |
| Xout | $\mathrm{XSEL}=1, \mathrm{X}_{\mathrm{IN}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.0 \mathrm{~V}$ | 0.27 |  | mA |
| X OUT | XSEL $=0, X_{\text {IN }}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=3.0 \mathrm{~V}$ | 10 |  | $\mu \mathrm{A}$ |
| 1 Hz , DO | $\mathrm{V}_{\mathrm{OH}}=2.0 \mathrm{~V}$ | 0.4 |  | mA |

## AC Electrical Characteristics

COP398/COP399: $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+85^{\circ} \mathrm{C}$ unless otherwise specified.
COP498/COP499: $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+70^{\circ} \mathrm{C}$ unless otherwise specified.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| COP Interface SK Frequency SK Duty Cycle | $\begin{aligned} & C S=1, C E=1 \text { COP498/COP499 } \\ & C S=1, C E=1 C O P 398 / C O P 399 \\ & S K \text { frequency } \geq 25 \mathrm{kHz} \\ & \text { SK frequency }=4.096 \mathrm{kHz} \end{aligned}$ | $\begin{gathered} 4.096 \\ 8.192 \\ 25 \\ 48 \end{gathered}$ | $\begin{gathered} 250 \\ 250 \\ 75 \\ 52 \end{gathered}$ | $\begin{gathered} \mathrm{kHz} \\ \mathrm{kHz} \\ \% \\ \% \end{gathered}$ |
| Inputs <br> CS <br> tcss <br> tcsh <br> DI <br> $\mathrm{t}_{\text {SETUP }}$ <br> thold |  | $\begin{gathered} 0.2 \\ 0 \\ \\ 0.4 \\ 0.4 \end{gathered}$ |  | $\mu \mathrm{s}$ $\mu \mathrm{s}$ <br> $\mu \mathrm{s}$ <br> $\mu \mathrm{S}$ |
| Output <br> DO <br> $t_{p d 1}, t_{p d 0}$ <br> $\mathrm{t}_{\mathrm{pd} 1}, \mathrm{t}_{\mathrm{pd}}$ | $\begin{aligned} & C_{L}=100 \mathrm{pF}, 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 5.5 \mathrm{~V}, \\ & \mathrm{~V}_{\text {OUT }}=1.5 \mathrm{~V} \\ & C_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{~V}_{\mathrm{CC}}=\text { Min., } \\ & \mathrm{V}_{\text {OUT }}=1.5 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 2.0 \\ & 2.4 \\ & \hline \end{aligned}$ | $\mu \mathrm{s}$ <br> $\mu \mathrm{s}$ |
| Crystal Osc. Frequency | $\begin{aligned} & \mathrm{XSEL}=1 \\ & \mathrm{XSEL}=0 \end{aligned}$ |  | $\begin{aligned} & 2.1 \\ & 65 \end{aligned}$ | $\begin{aligned} & \mathrm{MHz} \\ & \mathrm{kHz} \end{aligned}$ |



FIGURE 2. Synchronous Data Timing

## Connection Diagrams



FIGURE 3

## Pin Descriptions

| Pin | Description | Pin | Description <br> CS |
| :--- | :--- | :---: | :---: |
| Chip Select | 1 Hz | 1 Hz Square Wave Output |  |
| CE | Chip Enable | $\overline{O N}$ | Active Low Wake-Up Signal to COPS |
| SK | Serial Data Clock |  | Controller |
| DI | Serial Data Input | OVR | External Override Wake-Up for COPS |
| DO | Serial Data Output |  | Controller |
| XSEL | Crystal Option Select | OSC | Open Drain Oscillator Output |
| XIN | Crystal Oscillator Input | VCC | Power Supply |
| XOUT | Crystal Oscillator Output | GND | Ground |

COP398 and COP399 are extended temperature devices $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ of COP498 and COP499 $\left(0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$ respectively , with all other functional and electrical characteristics being the same. Therefore, no further attempt will be made to distinguish between COP498 and COP398 or between COP499 and COP399. Unless otherwise specified, the following descriptions will apply to both COP498 and COP499, and they will be known as the device.

## INSTRUCTION SET

COP498 has six instructions as indicated in Figure 4. Note that the MSB of any given instruction is a " 1 ". This bit is properly viewed as a start bit in the interface sequence. The lower 4 bits of the instruction contain the command for the device. One of the instructions (TSEC) should not be used in COP499 as it serves no purpose.
Instruction Opcode Comments

| MSB |  |  |
| :---: | :---: | :---: |
| WRITE | $1 \mathrm{~s} 1 \mathrm{r}_{1} \mathrm{r}_{0}$ | $s=\overline{\mathrm{ON}}$ (wake up signal) frequency select $1=16 \mathrm{~Hz}, 0=1 \mathrm{~Hz}$ (s selection for COP498 only) ( $s=0$ for COP499) |
| READ | $110 r_{1} \mathrm{r}_{0}$ | $\begin{aligned} & r_{1}, r_{0}=\text { register number }(00, \\ & 01,10,11) \end{aligned}$ |
| WREN | 10011 | Write enable |
| WRDS | 10000 | Write disable |
| TSEC | 10010 | Test timer seconds latch (COP498 only) |
| SLEEP | 10001 FIGURE | Put COPS controller to sleep ( $\overline{O N}$ high) |

## Functional Description

A block diagram of COP498 and COP499 is given in Figure 1. Positive logic is used. When a bit is set to the higher voltage it is a logic " 1 "; when a bit is reset to the lower
voltage it is a logic " 0 ". The COP498 can execute six instructions: READ (from any one of 4 registers in memory); WRITE (to any one of 4 registers in memory); WREN (write enable); WRDS (write disable); TSEC (test and reset timer seconds latch); and SLEEP (drive $\overline{O N}$ signal high to turn off COPS controller). The COP499 can execute all the above instructions except TSEC. All communications with the device are via the serial MICROWIRE interface. Both CS and CE (CE only in COP499) must be high to enable the device. The device must be deselected between instructions - either CS and/or CE must go low to insure proper operation. The deselecting of the device resets the counters and serial input register.

## READ/WRITE MEMORY

The device has 256 bits of read/write memory. The memory is organized as 4 registers of 64 bits each. The data is accessed serially through the Data input (DI) and Data Output (DO) pins. SK is the clock signal for data and instructions.
The memory address register can be conceived of as two registers: one two bits long and loaded directly from the instruction; the other six bits long and incremented by 1 with each SK pulse as long as the chip is selected. The two bit register does not change during the execution of a given instruction. The six bit register is reset to zero while the device is deselected. When counting, the six bit register wraps around from its maximum value back to zero. Thus memory locations are addressed relative to the number of SK pulses after the chip is selected.

## Functional Description (Continued)

The READ instruction will select one of the 4 registers (the register being identified in the instruction opcode as indicated in Figure 4) and output the contents of that register to the DO pin until the device is deselected. Note that data output from the device, as a result of a READ instruction, continues as long as the device is selected and clocks are provided. Reading more than 64 bits will cause rereading of some bits as the memory address register wraps around from the maximum value back to zero.
The WRITE instruction selects one of the 4 registers (the register being identified in the instruction opcode as indicated in Figure 4) and takes the data from the DI pin and stores that data into the memory register until the device is deselected. The write Operation continues as long as the device is selected and clocks are provided. Thus writing more than 64 bits will cause a portion of the data to be overwritten.

## TIMER (COP498 ONLY)

With the XSEL pin tied high ( $\mathrm{V}_{\mathrm{CC}}$ ), the timer is a 21 stage counter which can divide a 2.097152 MHz signal down to 1 Hz . This creates the 1 Hz signal output. With XSEL tied low (ground), the timer is a 15 stage counter which divides a 32.768 kHz signal down to create the 1 Hz signal output. The rising edge of the 1 Hz signal is used internally to set the timer seconds latch. A wake-up signal is generated at the $\overline{O N}$ output. This signal can be used to turn a COPS controller on. The wake-up rate is software selectable and may be either 1 Hz or 16 Hz . A bit in the WRITE instruction controls this wake-up rate (see Figure 4). By means of the SLEEP instruction a COPS controller may cause the $\overline{O N}$ signal to go high thereby providing a means for the controller to safely turn itself off.
An override capability is present whereby the $\overline{O N}$ pin may be prevented from going high. A "1" level at the OVR pin will force $\overline{O N}$ to go low (or stay low) thereby causing the controller to turn on or remain on. $\overline{O N}$ will remain low, and the controller on, as long as the OVR pin is high. To preserve timekeeping when using the override feature, a timer seconds latch is provided. This latch is set by the rising edge of the 1 Hz signal and is read and reset by the TSEC instruction. The timer seconds latch is primarily intended for use when the override feature is implemented. However, it does provide a convenient one second timer which is software testable over a common serial port.

## SYSTEM CONSIDERATIONS

When the COPS processor is being turned on and off, during the power supply transition between ground and operating voltage, some pulses may occur at the output pins of the processor. By using the WRDS and WREN instructions, together with the higher " 1 " level of the CE pin, accidental writing into the memory may be prevented. This is done by disabling the write operation before going to sleep and enabling the write operation when the COPS processor starts execution. A WRDS instruction is automatically executed if the SLEEP instruction causes $\overline{O N}$ to go high turning off the COPS processor. Furthermore, WREN instruction is disabled as long as $\overline{O N}$ remains high.
The XSEL pin, which identifies the timer counter length, should be tied to either $V_{\mathrm{CC}}$ or ground depending on the
crystal input. For proper operation, the state of XSEL should not be changed while the device is in operation. If the oscillator and timer features are not used, the $X_{I N}$ pin should be connected to the GND pin and XSEL tied to $\mathrm{V}_{\mathrm{CC}}$. If the override feature is not used the OVR pin should be connected to the GND pin.
The device is in a static mode when either the CS or CE pin is low. However, the device is in a dynamic mode when both CS and CE are high and at least one high level has been detected at SK while both pins are high. Because of this, a minimum frequency is specified for the SK clock. This minimum frequency really translates to maximum on and off times for the SK clock. As the SK clock slows down, the duty cycle must get cioser to $50 \%$. For best operation, the user should regard the maximum on and off times for the SK clock as about $122 \mu \mathrm{~s}$ (61 $\mu \mathrm{s}$ for COP398/COP399).

## COPS CONTROLLER TO COP498/COP499 HARDWARE INTERFACE

If the COPS controller is operating with a $4 \mu$ s instruction cycle time, a 47 k resistor should be connected between SK and $V_{C C}$ to speed up the rise time of the SK clock. If the override feature is used in COP498, the override signal should be connected to the OVR pin of the COP498 and an input of the COPS controller. This is simply to provide a means for the controller to know if it was turned on by override or normal timeout. The override signal should be free of noise. In systems where the COPS controlier is operating with $V_{C C}$ greater than 6 volts, SI and the override input on the controiler should have high impedance, standard TTL level input options selected. To minimize current drain in the controller, the override input to the controller should always use the high impedance option.
Figure $6 a$ illustrates the COP498 interface in a system with supply voltage less than 6 volts. The COPS controller can either be turned on by the timer or an external signal. A PNP transistor, controlled by the $\overline{O N}$ signal of the COP498, is used to gate the power to the COPS controller. A $0.05 \mu \mathrm{~F}$ capacitor is connected across the supply pins of the controller to reduce voltage variations due to current spikes. It is not recommended to use large capacitance values here as problems can be introduced if the power supply fall time is too long. The switched supply fall time should be kept to about ten instruction cycles of the COPS processor. Resistor R2, between the $\overline{\mathrm{ON}}$ pin of the COP498 and the base of the transistor, is used to limit current. Resistor R1, between the base and emitter of the transistor, is used to turn the transistor off when $\overline{O N}$ is high. The CE pin of the COP498 is tied to the $\mathrm{V}_{\mathrm{CC}}$ pin of the controller. This guarantees that the controller is at its full operating voltage before the COP498 can be accessed. When turned on, the PNP transistor should be saturated in order to minimize the voltage drop across it. The system power supply, which here is $\mathrm{V}_{\mathrm{CC}}$ to the COP498, must be high enough to insure that the controller $\mathrm{V}_{\mathrm{CC}}$ - which is the system supply less the voltage drop across the PNP transistor - is high enough to be recognized as a logic "1" at the CE input of the COP498. It is also desirable to have all input signals to the COP498 as close as possible to the COP498 supply levels to eliminate any static power drain which could significantly increase standby and operating current.

## Typical Performance Curves



Maximum Standby
Current for COP498/398


Maximum COP498/398
Operating Current


Maximum COP499/399
Operating Current


Minimum Sink Current for DO, $1 \mathrm{~Hz}, \mathrm{OSC}, \overline{O N}$


Maximum Sink Current for $\overline{O N}$

$X_{\text {OUT }}$ Minimum Sink Current with XSEL = 1

$X_{\text {OUT }}$ Minimum Sink
Current with XSEL $=0$


Minimum Source Current for DO, 1 Hz


Minimum Source Current for $\overline{O N}$


X Out Minimum Source Current with XSEL = 1

$\mathrm{X}_{\text {OUt }}$ Minimum Source
Current with XSEL $=0$


## Functional Description (Continued)



cs


FIGURE 5b. TSEC Instruction Timing


TL/DD/6684-7
FIGURE 6a. COP498-COP420 Interface


FIGURE 6b. COP499-COP420 Interface

## Functional Description (Continued)

Figure 6b illustrates the COP499 interface in a system with a supply voltage less than 6 volts. The COPS processor is being turned on by a switch (or an external signal) connected to the OVR pin.

Figure 7 illustrates a COP498 interface in a system with a supply voltage greater than 6 volts. In such a system, the COP498 cannot be connected directly across the system supply. The power to the COP498 is derived from the system supply by means of a standard zener diode arrangement. A zener diode with a breakdown of about 5 volts is recommended. A capacitor is connected across the COP498 supply pins to reduce voltage variations due to current spikes and to supply extra current when the COP498 is in active operation. Here it is assumed that the COP498 is in standby mode, i.e., deselected, most of the time and is active, selected, for a short period (less than 100 SK periods).
The zener diode series resistor R3 should be selected to meet the current requirements of the zener diode and the standby current of the device. The primary purpose of the zener diode is to place an upper limit on the value of $\mathrm{V}_{\mathrm{CC}}$ to the device. This insures that $V_{C C}$ to the device will not exceed the specified maximum value. Since the device will operate from 2.5 V to 6.0 V , the choice of zener diode and series resistor is not critical.

Note that the user may generate the two supply voltages in any manner compatible with system requirements.
Because the COPS controller and the device have different operating voltages, the high impedance standard TTL level input should be selected on the COPS controller for SI and any other input to the controller from the device.

## SAMPLE SYSTEM CURRENT DRAIN CALCULATION

Suppose a 5 V system consists of a COP420 and a COP498 with a 32.768 kHz crystal. The COP420 is being turned on


TL/DD/6684-9
once a second. Assume that the COP420 need 10 ms for internal reset and 10 ms to update all the necessary information, then the COP420 will be turned on for 20 ms every second, i.e., a duty cycle of $2 \%$; and the COP498 will be in operating mode for at most 10 ms , i.e., a duty cycle of less than $1 \%$. Because of the short duty cycle, it is further assumed that the COP498 current drain will be that of standby current, about $75 \mu \mathrm{~A}$ at 5 V . The current drain through the base of the switching transistor that turns on the COP420 can be estimated by the voltage drop across the current limiting resistor and in this case is assumed to be 3.5 mA .

COP498 current drain $=75 \mu \mathrm{~A}$
COP420 current drain $=0.02 \times 25 \mathrm{~mA}=500 \mu \mathrm{~A}$
Switching transistor base current $=0.02 \times 3.5 \mathrm{~mA}=70 \mu \mathrm{~A}$
Total system current drain $=500+70+75 \mu \mathrm{~A}=645 \mu \mathrm{~A}$
The result shows that it is possible to achieve the low cost of NMOS and low power dissipation of CMOS simultaneously with a system consisting of a COP498 and a COPS processor.

## COPS CONTROLLER - COP498/398 SOFTWARE INTERFACE

Figure 8 shows a typical flow chart for a COP498 or COP499 interface to a COPS microcontroller system. This flow chart also illustrates the override feature. Since the override feature is being used, the first step is to inquire the device if it is necessary to increment the time. It is assumed that timekeeping is a necessary part of the application. This interrogation of the device is accomplished by means of the TSEC instruction which dumps the contents of the timer seconds latch to the serial output port and resets the latch. If the latch was set, the time must be incremented. This is accomplished by reading the appropriate memory register into the controller, incrementing the time and writing the register back out to the device. The next step is to check for the override signal. If it is present a special override routine may be performed. If no override is present, the controller


TL/DD/6684-10
FIGURE 8. Typlcal COP498 Interface Flowchart

FIGURE 7. COP498-COP420L Interface with $\mathrm{V}_{\mathrm{S}}=9 \mathrm{~V}$ and 32.768 kHz Crystal

## Functional Description (Continued)

turns itself off by sending a SLEEP command to the device. After sending the SLEEP command, the controller goes into a loop to wait for power to go off. In the event the controller is turned back on by the override signal before the voltage has dropped, the loop has a time limit which, when exceeded, causes the controller to jump to the beginning of the program and start again. If the override feature is not used there is no need to test the timer seconds latch nor to test for the override signal. Without the override, the controller can only be turned on by the COP498 if the time out period has elapsed. Note also that the timer features continue to operate regardless of the state of the override signal. The override signal, when high, merely forces the $\overline{O N}$ pin to go low. The operation of the rest of the chip is in no way affected by the override signal.

## GENERAL CODE FOR SOFTWARE INTERFACE

The code in Figure 9a is recommended for interfacing the device to any COPS controller other than COP410L/

COP411L. The code in Figure $9 b$ is the recommended interface code for COP410L/COP411L. The code is written as subroutines and the code uses one level of subroutine internally. It is apparent from the code that the software interface is somewhat different for the READ and WRITE instructions than for the rest of the instructions. The routine labelled SETUP is assumed to be in page 2 of the ROM. The rest of the code may be located anywhere in program memory subject to the usual programming rules of COPS microcontrollers. The lower four bits of the instruction opcode are assumed to be located in RAM location COMAND, which is chosen as location 3,15. Data I/O uses register 2. The con-troller-COP498/499 interface is assumed to be as in Figure 6 or Figure 7. It is assumed that the SIO register in the COPS controller is enabled as serial I/O prior to entry to these routines.


FIGURE 9a. Software Interface to COP498/COP499 for COPS Controllers Other Than COP410L/COP411L

Functional Description (Continued)

| WRITE: | JSRP SETUP |  |
| :--- | :--- | :--- |
| RWI: | XAS | ; SEND COMMAND |
| RW2: | LD |  |
|  | XDS | POSITION Bd PROPERLY |

RW: LD
XAS
XIS
JP RW

OBD ; DISABLE THE COP498/499 ( $\mathrm{B}=0$ )
READ: JSRP SETUP
XAS
NOP
NOP
NOP
NOP
NOP
JP RW2
INSTRT: JSRP
XAS ; SEND INSTRUCTION
NOP
NOP
NOP
; DELAY FOR INSTRUCTION ACCEPT
NOP
FINISH: CLRA
RC
OBD ; DESELECT THE COP498/499
XAS ; TURN OFF THE CLOCK
RET

- PAGE 2

SETUP: LBI COMMAND
CLRA
SC
XAS ; TURN ON SK CLOCK
OBD ENABLE THE COP498/COP499 ( $B=15$ )
CLRA
XAS ; MAKE SURE NO INVALID DATA SENT
CLRA
AISC 1
SC
XAS ; SEND START BIT-MSD OF INSTRUCTION
LD ; FETCH INSTRUCTION
LBI 2,9
RET
FIGURE 9b. COP410L/COP411L Software Interface to COP498/COP499

The code in Figure 9a will read or write 64 bits at a time. Note that in the COP410L/411L the code in Figure $9 b$ will read or write 32 bits at a time. The code of Figure 10 is recommended if the user wishes to work in blocks of 64 bits with the COP410L/411L. Only the code which is different from that shown in Figure $9 b$ is shown in Figure 10.
The routine in Figure 10 will read/write into registers 2 and 1 in the COP410L/411L. Figure 10 illustrates the preferred method of achieving full utilization of the device memory when the COP410L/411L is the contoller. Remember that all the other routines are as shown in Figure 9B. Figure 10 illustrates only that code that must be changed to achieve
full usage of the device memory when using the COP410L/ 411L.

## GENERAL NOTES

1. For complete safety in all cases it is recommended that the SK clock be turned off after the device has been deselected since the device is dynamic when it is enabled, If the clock is turned off while the device is selected, special care must be given to the SK timing characteristics. In no case should the clock be turned off while the device is selected if the SK period is greater than about $50 \mu \mathrm{~s}$.

## Functional Description (Continued)

| WRITE: | JSRP | SETUP | ; INITIALIZE, SEE FIGURE 9B |
| :---: | :---: | :---: | :---: |
| RW1: | XAS |  | ; SEND COMMAND |
| RW2: | LD |  | ; POSITION Bd |
|  | XDS |  |  |
| RW: | ID |  |  |
|  | XAS |  |  |
|  | X | 3 | ; USE REGISTERS 2 AND 1 |
|  | LD |  |  |
|  | NOP |  |  |
|  | XAS |  |  |
|  | XIS | 3 |  |
|  | JP | RW |  |
|  | OBD |  | ; DESELECT THE COP498/499 |
|  | JP | FINISH |  |

FIGURE 10. COP410L/411L-COP498/499 Special Routine
2. The device does not become dynamic until both $C S$ and CE are high and at least one high level is seen at the SK input. Thus the device may be safely enabled prior to turning on the clock as long as SK is low when the device is enabled.
3. The device must be deselected between instructions. Failure to do so will yield improper operation. The device relies on the select lines changing state in order to clear internal registers. Only one of the select lines on the COP498 needs to go low between instructions.
4. The user must insure that a WREN (write enable) instruction has been performed in order to write to the device memory. The WREN command need be given only once unless the SLEEP feature is used. If $\overline{O N}$ goes high as a result of a SLEEP command, a write disable is automatically performed in order to provide maximum protection to the device memory while the COPS controller is powering up and powering down. As long as $\overline{O N}$ remains high, WRITE and WREN instructions are disabled. Thus when the COPS controller wakes up after previously issuing a SLEEP command, a WREN instruction is required before data can be written to the device.
5. The six bit section of the RAM address register will increment whenever there are clock pulses present when the CS and CE pins are high. Thus the user can position the RAM address register if he wishes by selecting the device, holding the DI pin low and supplying the appropriate number of clocks. Then, without deselecting the device, the user would send the instruction and read or write data. Although possible, this technique is not recommended as it is fairly involved.
6. When using the TSEC command in COP498 with the code as given in Figure 9, the master program should test for the accumulator greater than 1 to determine if the timer seconds latch was set. Note again, test for greater than 1 ; do not test for greater than zero.

## NOTE ON MICROWIRE INTERFACE

If the device is connected to a MICROWIRE interface containing other circuits whose DO (data output) pins may produce a signal swing higher than $V_{C C}$ of the device, some protection is needed on the DO pin of the device. This happens when the DO pins of several peripherals powered by different voltages are connected together; e.g., a COP452 at 4.5 V with a COP499 at 2.4 V . When the DO pin of COP498/499 is externally driven above its power supply voltage, a current will flow into it and this current must be limited to 1 mA . As an example we have two COP452s with a COP420L operating at 4.5 V and a COP499 operating at 2.4 V . When enabled, the DO pin of a COP452 may swing higher than 2.4 V , the power supply voltage of the COP499. One way to limit the current is to use a current limiting resistor of $2 \mathrm{k} \Omega$ between the DO pins of the COP452 and the COP499. NOTE: the SI pin of the COPS processor MUST BE A Hi-Z INPUT. Two configurations are possible as shown in Figure 11. Note that the resistor between DO and SI will give extra RC delay to the signal going from the DO pin to the SI pin of the COPS processor. Connection B is preferred because the DO signal from COP499 has nearly a whole SK cycle to become valid at SI input before the signal is read by the processor. When a ROMless COPS processor (COP401L/COP402/COP404L) is used for emulation, the circuit shown in Figure 12 may be used to simulate a Hi$Z$ input for the SI pin.


FIGURE 11. High Voltage Protection on DO pln

## Functional Description (Continued)



TL/DD/6684-12
FIGURE 12. Simulating Hi-Z SI Input on ROMless Processors

National Semiconductor Corporation

## DS8906 AM/FM Digital Phase-Locked Loop Synthesizer

## General Description

The DS8906 is a PLL synthesizer designed specifically for use in AM/FM radios. It contains the reference oscillator, a phase comparator, a charge pump, a $120 \mathrm{MHz} \mathrm{ECL} / \mathrm{I}^{2 \mathrm{~L}}$ dual modulus programmable divider, and a 20 -bit shift register/latch for serial data entry. The device is designed to operate with a serial data controller generating the necessary division codes for each frequency, and logic state information for radio function inputs/outputs.
The Colpitts reference oscillator for the PLL operates at 4 MHz . A chain of dividers is used to generate a 500 kHz clock signal for the external controller. Additional dividers generate a 12.5 kHz reference signal for FM and a 500 Hz reference signal for AM/SW. One of these reference signals is selected by the data from the controller for use by the phase comparator. Additional dividers are used to generate a 50 Hz timing signal used by the controller for "time-ofday'.
Data is transferred between the frequency synthesizer and the controller via a 3 wire bus system. This consists of a data input line, an enable line and a clock line. When the enable line is low, data can be shifted from the controller into the frequency synthesizer. When the enable line is transitioned from low to high, data entry is disabled and data present in the shift register is latched.
From the controller 22-bit data stream, the first 2 bits address the device permitting other devices to share the same bus. Of the remaining 20 -bit data word, the next 14 -bits are used for the PLL divide code. The remaining 6 bits are connected via latches to output pins. These 6 bits can be used to drive radio functions such as gain, mute, FM, AM, LW and SW only. These outputs are open collector. Bit 18 is used internally to select the AM or FM local oscillator input and to select between the 500 Hz and 12.5 kHz reference. A high level at bit 18 indicates FM and a low level indicates AM.
The PLL consists of a 14-bit programmable ${ }^{2} \mathrm{~L}$ divider, an ECL phase comparator, an ECL dual modulus ( $p / p+1$ ) prescaler, and a high speed charge pump. The programmable divider divides by $(\mathrm{N}+1), \mathrm{N}$ being the number loaded into the shift register (bits 1-14 after address). It is clocked by the AM input via an ECL $\div 7 / 8$ prescaler, or through a $\div$ 63/64 prescaler from the FM input. The AM input will work at frequencies up to 8 MHz , while the FM input works up to 120 MHz . The AM band is tuned with a frequency resolution of 500 Hz and the FM band is tuned with a resolution of 12.5 kHz . The buffered AM and FM inputs are self-biased and can be driven directly by the VCO thru a capacitor. The ECL phase comparator produces very accurate resolution of the phase difference between the input signal and the reference oscillator.

The high speed charge pump consists of a switchable constant current source $(-0.3 \mathrm{~mA})$ and a switchable constant current sink ( +0.3 mA ). If the VCO frequency is low, the charge pump will source current, and sink current if the VCO frequency is high.
A separate $\mathrm{V}_{\mathrm{CCM}}$ pin (typically drawing 1.5 mA ) powers the oscillator and reference chain to provide controller clocking frequencies when the balance of the PLL is powered down.

## Features

- Uses inexpensive 4 MHz reference crystal
- FIN capability greater than 120 MHz allows direct synthesis at FM frequencies
m FM resolution of 12.5 kHz allows usage of 10.7 MHz ceramic filter distribution
- Serial data entry for simplified control
- 50 Hz output for "time-of-day" reference with separate low power supply ( $\mathrm{V}_{\mathrm{CCM}}$ )
- 6-open collector buffered outputs for band switching and other radio functions
- Separate AM and FM inputs. AM input has 15 mV (typical) hysteresis


## Connection Diagram



## Absolute Maximum Ratings (Note 1)

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Supply Voltage

| $\left(V_{\mathrm{CC1}}\right)$ | 7 V |
| :---: | :---: |
| $\left(\mathrm{~V}_{\mathrm{CCM}}\right)$ | 7 V |
| Input Voltage | 7 V |
| Output Voltage | 7 V |

DC Electrical Characteristics (Notes 2 and 3)

| Symbol | Parameter | Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{1 \mathrm{H}}$ | Logical " 1 " Input Voltage |  |  | 2.1 |  |  | V |
| $\mathrm{I}_{\mathrm{H}}$ | Logical "1" Input Current | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC} 1}$ |  |  | 0 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Logical "0" Input Voltage |  |  |  |  | 0.7 | V |
| $\mathrm{I}_{\text {IL }}$ | Logical "0" Input Current | Data, Clock and ENABLE |  |  | -5 | -25 | $\mu \mathrm{A}$ |
| ${ }^{\text {IOH}}$ | Logical "1" Output Current All Bit Outputs, 50 Hz Output | $\mathrm{V}_{\mathrm{OH}}=5.25 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
|  | 500 kHz Output | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CCM}}=4.5 \mathrm{~V}$ |  |  |  | -250 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {OL }}$ | Logical " 0 " Output Voltage All Bit Outputs | $\mathrm{l}_{\mathrm{OL}}=5 \mathrm{~mA}$ |  |  |  | 0.5 | V |
|  | 50 Hz Output, 500 kHz Output | $\mathrm{I}_{\mathrm{OL}}=250 \mu \mathrm{~A}$ |  |  |  | -0.5 | V |
| $\mathrm{I}_{\text {CC1 }}$ | Supply Current (VCC1) | All Bit Outputs High |  |  | 90 | 160 | mA |
| ${ }^{\text {ICCM(STANDBY) }}$ | $V_{\text {CCM }}$ Supply Current | $\mathrm{V}_{\text {CCM }}=6.0 \mathrm{~V}$, All Other Pins Open |  |  | 1.5 | 4.0 | mA |
| IOUT | Charge Pump Output Current | $\begin{aligned} & 1.2 \mathrm{~V} \leq \mathrm{V}_{\mathrm{OUT}} \leq \mathrm{V}_{\mathrm{CCM}}-1.2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CCM}} \leq 6.0 \mathrm{~V} \end{aligned}$ | Pump Up | -0.10 | -0.30 | -0.6 | mA |
|  |  |  | Pump Down | 0.10 | 0.30 | 0.6 | mA |
|  |  |  | TRI-STATE ${ }^{\text {® }}$ |  | 0 | $\pm 100$ | nA |
| ICCm(operate) | VCCM Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CCM}}=6.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC1}}=5.25 \mathrm{~V} \text {, } \\ & \text { All Other Pins Open } \end{aligned}$ |  |  | 2.5 | 6.0 | mA |

AC Electrical Characteristics $v_{C C}=5 V, T_{A}=25^{\circ} \mathrm{C}, \mathrm{t}_{\mathrm{r}} \leq 10 \mathrm{~ns}, \mathrm{t}_{\mathrm{t}} \leq 10 \mathrm{~ns}$

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IN(MIN }}(\mathrm{F})$ | $\mathrm{F}_{\text {IN }}$ Minimum Signal Input | AM and FM Inputs, $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ |  | 20 | 100 | mV (rms) |
| $\mathrm{V}_{\operatorname{IN}(\mathrm{MAX})(\mathrm{F})}$ | FIN Maximum Signal Input | AM and FM Inputs, $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$ | 1000 | 1500 |  | mV (rms) |
| Foperate | Operating Frequency Range (Sine Wave Input) | $\begin{array}{ll} V_{I N}=100 \mathrm{mV} \text { rms } & A M \\ 0^{\circ} \mathrm{C} \leq T_{A} \leq 70^{\circ} \mathrm{C} & \mathrm{FM} \\ \hline \end{array}$ | $\begin{aligned} & 0.4 \\ & 60 \end{aligned}$ |  | $\begin{gathered} 8 \\ 120 \end{gathered}$ | $\begin{aligned} & \mathrm{MHz} \\ & \mathrm{MHz} \end{aligned}$ |
| $\mathrm{R}_{\text {IN }}$ (FM) | AC Input Resistance, FM | $120 \mathrm{MHz}, \mathrm{V}_{\text {IN }}=100 \mathrm{mV} \mathrm{rms}$ | 300 |  |  | $\Omega$ |
| $\mathrm{R}_{\text {IN }}(\mathrm{AM})$ | AC Input Resistance, AM | $2 \mathrm{MHz}, \mathrm{V}_{\text {IN }}=100 \mathrm{mV} \mathrm{rms}$ | 1000 |  |  | $\Omega$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance, FM and AM | $\mathrm{V}_{\mathrm{IN}}=120 \mathrm{MHz}$ | 3 | 6 | 10 | pF |
| $\mathrm{t}_{\mathrm{EN} 1}$ | Minimum ENABBLE High Pulse Width |  |  | 625 | 1250 | ns |
| teno | Minimum ENABLE Low Pulse Width |  |  | 375 | 750 | ns |
| tclkeno | Minimum Time before ENABLE Goes Low that CLOCK must be Low |  |  | -50 | 0 | ns |
| ${ }_{\text {teNOCLK }}$ | Minimum Time after ENABLE Goes Low that CLOCK must Remain Low |  |  | 275 | 550 | ns |
| tCLKEN1 | Minimum Time before ENABLE Goes High that Last Positive CLOCK Edge May Occur |  |  | 300 | 600 | ns |

AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}_{\mathrm{r}} \leq 10 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 10 \mathrm{~ns}$ (Continued)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :--- | :--- | :--- | :--- | :--- | :---: | :---: |
| $t_{\text {EN1CLK }}$ | Minimum Time After ENABLE <br> Goes High Before an Unused <br> Positive CLOCK Edge May Occur |  |  | 175 | 350 | ns |
| $t_{\text {CLKH }}$ | Minimum CLOCK High <br> Pulse Width |  |  | 275 | 550 | ns |
| $\mathrm{t}_{\text {CLKL }}$ | Minimum CLOCK Low <br> Pulse Width |  | 400 | 800 | ns |  |
| $\mathrm{t}_{\text {DS }}$ | Minimum DATA Setup Time, <br> Minimum Time Before CLOCK <br> that DATA Must be Valid |  |  | 150 | 300 | ns |
| $\mathrm{t}_{\text {DH }}$ | Minimum DATA Hold Time, <br> Minimum Time After CLOCK <br> that DATA Must Remain Valid |  | 400 | 800 | ns |  |

Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. Except for "Operating Temperature Range" they are not meant to imply that the devices should be operated at these limits. The table of "Electrical Characteristics" provides conditions for actual device operation.
Note 2: Unless otherwise specified $\mathrm{min} /$ max limits apply across the $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ temperature range for the DS 8906 .
Note 3: All currents into device pins shown as positive, out of device pins as negative, all voltages referenced to ground unless otherwise noted. All values shown as max or min on absolute value basis.

Schematic Diagrams (DS8906 AM/FM PLL Typical Input/Output Schematics)



TL/F/5775-4


TL/F/5775-6

Schematic Diagrams (DS8906 AM/FM PLL Typical Input/Output Schematics) (Continued)



TL/F/5775-8

## Timing Diagrams*

ENABLE vs CLOCK


TL/F/5775-9
CLOCK vs DATA


TL/F/5775-10


POSITIVE TRANSITION ON
ENABLE LATCHES IN NEW CODE IF PLL IS ADDRESSED.

## Applications Information

## SERIAL DATA ENTRY INTO THE DS8906

Serial information entry into the DS8906 is enabled by a low level on the ENABLE input. One binary bit is then accepted from the DATA input with each positive transition of the CLOCK input. The CLOCK input must be low for the specified time preceding and following the negative transition of the ENABLE input.
The first 2 bits accepted following the negative transition of the ENABLE input are interpreted as address. If these address bits are not 1,1 , no further information will be accepted from the DATA inputs, and the internal data latches will not be changed when ENABLE returns high.
If these first 2 bits are 1,1, then all succeeding bits are accepted as data, and are shifted successively into the internal shift register as long as ENABLE remains low.
Any data bits preceding the 20th to last bit will be shifted out, and are thus irrelevant. Data bits are counted as any bits following 2 valid (1,1) address bits with the ENABLE low.
When the ENABLE input returns high, any further serial data input is inhibited. Upon this positive transition of the ENABLE, the data in the internal shift register is transferred into the internal data latches.

Note that until this time, the states of the internal data latches have remained unchanged.
These data bits are interpreted as follows:
DATA BIT POSITION DATA INTERPRETATION

Last
2nd to Last
3rd to Last
4th to Last
5th to Last
6th to Last
7th to Last
8th to Last
9th to Last
10th to Last
11th to Last
12th to Last 13th to Last 14th to Last 15th to Last 16th to Last 17th to Last 18th to Last 19th to Last 20th to Last
Note. The actual divide code is $\mathrm{N}+1$, i.e., the number loaded plus 1 .

Typical Application
Electronically Tuned Radio Controller System; Direct Drive LED


## Logic Diagram


*Sections operating from $V_{\text {CCM }}$ supply
**Address (1, 1)

# DS8907 AM/FM Digital Phase-Locked Loop Frequency Synthesizer General Description 

The DS8907 is a PLL synthesizer designed specifically for use in AM/FM radios. It contains the reference oscillator, a phase comparator, a charge pump, a 120 MHz ECL/I2L dual modulus programmable divider, and an 18-bit shift register/latch for serial data entry. The device is designed to operate with a serial data controller generating the necessary division codes for each frequency, and logic state information for radio function inputs/outputs.
The Colpitts reference oscillator for the PLL operates at 4 MHz . A chain of dividers is used to generate a 500 kHz clock signal for the external controller. Additional dividers generate a 25 kHz reference signal for FM and a 10 kHz reference signal for AM. One of these reference signals is selected by the data from the controller for use by the phase comparator.
Data is transferred between the frequency synthesizer and the controller via a 3 wire bus system. This consists of a data input line, an enable line, and a clock line. When the enable line is low, data can be shifted from the controller into the frequency synthesizer. When the enable line is transitioned from low to high, data entry is disabled and data present in the shift register is latched.
From the controller 20-bit data stream, the first 2 bits address the device permitting other devices to share the same bus. Of the remaining 18 -bit data word, the next 13 bits are used for the PLL divide code. The remaining 5 bits are connected via latches to output pins. These 5 bits can be used to drive radio functions such as gain, mute, FM, AM and stereo only. These outputs are open collector. Bit 16 is used internally to select the AM or FM local oscillator input and to select between the 10 kHz and 25 kHz reference. A high level at bit 16 indicates $F M$ and a low level indicates AM.
The PLL consists of a 13-bit programmable 12L divider, an ECL phase comparator, an ECL dual modulus ( $p / p+1$ ) prescaler, and a high speed charge pump. The programma-
ble divider divides by $(N+1)$, $N$ being the number loaded into the shift register (bits $1-13$ after address). It is clocked by the AM input via an ECL $\div 7 / 8$ prescaler, or through a $\div 63 / 64$ prescaler from the FM input. The AM input will work at frequencies up to 15 MHz , while the FM input works up to 120 MHz . The AM band is tuned with a frequency resolution of 10 kHz and the FM band is tuned with a resolution of 25 kHz . The buffered AM and FM inputs are self biased and can be driven directly by the VCO through a capacitor. The ECL phase comparator produces very accurate resolution of the phase difference between the input signal and the reference oscillator. The high speed charge pump consists of a switchable constant current source ( -0.3 mA ) and a switchable constant current sink ( +0.3 mA ). If the VCO frequency is low, the charge pump will source current, and sink current if the VCO frequency is high. When using an AFC the charge pump output may be forced into TRI-STATE ${ }^{\oplus}$ by applying a low level to the charge pump enable input.
A separate $V_{C C M}$ pin (typically drawing 1.5 mA ) powers the oscillator and reference chain to provide controller clocking frequencies when the balance of the PLL is powered down.

## Features

■ Uses inexpensive 4 MHz reference crystal

- FIN capability greater than 120 MHz allows direct synthesis at FM frequencies
■ FM resolution of 25 kHz allows usage of 10.7 MHz ceramic filter distribution
- Serial data entry for simplified control
- 50 Hz output for "time-of-day" reference driven from separate low power $V_{\text {CCM }}$
- 5-open collector buffered outputs for controlling various radio functions
separate AM and FM inputs. AM input has 15 mV (typical) hysteresis


## Connection Diagram



| Absolute Maximum Ratings (Note 1) |  |  | Storage Temperature Range |  |  | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Specifications for Milltary/Aerospace products are not contained in thls datasheet. Refer to the assoclated rellability electrical test specifications document. |  |  | Lead Temperature (Soldering, 4 sec .) |  |  | $260^{\circ} \mathrm{C}$ |  |  |
| Supply Voltãge$\left(V_{C C 1}\right)$ |  |  |  | Min |  | Max | Units |  |
|  |  |  | Supply Voltage, $\mathrm{V}_{\mathrm{CC}}$ |  |  |  | V |  |
| (VCcm) |  | $\begin{aligned} & 7 V \\ & 7 V \end{aligned}$ | VCC1 |  | 4.75 | 5.25 |  |  |
| Input Voltage |  | 7V | $V_{\text {CCM }}$ |  | 4.5 | 6.0 | V |  |
| Output Voltage |  | 7 V | Temperature, $\mathrm{T}_{\text {A }}$ |  | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |  |
| DC Electrical Characteristics (Notes 2 and 3) |  |  |  |  |  |  |  |  |
| Symbol | Parameter | Conditions |  |  | MIn | Typ | Max | Units |
| $\mathrm{V}_{\text {IH }}$ | Logical "1" Input Voltage |  |  |  | 2.1 |  |  | V |
| ${ }_{\text {IH }}$ | Logical "1" Input Current | $\mathrm{V}_{\text {IN }}=2.7 \mathrm{~V}$ |  |  |  | 0 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Logical "0" Input Voltage |  |  |  |  |  | 0.7 | V |
| ILL | Logical "0" Input Current | Data, Clock | NABLE Inp | $\mathrm{V}_{1} \mathrm{~N}=0 \mathrm{~V}$ |  | -5 | -25 | $\mu \mathrm{A}$ |
| ILL | Logical "0" Input Current | Charge Pu | able, $\mathrm{V}_{\text {IN }}=0$ |  |  | -250 | -450 | $\mu \mathrm{A}$ |
| IOH | Logical "1" Output Current All Bit Outputs, 50 Hz Output | $\mathrm{V}_{\mathrm{OH}}=5.25$ |  |  |  |  | 50 | $\mu \mathrm{A}$ |
|  | 500 kHz Output | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ | $\mathrm{M}=4.5 \mathrm{~V}$ |  |  |  | -250 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {OL }}$ | Logical " 0 " Output Voltage All Bit Outputs | $\mathrm{l}^{\mathrm{OL}}=5 \mathrm{~mA}$ |  |  |  |  | 0.5 | V |
|  | 50 Hz Output, 500 Hz Output | $\mathrm{IOL}=250$ |  |  |  |  | 0.5 | V |
| ${ }_{\mathrm{COC}}$ | Supply Current (V${ }^{\text {CC1 }}$ ) | All Bits Outp |  |  |  | 90 | 160 | mA |
| ICCM(STANDBY) | $\mathrm{V}_{\text {CCM }}$ Supply Current | $\mathrm{V}_{\text {CCM }}=6.0$ | Other Pins O |  |  | 1.5 | 4.0 | mA |
| Iout | Charge Pump Ougtput Current | $1.2 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }}$ | Ccm -1.2V | Pump Up | -0.10 | -0.30 | -0.6 | mA |
|  |  | $V_{\text {CCM }} \leq 6.0 \mathrm{~V}$ |  | Pump Down | 0.10 | 0.30 | 0.6 | mA |
|  |  |  |  | TRI-STATE |  | 0 | $\pm 100$ | nA |
| ICCM(OPERATE) | V ${ }_{\text {CCM }}$ Supply Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CCM}}=6 . \\ & \text { All Other Pi } \end{aligned}$ | $\mathrm{CO}_{1}=5.25 \mathrm{~V}$ |  |  | 2.5 | 6.0 | mA |

AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}_{\mathrm{r}} \leq 10 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 10 \mathrm{~ns}$


AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}_{\mathrm{r}} \leq 10 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 10 \mathrm{~ns}$ (Continued)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| $t_{\text {EN1CLK }}$ | Minimum Time After ENABLE <br> Goes High Before an Unused <br> Positive CLOCK Edge May Occur |  |  | 175 | 350 | ns |
| $t_{\text {CLKH }}$ | Minimum CLOCK High <br> Pulse Width |  | 275 | 550 | ns |  |
| t CLKL | Minimum CLOCK Low <br> Pulse Width |  | 400 | 800 | ns |  |
| tos | Minimum DATA Setup Time, <br> Minimum Time before CLOCK <br> That DATA Must Be Valid |  | 150 | 300 | ns |  |
| $t_{\text {DH }}$ | Minimum DATA Hold Time, <br> Minimum Time after CLOCK <br> That DATA Must Remain Valid |  | 400 | 800 | ns |  |

Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. Except for "Operating Temperature Range" they are not meant to imply that the devices should be operated at these limits. The table of "Electrical Characteristics" provides conditions for actual device operation.
Note 2: Unless otherwise specified min/max limits apply across the $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ temperature range for the DS8907.
Note 3: All currents into device pins shown as positive, out of device pins as negative, all voltages referenced to ground unless otherwise noted. All values shown as max or min on absolute value basis.

Schematic Diagrams (DS8907 AM/FM PLL typical Input/Output Schematics)


TL/F/7511-3


TL/F/7511-7


TL/F/7511-8

Timing Diagrams*

*Timing diagrams are not drawn to scale. Scale within any one drawing may not be consistent, and intervals are defined positive as drawn.

## SERIAL DATA ENTRY INTO THE DS8907

Serial information entry into the DS8907 is enabled by a low level on the ENABLE input. One binary bit is then accepted from the DATA input with each positive transition of the CLOCK input. The CLOCK input must be low for the specified time preceding and following the negative transition of the ENABLE input.
The first two bits accepted following the negative transition of the ENABLE input are interpreted as address. If these address bits are not 1,1 no further information will be accepted from the DATA inputs, and the internal data latches will not be changed when ENABLE returns high.
If these first two bits are 1,1, then all succeeding bits are accepted as data, and are shifted successively into the internal shift register as long as ENABLE remains low.
Any data bits preceding the 18th to last bit will be shifted out, and thus are irrelevant. Data bits are counted as any bits following two valid address bits $(1,1)$ with the ENABLE low. When the ENABLE input returns high, any further serial data entry is inhibited. Upon this positive transition, the data in the internal shift register is transferred into the internal data latches. Note that until this time, the states of the internal data latches have remained unchanged.

These data bits are interpreted as follows:


Note: The actual divide code is $N+1$, i.e., the number loaded plus 1 .

## Typical Application

Electronically Tuned Radio Controller System; Direct Drive LED


TL/F/7511-12

Logic Diagram


TL/F/7511-13
*Sections operating from $\mathrm{V}_{\mathrm{CCM}}$ supply.
**Address (1, 1)

## DS8908 AM/FM Digital Phase-Locked Loop Frequency Synthesizer

## General Description

The DS8908 is a PLL synthesizer designed specifically for use in AM/FM radios. It contains the reference oscillator, a phase comparator, a charge pump, an operational amplifier, a $120 \mathrm{MHz} \mathrm{ECL} / /^{2 \mathrm{~L}}$ dual modulus programmable divider, and a 19 -bit shift register/latch for serial data entry. The device is designed to operate with a serial data controller generating the necesary division codes for each frequency, and logic state information for radio function inputs/outputs.
A 3.96 MHz pierce oscillator and divider chain generate a 1.98 MHz external controller clock, a $20 \mathrm{kHz}, 10 \mathrm{kHz}, 9 \mathrm{kHz}$, and a 1 kHz reference signals, and a 50 Hz time-of-day signal. The oscillator and divider chain are sourced by the $V_{C C M}$ pin thus providing a low power controller clock drive and time-of-day indication when the balance of the PLL is powered down.
The 21-bit serial data steram is transferred between the frequency synthesizer and the controller via a 3 -wire bus system comprised of a data line, a clock line, and an enable line.
The first 2 bits in the serial data stream address the synthesizer thus permitting other devices such as display drivers to share the same bus. The next 14 bits are used for the PLL( $N+1$ ) divide code. The 15th bit is used internally to select the AM or FM local oscillator input. A high level on this bit enables the FM input and a low level enables the AM input. The 16th and 17th bits are used to select one of the 4 reference frequencies. The 18th and 19th bits are connected via latches to open collector outputs. These outputs can be used to drive radio functions such as gain, mute, AM, FM, or charge pump current source levels.
The PLL consists of a 14-bit programmable ${ }^{2}$ L divider, an ECL phase comparator, an ECL dual modulus ( $p / p+1$ ) prescaler, a high speed charge pump, and an operational amplifier. The programmable divider divides by $(N+1), N$ being the number loaded into the shift register. The programmable divider is clocked through a $\div 7 / 8$ prescaler by the AM input or through a $\div 63 / 64$ prescaler by the FM input. The AM input will work at frequencies up to 15 MHz , while the FM input works up to 120 MHz . The VCO can be tuned with a frequency resolution of either $1 \mathrm{kHz}, 9 \mathrm{kHz}, 10 \mathrm{kHz}$, or 20 kHz . The buffered AM and FM inputs are self-biased and can be driven directly by the VCO through a capacitor. The ECL phase comparator produces very accurate resolution of the phase difference between the input signal and the reference oscillator. The high speed charge pump consists of a switchable constant current source and sink. The charge pump can be programmed to deliver from $75 \mu \mathrm{~A}$ to $750 \mu \mathrm{~A}$ of constant current by connection of an external resistor from pin Rprogram to ground or the open collector bit outputs. Connection of programming resistors to the bit outputs enables the controller to adjust the loop gain for the particular reference frequency selected. The charge pump will source current if the VCO frequency is high and sink
current if the VCO frequency is low. The low noise operational amplifier provided has a high impedance JFET input and a large output voltage range. The op amp's negative input is common with the charge pump output and its positive input is internally biased.

## Features

- Uses inexpensive 3.96 MHz reference crystal
- FIN capability greater than 120 MHz allows direct synthesis at FM frequencies
- FM resolution of either 10 kHz or 20 kHz allows usage of 10.7 MHz ceramic filter distribution
■ Serial data entry for simplified control
■ 50 Hz output for time-of-day reference driven from separate low power $V_{C C M}$
- 2 open collector buffered outputs for controlling various radio functions or loop gain
- Separate AM and FM inputs; AM input has 15 mV (typical) hysteresis
- Programmable charge pump current sources enable adjustment of system loop gain
- Operational amplifier provides high impedance load to charge pump output and a wide voltage range for the VCO input


## Connection Diagram



Absolute Maximum Ratings (Note 1)
Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Supply Voltage

| $\left(V_{\mathrm{CC} 1}\right)\left(\mathrm{V}_{\mathrm{CCM}}\right)$ | 7 V |
| :--- | ---: |
| $\left(\mathrm{~V}_{\mathrm{CC} 2}\right)$ | 17 V |
| Input Voltage | 7 V |
| Output Voltage | 7 V |

$\begin{array}{lr}\text { Storage Temperature Range } & -65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\ \text { Lead Temperature (Soldering, } 4 \text { seconds) } & 260^{\circ} \mathrm{C}\end{array}$
Operating Conditions

|  | Min | Max | Units |
| :--- | :---: | :---: | :---: |
| $V_{C C 1}$ | 4.5 | 5.5 | $V$ |
| $V_{C C 2}$ | $V_{C C 1}+1.5$ | 15.0 | $V$ |
| $V_{C C M}$ | 3.5 | 5.5 | $V$ |
| Temperature, $T_{A}$ | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |

DC Electrical Characteristics (Notes 2 and 3 )

| Symbol | Parameter | Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical "1" Input Voltage |  |  | 2.0 |  |  | V |
| $\mathrm{I}_{\mathrm{H}}$ | Logical "1" Input Current | $\mathrm{V}_{\mathrm{IN}}=2.7 \mathrm{~V}$ |  |  | 0 | 10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {IL }}$ | Logical "0"' Input Voltage |  |  |  |  | 0.8 | V |
| IIL | Logical "0" Input Current | Data, Clock, and ENABLE Inputs, $\mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V}$ |  |  | -5 | -25 | $\mu \mathrm{A}$ |
| $\mathrm{IOH}^{\text {l }}$ | Logical "1" Output Current All Bit Outputs, 50 Hz Output | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
|  | 1.98 MHz Output | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CCM}}=4.5 \mathrm{~V}$ |  |  |  | -250 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {OL }}$ | Logical " 0 " Output Voltage All Bit Outputs | $\mathrm{IOL}^{\prime}=5 \mathrm{~mA}$ |  |  |  | 0.5 | V |
|  | 50 Hz Output, 1.98 MHz Output | $\mathrm{IOL}=250 \mu \mathrm{~A}$ |  |  |  | 0.5 | V |
|  | 1.98 MHz Output | $\begin{aligned} & \mathrm{l}_{\mathrm{OL}}=20 \mu \mathrm{~A}, \mathrm{~T}_{\mathrm{A}}>70^{\circ} \mathrm{C} \\ & \mathrm{l}_{\mathrm{OL}}=20 \mu \mathrm{~A}, \mathrm{~T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C} \end{aligned}$ |  |  |  | $\begin{aligned} & 0.3 \\ & 0.4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| $\mathrm{l}_{\mathrm{CC} 1}$ | Supply Current (VCC1) | All Bit Outputs High |  |  |  | 160 | mA |
| ICCM | $V_{\text {CCM }}$ Supply Current | $\mathrm{V}_{\text {CCM }}=5.5 \mathrm{~V}$, All Other Pins Open |  |  | 2.5 | 4.0 | mA |
| Iout | Charge Pump Ougtput Current | $3.33 \mathrm{k} \leq$ RPROG $^{5} \leq 33.3 \mathrm{k}$ lout Measured between Pin 17 and Pin 18 $I_{\text {PROG }}=V_{C C 1} / 2 R_{\text {PROG }}$ | Pump Up | -20 | IPROG | +20 | \% |
|  |  |  | Pump Down | -20 | IPROG | +20 | \% |
|  |  |  | TRI-STATE® |  | 0 | 11 | nA |
| $\mathrm{I}_{\text {CC2 }}$ | V CC 2 Supply Current | $\begin{aligned} & V_{C C M}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC} 2}=15 \mathrm{~V} \\ & \text { All Other Pins Open } \end{aligned}$ |  |  | 6.7 | 11 | mA |
| OPVOH | Op Amp Minimum High Level | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-750 \mu \mathrm{~A}$ |  | $\mathrm{V}_{\mathrm{CC} 2}-0.4$ |  |  | V |
| OPVOL | Op Amp Maximum Low Level | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=750 \mu \mathrm{~A}$ |  |  |  | 0.6 | V |
| $\mathrm{CPO}_{\text {BIAS }}$ | Charge Pump Bias Voltage Delta | CPO Shorted to Op Amp Output CPO = TRI-STATE <br> Op Amp loL: $750 \mu \mathrm{~A}$ vs $-750 \mu \mathrm{~A}$ |  |  |  | 100 | mV |

AC Electrical Characteristics $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}_{\mathrm{r}} \leq 10 \mathrm{~ns}, \mathrm{t}_{\mathrm{t}} \leq 10 \mathrm{~ns}$

| Symbol | Parameter | Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IN(MIN)(F) }}$ | FIN Minimum Signal Input | AM and FM Inputs, $-40^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 85^{\circ} \mathrm{C}$ |  |  | 20 | 100 | mV (rms) |
| $\mathrm{V}_{\text {IN(MAX }}(\mathrm{F})$ | FIN Maximum Signal Input | $A M$ and $F M$ Inputs, $-40^{\circ} \mathrm{C} \leq T_{A} \leq 85^{\circ} \mathrm{C}$ |  | 1000 | 1500 |  | mV (rms) |
| Foperate | Operating Frequency Range (Sine Wave Input) | $\begin{aligned} & V_{\text {IN }}=100 \mathrm{mV} \mathrm{rms} \\ & -40^{\circ} \mathrm{C} \leq T_{A} \leq 85^{\circ} \mathrm{C} \end{aligned}$ | AM | 0.5 |  | 15 | MHz |
|  |  |  | FM | 80 |  | 120 | MHz |
| $\mathrm{R}_{\text {IN }}(\mathrm{FM})$ | AC Input Resistance, FM | $120 \mathrm{MHz}, \mathrm{V}_{\text {IN }}=100 \mathrm{mV}$ rms |  | 600 |  |  | $\Omega$ |
| $\mathrm{R}_{\text {IN }}(\mathrm{AM})$ | AC Input Resistance, AM | $15 \mathrm{MHz}, \mathrm{V}_{\text {IN }}=100 \mathrm{mV} \mathrm{rms}$ |  | 1000 |  |  | $\Omega$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance, FM and AM | $\mathrm{V}_{\text {IN }}=120 \mathrm{MHz}(\mathrm{FM}), 15 \mathrm{MHz}$ (AM) |  | 3 | 6 | 10 | pF |
| ${ }^{\text {t }}$ EN1 | Minimum ENABLE High Pulse Width |  |  |  | 625 | 1250 | ns |

AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}_{\mathrm{r}} \leq 10 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 10 \mathrm{~ns}$ (Continued)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {EN0 }}$ | Minimum ENABLE Low Pulse Width |  |  | 375 | 750 | ns |
| tCLKEN0 | Minimum Time before ENABLE Goes Low That CLOCK Must Be Low |  |  | -50 | 0 | ns |
| ${ }^{\text {teNoCLK }}$ | Minimum Time after ENABLE Goes Low That CLOCK Must Remain Low |  |  | 275 | 550 | ns |
| tclken 1 | Minimum Time before ENABLE Goes High That Last Positive CLOCK Edge May Occur |  |  | 300 | 600 | ns |
| ${ }_{\text {E EN1 }}$ CLK | Minimum Time after ENABLE Goes High before an Unused Positive CLOCK Edge May Occur |  |  | 175 | 350 | ns |
| ${ }^{\text {t CLKH }}$ | Minimum CLOCK High Pulse Width |  |  | 275 | 550 | ns |
| ${ }^{\text {t CLKL }}$ | Minimum CLOCK Low Pulse Width |  |  | 400 | 800 | ns |
| tos | Minimum DATA Set-Up Time, Minimum Time before CLOCK That DATA Must Be Valid |  |  | 150 | 300 | ns |
| ${ }^{\text {t }}$ H | Minimum DATA Hold Time, Minimum Time after CLOCK That DATA Must Remain Valid |  |  | 400 | 800 | ns |

Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. Except for "Operating Temperature Range" they are not meant to imply that the devices should be operated at these limits. The table of "Electrical Characteristics" provides conditions for actual device operation.
Note 2: Unless otherwise specified min/max limits apply across the $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ temperature range for the DS8908.
Note 3: All currents into device pins shown as positive, out of device pins as negative, all voltage referenced to ground unless otherwise noted. All values shown as $\max$ or $\min$ on absolute value basis.

Schematic Diagrams (DS8908 AM/FM PLL Typical Input/Output Schematics)


Schematic Diagrams (Continued)


TL/F/5111-5


TL/F/5111-8

Schematic Diagrams (Continued)


## Timing Diagrams*



TL/F/5111-11

## Timing Diagrams*



TL/F/5111-12
*Timing diagrams are not drawn to scale. Scale within any one drawing may not be consistent, and intervals are defined positive as drawn.

## SERIAL DATA ENTRY INTO THE DS8908

Serial information entry into the DS8908 is enabled by a low level on the ENABLE input. One binary bit is then accepted from the DATA input with each positive transition of the CLOCK input. The CLOCK input must be low for the specified time preceding and following the negative transition of the $\overline{\text { ENABLE }}$ input.
The first two bits accepted following the negative transition of the ENABLE input are interpreted as address. If these address bits are not 1,1 no further information will be accepted fromt he DATA inputs, and the internal data latches will not be changed when ENABLE returns high.
If these first two bits are 1,1, then all succeeding bits are accepted as data, and are shifted successively into the internal shift register as long as ENABLE remains low.
Any data bits preceding the 19th to last bit will be shifted out, and thus are irrelevant. Data bits are counted as any bits following two valid address bits $(1,1)$ with the ENABLE low. When the ENABLE input returns high, any further serial data entry is inhibited. Upon this positive transition, the data in the internal shift register is transferred into the internal data latches. Note that until this time, the states of the internal data latches have remained unchanged.

These data bits are interpreted as follows:

| Data Bit Position | Data Interpretation |
| :---: | :---: |
| Last | Bit 19 Output (Pin 2) |
| 2nd to Last | Bit 18 Output (Pin 1) |
| 3rd to Last | Ref. Freq. Select Bit(1)17 |
| 4th to Last | Ref. Freq. Select Bit(1)16 |
| 5th to Last | AM/FM Select Bit 15 |
| 6th to Last | (213) |
| 7th to Last | (212) |
| 8th to Last | (211) |
| 9th to Last | (210) |
| 10th to Last | $\left({ }^{9}\right)$ |
| 11th to Last | (28) |
| 12th to Last | $\left.\left(2^{7}\right)\right\} \div N^{(2)}$ |
| 13th to Last | (26) $\quad \div \mathrm{N}(2)$ |
| 14th to Last | (25) |
| 15th to Last | (2) |
| 16th to Last | (23) |
| 17th to Last | (2) |
| 18th to Last | (21) |
| 19th to Last | LSB of $\div \mathrm{N}\left(2^{0}\right)$ ) |

Note 1: See Reference Frequency Select Truth Table.
Note 2: The actual divide code is $N+1$, ie., the number loaded plus 1 .

## Truth Table

Reference Frequency Selection Truth Table

| Serial Data |  | Reference <br> Frequency |
| :---: | :---: | :---: |
| Bit 16 | Bit 17 | $\mathbf{( k H z )}$ |
| 1 | 1 | 20 |
| 1 | 0 | 10 |
| 0 | 1 | 9 |
| 0 | 0 | 1 |

Typical Application Additional application notes are located at the back of section 11.
Electronically Tuned Radio Controller System; Direct Drive LED



# DS8911/DS8912 AM/FM/TV Sound Up-Conversion Frequency Synthesizers 

## General Description

The DS8911 and DS8912 are digital Phase-Locked Loop (PLL) frequency synthesizers intended for use as Local Oscillators (LO) in electronically tuned radios. The devices are used in conjunction with a serial data controller, a loop filter, some varactor diodes and several passive elements to provide the local oscillator function for both AM and FM tuning.
The conventional superheterodyne AM receiver utilizes a low IF or down conversion tuning approach whereby the IF is chosen to be below the frequencies to be received. The DS8911 and DS8912 PLL's on the other hand, utilize an upconversion technique in the AM mode whereby the first IF frequency is chosen to be well above the RF frequency range to be tuned. This approach eliminates the need for tuned circuits in the AM frontend since the image, half IF, and other spurious responses occur far beyond the range of frequencies to be tuned. Sufficient selectivity and second IF image protection is provided by a crystal filter at the output of the first mixer.
A significant cost savings can be realized utilizing this upconversion approach to tuning. Removal of the AM tuned circuits eliminates the cost of expensive matched varactor diodes and reduces the amount of labor required for alignment down from 6 adjustments to 2 . Additional cost savings are realized because up-conversion enables both the AM and FM bands to be tuned using a single Voltage Controlled Oscillator (VCO) operating between 98 and 120 MHz . (The 2 to 1 LO tuning range found in conventional AM down conversion radios is reduced to a $10 \%$ tuning range; 9.94 MHz to 11.02 MHz ).
Up-conversion AM tuning is accomplished by first dividing the VCO signal down by a modulus 10 (DS8911) or 20 (DS8912) to obtain the LO signal. This LO in turn is mixed on chip with the RF signal to obtain a first IF at the MIXER output pins. This first IF after crystal filtering is mixed (externally) with a reference frequency provided by the PLL to obtain a 450 kHz second IF frequency. The DS8911 derives the 450 kHz second IF by mixing an 11.55 MHz first IF with a 12.00 MHz reference frequency. The DS8912 derives
the 450 kHz second IF by mixing a 4.45 MHz first IF with a 4.00 MHz reference frequency.

FM and WB (weather band) tuning is done using the conventional down conversion approach. Here the VCO signal is buffered to produce the LO signal and then mixed on chip with the RF signal to obtain an IF frequency at the MIXER output pins. This IF frequency is typically chosen to be 10.7 MHz although placement at 11.50 MHz can further enhance AM mode performance and minimize IF circuitry.
The DS8911 was designed to utilize an 11.55 MHz crystal filter because of its superior phase noise and temperature drift characteristics. The DS8912 on the other hand was designed to utilize a 4.45 MHz ceramic filter for cost savings in applications not requiring high performance.
Both PLLs provide phase comparator reference frequencies of $10,12.5,25$, and 100 kHz . The tuning resolutions resulting from these reference frequencies are determined by dividing the reference by the premix modulus. Table II shows the tuning resolutions possible.
The DS8911 and DS8912 contain the following logic elements: a voltage controlled oscillator, a reference oscillator, a 14 -bit programmable dual-modulus counter, a reference frequency divider chain, a premix divider, a mixer, a phase comparator, a charge pump, an operational amplifier, and control circuitry for latched serial data entry.

## Features

- Direct synthesis of LW, MW, SW, FM, and WB frequencies
- Serial data entry for simplified processor control

I 10, 12.5, 25, and 100 kHz reference frequencies
m 8 possible tuning resolutions (see Table II)

- An op amp with high impedance inputs for loop filtering
- Programmable mixer with high dynamic range
$\square$ Fast-lock feature for Automatic Road Information (ARI) systems


## Connection Diagrams



Note：Device pins marked with an asterisk（＊）are not guaranteed to meet the NSC standard requirement for Electrostatic Discharge（ESD）protection of 2000 volts． The functional requirements of the application prohibit the additional resistive or capacitive components required for ESD protection on these pins．

## Pin Descriptions

$\mathbf{V}_{\text {cci }}$ ：The $\mathrm{V}_{\mathrm{CC} 1}$ pin provides a 5 V supply source for all circuitry except the reference divider chain，op amp and mix－ er sections of the die．
$V_{\text {cc2：}}$ The $V_{C C 2}$ pin provides a 12 V supply source for the Op amp．
$\mathbf{V}_{\text {CCL }}$ ：The $\mathrm{V}_{\mathrm{CCL}}$ pin provides an isolated 5 V supply source for the premix divider and mixer functions．
$V_{\text {ССм }}$ ：The $\mathrm{V}_{\text {ССМ }}$ pin provides a 5 V supply source for the reference oscillator and divider chain down through the 50 Hz output，thus enabling low standby current for time－of－day clock applications．
GND1，GND2，GNDL and GNDM：Provide isolated circuit ground for the various sections of the device．
DATA and CLOCK：The DATA and CLOCK inputs are for serial data entry from a controller．They are CMOS inputs with TTL logic thresholds．The 24－bit data stream is loaded into the PLL on the positive transition of the CLOCK．The first 14 bits of the data stream select PLL divide code in binary form MSB first．The 15th through 24th bits select the premix modulus，the reference frequency，the loop re－ sponse mode，the bit output status，and the test／operate modes as shown in Tables I through V．
ENABLE：The ENABLE input is a CMOS input with a TTL logic threshold．The ENABLE input enables data when at a logic＂one＂and latches data on the transition to a logic ＂zero＂．
BIT Outputs：The open－collector BIT outputs provide either the status of shift register bits 22，23，and 24 or enable access to key internal circuit test nodes．The mode for the bit outputs is controlled by shift register bits 20 and 21 ．In operation，the bit outputs are intended to drive radio func－ tions such as gain，mute，and AM／FM status．These outputs
can also be used to program the loop gain by connection of an external resistor to IPROG．Bit 24 output can also be used as a 300 millisecond timer under control of shift regis－ ter bit 19 ．During service testing，these pins can be used for the purpose of either monitoring or driving internal logic points as indicated in the TEST MODES description under Table V．
VCOb and VCOe：The Voltage Controlled Oscillator inputs drive the 14 －bit programmable counter and the premix divid－ er．These inputs are the base and emitter leads of a transis－ tor which require connection of a coil，varactor，and several capacitors to function as a Colpitts oscillator．The VCO is designed to operate up to 225 MHz ．The VCO＇s minimum operating frequency may be limited by the choice of refer－ ence frequency and the 961 minimum modulus constraint of the 31／32 dual modulus counter．
RF＋and RF－：The Radio Frequency inputs are fed differ－ entially into the mixer．
IMXR：The bias current for the mixer is programmed by con－ nection of external resistors．
MIXER and MIXER：The MIXER outputs are the collectors of the double balanced pair mixer transistors．They are in－ tended to operate at voltages greater than $\mathrm{V}_{\mathrm{CC} 1}$ ．
OSCb and OSCc：The Reference Oscillator inputs are part of an on－chip Pierce oscillator designed to work in conjunc－ tion with 2 capacitors and a crystal resonator．The DS8911 requires a 12 MHz crystal，while the DS8912 requires a 4 MHz crystal．
The OSC input signal is mixed externally with the 1st AM IF output to obtain a 450 kHz 2nd IF frequency in the AM mode．
2 MHz ：The 2 MHz output is provided to drive a controller＇s clock input．

## Pin Descriptions (Continued)

50 Hz : The 50 Hz output is provided as a time reference for radios with time-of-day clocks.
IPROG: The IPROG pin enables the charge pump to be programmed from .5 mA to 1.5 mA by connection of an extenal resistor to ground.
CPO: The Charge Pump Output circuit sources current if the VCO frequency is high and sinks current if the VCO frequency is low. The CPO is wired directly to the negative input of the loop filter op amp.
OP AMP: The OP AMP output is provided for loop filtering. The op amp has high impedance PMOS gate inputs and is wired as a transconductance amplifier/filter. The op amp's positive input is internally referenced while it's negative input is common with the CPO output.

Reference Tables DS8911 (DS8912)
TABLE I

| Bit 15 | Premix Modulus |
| :---: | :---: |
| 0 | $\div 1$ |
| 1 | $\div 10(\div 20)$ |

TABLE II

| Bit |  | Reference | Tuning Resolution |  |
| :---: | :---: | :---: | :---: | :---: |
| $\mathbf{1 6}$ | $\mathbf{1 7}$ | Frequency | $\div \mathbf{1}$ Premix | $\div \mathbf{1 0}(\div \mathbf{2 0})$ Premix |
| 0 | 0 | 10 kHz | 10 kHz | $1(.5) \mathrm{kHz}$ |
| 0 | 1 | 12.5 kHz | 12.5 kHz | $1.25(.625) \mathrm{kHz}$ |
| 1 | 0 | 25 kHz | 25 kHz | $2.5(1.25) \mathrm{kHz}$ |
| 1 | 1 | 100 kHz | 100 kHz | $10(5) \mathrm{kHz}$ |

TABLE III

| Bit 18 | Loop Response |
| :---: | :---: |
| 0 | Normal Lock |
| 1 | Fast Lock |

## FAST LOCK OPERATION

The fast lock mode provides a means of moving from one frequency selection to another frequency selection anywhere on the band in a very short time frame. This is accomplished by setting a bit in the microprocessor serial data stream when loading a new frequency. When fast lock is activated the charge pump output (CPO) is latched into the pump up or down state, which drives the CPO at the maximum rate to correct the VCO frequency. The PLL meanwhile operates in a frequency lock mode, constantly comparing the frequencies and reducing any phase discrepancies. When the VCO passes beyond the desired lock frequency the CPO unlatches and reverts back to the phase lock mode of operation. The frequency lock mode of operation (during CPO latchup) ensures that the phases are always close and will quickly settle into phase lock once the CPO unlatches.

TABLE IV

| Bit 19 | Timer |
| :---: | :---: |
| 0 | Bit 24 Status |
| 1 | $\overline{\text { Bit } 24}$ for 300 ms |

## TIMER OPERATION

The timer function is provided for use as a retriggerable "one shot" to enable muting for approximately 300 milliseconds after station changes. The timer is enabled at bit 24's output if the normal operating mode is selected (shift register bits 20 and $21=$ "LOW") and shift register bit 19 data is latched as a "HI". The timer's output state will invert immediately upon latching bit 19 " HI " and remain inverted for approximately 300 milliseconds. If the user readdresses the device with bit 19 data "LOW" before the timer finishes its cycle the timer's BIT 24 output will finish out the 300 ms pulse. Readdressing the device with bit 19 "HI" before the timer finishes its cycle will extend the BIT 24 output pulse width by 300 ms . Addressing should be performed immediately after the 50 Hz output transitions "HI". BIT 24's output state is not guaranteed during the first 300 ms after $\mathrm{V}_{\mathrm{CC}_{1}}$ power up as a result of a timer reset in progress.

TABLE V

| Bit |  | FUNCTION OF |
| :---: | :---: | :---: |
| PINS 3, 4, \& 5 |  |  |

## TEST MODE OPERATION

Test Mode 1: Enables the BIT output pins to edge trigger the phase comparator inputs and monitor an internal lock detector. BIT 22 negative edge triggers the reference divider input of the phase comparator if the reference divider state is low. BIT 23 provides the open collector ORing of the phase comparator's pump up and down outputs. BIT 24 negative edge triggers the N counter input of the phase comparator if the N counter state is preconditioned low.
Test Mode 2: Enables the BIT outputs to clock the programmable N counter, monitor its output, and force either its load or count condition. BIT 22 provides the N counter output which negative edge triggers the phase comparator and which appears low one N counter clock pulse before it reloads. BIT 23 positive edge triggers the N counter's clock input if the prescaler's output is preconditioned HI. BIT 24 clears the N counter output so that loading will occur on the next $N$ counter clock edge.
Test Mode 3: Enables the BIT outputs to clock the 50 Hz and 10 kHz reference dividers, monitor the reference divider input to the phase comparator, and reset the fast lock latch. BIT 22 positive edge clocks the 10 kHz reference divider chain if the 10 kHz output is preconditioned HI. BIT 22 also positive edge clears the fast lock latch condition. Bit 23 positive edge clocks the 50 Hz divider chain. BIT 24 is the reference divider negative edge trigger input to the phase comparator.

Absolute Maximum Ratings (Note 1)
Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Supply Voltage

| $V_{C C M}$ | 7 V |
| :--- | ---: |
| $V_{\mathrm{CC} 1}$ | 7 V |
| $V_{\mathrm{CC} 2}$ | 15 V |
| Input Voltage | 7 V |
| Output Voltage |  |
| Logic | 7 V |
| Op Amp and Mixer Outputs | 15 V |

$\begin{array}{lr}\text { Storage Temperature Range } & -65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\ \text { Lead Temp. (Soldering, } 10 \text { seconds) } & 300^{\circ} \mathrm{C}\end{array}$
Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| $V_{C C M}$ | 3.5 | 5.5 | $V$ |
| $V_{C C 1}$ | 4.5 | 5.5 | $V$ |
| $V_{C C 2}$ | 7.0 | 12.0 | $V$ |
| Temperature, $T_{A}$ | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |

DC Electrical Characteristics (Notes 2 and 3 )

| Symbol | Parameter |  | Test Conditions |  | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | Logic "1" Input Voltage |  |  |  | 2.0 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Logic "0" Input Voltage |  |  |  |  |  | 0.8 | V |
| IIH | Logic "1" Input Current |  | $\mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |  |  |  | 10 | $\mu \mathrm{A}$ |
| ILL | Logic "0" Input Current |  | Data, Clock and Enable Inputs, $\mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V}$ |  |  |  | -10 | $\mu \mathrm{A}$ |
| $\overline{\mathrm{VOH}}$ | Logic " 1 " Output Voltage | 2 MHz | $\mathrm{IOH}^{\prime}=-20 \mu \mathrm{~A}$ |  | $V_{\text {CCM }}-0.3$ |  |  | V |
|  |  |  | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |  | $\mathrm{V}_{\mathrm{CCM}}-2$ |  |  | V |
|  |  | Op Amp | $\mathrm{IOH}=-1.5 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}_{2}-1.5}$ |  |  | V |
| $\overline{\mathrm{VOL}}$ | Logic "0" Output Voltage | 2 MHz | $\mathrm{I}_{\mathrm{OL}}=20 \mu \mathrm{~A}$ |  |  |  | 0.3 | V |
|  |  |  | $\mathrm{IOL}^{\prime}=400 \mu \mathrm{~A}$ |  |  |  | 0.4 | V |
|  |  | 50 Hz | $\mathrm{I}_{\mathrm{OL}}=250 \mu \mathrm{~A}$ |  |  |  | 0.3 | V |
|  |  | Bit Outputs | $\mathrm{OL}=1 \mathrm{~mA}$ |  |  |  | 0.3 | V |
|  |  | Op Amp | $\mathrm{IOL}=1.5 \mathrm{~mA}$ |  |  |  | 1.5 | V |
| $\overline{V_{\text {BIAS }}}$ | Op Amp Input V $\Delta$ |  | Op Amp l/O Shorted, $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC} 2}=12 \mathrm{~V}$, CPO $=$ TRI-STATE ${ }^{\oplus}$, Op Amp IOH vs. $\mathrm{IOL}^{2}$ Applied |  |  |  | 150 | mV |
| ICEX | High Level Output Current | Bit Outputs | $\mathrm{V}_{\mathrm{CC}_{1}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=8.8 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
|  |  | 50 Hz | $V_{C C_{M}}=3.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  |  | 10 | $\mu \mathrm{A}$ |
|  |  | Mixers | $\mathrm{V}_{\mathrm{CC}_{\mathrm{L}}}=\mathrm{V}_{\mathrm{CC}_{1}}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=8.8 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| $\overline{\mathrm{ICPO}}$ | Charge Pump Program Current |  | $\begin{array}{\|l} 0.5 \mathrm{~mA}<I_{\mathrm{CPO}}<1.5 \mathrm{~mA} \\ 2 \text { IPROG } V_{\mathrm{CC}} / R_{\text {PROG }}, \\ \text { Measured I IPROG } \end{array}$ | Pump-up | -20 | 2 IPROG | +20 | \% |
|  |  |  | Pump-down | -20 | 2 IPRCG | +20 | \% |
|  |  |  | TRI-STATE |  | 0 | 100 | nA |
| ICCM | $V_{\text {CCM }}$ Supply Current |  |  | $\mathrm{V}_{\text {CCM }}=5.5 \mathrm{~V}$ |  |  | 0.5 | 1.0 | mA |
| $\begin{aligned} & \overline{\mathrm{ICCl}^{+}+} \\ & \mathrm{I}_{\mathrm{CCL}} \end{aligned}$ | $V_{C C 1}+V_{C C L}$ Supply Current |  |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, Bits Hi, $\mathrm{I}_{\mathrm{MXR}}$ and $\mathrm{I}_{\text {PROG }}$ Open |  |  | 25 | 35 | mA |
| ICC2 | $\mathrm{V}_{\mathrm{CC} 2}$ Supply Current |  | $\mathrm{V}_{\mathrm{CC} 2}=12 \mathrm{~V}$ |  |  | 1.5 | 2.5 | mA |
| $\mathrm{R}_{\text {IN }}$ | Mixer Input Impedance |  | $\begin{aligned} & l_{\mathrm{MXR}}=2.5 \mathrm{~mA} \\ & I_{\text {MXR }}=7.5 \mathrm{~mA} \end{aligned}$ |  |  | $\begin{aligned} & \hline \text { TBD } \\ & \text { TBD } \end{aligned}$ |  | $\Omega$ $\Omega$ |
| Rout | Mixer Output Impedance |  | $\begin{aligned} & l_{\mathrm{MXR}}=2.5 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{MXR}}=7.5 \mathrm{~mA} \end{aligned}$ |  |  | $\begin{aligned} & \hline \text { TBD } \\ & \text { TBD } \end{aligned}$ |  | ת |
| $g_{m}$ | Mixer Transconductance |  | $\begin{aligned} & l_{\mathrm{MXR}}=2.5 \mathrm{~mA} \\ & I_{\mathrm{MXR}}=7.5 \mathrm{~mA} \end{aligned}$ |  |  | $\begin{aligned} & \hline \text { TBD } \\ & \text { TBD } \end{aligned}$ |  | mhos mhos |
| $\overline{N F}$ | Noise Figure |  | $\begin{aligned} & I_{M X R}=2.5 \mathrm{~mA}, R_{S}=50 \Omega \\ & I_{M X R}=7.5 \mathrm{~mA}, R_{S}=10 \Omega \end{aligned}$ |  |  | $\begin{aligned} & \text { TBD } \\ & \text { TBD } \end{aligned}$ |  | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \end{aligned}$ |
| XMOD | Cross Modulation |  | $\begin{aligned} & l_{\mathrm{MXR}}=2.5 \mathrm{~mA} \\ & l_{\mathrm{MXR}}=7.5 \mathrm{~mA} \end{aligned}$ |  |  | $\begin{aligned} & \hline \text { TBD } \\ & \text { TBD } \end{aligned}$ |  | mVRms mVRms |
| IMXR | Mixer Current |  | $V_{C C 1}=5.5 \mathrm{~V}$ |  | 1 |  | 7.5 | mA |
| $\mathrm{VCO}_{\text {MAX }}$ | $\mathrm{VCO}_{\text {MAX }}$ frequency |  |  |  |  |  | 225 | MHz |

Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteod. Except for "Operating Temperature Range", they are not meant to imply that the device should be operated at these limits.
Note 2: Unless otherwise specified, $\min / \mathrm{max}$ limits apply across the $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ temperature range for DS 8911 and DS 8912 .
Note 3: All currents into device pins are shown as positive, out of device pins as negative, all voltage referenced to ground unless otherwise noted. All values shown as maximum or minimum on absolute value basis.

| Symbol | Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{r}$ | 20\%-80\% Rise Time | $\mathrm{V}_{\mathrm{CC}_{1}}=4.5 \mathrm{~V}$ to 5.5 V |  | 200 | ns |
| $\mathrm{t}_{\mathrm{f}}$ | 80\% -20\% Fall Time |  |  | 200 | ns |
| DATASU | Data Setup Time |  | 100 |  | ns |
| $\mathrm{DATA}_{H}$ | Data Hold Time |  | 100 |  | ns |
| $E N_{\text {SU }}$ | Enable Setup Time |  | 100 |  | ns |
| $\mathrm{EN}_{\mathrm{H}}$ | Enable Hold Time |  | 100 |  | ns |
| ENPW + | Enable Positive Pulse Width |  | 200 |  | ns |
| CLK ${ }_{\text {PW }}^{+}$ | Clock Positive Pulse Width |  | 200 |  | ns |
| CLKPW - | Clock Negative Pulse Width |  | 200 |  | ns |

Note 1: "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. Except for "Operating Temperature Range", they are not meant to imply that the device should be operated at these limits.
Note 2: Unless otherwise specified, $\min /$ max limits apply across the $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ temperature range for DS8911 and DS8912.
Note 3: All currents into device pins are shown as positive, out of device pins as negative, all voltage referenced to ground unless otherwise noted. All values shown as maximum or minimum on absolute value basis.

## Timing Diagram



TL/F/7398-10

## MICROWIRETM Bus Format



ENABLE


BIT 22 OUTPUT


BIT 23 OUTPUT


TABLE VI. DS8911 Tuning Characteristics

| Mode | IF <br> Frequency <br> $(\mathrm{MHz})$ | Tuning <br> Range <br> $(\mathrm{MHz})$ | VCO <br> Range <br> $(\mathrm{MHz})$ | Premix <br> Modulus | Reference <br> Frequency <br> $(\mathrm{kHz})$ | Tuning <br> Resolution <br> $(\mathbf{k H z})$ | Image <br> $(\mathrm{MHz})$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LW | $11.55 / .450$ | $.145-.290$ | $112.4-114.1$ | 10 | 10 | 1 | $22-23$ |
| MW | $11.55 / .450$ | $.515-1.61$ | $99.4-110.2$ | 10 | $10,12.5,25,100$ | $1,1.25,2.5,10$ | $21-23$ |
| SW | $11.55 / .450$ | $5.94-6.2$ | 53.5 to 56.1 | 10 | $10,12.5,25$ | $1,1.25,2.5$ | $28-30$ |
| FM | 10.7 | $87.4-108.1$ | $98.1-118.8$ | 1 | $10,12.5,25,100$ | $10,12.5,25,100$ | $109-130$ |
| WB | 10.7 | $162.4-162.6$ | $151-152$ | 1 | $12.5,25$ | $12.5,25$ | $140-142$ |
| $\mathrm{TV}_{1}$ | 10.7 | $59.75-87.75$ | $70.45-98.45$ | 1 | 25 | 25 | $81-109$ |
| $\mathrm{TV}_{2}$ | 10.7 | $179.75-215.75$ | $169.1-205.1$ | 1 | 25 | 25 | $158-194$ |

TABLE VII. DS8912 Tuning Characteristics

| Mode | IF <br> Frequency <br> $(\mathrm{MHz})$ | Tuning <br> Range <br> $(\mathrm{MHz})$ | VCO <br> Range <br> $(\mathrm{MHz})$ | Premix <br> Modulus | Reference <br> Frequency <br> $(\mathbf{k H z})$ | Tuning <br> Resolution <br> $\mathbf{( k H z )}$ | Image <br> $(\mathrm{MHz})$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LW | $4.45 / .450$ | $.145-.290$ | $91.9-94.8$ | 20 | 10 | .5 | $13-14$ |
| MW | $4.45 / .450$ | $.515-1.61$ | $99.6-121.2$ | 20 | $10,12.5,25,100$ | $.5, .625,1.25,5$ | $14-17$ |
| SW | $4.45 / .450$ | $5.94-6.2$ | $207.9-213.1$ | 20 | 25,100 | $1.25,5$ | $14-16$ |
| FM | 10.7 | $87.4-108.1$ | $98.1-118.8$ | 1 | $10,12.5,25,100$ | $10,12.5,25,100$ | $109-130$ |
| WB | 10.7 | $162.4-162.6$ | $151-152$ | 1 | $12.5,25$ | $12.5,25$ | $140-142$ |

Input and Output Schematics


Input and Output Schematics (Continued)


TL/F/7398-13



OP AMP INPUT AND CHARGE PUMP OUTPUT


TL/F/7398-18


Note 1：Logic labels（in parentheses）pertain to the DS8912 option．
TL／F／7398－4
Note 2：The 14 bit programmable N counter is a dual modulus counter with $31 / 32$ prescaler．The minimum continuous modulus of the N counter is 961 ．（There are a limited number of valid modulus codes below 961 ．）

## Typical Application



## MM5450/MM5451 LED Display Drivers

## General Description

The MM5450 and MM5451 are monolithic MOS integrated circuits utilizing N -channel metal-gate low threshold, enhancement mode, and ion-implanted depletion mode devices. They are available in 40 -pin molded or cavity dual-in-line packages. A single pin controls the LED display brightness by setting a reference current through a variable resistor connected to $\mathrm{V}_{\mathrm{DD}}$.

## Features

- Continuous brightness control
- Serial data input
- Enable (on MM5450)
- Wide power supply operation
- TTL compatibility
- 34 or 35 outputs, 15 mA sink capability
- Alphanumeric capability


## Applications

- COPSTM or microprocessor displays
- Industrial control indicator
- Relay driver

■ Digital clock, thermometer, counter, voltmeter

- Instrumentation readouts
- No load signal required


## Block Diagram



TL/F/6136-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
$\begin{array}{lr}\text { Voltage at Any Pin } & V_{S S} \text { to } V_{S S}+12 \mathrm{~V} \\ \text { Operating Temperature } & -25^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}\end{array}$

Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Power Dissipation
560 mW at $+85^{\circ} \mathrm{C}$
1 W at $+25^{\circ} \mathrm{C}$
$+150^{\circ} \mathrm{C}$
$300^{\circ} \mathrm{C}$
Junction Temperature
Lead Temperature (Soldering, 10 sec. )

## Electrical Characteristics

$\mathrm{T}_{\mathrm{A}}$ within operating range, $\mathrm{V}_{\mathrm{DD}}=4.5 \mathrm{~V}$ to $11.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ unless otherwise specified

| Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply |  | 4.75 |  | 11 | V |
| Power Supply Current | Excluding Output Loads |  |  | 7 | mA |
| Input Voltages <br> Logical "0" Level ( $V_{L}$ ) <br> Logica! " 1 " Level ( $\mathrm{V}_{\mathrm{H}}$ ) | $\pm 10 \mu \mathrm{~A}$ Input Bias <br> $4.75 \mathrm{~V} \leq \mathrm{V}_{\mathrm{DD}} \leq 5.25 \mathrm{~V}$ <br> $V_{D D}>5.25 \mathrm{~V}$ | $\begin{gathered} -0.3 \\ 2.2 \\ V_{D D}-2 V \end{gathered}$ |  | $\begin{gathered} 0.8 \\ V_{D D} \\ V_{D D} \end{gathered}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ |
| Brightness Input (Note 2) |  | 0 |  | 0.75 | mA |
| Output Sink Current Segment OFF Segment ON | $V_{\text {OUT }}=3.0 \mathrm{~V}$ <br> $V_{\text {OUT }}=1 \mathrm{~V}$ (Note 3) <br> Brightness Input $=0 \mu \mathrm{~A}$ <br> Brightness Input $=100 \mu \mathrm{~A}$ <br> Brightness Input $=750 \mu \mathrm{~A}$ | $\begin{gathered} 0 \\ 0 \\ 2.0 \\ 15 \\ \hline \end{gathered}$ | 2.7 | $\begin{aligned} & 10 \\ & 15 \\ & 10 \\ & 4 \\ & 25 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ |
| Brightness Input Voltage (Pin 19) | Input Current $750 \mu \mathrm{~A}$ | 3.0 |  | 4.3 | V |
| Output Matching (Note 1) |  |  |  | $\pm 20$ | \% |
| Clock Input Frequency, $\mathrm{f}_{\mathrm{C}}$ High Time, $\mathrm{t}_{\mathrm{h}}$ Low Time, $\dagger_{1}$ | (Notes 5 and 6) | $\begin{aligned} & 950 \\ & 950 \end{aligned}$ |  | 500 | $\begin{gathered} \mathrm{kHz} \\ \mathrm{~ns} \\ \mathrm{~ns} \end{gathered}$ |
| Data Input Set-Up Time, tos Hole Time, $\mathrm{t}_{\mathrm{DH}}$ |  | $\begin{aligned} & 300 \\ & 300 \end{aligned}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| Data Enable Input Set-Up Time, tes |  | 100 |  |  | ns |

Note 1: Output matching is calculated as the percent variation $\left(l_{\mathrm{MAX}}+\mathrm{I}_{\mathrm{MIN}}\right) / 2$.
Note 2: With a fixed resistor on the brightness input pin, some variation in brightness will occur from one device to another. Maximum brightness input current can be 2 mA as long as Note 3 and junction temperature equation are complied with.
Note 3: See Figures 5, 6, and 7 for Recommended Operating Conditions and limits. Absolute maximum for each output should be limited to 40 mA .
Note 4: The V Vut voltage should be regulated by the user. See Figures 6 and 7 for allowable $V_{\text {OUt }}$ vs lout operation.
Note 5: AC input waveform specification for test purpose: $\mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{f}=500 \mathrm{kHz}, 50 \% \pm 10 \%$ duty cycle.
Note 6: Clock input rise and fall times must not exceed 300 ns .

## Connection Diagrams



## Connection Diagrams (Continued)



## Functional Description

Both the MM5450 and the MM5451 are specifically designed to operate 4- or 5 -digit alphanumeric displays with minimal interface with the display and the data source. Serial data transfer from the data source to the display driver is accomplished with 2 signals, serial data and clock. Using a format of a leading " 1 " followed by the 35 data bits allows data transfer without an additional load signal. The 35 data bits are latched after the 36th bit is complete, thus providing non-multiplexed, direct drive to the display. Outputs change only if the serial data bits differ from the previous time. Display brightness is determined by control of the output current for LED displays. A 0.001 capacitor should be connected to brightness control, pin 19, to prevent possible oscillations.
A block diagram is shown in Figure 1. For the MM5450 a DATA ENABLE is used instead of the 35th output. The DATA ENABLE input is a metal option for the MM5450. The output current is typically 20 times greater than the current into pin 19, which is set by an external variable resistor. There is an internal limiting resistor of $400 \Omega$ nominal value.
Figure 4 shows the input data format. A start bit of logical "1" precedes the 35 bits of data. At the 36th clock a LOAD signal is generated synchronously with the high state of the clock, which loads the 35 bits of the shift registers into the latches. At the low state of the clock a RESET signal is generated which clears all the shift registers for the next set of data. The shift registers are static master-slave configuration. There is no clear for the master portion of the first shift register, thus allowing continuous operation.

There must be a complete set of 36 clocks or the shift registers will not clear.
When the chip first powers ON an internal power ON reset signal is generated which resets all registers and all latches. The START bit and the first clock return the chip to its normal operation.
Figure 2 shows the pin-out of the MM5450 and MM5451. Bit 1 is the first bit following the start bit and it will appear on pin 18. A logical " 1 " at the input will turn on the appropriate LED.
Figure 3 shows the timing relationships between data, clock and DATA ENABLE. A max clock frequency of 0.5 MHz is assumed.
For applications where a lesser number of outputs are used, it is possible to either increase the current per output, or operate the part at higher than IV VOUT. The following equation can be used for calculations.

$$
T_{j}=\left(V_{\text {OUT }}\right)(\text { LED })(\text { No. of segments })\left(124^{\circ} \mathrm{C} / \mathrm{W}\right)+T_{A}
$$ where:

$\mathrm{T}_{\mathrm{j}}=$ junction temperature $+150^{\circ} \mathrm{C}$ max
$V_{\text {OUT }}=$ the voltage at the LED driver outputs
LEED $=$ the LED current
$124^{\circ} \mathrm{C} / \mathrm{W}=$ thermal coefficient of the package
$\mathrm{T}_{\mathrm{A}}=$ ambient temperature
The above equation was used to plot Figure 5, Figure 6 and Figure 7.


FIGURE 3

## Functional Description (Continued)



## Typical Performance Characteristics



FIGURE 5


FIGURE 6


TL/F/6136-8
FIGURE 7

## Typical Applications



TL/F/6136-9

FIGURE 8. Typical Application of Constant Current Brightness Control


Typical Applications (Continued)
Basic Electronically Tuned Radio System


TL/F/6136-11

Duplexing 8 Digits with One MM5450


National
Semiconductor
Corporation

## MM5452/MM5453 Liquid Crystal Display Drivers

## General Description

The MM5452 is a monolithic integrated circuit utilizing CMOS metal gate, low threshold enhancement mode devices. It is available in a 40-pin molded package. The chip can drive up to 32 segments of LCD and can be paralleled to increase this number. The chip is capable of driving a $41 / 2-$ digit 7 -segment display with minimal interface between the display and the data source.
The MM5452 stores display data in latches after it is clocked in, and holds the data until new display data is received.

## Features

- Serial data input
- No load signal required
- DATA ENABLE (MM5452)
- Wide power supply operation
- TTL compatibility
- 32 or 33 outputs
- Alphanumeric and bar graph capability
- Cascaded operation capability


## Applications

- COPSTM or microprocessor displays
- Industrial control indicator
- Digital clock, thermometer, counter, voltmeter
- Instrumentation readouts
- Remote displays


## Block Diagram



FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin
$V_{S S}$ to $V_{S S}+10 \mathrm{~V}$
Operating Temperature
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Power Dissipation | 300 mW at $+70^{\circ} \mathrm{C}$ |
|  | 350 mW at $+25^{\circ} \mathrm{C}$ |
| Junction Temperature | $+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, 10 sec.$)$ | $300^{\circ} \mathrm{C}$ |

## Electrical Characteristics

$T_{A}$ within operating range, $\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{~V}$ to $10 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise specified

| Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply |  | 3 |  | 10 | V |
| Power Supply Current | Excluding Outputs $\begin{aligned} & O S C=V_{S S}, B P \text { IN @ } 32 \mathrm{~Hz} \\ & V_{D D}=5 \mathrm{~V} \text {, Open Outputs, No Clock } \end{aligned}$ |  |  | $\begin{aligned} & 40 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| Clock Frequency |  |  |  | 500 | kHz |
| Input Voltages <br> Logical '0' Level <br> Logical '1’ Level | $\begin{aligned} & V_{D D}<4.75 \\ & V_{D D} \geq 4.75 \\ & V_{D D}>5.25 \\ & V_{D D} \leq 5.25 \end{aligned}$ | $\begin{gathered} -0.3 \\ -0.3 \\ 0.8 V_{D D} \\ 2.0 \end{gathered}$ |  | $\begin{gathered} 0.1 V_{D D} \\ 0.8 \\ V_{D D} \\ V_{D D} \\ \hline \end{gathered}$ | $\begin{aligned} & V \\ & v \\ & v \\ & v \end{aligned}$ |
| Output Current Levels <br> Segments <br> Sink <br> Source <br> Backplane <br> Sink <br> Source | $\begin{aligned} & V_{D D}=3 V, V_{O U T}=0.3 V \\ & V_{D D}=3 V, V_{O U T}=V_{D D}-0.3 V \\ & V_{D D}=3 V, V_{O U T}=0.3 V \\ & V_{D D}=3 V, V_{O U T}=V_{D D}-0.3 V \end{aligned}$ | $\begin{array}{r} 20 \\ 320 \\ \hline \end{array}$ |  | $\begin{aligned} & -20 \\ & -320 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Output Offset Voltage | Segment Load 250 pF <br> Backplane Load 8750 pF (Note 1) |  |  | $\pm 50$ | mV |
| Clock Input Frequency, $\mathrm{f}_{\mathrm{C}}$ | (Notes 2 and 3) |  |  | 500 | kHz |
| High Time, $t_{h}$ |  | 950 |  |  | ns |
| Low Time, $\mathrm{t}_{1}$ |  | 950 |  |  | ns |
| Data Input Set-Up Time, tDS Hold Time, $t_{D H}$ |  | $\begin{aligned} & 300 \\ & 300 \end{aligned}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| Data Enable Input Set-Up Time, $t_{D E S}$ |  | 100 |  |  | ns |

Note 1: This parameter is guaranteed (not $100 \%$ production tested) over operating temperature and supply voltage ranges. Not to be used in Q.A. testing. Note 2: AC input waveform for test purpose: $\mathrm{t}_{\mathrm{r}} \leq 20 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{f}=500 \mathrm{kHz}, 50 \% \pm 10 \%$ duty cycle.
Note 3: Clock input rise and fall times must not exceed 300 ns .

## Connection Diagrams



## Dual-In-Line Package



Plastic Chip Carrier


Top View

Top Vlew


## Functional Description

The MM5452 is specifically designed to operate $41 / 2$-digit 7 segment displays with minimal interface with the display and the data source. Serial data transfer from the data source to the display driver is accomplished with 2 signals, serial data and clock. Since the MM5452 does not contain a character generator, the formatting of the segment information must be done prior to inputting the data to the MM5452. Using a format of a leading " 1 " followed by the 32 data bits allows data transfer without an additional load signal. The 32 data
bits are latched after the 36th clock is complete, thus providing non-multiplexed, direct drive to the display. Outputs change only if the serial data bits differ from the previous time.
A block diagram is shown in Figure 1. For the MM5452 a $\overline{\text { DATA ENABLE }}$ is used instead of the 33rd output. If the DATA ENABLE signal is not required, the 33rd output can be brought out. This is the MM5453 device.

Functional Description (Continued)
Figure 4 shows the input data format. A start bit of logical " 1 " precedes the 32 bits of data. At the 36 th clock a LOAD signal is generated synchronously with the high state of the clock, which loads the 32 bits of the shift registers into the latches. At the low state of the clock a RESET signal is generated which clears all the shift registers for the next set of data. The shift registers are static master-slave configuration. There is no clear for the master portion of the first shift register, thus allowing continuous operation.

If the clock is not continuous, there must be a complete set of 36 clocks otherwise the shift registers will not clear.
Figure 2a shows the pin-out of the MM5452. Bit 1 is the first bit following the start bit and it will appear on pin 18.
Figure 3 shows the timing relationships between data, clock and DATA ENABLE.


FIGURE 3


FIGURE 4. Input Data Format

Functional Description (Continued)
Figure 5 shows a typical application. Note how the input data maps to the output pins and the display. The MM5452 and MM5453 do not have format restrictions, as all outputs
are controllable. This application assumes a specific display pinout. Different display/driver connection patterns will, of course, yield a different input data format.


TL/F/6137-6
Consult LCD manufacturer's data sheet for specific pinouts.
FIGURE 5. Typical 4½-Digit Display Application

Functional Description (Continued)


TL/F/6137-7
*The minimum recommended value for R for the oscillator input is $9 \mathrm{k} \Omega$. An RC time constant of approximately $4.91 \times 10^{-4}$ should produce a backplane frequency between 30 Hz and 150 Hz .

FIGURE 6. Parallel Backplane Outputs


TL/F/6137-8
FIGURE 7. External Backplane Clock

Figure 8 shows a four wire remote display that takes advantage of the device's serial input to move many bits of display information on a few wires.

## USING AN EXTERNAL CLOCK

The MM5452/MM5453 LCD Drivers can be used with an externally supplied clock, provided it has a duty cycle of $50 \%$. Deviations from a $50 \%$ duty cycle result in an offset voltage on the LCD. In Figure 7, a flip-flop is used to assure a $50 \%$ duty cycle. The oscillator input is grounded to prevent oscillation and reduce current consumptions in the chips. The oscillator is not used.
Using an external clock allows synchronizing the display drive with AC power, internal clocks, or DVM integration time to reduce interference from the display.

Figure 9 is a general block diagram that shows how the device's serial input can be used to advantage in an analog display. The analog voltage input is compared with a staircase voltage generated by a counter and a digital-to-analog converter or resistor array. The result of this comparison is clocked into the MM5452, MM5453. The next clock pulse increments the staircase and clocks the new data in.
With a buffer amplifier, the same staircase waveform can be used for many displays. The digital-to-analog converter need not be linear; logarithmic or other non-linear functions can be displayed by using weighted resistors or special DACs. This system can be used for status indicators, spectrum analyzers, audio level and power meters, tuning indicators, and other applications.

Functional Description (Continued)


TL/F/6137-9
FIGURE 8. Four Wire Remote Display


TL/F/6137-10
Data is high until staircase > input
FIGURE 9. Analog Display

National
Semiconductor

## MM5483 Liquid Crystal Display Driver

## General Description

The MM5483 is a monolithic integrated circuit utilizing CMOS metal-gate low-threshold enhancement mode devices. It is available in a 40 -pin molded package. The chip can drive up to 31 segments of LCD and can be cascaded to increase this number. This chip is capable of driving a $41 / 2^{-}$ digit 7 -segment display with minimal interface between the display and the data source.
The MM5483 stores the display data in latches after it is latched in, and holds the data until another load pulse is received

- Wide power supply operation
- TTL compatibility
- 31 segment outputs
- Alphanumeric and bar graph capability
- Cascade capability


## Applications

- COPSTM or microprocessor displays
- Industrial control indicator
- Digital clock, thermometer, counter, voltmeter
- Instrumentation readouts
- Remote displays

Features
Serial data input
Serial data output

## Block and Connection Diagrams



TL/F/6140- 1
FIGURE 1


FIGURE 2

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin

$$
\begin{array}{r}
V_{S S} \text { to } V_{S S}+10 \mathrm{~V} \\
-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}
\end{array}
$$

Power Dissipation
300 mW at $+85^{\circ} \mathrm{C}$ 350 mW at $+25^{\circ} \mathrm{C}$
$+150^{\circ} \mathrm{C}$
Junction Temperature
$300^{\circ} \mathrm{C}$

## DC Electrical Characteristics

$T_{A}$ within operating range, $\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{~V}$ to $10 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise specified

| Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supply |  | 3.0 |  | 10 | V |
| Power Supply Current | $\begin{aligned} & R=1 \mathrm{M}, \mathrm{C}=470 \mathrm{pF}, \\ & \text { Outputs Open } \\ & \mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DD}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DD}}=10.0 \mathrm{~V} \\ & \mathrm{OSC}=0 \mathrm{~V}, \text { Outputs Open, } \\ & \mathrm{BPIN}=32 \mathrm{~Hz}, \mathrm{~V}_{\mathrm{DD}}=3.0 \mathrm{~V} \\ & \hline \end{aligned}$ |  | $\begin{gathered} 9 \\ 17 \\ 35 \\ \\ 1.5 \\ \hline \end{gathered}$ | $\begin{array}{r} 15 \\ 25 \\ 45 \\ \\ 2.5 \\ \hline \end{array}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| Input Voltage Levels <br> Logic " 0 " <br> Logic " 1 " <br> Logic "0" <br> Logic "1" | Load, Clock, Data $\begin{aligned} & V_{D D}=5.0 \mathrm{~V} \\ & V_{D D}=5.0 \mathrm{~V} \\ & V_{D D}=3.0 \mathrm{~V} \\ & V_{D D}=3.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 2.4 \\ & 2.0 \end{aligned}$ |  | $\begin{aligned} & 0.9 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Output Current Levels Segments and Data Out Sink Source | $\begin{aligned} & V_{D D}=3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=0.3 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DD}}=3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=2.7 \mathrm{~V} \end{aligned}$ | $\begin{array}{r} 20 \\ 20 \\ \hline \end{array}$ |  |  | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
| BP OUT Sink Source | $\begin{aligned} & V_{D D}=3.0 \mathrm{~V}, V_{\text {OUT }}=0.3 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DD}}=3.0 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=2.7 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 320 \\ & 320 \end{aligned}$ |  |  | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |

AC Electrical Characteristics $V_{D D} \geq 4.7 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V}$ unless otherwise specified

| Symbol | Parameter | Min | Typ | Max | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{C}}$ | Clock Frequency, $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V}$ |  |  | 500 | kHz |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock Period High | (Notes 1, 2 ) | 500 |  |  |
| $\mathrm{t}_{\mathrm{CL}}$ | Clock Period Low |  | 500 |  | ns |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Set-Up before Clock | 300 |  | ns |  |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time after Clock |  |  | ns |  |
| $\mathrm{t}_{\mathrm{LW}}$ | Minimum Load Pulse Width | 100 |  |  | ns |
| $\mathrm{t}_{\mathrm{LTC}}$ | Load to Clock | 500 |  |  | ns |
| $\mathrm{t}_{\mathrm{CDO}}$ | Clock to Data Valid | 400 |  |  | ns |

Note 1: AC input waveform specification for test purpose: $t_{r} \leq 20 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{f}=500 \mathrm{kHz}, 50 \% \pm 10 \%$ duty cycle.
Note 2: Clock input rise and fall times must not exceed 300 ns .
Note 3: Output offset voltage is $\pm 50 \mathrm{mV}$ with $\mathrm{C}_{\text {SEGMENT }}=250 \mathrm{pF}, \mathrm{C}_{\mathrm{BP}}=8750 \mathrm{pF}$.

## Functional Description

A block diagram for the MM5483 is shown in Figure 1 and a package pinout is shown in Figure 2. Figure 3 shows a possible 3 -wire connection system with a typical signal format for Figure 3. Shown in Figure 4, the load input is an asynchronous input and lets data through from the shift register to the output buffers any time it is high. The load input can be connected to $V_{D D}$ for 2-wire control as shown in Figure 5. In the 2 -wire control mode, 31 bits (or less depending on
the number of segments used) of data are clocked into the MM5483 in a short time frame (with less than 0.1 second there probably will be no noticeable flicker) with no more clocks until new information is to be displayed. If data was slowly clocked in, it can be seen to "walk" across the display in the 2 -wire mode. An AC timing diagram can be seen in Figure 6. It should be noted that data out is not a TTLcompatible output.

Functional Description (Continued)


FIGURE 3. Three-Wire Control Mode


FIGURE 4. Data Format Diagram


National

## MM5484 16-Segment LED Display Driver

## General Description

The MM5484 is a low threshold N -channel metal gate circuit using low threshold enhancement and ion implanted depletion devices. The MM5484 is available in a 22-pin molded package and is capable of driving 16 LED segments.

## Features

- Serial data input
- Wide power supply operation
- 16 output, 15 mA sink capability

■ MM5484 is cascadeable

- TTL compatibility
- No load signal required
- Non multiplex display
- $21 / 2$ digit capability-MM5484


## Applications

- COPSTM or microprocessor displays
- Instrumentation readouts
- Industrial control indicator
- Relay driver


## Block and Connection Diagrams



FIGURE 1. MM5484

Dual-In-Line Package


Order Number MM5484N
See NS Package Number N22A

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at LED Outputs
$V_{S S}-0.5 \mathrm{~V}$ to $\mathrm{V}_{S S}+12 \mathrm{~V}$
Voltage at Other Pins
$V_{S S}-0.5 \mathrm{~V}$ to $\mathrm{V}_{S S}+10 \mathrm{~V}$

DC Electrical Characteristics $\mathrm{V}_{D D}=4.5 \mathrm{~V}$ to $9 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| Parameter | Conditions | Min | Typ | Max | Units |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage |  | 4.5 |  | 9 | V |
| Supply Current |  |  | 5 | 10 | mA |
| Logic One |  |  |  |  |  |
| Input High Level $\mathrm{V}_{\mathrm{IH}}$ |  |  |  | $V_{\mathrm{DD}}+0.5$ | V |
| Logic Zero |  |  |  |  |  |
| Input Low Level VIL |  |  | 0.8 | V |  |
| Input Current |  |  |  | 7.5 | $\mu \mathrm{~A}$ |
| Input Capacitance | High or Low Level |  |  | pF |  |

## OUTPUTS

| Data Output Voltage High Level $\mathrm{V}_{\mathrm{OH}}$ Low Level $\mathrm{V}_{\mathrm{OL}}$ Segment Off (Logic Zero on Input) | $\begin{aligned} & \text { IOUT }=0.1 \mathrm{~mA} \\ & \text { IOUT }=-0.1 \mathrm{~mA} \\ & V_{\text {OUT }}=12 \mathrm{~V} \\ & \mathrm{R}_{\text {EXT }}=400 \Omega \\ & \hline \end{aligned}$ | $V_{D D}-0.5$ |  | $\begin{aligned} & 0.5 \\ & 50 \end{aligned}$ | $\begin{gathered} \mathrm{V} \\ \mathrm{~V} \\ \mu \mathrm{~A} \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Output Current Segment On (Logic One on Input) Output Voltage | $\begin{aligned} & \mathrm{I}_{\mathrm{OUT}}=15 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{DD}} \geq 6 \mathrm{~V} \end{aligned}$ |  | 0.5 | 1.0 | V |

## AC Electrical Characteristics

(See Figure 3.) $\mathrm{V}_{\mathrm{DD}}=4.5 \mathrm{~V}$ to $9 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ unless otherwise specified

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{C}}$ | Clock Frequency |  |  |  | 0.5 | MHz |
| $\mathrm{t}_{\mathrm{h}}$ | High Time |  | 0.95 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{1}$ | Low Time |  | 0.95 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{S} 1}$ | Data Setup Time |  | 0.5 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{H} 1}$ | Data Hold Time |  | 0.5 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{S} 2}$ | Enable Setup Time |  | 0.5 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{H} 2}$ | Enable Hold Time |  | 0.5 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{pd}}$ | Data Out Delay |  |  |  | 0.5 | $\mu \mathrm{~s}$ |

Note 1: Under no condition should the power dissipated by the segment driver exceed 50 mW nor the entire chip power dissipation exceed 500 mW .
Note 2: AC input waveform specification for test purpose: $\mathrm{t}_{\mathrm{r}} \leq 20 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{f}=500 \mathrm{kHz}, 50 \% \pm 10 \%$ duty cycle.
Note 3: Clock input rise and fall times must not exceed 500 ns .

## Functional Description

The MM5484 is designed to drive LED displays directly. Serial data transfer from the data source to the display driver is accomplished with 3 signals, DATA IN, CLOCK and ENABLE. The signal ENABLE acts as an envelope and only while this signal is at a logic ' 1 ' do the circuits recognize the clock signal.
While ENABLE is high, data on the serial data input is transferred and shifted in the internal shift register on the rising clock edge, i.e. a logic ' 0 ' to logic ' 1 ' transition.

When the ENABLE signal goes to a low (logic zero state), the contents of the shift register is latched and the display will show the new data. While new data is being loaded into the SR the display will continue to show the old data.
For the MM5484, data is output from the serial DATA OUT pin on the falling edge of clock so cascading is made simple with race hazards eliminated.
When the chip first powers on, an internal power on reset signal is generated which resets the SR and latches to zero so that the display will be off.

## Timing Diagram



TL/F/6141-5
FIGURE 3

National Semiconductor Corporation

## MM5486 LED Display Driver

## General Description

The MM5486 is a monolithic MOS integrated circuit utilizing N -channel metal-gate low-threshold, enhancement mode and ion-implanted depletion mode devices. It is available in a 40-pin molded dual-in-line package. A single pin controls the LED display brightness by setting a reference current through a variable resistor connected to $V_{D D}$.

## Features

- Continuous brightness control
- Serial data input/outut
- External load input
- Cascaded operation capability

■ Wide power supply operation

- TTL compatibility
- 33 outputs, 15 mA sink capability
- Alphanumeric capability


## Applications

- COPSTM or microprocessor displays
- Industrial control indicator
- Relay driver
- Digital clock, thermometer, counter, voltmeter
- Instrumentation readouts
- Reference MOS Brief \#1


## Block and Connection Diagrams



FIGURE 1


Order Number MM5486N See NS Package Number N40A

Top View
FIGURE 2

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Pin
$V_{S S}$ to $V_{S S}+12 \mathrm{~V}$
$-25^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

## Functional Description

The MM5486 is specifically designed to operate four-digit alphanumeric displays with minimal interface with the display and the data source. Serial data transfer from the data source to the display driver is accomplished with 3 signals, serial data, clock, and load. The data bits are latched by a positive-level load signal, thus providing non-multiplexed, direct drive to the display. When load is high, the data in the shift registers is displayed on the output drivers. Outputs change only if the serial data bits differ from the previous time. Display brightness is determined by control of the output current for LED displays. A $0.001 \mu \mathrm{~F}$ capacitor should be connected to brightness control, pin 19, to prevent possible oscillations. The output current is typically 20 times greater than the current into pin 19, which is set by an external variable resistor. There is an internal limiting resistor of $400 \Omega$ nominal value.
A block diagram is shown in Figure 1.
Figure 4 shows the input data format. Bit " 1 " is the first bit into the data input pin and it will appear on pin 17. A logical " 1 " at the input will turn on the appropriate LED. The load signal latches the 33 bits of the shift register into the latches. The data out pin allows for cascading the shift registers for more than 33 output drivers.

When the chip first powers ON, an internal power ON reset signal is generated which resets all registers and latches. The leading clock returns the chip to its normal operation.
Figure 3 shows the timing relationship between data, clock and data enable. A maximum clock frequency of 0.5 MHz is assumed.

For applications where a lesser number of outputs are used, it is possible to either increase the current per output, or operate the part at higher than IV VOUT. The following equation can be used for calculations:

$$
T_{J}=\left(V_{O U T}\right)\left(I_{\text {LED }}\right)(\text { No. of segments })\left(124^{\circ} \mathrm{C} / \mathrm{W}\right)+T_{A}
$$ where:

$\mathrm{T}_{\mathrm{J}}=$ junction temperature $+150^{\circ} \mathrm{C}$ max.
$V_{\text {OUT }}=$ the voltage at the LED driver outputs
led $=$ the LED current
$124^{\circ} \mathrm{C} / \mathrm{W}=$ thermal coefficient of the package
$T_{A}=$ ambient temperature
The above equation was used to plot Figure 6, Figure 7, and Figure 8.


TL/F/6142-3
FIGURE 3


TL/F/6142-4
*This leading clock is necessary only after power ON.
FIGURE 4. Input Data Format


FIGURE 5

## Typical Applications



FIGURE 6


FIGURE 7


FIGURE 8


TL/F/6142-9

$$
\mathrm{I}_{19}=\frac{\Delta V}{1 \mathrm{k}}
$$

FIGURE 9. Constant Current Brightness Control


TL/F/6142-10

Typical Applications (Continued)


Duplexing 8 Digits with One MM5486

*This driver has 7 segments only.

National
Semiconductor Corporation

## MM58201 Multiplexed LCD Driver

## General Description

The MM58201 is a monolithic CMOS LCD driver capable of driving up to 8 backplanes and 24 segments. A 192-bit RAM stores the data for the display. Serial input and output pins are provided to interface with a controller. An RC oscillator generates the timing necessary to refresh the display. The magnitude of the driving waveforms can be adjusted with the $V_{T C}$ input to optimize display contrast. Four additional bits of RAM allow the user to program the number of backplanes being driven, and to designate the driver as either a master or slave for cascading purposes. When two or more drivers are cascaded, the master chip drives the backplane lines, and the master and each slave chip drive 24 segment lines. Synchronizing the cascaded drivers is accomplished by tying the RC OSC pins together and the BP1 pins together.

The MM58201 is packaged in a 40-lead dual-in-line package, or 44 lead plastic chip carrier package.

Features
■ Drives up to 8 backplanes and 24 segment lines

- Stores data for display
- Cascadable

E Low power
■ Fully static operation

## Applications

■ Dot matrix LCD driver

- Multiplexed 7-segment LCD driver
- Serial in/Serial out memory


## Block Diagram



TL/F/6146-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.

Voltage at Any Pin
$V_{S S}-0.3 \mathrm{~V}$ to $\mathrm{V}_{S S}+18 \mathrm{~V}$
Operating Temperature Range
$0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Package Dissipation | 500 mW |
| Operating $\mathrm{V}_{\mathrm{DD}}$ Range | $\mathrm{V}_{\mathrm{SS}}+7.0 \mathrm{~V}$ to V SS +18.0 V |
| Lead Temperature (Soldering, |  |
| 10 seconds) | $300^{\circ} \mathrm{C}$ |

DC Electrical Characteristics $\operatorname{Min} / \max$ limits apply across temperature range unless otherwise noted.

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICC | Quiescent Supply Current |  |  |  | 0.3 | mA |
| $\mathrm{V}_{\text {IN(1) }}$ | Logical "1" Input Voltage |  | $0.45 V_{\text {DD }}$ |  | $\mathrm{V}_{\mathrm{DD}}+0.3$ | V |
| $\mathrm{V}_{\text {IN }(0)}$ | Logical "0" Input Voltage |  | $\mathrm{V}_{S S}-0.3$ |  | 1.0 | V |
| VOUT(0) | Logical "0" Output Voltage | $\mathrm{I}_{\text {SINK }}=0.6 \mathrm{~mA}$ |  |  | 0.4 | V |
| IOUT(1) | Logical "1" Output Leakage Current | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {DD }}$ | 0 |  | $\pm 10$ | $\mu \mathrm{A}$ |
| $\ln (1)$ | Logical "1" Input Leakage Current | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{DD}}$ | 0 |  | 1.0 | $\mu \mathrm{A}$ |
| ${ }_{1}(\mathbb{N}(0)$ | Logical " 0 " Input Leakage Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ | -1.0 |  | 0 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{TC}}$ | Input Voltage |  | 4.5 |  | $V_{D D}+0.3$ | V |
| $\mathrm{V}_{\text {TC }}$ | Input Impedance |  | 10 |  | 30 | k $\Omega$ |
| $\mathrm{Z}_{\text {OUT }}$ | Output Impedance | Backplane and Segment Outputs |  |  | 10 | k $\Omega$ |
| ZOUT | DC Offset Voltage | Between Any Backplane and Segment Output | 0 |  | $\pm 10$ | mV |

AC Electrical Characteristics $T_{A}$ and $V_{D D}$ within operating range unless otherwise noted.

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| fosc | Oscillator Frequency* |  | $128 \eta$ |  | $400 \eta$ | Hz |
| $\mathrm{f}_{\text {CLK IN }}$ | Clock Frequency |  | DC |  | 100 | kHz |
| ton | Clock Pulse Width |  | 5.0 |  |  | $\mu \mathrm{s}$ |
| toff | Clock OFF Time |  | 5.0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {s }}$ | Input Data Set-Up Time |  | 2.0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{H}}$ | Input Data Hold Time |  | 1.0 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {ACC }}$ | Access Time |  | 5.0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{tr}_{\mathrm{r}}$ | Rise Time | Backplane, Segment Outputs $\mathrm{C}_{\mathrm{L}}=2000 \mathrm{pF}$ |  |  | 60 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{f}}$ | Fall Time | Backplane, Segment Outputs $C_{L}=2000 \mathrm{pF}$ |  |  | 60 | $\mu \mathrm{S}$ |

* $\eta$ is the number of backplanes programmed.


## Connection Diagrams

Dual-In-Line Package

TL/F/6146-2


Top View
Plastic Chip Carrler


TL/F/6146-10
Top View

FIGURE 2
Order Number MM58201N or MM58201V See NS Package Number N40A or V44A

## Switching Time Waveforms


Backplane Output



## Functional Description

A functional diagram of the MM58201 LCD driver is shown in Figure 1. Connection diagrams are shown in Figure 2.

## SERIAL INPUTS AND OUTPUTS

A negative-going edge on the $\overline{\mathrm{CS}}$ input initiates a frame. The $\overline{\mathrm{CS}}$ input must then stay low for at least one rising edge of CLK IN, and may not be pulsed low again for the next 31 clocks. At least one clock must occur while $\overline{\mathrm{CS}}$ is high. If CLK IN is held at a logic " 1 ", $\overline{C S}$ is disabled. This allows the signal that drives $\overline{\mathrm{CS}}$ to be used for other purposes when the MM58201 is not being addressed.
CLK IN latches data from the DATA IN input on its rising edge. Data from the DATA OUT pin changes on the falling edge of CLK IN and is valid before the next rising edge.
The first five bits of data following $\overline{\mathrm{CS}}$ are the address bits (Figure 3). The address selects the column where the operation is to start. Bit 1 is the MSB and bit 5 is the LSB. The sixth bit is the read/write bit. A logic " 1 " specifies a read operation and a logic " 0 " specifies a write operation. The next 24 bits are the data bits. The first data bit corresponds to the BP1 row of the display, the second data bit to the BP2 row, and so on. After the eighth and sixteenth data bits, the column pointer is incremented. When starting address 10110 or 10111 is specified, the column pointer increments from 10111 to 00000.
During a read or write cycle, the LCD segment outputs do not reflect the data in the RAM. To avoid disrupting the pattern viewed on the display, the read or write cycle time should be kept short. Since the LCD turn-on time can be as little as 30 ms , a clock rate of at least 10 kHz would be required in order to address the entire contents of the RAM within that time interval. The formula below can be used to estimate the minimum clock rate:

$$
f_{C L K} I N=\frac{30}{\left(t_{L C D}-7 t_{s}\right)}
$$

where $t_{s}$ is the processor's set-up time between each read or write cycle, and $t_{L C D}$ is the minimum turn-on or turn-off time of the LCD as specified by the LCD manufacturer.
The DATA OUT output is an open drain N -channel device to $V_{S S}$ (Figure 4). With an external pull-up this configuration allows the controller to operate at a lower supply voltage, and also permits the DATA OUT output to be wired in parallel with the DATA OUT outputs from any other drivers in the system.
To program the number of backplanes being driven and the M/S bit, load address 11000, a write bit, three bits for the number of backplanes (Table I), and the $M / \overline{\mathrm{S}}$ bit. The remaining 20 data bits will be ignored but it is necessary to provide 21 more clocks before initiating another frame.

TABLE I. Backplane Select

| Number of <br> Backplanes | B2 | B1 | B0 |
| :---: | :---: | :---: | :---: |
| 2 | 0 | 0 | 1 |
| 3 | 0 | 1 | 0 |
| 4 | 0 | 1 | 1 |
| 5 | 1 | 0 | 0 |
| 6 | 1 | 0 | 1 |
| 7 | 1 | 1 | 0 |
| 8 | 1 | 1 | 1 |

## RC OSC Pin

This oscillator generates the timing required for multiplexing the liquid crystal display. The oscillator operates at a frequency that is $4 \eta$ times the refresh rate of the display, where $\eta$ is the number of backplanes programmed. Since the refresh rate should be in the range from 32 Hz to 100 Hz , the oscillator frequency must be:

$$
128 \eta \leq \text { fosc } \leq 400 \eta
$$

The frequency of oscillation is related to the external $R$ and C components in the following way:

$$
\mathrm{fOSC}=\frac{1}{1.25 R C} \pm 30 \%
$$

The value used for the external resistor should be in the range from $10 \mathrm{k} \Omega$ to $1 \mathrm{M} \Omega$.
The value used for the external capacitor should be less than $0.005 \mu \mathrm{~F}$.

## $\mathbf{V}_{\mathbf{T C}}$ Pin

The $V_{T C}$ pin is an analog input that controls the contrast of the segments on the LCD. If eight backplanes are being driven $(\eta=8)$, a voltage of typically 8 V is required at $25^{\circ} \mathrm{C}$. The voltage for optimum contrast will vary from display to display. It also has a significant negative temperature coefficient.
The voltage source on the $\mathrm{V}_{\mathrm{TC}}$ input must be of relatively low impedance since the input impedance of $V_{T C}$ ranges from $10 \mathrm{k} \Omega$ to $30 \mathrm{k} \Omega$. A suitable circuit is shown in Figure 5.
In a standby mode, the $\mathrm{V}_{\mathrm{TC}}$ input can be set to $\mathrm{V}_{\mathrm{SS}}$. This reduces the supply current to less than $300 \mu \mathrm{~A}$ per driver.

## BACKPLANE AND SEGMENT OUTPUTS

Connect the backplane and segment outputs directly to the LCD row and column lines. The outputs are designed to drive a display with a total ON capacitance of up to 2000 pF . The output structure consists of transmission gates tapped off of a resistor string driven by $V_{T C}$ (Figure 6).
A critical factor in the lifetime of an LCD is the amount of DC offset between a backplane and segment signal. Typically, 50 mV of offset is acceptable. The MM58201 guarantees an offset of less than 10 mV .
The BP1 output is disabled when the M/ $\bar{S}$ bit is set to zero. This allows the BP1 output from the master chip to be connected directly to it so that synchronizing signals can be generated. Synchronization occurs once each refresh cycle, so the cascaded chips are assured of remaining synchronized.

Functional Description (Continued)

| cs |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | MUST RISE BY THIS POINT |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | RISE AT ANY TIME |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| CLK IN |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| dATA IN | DON'T CARE |  | A4 | A3 |  | A2 | AI | AO | R/ $\bar{W}$ |  |  | 01 | 02 |  | D3 | 022 |  |  | 023 |  | 024 | DON'T CARE |  |  |  |  |
| DATA OUT | S1 | S2 | S3 | S4 | S5 | S6 | S7 | S8 | S9 |  | S10 | 01 | 02 |  | 03 | $\cdots$ |  | 022 | 023 |  | 024 | 521 | S22 | S23 | \$24 |  |
|  |  |  |  |  |  |  |  |  |  |  | S11 | S12 | S13 | S14 | 515 | S16 | 517 | S18 | S19 | S20 |  |  |  |  |  |
| 8P1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 01 | D9 | D17 |  |  |  |  |  |  |  |  |  | 82 |
| BP2 |  |  |  |  |  |  |  |  |  |  |  |  |  | D2 | 010 | 018 |  |  |  |  |  |  |  |  |  | 81 |
| BP3 |  |  |  |  |  |  |  |  |  |  |  |  |  | D3 | 011 | D19 |  |  |  |  |  |  |  |  |  | 801 |
| 8P4 |  |  |  |  |  |  |  |  |  |  |  |  |  | 04 | 012 | 020 |  |  |  |  |  |  |  |  |  | M/ ${ }^{\text {I }}$ |
| BP5 |  |  |  |  |  |  |  |  |  |  |  |  |  | 05 | 013 | 021 |  |  |  |  |  |  |  |  |  |  |
| BP6 |  |  |  |  |  |  |  |  |  |  |  |  |  | 06 | 014 | 022 |  |  |  |  |  |  |  |  |  |  |
| BP7 |  |  |  |  |  |  |  |  |  |  |  |  |  | 07 | D15 | 023 |  |  |  |  |  |  |  |  |  |  |
| ${ }^{\text {3P8 }}$ |  |  |  |  |  |  |  |  |  |  |  |  |  | 08 | 016 | D24 |  |  |  |  |  |  |  |  |  |  |
| A4 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | - | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| A3 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - | 1 |  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| A2 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 |  | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 |
| AI | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 |  | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 |
| AO | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |  | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | , | 1 | 0 | 1 | 0 |

Diagram above shows where data will appear on display if starting address 01100 is specified in data format.
FIGURE 3. Data Format


TL/F/6146-7
FIGURE 4. DATA OUT Structure

Functional Description (Continued)


FIGURE 5. Typical Application


TL/F/6146-9
FIGURE 6. Structure of LCD Outputs

## National Semiconductor Corporation

## MM58248 High Voltage Display Driver

## General Description

The MM58248 is a monolithic MOS integrated circuit utilizing CMOS metal gate low threshold P - and N -channel devices. It is available both in 40-pin molded dual-in-line packages or as dice. The MM58248 is particularly suited for driving high voltage ( 60 V max) vacuum fluorescent (VF) displays (e.g., a $5 \times 7$ dot matrix display).

## Applications

- COPSTM or microprocessor-driven display
- Instrumentation readouts
- Industrial control indicator
- Digital clock, thermostat, counter, voltmeter

■ Word processor text displays

- Automotive dashboards


## Features

- Direct interface to high voltage display
- Serial data input

■ No external resistors required

- Wide display power supply operation
- LSTTL compatible inputs
- Software compatible with NS display driver family
- Compatible with alphanumeric or dot matrix displays
- No load signal required


## Block Diagram



TL/F/5599-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.

Voltage at Any Input Pin
Voltage at Any Display Pin
$V_{D D}+\left|V_{D I S}\right|$
Storage Temperature
Power Dissipation

$$
\begin{array}{r}
V_{D D}+0.3 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{SS}}-0.3 \mathrm{~V} \\
\mathrm{~V}_{\mathrm{DD}} \text { to } \mathrm{V}_{\mathrm{DD}}-62.5 \mathrm{~V} \\
62.5 \mathrm{~V} \\
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\
500 \mathrm{~mW} \text { at }+85^{\circ} \mathrm{C}
\end{array}
$$

$\begin{array}{ll}\text { Junction Temperature } & 130^{\circ} \mathrm{C} \\ \begin{array}{l}\text { Lead Temperature } \\ \text { (Soldering, } 10 \text { seconds) }\end{array} & 260^{\circ} \mathrm{C}\end{array}$
Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage ( $\mathrm{V}_{\mathrm{DD}}$ ) |  |  |  |
| $\mathrm{V}_{\text {SS }}=0 \mathrm{~V}$ | 4.5 | 5.5 | V |
| Display Voltage ( $\mathrm{V}_{\text {DIS }}$ ) | -55 | -25 | V |
| Temperature Range | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |

## DC Electrical Characteristics

$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ unless otherwise specified

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {D }}$ | Power Supply Currents | $V_{I N}=V_{S S} \text { or } V_{D D}, V_{S S}=0 V$ <br> $V_{\text {DIS }}$ Disconnected |  |  | 150 | $\mu \mathrm{A}$ |
| IDIS |  | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-55 \mathrm{~V}, \text { All Outputs Low } \end{aligned}$ |  |  | 10 | mA |
| $V_{\text {IL }}$ | Input Logic Levels DATA IN, CLOCK Logic ' 0 ' |  |  |  | 0.8 | V |
| $\mathrm{V}_{1}$ | Input Logic Levels DATA IN, CLOCK Logic '1' | (Note 1) | 2.4 |  |  | V |
| $\mathrm{I}_{\mathrm{N}}$ | Input Currents, DATA IN, CLOCK | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{DD}}$ | $-10$ |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance, DATA IN, CLOCK |  |  |  | 15 | pF |
| Roff | Display Output Impedances Output Off (Figure 3a) | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-40 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-55 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 60 \\ & 70 \\ & 80 \end{aligned}$ |  | $\begin{aligned} & 400 \\ & 550 \\ & 650 \end{aligned}$ | $\begin{aligned} & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \end{aligned}$ |
| RoN | Display Output Impedances Output on (Figure 3b) | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-40 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-55 \mathrm{~V} \\ & \hline \end{aligned}$ |  | $\begin{array}{r} 3.0 \\ 2.6 \\ 2.3 \\ \hline \end{array}$ | $\begin{aligned} & 4.0 \\ & 3.7 \\ & 3.4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \hline \end{aligned}$ |
| $\mathrm{V}_{\text {DOL }}$ | Display Output Low Voltage | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \text { IOUT }=\text { Open Circuit, }, \\ & -55 \mathrm{~V} \leq V_{\text {DIS }} \leq-25 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {DIS }}$ |  | $\mathrm{V}_{\text {DIS }}+4$ | V |

Note 1: 74LSTTL $V_{O H}=2.7 \mathrm{~V} @ I_{O U T}=-400 \mu \mathrm{~A}, T T L V_{O H}=2.4 \mathrm{~V} @ I_{\mathrm{OUT}}=-400 \mu \mathrm{~A}$.
AC Electrical Characteristics $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V} D=5 \mathrm{~V} \pm 0.5 \mathrm{~V}$

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{fc}_{\mathrm{C}}$ | Clock Input Frequency | (Notes 2, 3) |  |  | 1.0 | MHz |
| $\mathrm{t}_{\mathrm{H}}$ | Clock Input High Time |  | 300 |  |  | ns |
| $\mathrm{t}_{\mathrm{L}}$ | Clock Input Low Time |  | 300 |  |  | ns |
| $t_{\text {DS }}$ | Data Input Setup Time | $C_{L}=50 \mathrm{pF}$ | 100 |  |  | ns |
| ${ }_{\text {t }}{ }_{\text {DH }}$ | Data Input Hold Time |  | 100 |  |  | ns |

Note 2: $A C$ input waveform specification for test purposes: $t_{r}, t_{f} \leq 20 \mathrm{~ns}, \mathrm{f}=1 \mathrm{MHz}, 50 \% \pm 10 \%$ duty cycle.
Note 3: Clock input rise and fall times must not exceed $5 \mu \mathrm{~s}$.

Connection Diagrams



Top View
Order Number MM58248V See NS Package Number V44A

FIGURE 2

## Functional Description

This product is specifically designed to drive multiplexed or non-multiplexed high voltage alphanumeric or dot matrix vacuum fluorescent (VF) displays. Character generation is done externally in the microprocessor, with a serial data path to the display driver. The MM58248 uses two signals, DATA IN and CLOCK, with a format of a leading ' 1 ' followed by the 35 data bits, hence allowing data transfer without an additional signal. A block diagram of the MM58248 is shown in Figure 1.
Figure 2 shows the pinout of the MM58248 device, where output 1 (pin 18) is equivalent to bit 1, i.e., the first bit of data to be loaded into the shift register following the start bit. A logic ' 1 ' at the input will turn on the corresponding display digit/segment/dot output.
A significant reduction in discrete board components can be achieved by the use of the MM58248, because external pull-down resistors are not required. Due to the nature of the output stage, both its on and off impedance values vary as a function of the display voltage applied. However, Figures $3 a$ and $3 b$ show that this output impedance will remain constant for a fixed value of display voltage.
Figure 4 demonstrates the critical timing requirements between CLOCK and DATA IN for the MM58248.
When the chip first powers on, an internal reset is generated, resetting all registers and latches. The chip returns to
normal operation on application of the start bit and the first clock pulse, and so all interface signals should be inactive at power on.
In Figure 5, a start bit of logic ' 1 ' precedes the 35 bits of data, each bit being accepted on the rising edge of CLOCK, i.e., a '0'-'1' transition. At the 36th clock, a LOAD signal is generated synchronously with the high state of the clock, thus loading the 35 bits of the shift register into the latches. At the low state of the clock, a RESET signal is generated, clearing all bits of the shift register for the next set of data. Hence, a complete set of 36 clock pulses is needed for the MM58248, or the shift register will not clear. If, at any given time, it is required that the display be cleared under microprocessor control, i.e., without power on reset, then the following flushing routine may be used. Clock in 36 'zeroes', followed by a 'one' (start bit), followed by 35 'zeroes'. This procedure will completely blank the display.
Figure 6 shows a schematic diagram of a microprocessorbased system where the MM58248 is used to provide the anode drive for a 32 -digit $5 \times 7$ dot matrix vacuum fluorescent (VF) display. The grid drive in this example is provided by another member of the high voltage display driver family, namely the MM58241, which has the additional features of a BLANKING CONTROL pin, a DATA OUT pin, and an ENABLE (external load signal) pin.

Functional Description (Continued)


FIGURE 3a. Output Impedance Off


TL/F/5599-4
FIGURE 3b. Output Impedance On

## Timing Diagrams



For the purposes of $A C$ measurement, $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}$.
TL/F/5599-5
FIGURE 4. Clock and Data Timings


## Typical Applications



FIGURE 6. Microprocessor-Controlled Word Processor

## MM58241 High Voltage Display Driver

## General Description

The MM58241 is a monolithic MOS integrated circuit utilizing CMOS metal gate low threshold P - and N -channel devices. It is available both in 40-pin molded dual-in-line packages or as dice. The MM58241 is particularly suited for driving high voltage ( 60 V max) vacuum fluorescent (VF) displays (e.g., a 32-digit alphanumeric or dot matrix display).

## Applications

- COPSTM or microprocessor-driven displays
- Instrumentation readouts
- Industrial control indicator

■ Digital clock, thermostat, counter, voltmeter

- Word processor text displays

■ Automotive dashboards

## Block Diagram



FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Input Pin
Voltage at Any Display Pin
$V_{D D}+\left|V_{D I S}\right|$
Storage Temperature

$$
-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}
$$

Power Dissipation

$$
500 \mathrm{~mW} \text { at }+85^{\circ} \mathrm{C}
$$

Junction Temperature

$$
\begin{array}{r}
V_{D D}+0.3 V \text { to } V_{S S}-0.3 \mathrm{~V} \\
V_{D D} \text { to } V_{D D}-62.5 \mathrm{~V} \\
62.5 \mathrm{~V}
\end{array}
$$

$$
130^{\circ} \mathrm{C}
$$

Lead Temperature
(Soldering, 10 sec .)

## Operating Conditions

|  | Min | Max | Units |
| :--- | :---: | :---: | :---: |
| Supply Voltage $\left(V_{D D}\right)$   <br> $V_{S S}=0 \mathrm{~V}$   | 4.5 | 5.5 | V |
| Display Voltage $\left(\mathrm{V}_{\text {DIS }}\right)$ | -55 | -25 | V |
| Temperature Range | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |

## DC Electrical Characteristics

$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ unless otherwise specified

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IDD } \\ & \text { IDIS } \end{aligned}$ | Power Supply Currents | $V_{I N}=V_{S S}$ or $V_{D D}, V_{S S}=0 V$, <br> $V_{\text {DIS }}$ Disconnected <br> $V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DIS}}=-55 \mathrm{~V}$ <br> All Outputs Low |  |  | $\begin{gathered} 150 \\ 10 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & V_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | Input Logic Levels DATA IN, CLOCK ENABLE, BLANK <br> Logic ' ${ }^{\prime}$ ' <br> Logic '1' | (Note 1) | 2.4 |  | 0.8 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OL}}$ <br> V <br> $\mathrm{V}_{\mathrm{OH}}$ | Data Output Logic Levels <br> Logic ' 0 ' <br> Logic '1' <br> Logic ' 1 ' | $\begin{aligned} & \text { I OUT }=400 \mu \mathrm{~A} \\ & \text { IOUT }=-10 \mu \mathrm{~A} \\ & \text { I OUT }=-500 \mu \mathrm{~A} \end{aligned}$ | $\begin{gathered} V_{D D}-0.5 \\ 2.8 \\ \hline \end{gathered}$ |  | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ |
| $\mathrm{I}_{\mathrm{IN}}$ | Input Currents DATA IN, CLOCK <br> ENABLE, BLANK | $V_{I N}=0 V$ or $V_{D D}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance DATA IN, CLOCK ENABLE, BLANK |  |  |  | 15 | pF |
| RofF <br> $\mathrm{R}_{\mathrm{ON}}$ | Display Output Impedances <br> Output Off (Figure 3a) <br> Output On (Figure 3b) | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{D I S}=-25 \mathrm{~V} \\ & V_{D I S}=-40 \mathrm{~V} \\ & V_{D I S}=-55 \mathrm{~V} \\ & V_{D I S}=-25 \mathrm{~V} \\ & V_{D I S}=-40 \mathrm{~V} \\ & V_{D I S}=-55 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 60 \\ & 70 \\ & 80 \end{aligned}$ | $\begin{aligned} & 3.0 \\ & 2.6 \\ & 2.3 \\ & \hline \end{aligned}$ | $\begin{aligned} & 400 \\ & 550 \\ & 650 \\ & 4.0 \\ & 3.7 \\ & 3.4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \hline \end{aligned}$ |
| $\mathrm{V}_{\text {DOL }}$ | Display Output Low Voltage | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \text { IOUT }=\text { Open Circuit, } \\ & -55 \mathrm{~V} \leq \mathrm{V}_{\text {DIS }} \leq-25 \mathrm{~V} \end{aligned}$ | $V_{\text {DIS }}$ |  | $V_{\text {DIS }}+4$ | V |

Note 1: 74LSTTL $V_{O H}=2.7 \mathrm{~V} @ I_{O U T}=-400 \mu \mathrm{~A}, T \mathrm{TL} V_{O H}=2.4 \mathrm{~V} @ \mathrm{I}_{\mathrm{OUT}}=-400 \mu \mathrm{~A}$.

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{f}_{\mathrm{C}} \\ & \mathrm{t}_{\mathrm{H}} \end{aligned}$ | Clock Input Frequency High Time Low Time | (Notes 3 and 4) | $\begin{aligned} & 300 \\ & 300 \\ & \hline \end{aligned}$ |  | 800 | $\begin{aligned} & \mathrm{kHz} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \end{aligned}$ |
| $\begin{aligned} & \text { tos } \\ & t_{\mathrm{DH}} \\ & \hline \end{aligned}$ | Data Input Set-Up Time Hold Time |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ |  |  | ns ns |
| $\begin{aligned} & \mathrm{t}_{\mathrm{ES}} \\ & \mathrm{t}_{\mathrm{EH}} \end{aligned}$ | Enable Input Set-Up Time Hold Time |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| $\mathrm{t}_{\text {CDO }}$ | Data Output CLOCK Low to Data Out Time | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 500 | ns |

Note 2: For timing purposes, the signals ENABLE and BLANK can be considered to be totally independent of each other.
Note 3: AC input waveform specification for test purposes: $t_{r}, t_{f} \leq 20 n s, f=800 \mathrm{kHz}, 50 \% \pm 10 \%$ duty cycle.
Note 4: Clock input rise and fall times must not exceed $5 \mu \mathrm{~s}$.

## Connection Diagrams



FIGURE 2
Order Number MM58241N or MM58241V
See NS Package Number N40A or V44A

## Functional Description

This product is specifically designed to drive multiplexed or non-multiplexed high voltage alphanumeric or dot matrix vacuum fluorescent (VF) displays. Character generation is done externally in the microprocessor, with a serial data path to the display driver. The MM58421 uses three signals, DATA IN, CLOCK and ENABLE, where ENABLE acts as an external load signal. Display blanking can be achieved by means of the BLANKING CONTROL input, and a logic ' 1 ' will turn off all sections of the display. A block diagram of the MM58241 is shown in Figure 1.
Figure 2 shows the pinout of the MM58241 device, where output 1 (pin 18) is equivalent to bit 1 , i.e., the first bit of data


Top Vlew
to be loaded into the shift register following ENABLE high. A logic ' 1 ' at the input will turn on the corresponding display digit/segment/dot output.
A significant reduction in discrete board components can be achieved by use of the MM58241, because external pulldown resistors are not required. Due to the nature of the output stage, both its on and off impedance values vary as a function of the display voltage applied. However, Figures 3a and $3 b$ show that this output impedance will remain constant for a fixed value of display voltage.

## Functional Description (Continued)

Figure 4 demonstrates the critical timing requirements between CLOCK and DATA IN for the MM58241.
When the chip first powers on, an internal reset is generated, resetting all registers and latches. The chip returns to normal operation on application of ENABLE, and so all interface signals should be inactive at power on.
In Figure 5, the ENABLE signal acts as an envelope, and only while this signal is at a logic ' 1 ' does the circuit accept CLOCK input signals. Data is transferred and shifted in the internal shift register on the rising clock edge, i.e., ' 0 '-' 1 ' transition. When the ENABLE signal goes low, the contents of the shift registers are latched, and the display will show
new data. During data transfer, the display will show old data. DATA OUT is also provided on the MM58241, being output on the falling edge. At any time, the display may be blanked under processor control, using the BLANKING CONTROL input.
Figure 6 shows a schematic diagram of a microprocessorbased system where the MM58241 is used to provide the grid drive for a 32-digit $5 \times 7$ dot matrix vaccum fluorescent (VF) display. The anode drive in this example is provided by another member of the high voltage display driver family, namely the MM58248, which does not require an externally generated load signal.


FIGURE 3a. Output Impedance Off


TL/F/5600-4
FIGURE 3b. Output Impedance On
Timing Diagrams


For the purposes of $A C$ measurements, $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}$.

FIGURE 4. Clock and Data Timings


## Typical Application



TL/F/5600-7
FIGURE 6. Microprocessor-Controlled Word Processor

## National Semiconductor Corporation

## MM58242 High Voltage Display Driver

## General Description

The MM58242 is a monolithic MOS integrated circuit utilizing CMOS metal gate low threshold P and N -channel devices. It is available both in 28 -pin molded dual-in-line packages or as dice. The MM58242 is particularly suited for driving high voltage (60V max) vacuum fluorescent (VF) displays (e.g., a 20 -digit alphanumeric or dot matrix display).

## Applications

- COPSTM or microprocessor-driven displays
- Instrumentation readouts
- Industrial control indicator
- Digital clock, thermostat, counter, voltmeter

■ Word processor text displays

- Automotive dashboards


## Block Diagram



TL/F/7924-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Input Pin
Voltage at Any Display Pin
$V_{D D}+\left|V_{D I S}\right|$
Storage Temperature
$V_{D D}+0.3 V$ to $V_{S S}-0.3 V$
$V_{D D}$ to $V_{D D}-62.5 \mathrm{~V}$
62.5 V
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Power Dissipation
500 mW at $+85^{\circ} \mathrm{C}$ $130^{\circ} \mathrm{C}$
Junction Temperature
Lead Temperature (Soldering, 10 sec .) $260^{\circ} \mathrm{C}$

## Operating Conditions

|  | Min | Max | Units |
| :--- | :---: | :---: | :---: |
| Supply Voltage $\left(V_{D D}\right)$ |  |  |  |
| $V_{S S}=0 \mathrm{~V}$ | 4.5 | 5.5 | V |
| Display Voltage $\left(\mathrm{V}_{\text {DIS }}\right)$ | -55 | -25 | V |
| Temperature Range | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |

## DC Electrical Characteristics

$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{D D}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V}$ unless otherwise specified

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{I}_{\mathrm{DD}} \\ & \mathrm{I}_{\mathrm{DIS}} \end{aligned}$ | Power Supply Currents | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{SS}} \text { or } \mathrm{V}_{\mathrm{DD}}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DIS}} \text { Disconnected } \\ & \mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DIS}}=55 \mathrm{~V} \\ & \text { All Outputs Low } \end{aligned}$ |  |  | $\begin{gathered} 150 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ $\mathrm{mA}$ |
| $\begin{aligned} & V_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | Input Logic Levels DATA IN, CLOCK ENABLE, BLANK <br> Logic ' 0 ' Logic '1' | (Note 1) | 2.4 |  | 0.8 | $\begin{aligned} & V \\ & v \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OL}}$ <br> $\mathrm{V}_{\mathrm{OH}}$ <br> $\mathrm{V}_{\mathrm{OH}}$ | Data Output Logic Levels <br> Logic '0' <br> Logic '1' <br> Logic '1' | $\begin{aligned} & \text { I OUT }=400 \mu \mathrm{~A} \\ & \text { IOUT }=-10 \mu \mathrm{~A} \\ & \text { I OUT }=-500 \mu \mathrm{~A} \end{aligned}$ | $\begin{gathered} \mathrm{V}_{\mathrm{DD}}-0.5 \\ 2.8 \\ \hline \end{gathered}$ |  | 0.4 | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ |
| IN | Input Currents DATA IN, CLOCK ENABLE, BLANK | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{DD}}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{1 \mathrm{~N}}$ | Input Capacitance DATA IN, CLOCK ENABLE, BLANK |  |  |  | 15 | pF |
| Roff <br> $\mathrm{R}_{\mathrm{ON}}$ | Display Output Impedances Output Off (Figure 3a) <br> Output On (Figure 3b) | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-40 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-55 \mathrm{~V} \\ & \mathrm{~V}_{\text {DIS }}=-25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=40 \mathrm{~V} \\ & \mathrm{~V}_{\text {DIS }}=-55 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & 60 \\ & 70 \\ & 80 \end{aligned}$ | $\begin{aligned} & 3.0 \\ & 2.6 \\ & 2.3 \\ & \hline \end{aligned}$ | $\begin{aligned} & 400 \\ & 550 \\ & 650 \\ & 4.0 \\ & 3.7 \\ & 3.4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \hline \end{aligned}$ |
| $\mathrm{V}_{\text {DOL }}$ | Display Output Low Voltage | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \text { IOUT }=\text { Open Circuit, } \\ & -55 \mathrm{~V} \leq \mathrm{V}_{\mathrm{DIS}} \leq-25 \mathrm{~V} \end{aligned}$ | $V_{\text {DIS }}$ |  | $\mathrm{V}_{\mathrm{DIS}}+4$ | V |

Note 1: $74 \mathrm{LSTTL} \mathrm{V}_{\mathrm{OH}}=2.7 \mathrm{~V}$ @ IOUT $=-400 \mu \mathrm{~A}, T \mathrm{~L} V_{\mathrm{OH}}=2.4 \mathrm{~V} @$ IOUT $=-400 \mu \mathrm{~A}$.

AC Electrical Characteristics $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{D D}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}$

| Parameter | Conditions | Min | Typ | Max | Units |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Clock Input |  |  |  |  |  |
| Frequency, fC |  |  |  |  |  |
| High Time, $t_{H}$ |  |  |  |  |  |
| Low Time, $t_{L}$ |  |  |  |  |  |$\quad$ (Notes 3 and 4)

Note 2: For timimg purposes, the signals ENABLE and BLANK can be considered to be totally independent of each other,
Note 3: AC input waveform specification for test purposes: $\mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{f}=800 \mathrm{kHz}, 50 \% \pm 10 \%$ duty cycle.
Note 4: Clock input rise and fall times must not exceed $5 \mu \mathrm{~s}$.

## Connection Diagrams

## Dual-In-Line Package


Order Number MM58242N See NS Package Number N28B

Plastic Chip Carrier


## Functional Description

This product is specifically designed to drive multiplexed or non-multiplexed high voltage alphanumeric or dot matrix vacuum fluorescent (VF) displays. Character generation is done externally in the microprocessor, with a serial data path to the display driver. The MM58242 uses three signals, DATA IN, CLOCK and ENABLE, where ENABLE acts as an external load signal. Display blanking can be achieved by means of the BLANKING CONTROL input, and a logic ' 1 ' will turn off all sections of the display. A block diagram of the MM58242 is shown in Figure 1.
Figure 2 shows the pinout of the MM58242 device, where output 1 (pin 12) is equivalent to bit 1 (i.e., the first bit of data to be loaded into the shift register following ENABLE high). A logic ' 1 ' at the input will turn on the corresponding display digit/segment/dot output.
A significant reduction in discrete board components can be achieved by use of the MM58242, because external pulldown resistors are not required. Due to the nature of the output stage, both its on and off impedance values vary as a function of the display voltage applied, However, Figures 3a and $3 b$ show that this output impedance will remain constant for a fixed value of display voltage.
Figure 4 demonstrates the critical timing requirements between CLOCK and DATA IN for the MM58242.

When the chip first powers on, an internal reset is generated, resetting all registers and latches. The chip returns to normal operation on application of ENABLE, and so all interface signals should be inactive at power on.
In Figure 5, the ENABLE signal acts as an envelope, and only while this signal is at a logic ' 1 ' does the circuit accept CLOCK input signals. Data is transferred and shifted in the internal shift register on the rising clock edge, i.e., ' 0 '-' 1 ' transition. When the ENABLE signal goes low, the contents of the shift registers are latched, and the display will show new data. During data transfer, the display will show old data. DATA OUT is also provided on the MM58242 being output on the falling edge. At any time, the display may be blanked under processor control, using the BLANKING CONTROL input.
Figure 6 shows a schematic diagram of a microprocessorbased system where the MM58242 is used to provide the grid drive for a 40 -digit 2 line $5 \times 7$ multiplexed vacuum fluorescent (VF) display. The anode drive in this example is provided by another member of the high voltage display driver family, namely the MM58248, which does not require an externally generated load signal.


## Timing Diagrams



TL/F/7924-5
For the purposes of $A C$ measurement, $\mathrm{V}_{1 \mathrm{H}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}$.
FIGURE 4. Clock and Data Timings


FIGURE 5. MM58242 Timings (Data Format)

## Typical Application



FIGURE 6. Microprocessor-Controlled Word Processor

## MM58342 High Voltage Display Driver

## General Description

The MM58342 is a monolithic MOS integrated circuit utilizing CMOS metal gate low threshold $P$ - and $N$-channel devices. It is available both in 28 -pin molded dual-in-line packages or as dice. The MM58342 is particularly suited for driving high voltage ( 35 V max) vacuum fluorescent (VF) displays (e.g., a 20 -digit alphanumeric or dot matrix display).

## Applications

- COPSTM or microprocessor-driven displays
- Instrumentation readouts
- Industrial control indicator

■ Digital clock, thermostat, counter, voltmeter

- Word processor text displays
- Automotive dashboards


## Features

- Direct interface to high voltage display
- Serial data input
- No external resistors required
- Wide display power supply operation
- LSTTL compatible inputs
- Software compatible with NS display driver family
- Compatible with alphanumeric or dot matrix displays
- Display blanking control input
- Simple to cascade


## Block Diagram



FIGURE 1

TL/F/7925-1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Voltage at Any Input Pin Voltage at Any Display Pin
$V_{D D}+\left|V_{D I S}\right|$
Storage Temperature
Power Dissipation Junction Temperature
Lead Temperature (Soldering, 10 sec .)
$V_{D D}+0.3 V$ to $V_{S S}-0.3 V$
$V_{D D}$ to $V_{D D}-36.5 \mathrm{~V}$ 36.5 V
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
500 mW at $+85^{\circ} \mathrm{C}$ $130^{\circ} \mathrm{C}$ $260^{\circ} \mathrm{C}$

## Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage $\left(V_{D D}\right)$ <br> $V_{S S}=0 V$ | 4.5 | 5.5 | $V$ |
| Display Voltage $\left(V_{D I S}\right)$ | -30 | -10 | $V$ |
| Temperature Range | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |

## DC Electrical Characteristics

$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ uniess otherwise specified

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IDD } \\ & \text { IDIS } \end{aligned}$ | Power Supply Currents | $V_{I N}=V_{S S} \text { or } V_{D D}, V_{S S}=0 V$ <br> $V_{\text {DIS }}$ Disconnected <br> $\mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DIS}}=-30 \mathrm{~V}$ <br> All Outputs Low |  |  | 150 10 | $\mu \mathrm{A}$ <br> mA |
| $\begin{aligned} & V_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | Input Logic Levels DATA IN, CLOCK ENABLE, BLANK <br> Logic ' 0 ' Logic '1' | (Note 1) | 2.4 |  | 0.8 | $\begin{aligned} & V \\ & v \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OL}}$ <br> $\mathrm{V}_{\mathrm{OH}}$ <br> $\mathrm{V}_{\mathrm{OH}}$ | Data Output Logic Levels <br> Logic ' 0 ' <br> Logic '1' <br> Logic '1' | $\begin{aligned} & \text { I OUT }=400 \mu \mathrm{~A} \\ & \text { I OUT }=-10 \mu \mathrm{~A} \\ & \text { I OUT }=-500 \mu \mathrm{~A} \end{aligned}$ | $\begin{gathered} V_{D D}-0.5 \\ 2.8 \\ \hline \end{gathered}$ |  | 0.4 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| IN | Input Currents DATA IN, CLOCK ENABLE, BLANK | $\mathrm{V}_{I N}=O \mathrm{~V}$ or $\mathrm{V}_{\mathrm{DD}}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{CIN}_{\text {IN }}$ | Input Capacitance DATA IN, CLOCK ENABLE, BLANK |  |  |  | 15 | pF |
| Roff $\mathrm{R}_{\text {ON }}$ | Display Output Impedances Output Off (Figure 3a) <br> Output On (Figure 3b) | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-10 \mathrm{~V} \\ & \mathrm{~V}_{\text {DIS }}=-20 \mathrm{~V} \\ & \mathrm{~V}_{\text {DIS }}=-30 \mathrm{~V} \\ & \mathrm{~V}_{\text {DIS }}=-10 \mathrm{~V} \\ & \mathrm{~V}_{\text {DIS }}=-20 \mathrm{~V} \\ & \mathrm{~V}_{\text {DIS }}=-30 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & 55 \\ & 60 \\ & 65 \end{aligned}$ | $\begin{aligned} & 700 \\ & 600 \\ & 500 \\ & \hline \end{aligned}$ | $\begin{aligned} & 250 \\ & 300 \\ & 400 \\ & 800 \\ & 750 \\ & 680 \\ & \hline \end{aligned}$ | $\begin{gathered} \mathrm{k} \Omega \\ \mathrm{k} \Omega \\ \mathrm{k} \Omega \\ \Omega \\ \Omega \\ \Omega \\ \hline \end{gathered}$ |
| V ${ }_{\text {DOL }}$ | Display Output Low Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \text { IOUT }=\text { Open Circuit, } \\ & -30 \mathrm{~V} \leq \mathrm{V}_{\mathrm{DIS}} \leq-10 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {DIS }}$ |  | $V_{D I S}+2$ | V |

Note 1: 74LSTTL $V_{O H}=2.7 \mathrm{~V} @ \mathrm{I}_{\mathrm{OUT}}=-400 \mu \mathrm{~A}, \mathrm{TTL} \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} @ \mathrm{I}_{\mathrm{OUT}}=-400 \mu \mathrm{~A}$.


Note 2: For timing purposes, the signals ENABLE and BLANK can be considered to be totally independent of each other.
Note 3: AC input waveform specification for test purposes: $t_{r}, t_{f} \leq 20 \mathrm{~ns}, \mathrm{f}=800 \mathrm{kHz}, 50 \% \pm 10 \%$ duty cycle.
Note 4: Clock input rise and fall times must not exceed $5 \mu \mathrm{~s}$.

## Connection Diagrams

Dual-In-Line Package

TL/F/7925-2
Top Vlew
FIGURE 2

Order Number MM58342N
See NS Package Number N28B

## Functional Description

This product is specifically designed to drive multiplexed or non-multiplexed high voltage alphanumeric or dot matrix vacuum fluorescent (VF) displays. Character generation is done externally in the microprocessor, with a serial data path to the display driver. The MM58342 uses three signals, DATA IN, CLOCK and ENABLE, where ENABLE acts as an external load signal. Display blanking can be achieved by means of the BLANKING CONTROL input, and a logic ' 1 ' will turn off all sections of the display. A block diagram of the MM58342 is shown in Figure 1.

Plastic Chip Carrler


TL/F/7925-8
Top View
Order Number MM58342V
See NS Package Number V28A

Figure 2 shows the pinout of the MM58342 device, where output 1 (pin 12) is equivalent to bit 1 (i.e., the first bit of data to be loaded into the shift register following ENABLE high). A logic ' 1 ' at the input will turn on the corresponding display digit/segment/dot output.
A significant reduction in discrete board components can be achieved by use of the MM58342, because external pulldown resistors are not required. Due to the nature of the output stage, both its on and off impedance values vary as a function of the display voltage applied. However, Figures 3a

## Functional Description (Continued)

and $3 b$ show that this output impedance will remain constant for a fixed value of display voltage.
Figure 4 demonstrates the critical timing requirements between CLOCK and DATA IN for the MM58342.
When the chip first powers on, an internal reset is generated, resetting all registers and latches. The chip returns to normal operation on application of ENABLE, and so all interface signals should be inactive at power on.
In Figure 5, the ENABLE signal acts as an envelope, and only while this signal is at a logic ' 1 ' does the circuit accept CLOCK input signals. Data is transferred and shifted in the internal shift register on the rising clock edge, i.e., '0'-'1' transition. When the ENABLE signal goes low, the contents
of the shift registers are latched, and the display will show new data. During data transfer, the display will show old data. DATA OUT is also provided on the MM58342 being output on the falling edge. At any time, the display may be blanked under processor control, using the BLANKING CONTROL input.
Figure 6 shows a schematic diagram of a microprocessorbased system where the MM58342 is used to provide the grid drive for a 40 -digit 2 line $5 \times 7$ multiplexed vacuum fluorescent (VF) display. The anode drive in this example is provided by another member of the high voltage display driver family, namely the MM58348, which does not require an externally generated load signal.


## Timing Diagrams



For the purposes of $A C$ measurement, $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}$.
FIGURE 4. Clock and Data Timings

Timing Diagrams (Continued)


TL/F/7925-6
FIGURE 5. Timings (Data Format)

## Typical Application



TL/F/7925-7
FIGURE 6. Microprocessor-Controlled Word Processor

## MM58348 High Voltage Display Driver

## General Description

The MM58348 is a monolithic MOS integrated circuit utilizing CMOS metal gate low threshold $P$ and $N$-channel devices. It is available both in 40 -pin molded dual-in-line packages or as dice. The MM58348 is particularly suited for driving high voltage ( 35 V max) vacuum fluorescent (VF) displays (e.g., a $5 \times 7$ dot matrix display).

## Features

- Direct interface to high voltage display
- Serial data input
- No external resistors required
- Wide display power supply operation
- LSTTL compatible inputs
- Software compatible with NS display driver family
- Compatible with alphanumeric or dot matrix displays
- No load signal required


## Block Diagram



TL/F/560t-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.

Voltage at Any Input Pin
Voltage at Any Display Pin
$V_{D D}+\left|V_{D I S}\right|$
Storage Temperature
Power Dissipation Junction Temperature Lead Temperature (Soldering, 10 seconds)
$V_{D D}+0.3 V$ to $V_{S S}-0.3 V$
$V_{D D}$ to $V_{D D}-36.5 \mathrm{~V}$ 36.5 V
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
500 mW at $+85^{\circ} \mathrm{C}$
$130^{\circ} \mathrm{C}$
$260^{\circ} \mathrm{C}$

## Operating Conditions

|  | Min | Max | Units |
| :---: | :---: | :---: | :---: |
| Supply Voltage $\left(V_{D D}\right)$   <br> $V_{S S}=0 \mathrm{~V}$   | 4.5 | 5.5 | V |
| Display Voltage $\left(\mathrm{V}_{\mathrm{DIS}}\right)$ | -30 | -10 | V |
| Temperature Range | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |

## DC Electrical Characteristics

$T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ unless otherwise specified.

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IDD | Power Supply Currents | $\begin{aligned} & V_{I N}=V_{S S} \text { or } V_{D D}, V_{D D}=5.5 \mathrm{~V} \\ & V_{S S}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DIS}} \text { Disconnected } \end{aligned}$ |  |  | 150 | $\mu \mathrm{A}$ |
| IDIS |  | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{DIS}}=-30 \mathrm{~V}, \text { All Outputs Low } \end{aligned}$ |  |  | 10 | mA |
| $\mathrm{V}_{\text {IL }}$ | Input Logic Levels DATA IN, CLOCK Logic '0' Logic '1' |  |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ |  |  | 2.4 |  |  | V |
| IN | Input Currents DATA IN, CLOCK | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{DD}}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance DATA IN, CLOCK |  |  |  | 15 | pF |
| Roff | Display Output Impedances Output Off (Figure 3a) | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, V_{S S}=0 \mathrm{~V} \\ & V_{D I S}=-10 \mathrm{~V} \\ & V_{D I S}=-20 \mathrm{~V} \\ & V_{D I S}=-30 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 55 \\ & 60 \\ & 65 \end{aligned}$ |  | $\begin{aligned} & 250 \\ & 300 \\ & 400 \end{aligned}$ | $\begin{aligned} & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \end{aligned}$ |
| RON | Output On (Figure 3b) | $\begin{aligned} & V_{\text {DIS }}=-10 \mathrm{~V} \\ & V_{\text {DIS }}=-20 \mathrm{~V} \\ & V_{\text {DIS }}=-30 \mathrm{~V} \end{aligned}$ |  | $\begin{array}{r} 700 \\ 600 \\ 500 \\ \hline \end{array}$ | $\begin{aligned} & 800 \\ & 750 \\ & 680 \\ & \hline \end{aligned}$ | $\begin{aligned} & \Omega \\ & \Omega \\ & \Omega \\ & \hline \end{aligned}$ |
| $\mathrm{V}_{\text {DOL }}$ | Display Output Low Voltage | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V} \text {, IOUT }=\text { Open Circuit, }, \\ & -30 \mathrm{~V} \leq \mathrm{V}_{\text {DIS }} \leq-10 \mathrm{~V} \end{aligned}$ | V DIS |  | $\mathrm{V}_{\text {DIS }}+2$ | V |

Note 1: 74LSTTL. $V_{O H}=2.7 \mathrm{~V} @ I_{O U T}=-400 \mu \mathrm{~A}, T \mathrm{TL} \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} @ \mathrm{I}_{\mathrm{OUT}}=-400 \mu \mathrm{~A}$.
AC Electrical Characteristic $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}$

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| $f_{C}$ | Clock Input Frequency | (Notes 2 and 3) |  |  | 1.0 | MHz |
| $\mathrm{t}_{\mathrm{H}}$ | Clock Input High Time |  | 300 |  |  | ns |
| $\mathrm{t}_{\mathrm{L}}$ | Clock Input Low Time |  | 300 |  |  | ns |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Input Set-Up Time |  | 100 |  |  | ns |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Input Hold Time |  | 100 |  |  | ns |

Note 2: AC input waveform specification for test purpose: $\mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{f}=1 \mathrm{MHz}, 50 \% \pm 10 \%$ duty cycle.
Note 3: Clock input rise and fall times must not exceed $5 \mu \mathrm{~s}$.

## Connection Diagrams

Dual-In-Line Package


Order Number MM58348N See NS Package Number N40A

## Functional Description

This product is specifically designed to drive multiplexed or non-multiplexed high voltage alphanumeric or dot matrix vacuum fluorescent (VF) displays. Character generation is done externally in the microprocessor, with a serial data path to the display driver. The MM58348 uses two signals, DATA $\mathbb{I N}$ and CLOCK, with a format of a leading " 1 " followed by the 35 data bits, hence allowing data transfer without an additional signal. A block diagram of the MM58348 is shown in Figure 1.
Figure 2 shows the pinout of the MM58348 device, where output 1 (pin 18) is equivalent to bit 1, (i.e., the first bit of

data to be loaded into the shift register following the start bit). A logic " 1 " at the input will turn on the corresponding display digit/segment/dot output.
A significant reduction in discrete board components can be achieved by use of the MM58348, because external pulldown resistors are not required. Due to the nature of the output stage, both its on and off impedance values vary as a function of the display voltage applied. However, Figure 3a and $3 b$ show that this output impedance will remain constant for a fixed value of display voltage.

## Functional Description (Continued)

Figure 4 demonstrates the critical timing requirements between CLOCK and DATA IN for the MM58348.
When the chip first powers on, an internal reset is generated, resetting all registers and latches. The chip returns to normal operation on application of the start bit and the first clock pulse, and so all interface signals should be inactive at power on.
In Figure 5, a start bit of logic " 1 " precedes the 35 bits of data, each bit being accepted on the rising edge of CLOCK, i.e., a "0"-"1" transition. At the 36th clock, a LOAD signal is generated synchronously with the high state of the clock, thus loading the 35 bits of the shift register into the latches. At the low state of the clock, a RESET signal is generated, clearing all bits of the shift register for the next set of data. Hence, a complete set of 36 clock pulses is needed
for the MM58348, or the shift register will not clear. If, at any given time, it is required that the display be cleared under microprocessor control, i.e., without power on reset, then the following flushing routine may be used. Clock in 36 "zeroes", followed by a "one" (start bit), followed by 35 "zeroes". This procedure will completely blank the display.
Figure 6 shows a schematic diagram of a microprocessorbased system where the MM58348 is used to provide the anode drive for a 32 -digit $5 \times 7$ dot matrix vacuum fluorescent (VF) display. The grid drive in this example is provided by another member of the high voltage display driver family, namely the MM58341, which has the additional features of a BLANKING CONTROL pin, a DATA OUT pin, and an EN. ABLE (external load signal) pin.

## Timing Diagrams



TL/F/5601-5 For the purpose of $A C$ measurement, $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}$

FIGURE 4. Clock and Data Timings


TL/F/5601-6
FIGURE 5. MM58348 Timings (Data Format)

## Typical Application



FIGURE 6. Microprocessor-Controlled Word Processor

National Semiconductor Corporation

## MM58341 High Voltage Display Driver

## General Description

The MM58341 is a monolithic MOS integrated circuit utilizing CMOS metal gate low threshold P and N -channel devices. It is available both in 40 -pin molded dual-in-line packages or as dice. The MM58341 is particularly suited for driving high voltage ( 35 V max) vacuum fluorescent (VF) displays, (e.g., a 32 -digit alphanumeric or dot matrix display).

## Applications

- COPSTM or microprocessor-driven displays
- Instrumentation readouts
- Industrial control indicator
- Digital clock, thermostat, counter, voltmeter
- Word processor text displays

■ Automotive dashboards

## Features

- Direct interface to high voltage display
- Serial data input

■ No external resistors required

- Wide display power supply operation
- LSTTL compatible inputs
- Software compatible with NS display driver family
- Compatible with alphanumeric or dot matrix displays
- Display blanking control input
- Simple to cascade


## Block Diagram



TL/F/5603-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Milltary/Aerospace products are not contalned in this datasheet. Refer to the assoclated rellability electrical test specifications document.

| Voltage at Any Input Pin | $V_{D D}+0.3 \mathrm{~V}$ to $\mathrm{V}_{S S}-0.3 \mathrm{~V}$ |
| :--- | ---: |
| Voltage at Any Display Pin | $V_{D D}$ to $\mathrm{V}_{\mathrm{DD}}-36.5 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{DD}}+\left\|\mathrm{V}_{\mathrm{DIS}}\right\|$ | 36.5 V |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Power Dissipation | 500 mW at $+85^{\circ} \mathrm{C}$ |
| Junction Temperature | $130^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, 10 seconds) | $260^{\circ} \mathrm{C}$ |

## DC Electrical Characteristics

$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ unless otherwise specified

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IDD | Power Supply Currents | $V_{I N}=V_{S S} \text { or } V_{D D}, V_{S S}=O V$ <br> $V_{\text {DIS }}$ Disconnected |  |  | 150 | $\mu \mathrm{A}$ |
| IDIS |  | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V} \\ & V_{D I S}=-30 \mathrm{~V}, \text { All Outputs Low } \end{aligned}$ |  |  | 10 | mA |
| VIL | Input Logic Levels DATA IN, CLOCK ENABLE, BLANK Logic ' 0 ' |  |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input Logic Levels DATA IN, CLOCK ENABLE, BLANK Logic '1' | (Note 1) | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Data Output Logic Levels Logic '0' | IOUT $=400 \mu \mathrm{~A}$ |  |  | 0.4 | V |
| V OH | Data Output Logic Levels Logic '1' | IOUT $=-10 \mu \mathrm{~A}$ | $V_{D D}-0.5$ |  |  | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Data Output Logic Levels Logic '1' | IOUT $=-500 \mu \mathrm{~A}$ | 2.8 |  |  | V |
| ${ }_{1} \mathrm{~N}$ | Input Currents DATA IN, CLOCK ENABLE, BLANK | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{DD}}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance DATA IN, CLOCK ENABLE, BLANK |  |  |  | 15 | pF |
| R OFF | Display Output Impedances Output Off (Figure 3a) | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V} \\ & V_{D I S}=-10 \mathrm{~V} \\ & V_{D I S}=-20 \mathrm{~V} \\ & V_{D I S}=-30 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 55 \\ & 60 \\ & 65 \end{aligned}$ |  | $\begin{aligned} & 250 \\ & 300 \\ & 400 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \mathrm{k} \Omega \\ & \hline \end{aligned}$ |
| RON | Display Output Impedances Output On (Figure 3b) | $\begin{aligned} & V_{\text {DIS }}=-10 \mathrm{~V} \\ & V_{\text {DIS }}=-20 \mathrm{~V} \\ & V_{\text {DIS }}=-30 \mathrm{~V} \end{aligned}$ |  | $\begin{aligned} & 700 \\ & 600 \\ & 500 \\ & \hline \end{aligned}$ | $\begin{aligned} & 800 \\ & 750 \\ & 680 \\ & \hline \end{aligned}$ | $\begin{aligned} & \Omega \\ & \Omega \\ & \Omega \end{aligned}$ |
| $\mathrm{V}_{\text {DOL }}$ | Display Output Low Voltage | $\begin{aligned} & V_{D D}=5.5 \mathrm{~V}, \text { IOUT }=\text { Open Circuit, } \\ & -30 \mathrm{~V} \leq \mathrm{V}_{\text {DIS }} \leq-10 \mathrm{~V} \end{aligned}$ | $V_{\text {DIS }}$ |  | $\mathrm{V}_{\text {DIS }}+2$ | V |

Note 1: 74LSTTL $V_{O H}=2.7 \mathrm{~V}$ @ ! OUT $=-400 \mu \mathrm{~A}, \mathrm{TTL} V_{O H}=2.4 \mathrm{~V}$ @ $\mathrm{I}_{\mathrm{OUT}}=-400 \mu \mathrm{~A}$.

AC Electrical Characteristics $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 0.5 \mathrm{~V}$

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{C}}$ | Clock Input Frequency | (Notes 3, 4) |  |  | 800 | kHz |
| $\mathrm{t}_{\mathrm{H}}$ | Clock Input High Time |  | 300 |  |  | ns |
| $t_{L}$ | Clock Input Low Time |  | 300 |  |  | ns |
| $t_{\text {DS }}$ | Data Input Setup Time |  | 100 |  |  | ns |
| ${ }_{\text {t }}{ }_{\text {d }}$ | Data Input Hold Time |  | 100 |  |  | ns |
| tes | Enable Input Setup Time |  | 100 |  |  | ns |
| $\mathrm{t}_{\mathrm{EH}}$ | Enable Input Hold Time |  | 100 |  |  | ns |
| tCDO | Data Output Clock Low to Data Out Time | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  | 500 | ns |

Note 2: Note that, for timing purposes, the signals ENABLE and BLANK can be considered to be totally independent of each other.
Note 3: AC input waveform specification for test purpose: $\mathrm{t}_{\mathrm{r}} \leq 20 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leq 20 \mathrm{~ns}, \mathrm{f}=800 \mathrm{kHz}, 50 \% \pm 10 \%$ duty cycle.
Note 4: Clock input rise and fall times must not exceed $5 \mu \mathrm{~s}$.

## Connection Diagrams



TL/F/5603-2
Top View
Order Number MM58341N See NS Package Number N40A

Plastic Chip Carrier


## Functional Description

This product is specifically designed to drive multiplexed or non-multiplexed high voltage alphanumeric or dot matrix vacuum fluorescent (VF) displays. Character generation is done externally in the microprocessor, with a serial data path to the display driver. The MM58341 uses three signals, DATA IN, CLOCK and ENABLE, where ENABLE acts as an external load signal. Display blanking can be achieved by means of the BLANKING CONTROL input, and a logic ' 1 ' will turn off all sections of the display. A block diagram of the MM58341 is shown in Figure 1.
Figure 2 shows the pinout of the MM58341 device, where output 1 (pin 18) is equivalent to bit 1 (i.e., the first bit of data to be loaded into the shift register following ENABLE high). A logic ' 1 ' at the input will turn on the corresponding display digit/segment/dot output.
A significant reduction in discrete board components can be achieved by use of the MM58341, because external pulldown resistors are not required. Due to the nature of the output stage, both its on and off impedance values vary as a function of the display voltage applied. However, Figures 3a and $3 b$ show that this output impedance will remain constant for a fixed value of display voltage.
Figure 4 demonstrates the critical timing requirements between CLOCK and DATA IN for the MM58341.
When the chip first powers on, an internal reset is generated, resetting all registers and latches. The chip returns to normal operation on application of ENABLE, and so all interface signals should be inactive at power on.
In Figure 5, the ENABLE signal acts as an envelope, and only while this signal is at a logic ' 1 ' does the circuit accept CLOCK input signals. Data is transferred and shifted in the internal shift register on the rising clock edge, i.e., '0'-'1' transition. When the ENABLE signal goes low, the contents of the shift registers are latched, and the display will show new data. During data transfer, the display will show old data. DATA OUT is also provided on the MM58341, being output on the falling edge. At any time, the display may be blanked under processor control, using the BLANKING CONTROL input.
Figure 6 shows a schematic diagram of a microprocessorbased system where the MM58341 is used to provide the grid drive for a 32 -digit $5 \times 7$ dot matrix vacuum fluorescent (VF) display. The anode drive in this example is provided by another member of the high voltage display driver family, namely the MM58348, which does not require an externally generated load signal.

Functional Decription (Continued)


FIGURE 3a. Output Impedance Off


TL/F/5603-4
FIGURE 3b. Output Impedance On
Timing Diagrams


TL/F/5603-5
For the purposes of AC measurements, $\mathrm{V}_{I H}=2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}$.
FIGURE 4. Clock and Data Timings


FIGURE 5. MM58341 Timings (Data Format)

## Typical Application



FIGURE 6. Microprocessor-Controlled Word Processor

# New CMOS Vacuum Fluorescent Drivers Enable Three Chip System to Provide Intelligent Control of Dot Matrix VF Display 

National Semiconductor Corp. Application Note 440
Tom Markman


## INTRODUCTION

Vacuum Fluorescent (VF) displays are becoming more and more common in a variety of applications. Manufacturers of everything from Automobiles to Video Recorders have taken advantage of these easy to read displays. VF displays are available in a wide variety of configurations; clock displays, calculator displays, multi-segment, and dot matrix displays are readily available at a low cost. This application note develops and covers in some detail a small CMOS system consisting of a single chip microcontroller and two display drivers which control a 20 character, $5 \times 7$ dot matrix VF display.
Figure 1 shows the schematic of the system. The microcontroller, a COPSTM 424C, receives a character in ASCII form from the host system, stores the ASCII value of the character in its onboard RAM, converts the ASCII value to a 5 byte data word suitable for the display drivers and displays it on the VF display. The COPS also refreshes the display continuously while performing character update, much like a dumb terminal. Not including the address decoding logic, this application requires only the onboard RAM and ROM of the COPS424C, and National's MM58341 and MM58348 VF display drivers. If a steady message or a scrolling sentence is desired, only small changes in the COPS software are re-
quired. In this case the messages could be stored in the ROM of the COPS and the need for a host system would be eliminated.

## VF DISPLAY AND VF DISPLAY DRIVER REQUIREMENTS

The display used in this application was an Itron \#DC205G2. This 20 segment, $5 \times 7$ dot matrix, multiplexed display required a filament voltage of 5.7 Vac and a filament current of 37 mAac. The anode and grid voltages were supplied by the display drivers. The voltage and current requirements vary considerably for different displays depending on the size and number of characters, and the configuration (dot matrix, 7 segment, 14 segment, etc.). To determine the voltage requirements for a particular display, a simple calculation can be made. If maximum possible brightness of the display is desired, the following equation must be true:
$E_{t} \geq E_{b}+E_{k}+\left(l_{b}\right)\left(R_{o n}\right)$ where:
$E_{t}$ is the total Voltage of the display drvier or $\left|V_{\text {dis }}\right|+V_{d d}$
$E_{k}$ is the display Cathode Bias Voltage
$E_{b}=E_{c}$ is the typical Anode or Grid Voltage (Vpp)
$\mathrm{I}_{\mathrm{b}}$ is the typical anode current (mAp-p)
$R_{o n}$ is the display driver output impedance ( $\Omega$ )


TL/F/8683-1
FIGURE 1. System Diagram Showing the Basic 3-Chip Display Controller and the Interface to a Microprocessor System

If the maximum brightness is not desired, the following equation can be used: $\left(E_{t}\right)(1.2) \geq E_{b}+E_{k}+\left(l_{b}\right)\left(R_{\text {on }}\right)$. In this application, the calculated $E_{t}$ was 42.25 V , however, the display was legible under normal lighting conditions, with an $\mathrm{E}_{\mathrm{t}}$ as low as 25 V . If your display requires more than the 35 V output of the MM58341 and MM58348, pin for pin compatible 60V VF Display Drivers (MM58241, MM58248) are available.
Figure 2 shows the relationship between the required VF display voltages. The cut-off voltage $\left(\mathrm{E}_{\mathrm{k}}\right)$ is set by the Zener diode on the center tap of the filament transformer. This value is given in the VF display data sheet.

## Avoiding Flicker and Pulsing

There are two different conditions which may cause the display to appear to flicker. The first is the refresh rate. This is particularly a problem on displays where the micro-controller must up-date more than 25 characters. Since the human
eye begins to notice flicker at about 40 Hz , a display with a refresh rate less than that will appear to be flashing on and off.
The second type of flicker occurs when the refresh rate is between 40 Hz and 90 Hz . In this case, the display will appear to be rolling rather than flashing. This condition occurs when the refresh rate and the filament frequency are close together. If a character is only on during the time when the filament voltage is negative, it will appear to be slightly brighter than the character next to it which may only be on during the positive cycle of the filament voltage. If this is the case, as it was in this application, the simplest solution is to increase the frequency of the filament. A DC oscillator circuit, such as the one shown in Figure 3, can be used to replace the AC voltage source. The filament frequency can be easily adjusted to eliminate this condition.


TL/F/8683-2
FIGURE 2. Voltage Levels for VF Display


TL/F/8683-3
FIGURE 3. Filament Oscillator Circuit

## VF Display Drivers

Two high voltage display drivers were needed to control the VF display. A MM58341, was used to control the grids and a MM58348 was used to control the individual pixels or anodes. Both of these drivers receive serial information and output 32 and 35 segments of data respectively.
The MM58341 has three control pins which make it ideal for controlling the grids of a VF display. The blanking control pin will turn off all segments of the display when a logic ' 1 ' is applied to this pin. This is particularly important for reducing ghosting, and controlling brightness. Ghosting is a condition where the last characters shadow appears behind the character being displayed. The enable pin acts as an envelope for the input signal. Only while it is at a logic ' 1 ' level will the circuit accept clock inputs. When the pin goes low, all the data is latched and displayed. A data out pin is also provided for cascading. If the display has more than 32 grids, a second grid driver can be cascaded by connecting the data out pin to the input data for the second grid driver.
The MM58348 is a 35 bit shift register and latch which is used to control each pixel or dot. When a leading 1, fol-
lowed by 35 bits of data, is received, the data is latched and displayed. The chip is automatically reset upon power up.

## MULTIPLEXED DISPLAY REFRESH TIMING

Considering first the digit driver (MM58341), it becomes clear that the digits must be enabled or refreshed sequentially and that this process must be continuous regardless if the display data has changed. The data for the MM58341 is simply a 1 followed by 19 zeroes where the 1 is shifted through the internal registers of the MM58341. As each digit is enabled, the corresponding segment data is displayed. To insure that no ghosting effects are seen during the transition between digits, the blanking control is activiated just before the data is latched into the dot or anode driver and deactivated just after the data has been latched. During this time when the blanking control is activated, the grid driver is clocked shifting the 1 to the next location. Figure 4 shows the micro-controller waveforms and the resultant display waveforms for the 20 character display.


FIGURE 4. Timing Diagram

In between digit strobes, the segment data is updated. The first 34 bits of segment data are set up in the dot driver and the blanking signal is activated to disable all 20 digits. The 35th bit of data is clocked in, updating the segments. Since the MM58348 resets its internal shift register each time the data is latched, it can accept all but the final data bit while still displaying the previous digit. The digit driver is then clocked, shifting the digit strobe to the next position. The enable is then brought low, enabling the next digit. Finally blanking control is deactivated and the data displayed.
During the time which the blanking control is high, the order in which the segments or the digits are updated is not critical. Since this occurs while the display is blank. The digit driver may be clocked first, or the segments could be changed first. In general, the philosophy for the driving this VF multiplexed display is outlined in Figure 5.

## HOST INTERFACE AND PROGRAMMING

With a minimal amount of address decoding and an eight bit latch, COPS can be interfaced with a common microprocessor bus. When a character has been input into the host to be displayed, the ASCII value of that character is latched into the eight bit latch (MM74HC373) and is read on the L port (L0-6) of the COPS. The MSB of the ASCII value must be a logic 1. This MSB is the signal to the COPS that a new character is being presented. Once the character has been stored, an interrupt is sent from the COPS to the host through the D-0 port. The COPS checks for a new character being input every $200 \mu \mathrm{~s}$. If a character is being sent, 1 ms is required to store that character in the RAM of the COPS. With the COPS controlling the display, the host micro-processor is not being tied down with character look-up and display refresh. A simple flowchart of the host requirements is shown in Figure 6.

## COPS SOFTWARE

There are four main sections of the COPS software. The first section, the initialization of the RAM, sets up the RAM as shown in Figure 7. A ' 0 ' is stored in all of the LSB positions and a ' 2 ' is stored in all of the MSB positions. Since the COPS is in a constant display loop, this is necessary to insure a blank display. 20 H is the ASCII value of a space. With the RAM set up in this way, a maximum of 28 characters can be stored in RAM. Since the display in this application is only 20 characters long, RAM locations M1,4 to M1,11 and M3,4 to M3,11 are not used. RAM locations 1,12 to 1,15 and 3,12 to 3,15 are used as temporary storage throughout the program and cannot be used for character storage.
The second part of the program, stores the new characters sent by the host CPU in RAM. Once a character has been sent, this section of the program checks the ASCII value of that character to see if it is a control character or a display character. If it is a display character, the character is stored in RAM and an interrupt is sent to the host. There are three control characters which the COPS program will recognize. Cursor forward (ASCII value 08H) moves the cursor forward without destroying the data, cursor backwards (ASCII value 0 CH ) moves the cursor backwards without destroying the data, and return (ASCII value ODH) will clear the display and put the cursor at the beginning of the display. To recognize and store a character, 1 ms is required.
The third part of the program, the display loop, is the heart of the program. Unless a new character has been detected, the program is always in this loop. This section does the


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LSB <br> Chr 1 | LSB <br> Chr 2 | $\begin{aligned} & \text { LSB } \\ & \text { Chr } 3 \end{aligned}$ | $\begin{gathered} \text { LSB } \\ \text { Chr } 4 \end{gathered}$ | $\begin{gathered} \mathrm{LSB} \\ \mathrm{Chr} 5 \end{gathered}$ | $\left\|\begin{array}{c} \mathrm{LSB} \\ \mathrm{Chr} 6 \end{array}\right\|$ | $\begin{array}{\|l\|} \hline \text { LSB } \\ \mathrm{Chr} 7 \end{array}$ | $\begin{array}{\|l\|} \hline \text { LSB } \\ \text { Chr } 8 \end{array}$ | $\begin{gathered} \text { LSB } \\ \text { Chr } 9 \end{gathered}$ | $\begin{gathered} \text { LSB } \\ \text { Chr } 10 \end{gathered}$ | $\begin{aligned} & \text { LSB } \\ & \text { Chr } 11 \end{aligned}$ | $\begin{gathered} \text { LSB } \\ \text { Chr } 12 \end{gathered}$ | $\begin{gathered} \text { LSB } \\ \text { Chr } 13 \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { LSB } \\ \text { Chr } 14 \end{array}$ | LSB <br> Chr 15 | $\begin{gathered} \text { LSB } \\ \text { Chr } 16 \end{gathered}$ |
| MSB <br> Pointer | $\left\|\begin{array}{c} \text { LSB } \\ \text { Pointer } \end{array}\right\|$ | Temp. ASCII STORAGE |  |  |  |  |  |  |  |  |  | $\begin{array}{\|c\|} \hline \text { LSB } \\ \text { Chr } 17 \end{array}$ | $\begin{array}{\|c\|c\|} \hline \text { LSB } \\ \text { Chr } 18 \end{array}$ | $\begin{array}{\|c\|} \hline \text { LSB } \\ \text { Chr } 19 \end{array}$ | $\begin{gathered} \text { LSB } \\ \text { Chr } 20 \end{gathered}$ |
| MSB <br> Chr 1 | MSB <br> Chr 2 | MSB <br> Chr 3 | MSB <br> Chr 4 | $\begin{aligned} & \text { MSB } \\ & \text { Chr } 5 \end{aligned}$ | $\begin{aligned} & \text { MSB } \\ & \text { Chr } 6 \end{aligned}$ | $\begin{aligned} & \text { MSB } \\ & \text { Chr } 7 \end{aligned}$ | $\begin{aligned} & \text { MSB } \\ & \text { Chr } 8 \end{aligned}$ | $\begin{aligned} & \text { MSB } \\ & \text { Chr } 9 \end{aligned}$ | MSB Chr 10 | MSB <br> Chr 11 | $\begin{array}{\|c\|} \hline \text { MSB } \\ \text { Chr } 12 \end{array}$ | MSB Chr 13 | $\begin{gathered} \text { MSB } \\ \text { Chr } 14 \end{gathered}$ | MSB <br> Chr 15 | $\begin{array}{\|c\|} \hline \text { MSB } \\ \text { Chr } 16 \end{array}$ |
| Temp. Storage of Pointer |  |  |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { MSB } \\ \text { Chr } 17 \end{gathered}$ | MSB Chr 18 | MSB Chr 19 | $\begin{array}{\|c\|} \hline \text { MSB } \\ \text { Chr } 20 \end{array}$ |

FIGURE 7. COPS RAM Map

| Matrix | PAD | Column 1 | Column 2 | Column 3 | Column 4 | Column 5 | PAD |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Binary | 0001001111101010001001000010100000111110 |  |  |  |  |  |  |
| Hex. | 13 | EA | 24 | 28 | $3 E$ |  |  |

FIGURE 8
character font look-up, shifts the character data out the COPS serial port to the MM58348, and controls the MM58341 through the four bit parallel port (GO-4). Because the most significant nibble of the program counter is used as part of some COPS instructions, it is important that parts of the program are located at specific locations in ROM.
The final part of the program is the data. Each character is represented by a 5 byte data word. Each byte of the data word is stored at a different location in ROM. Fonts for characters with the ASCII values from $20 \mathrm{H}-5 \mathrm{AH}$ have already been stored in ROM. These characters can be changed or more characters can be added. The only limitation to the number of characters is the amount of available ROM.

## CREATING THE 5 BYTE DATA WORD

Any number or combination of pixels or dots can be turned on at a time. To create a new character, it is easiest to first create a binary string which represents the character. A ' 1 ' in the binary string will turn on the pixel, a ' 0 ' will turn it off. To create this string, start in the upper left corner of the matrix and go down the columns.
The letter 'A' (Figure 9) would have a binary string shown in Figure 8. The data must be padded to make it an even 5 bytes in length. The pad at the beginning of the data (0001) is used as the leading 1 for the MM58348. The one bit pad at the end of the binary string must be a 0 . If a 1 were sent as the pad, it would be used as the start bit for the next character.
The 5 byte data word that would be stored in ROM and represent the letter ' $A$ ' would then be 13EA24283E.

## STORING THE DATA IN ROM

The 5 bytes of data are stored in 5 different locations in ROM. The first byte of data will be stored, LSB first, at location 200 H plus the ASCII value of the character. For example, the ASCII value of the letter ' $A$ ' is 41 H . The first byte of data for the letter ' $A$ ' would be stored, least significant bit first, at 241 H . The second byte of data is stored at the location of the first data byte plus 60 H or in this case at 2A1H. The location of the third byte is 40 H plus the location of the
second byte. In this case, the third byte of data would be stored at 2 E 1 H . The fourth byte of data is stored at 300 H plus the ASCII value of the character or at 341 H for the letter ' $A$ '. The final byte of data is stored 40 H from the fourth byte or at 381H. Remember the LSB of each byte is stored first. Table I shows the locations in ROM and the values stored in them for the letter ' A '.
This application shows a VF display controller designed with a minimum number of IC's. If additional information about VF displays or VF display drivers is required, refer to Application Note AN-371 (The MM58348/ 342/341/248/242/241 direct drive Vacuum Fluorescent (VF) Displays.

## TABLE I. Character Data of ' $A$ ' and Its Locations in ROM

| Address <br> In ROM | Data <br> Stored |
| :---: | :---: |
| 0241 H | 31 |
| $02 \mathrm{A1H}$ | AE |
| 02 E 1 H | 42 |
| 0341 H | 82 |
| 0381 H | E3 |



FIGURE 9. $5 \times 7$ Character as Stored in ROM
.CHIP 424C ;DEFINES COPS CHIP
;THIS SECTION INITIALIZES THE RAM IN THE COPS BY LOADING A ;2 IN THE MSB AND A O IN THE LSB LOCATIONS OF EACH CHARACTER. ;IT ALSO STOPS THE CLOCK AND SETS THE POINTER AT THE FIRST ;CHARACTER OF THE DISPLAY.

RESET
CLRA
LBI 3,15 ;LOADS A 2 IN ALL
JSR CLEAR2 ;MSB LOCATIONS
LBI 2,15 ;LOADS A 2 IN ALL
JSR CLEAR2 ;MSB LOCATIONS
LBI 1,15 ;LOADS A 0 IN ALL
JSR CLEAR ;LSB LOCATIONS
LBI 0,15 ;LOADS A 0 IN ALL
JSR CLEAR ;LSB LOCATIONS
CLRA ;LOADS POINTER IN RAM
XAD 1,15 ;MSB IN 1,0F
CLRA
AISC 15 ;LSB IN 1,OE
XAD 1,14
RC ;RESETS CARRY TO
XAS ; STOP CLOCK
JMP START
CLEAR: CLRA ;CLEARS REGISTORS
XDS 0
JMP CLEAR
RET
CLEAR2: CLRA ;PUTS A 2 IN REGISTORS
AISC 02
XDS 0
JMi CLEAR2
RET

Section 2 of COPS Software
;THIS SECTION OF CODE IS ONLY EXECUTED WHEN A NEW ;CHARACTER HAS BEEN ENTERED. IF THE CHARACTER IS ;A CONTROL CHARACTER, THE CURSOR IS MOVED ACCORDINGLY, ;OTHERWISE THE CHARACTER IS STORED IN THE RAM OF THE COPS.
;NEW CHARACTER HAS BEEN ENTERED
NEW: LBI 1,OC ;DUMMY POINTER
INL ;READS ASCII FROM
XIS $0 \quad$;DATA BUS
X 0
IDD 1,OD
RC ;CHAR. MSB=0 THEN YES
AISC 15 ;MSB $<>0$ THEN NO
JMP SPECIAL
AISC 01
LDD 1,OE ;STORE ASCII IN RAM
CAB
LDD 1,0F
XABR
LDD 1,OC ;MSB IN 1,OC
X 2
LDD $1,0 D$;LSB IN $1, O D$
X 0

Section 2 of COPS Software (Continued)

JSR CURFOR
LBI 0,01
OBD
LBI 0,0
OBD
JMP START
;SPECIAL CHARS. (CR, LF, CLEAR DISPLAY)

CURFOR:

OK :
SKIP:

CURBAC:
GOOD :

SPECIAL:
IDD 1,OC ;CONTROL CHAR. HAS BEEN
AISC 03 ;DETECTED
JMP NOTRET
JMP RESET ;RETURN CLEARS DISPLAY,STARTS ;PROGRAM OVER
NOTRET: AISC 01 ;NOT RETURN, CHECK FOR CURSOR JMP CFOR ;FORWARD JMP CURBAC ;BY DEFAULT, CURSOR BACKWARDS

CFOR:
IDD 1,OE ;MOVES CURSOR FORWARD ONE COMP ;SPACE. IF CURSOR IS AISC 01 ;MOVED BEYOND THE END OF JMP OK ;DISPLAY, IT WRAPS AROUND AISC OF ;TO THE OTHER END. DATA IS XAD 1,0E ;NOT DESTROYED BY MOVING CLRA AISC 01 LBI $1,0 \mathrm{~F}$ XOR JMP SKIP COMP LBI 1,0E X 0 RET
LDD 1,OF ;MOVES CURSOR BACK ONE AISC 01 JMP GOOD LBI 1,0E CLRA AISC 01 XOR X 0 JMP START
XAD 1,0F JMP START

JSR CURFOR JMP START
;DISPLAY LOOP

## Section 3 of COPS Software

;THIS IS THE DISPLAY LOOP OF THE PROGRAM. UNLESS A NEW CHARACTER ;HAS BEEN ENTERED AND IS BEING STORED, THE PROGRAM IS AJWAYS IN ;THIS DISPLAY LOOP. IT LOOKS UP THE CHARACTER FONT, SHIFTS THE ;CHARACTER DATA OUT THE SERIAL PORT AND CONTROLS THE GRID DRIVER.

START: LBI 2,15 ;DISPLAY LOOP POINTER JSR HERE ;GOTO DISPLAY LOOP LBI 3,03 ;SECOND DISPLAY LOOP POINTER JSR HERE ;GOTO DISPLAY LOOP OGI 09 ;LOADS A 1 IN GRID DRIVER OGI OD OGI 09

JMP START
;CHECKS FOR NEW CHAR

HERE : RC
ININ
AISC 15
JMP OLDCHR
JMP NEW
;DISPLAY LOOP FOR OLD CHAR AND ; LOOK UP

| OLDCHR: | ID 2 | ;LOOKS UP FIRST BYTE OF CHR.FONT |
| :---: | :---: | :---: |
|  | JSR DATA4 | ; $200 \mathrm{H}+$ ASCII VALUE |
|  | AISC 06 | ;ADDS 06 H TO MSB OF ASCII |
|  | JSR DATA2 | ;LOOKS UP SECOND BYTE OF CHR FONT |
|  | AISC OA | ;ADDS OAH TO MSB OF ASCII |
|  | JSR DATA2 | ;LOOKS UP THIRD BYTE OF CHR. FONT |
|  | JSR DATA3 | ;LOOKS UP THIRD BYTE OF CHR. FONT |
|  |  | ; AT 300H+ASCII VALUE |
|  | AISC 06 | ;ADDS 06H TO MSB OF ASCII VALUE |
|  | OGI 02 | ;TURNS ON BLANKING CONTROL |
|  | JSR DATA3 | ;LOOKS UP LAST BYTE OF CHR. FONT |

OGI OA ;ENABLE,BLANKING CONTROL OGI OE ;ENABLE,BLANKING CONTROL,CLOCK OGI OA ;ENABLE,BLANKING CONTROL OGI OO ;A O SHIFTED IN

LD 0
XDS 2 JMP HERE RET

RIGHT: IBI 3,15
CQMA
JSR SHIFT ;OUTPUTS A
X 0 ;NEW DATA
JSR SHIFT ;OUTPU'S A LEI 01 ;COUNTER MODE IDD 3,14 ;1,0 IN A XABR ;A IN BR IDD $3,13 \quad ; 1,1$ IN $A$ CAB ;A IN BD LD 2 RET

## Section 3 of COPS Software (Continued)

```
POINTER:
    LEI 01 ;COUNTER MODE
        XAS ;A IN SIO
        XABR ;BR IN A
        AISC 02 ;ADD 2
        XAD 3,14 ;A IN 1,0
        CBA
        XAD 3,13
        LBI 3,15
        XAS
        LEI 08 ;SERIAL MODE
        ;SIO IN A
        JMP RIGHT
    ;SHIFTS OUT SERIAL PORT
SHIFT:
        LEI 08
        SC
        XAS ;THE SERIAL PORT WITH EACH
        NOP ;CLOCK CYCLE
        NOP
        RC
        XAS
        RET
    . =0200
DATA3: IQID
        JMP RIGHT
        LQID
        JMP POINTER
        .=0300
DATA3:
        LQID
        JMP RIGHT
```


## Section 4 of COPS Software

;THE CHARACTER FONTS FOR THE CHARACTERS WITH ASCII VALUES BETWEEN 2OH AND 5AH HAVE BEEN STORED IN THIS SECTION OF THE PROGRAM.

```
    ;DATA FOR FIRST 2 BYTES OF EACH
    ; CHAR.
    .=0220
.WORD 001, 001, 001, 021, 021, OCl, 061, 001
.WORD 031, 001, 041, 011, 001, 011, 001, 001
.WORD 071, 001, 041, 081, 011, 0E1, 031, 081
.WORD 061, 061, 001, 001, 001, 021, 001, 041
.WORD 071, 031, 081, 071, 081, OF1, OF1, 071
.WORD OFl, 081, 081, OFl, OFl, OFl, OFl, 071
.WORD OF1, O71, OFl, 061, 081, OFl, OF1, OFl
.WORD OC1, OCl, O81
```

;DATA FOR SECOND 2 BYTES OF EACH
; CHAR.
. $=0280$
.WORD 000, 000, OCl, OF9, OA4, 095, 02D, 000 .WORD 088, 000, 054, 020, 000, 020, 000, 014 .WORD O1D, 082, 003, 005, 058, 045, OAC, 001 .WORD 02D, 023, 000, 000, 020, 058, 001, 001 .WORD OOD, OAE, OF3, OOD, OF3, O2F, O2F, OOD .WORD 02E, OO3, OOD, O2E, OOE, 08E, 08E, 00D .WORD 02F, OOD, 02F, 025, 001, 00C, 008, OOC .WORD 056, 040, 017
;THIRD 2 BYTES OF DATA FOR EACH CHAR.
. $=02 \mathrm{CO}$
.WORD 000, OE3, 000, OAC, OFB, 040, OA5, 083 .WORD OOA, 002, OF3, OF1, 034, 040, 008, 040 .WORD 046, OF7, O2E, 046, 021, 086, 046, 02E .WORD 046, O46, OAO, OB4, OAO, OAO, 015, 022 .WORD OE6, O42, O4E, 006, OOE, 046, 042, 046 .WORD 040, OF7, 006, OAO, 004, 080, OEO, 006 .WORD 042, 026, 062, 046, OF3, 004, 008, 034 .WORD 040, 070, 046
;FOURTH TWO BYTES OF DATA FOR EACH CHAR.
. $=0320$
.WORD 000, 008, 007, OF7, OAA, 031, 028, 000 .WORD 008, 02A, 049, 080, 000, 080, 000, 001 .WORD 01D, 018, 09C, 09D, 0F7, 01D, 09C, 084 .WORD 09C, OAC, 000, 000, 022, 041, 041, 08C .WORD ODC, 082, 09C, 01C, 01C, 09C, 084, 09C .WORD 080, O1C, OEF, 022, 018, 002, 020, 01C .WORD 084, 02C, OA4, 09C, 00C, 018, 028, 010 .WORD 041, 009, O1D
;LAST BYTES OF DATA FOR EACH CHAR.
. $=0380$
.WORD 000, 000, 000, 082, 084, 064, OAO, 000 .WORD 000, 083, 044, 001, 000, 001, 000, 004 .WORD 0C7, 020, 026, OCC, 080, OC9, OC8, O0E .WORD 0C6, 087, 000, 000, 028, 082, 001, 006 .WORD 027, OE3, OC6, 044, 0C7, 028, 008, OC5 .WORD OEF, 028, 008, 028, 020, OEF, OEF, 0C7 .WORD 006, OA7, 026, OC4, 008, OCF, O8F, OCF .WORD 06C, OOC, O2C
. END

National Semiconductor Corporation


## NMC27C32B 32,768-Bit (4k x 8) UV Erasable CMOS PROM

## Features

## General Description

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

## Block Diagram



Pin Names

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

## Connection Diagram

| $\begin{array}{\|l\|l\|} \hline 27 C 56 \\ 27256 \end{array}$ | $\begin{gathered} 27 \mathrm{C} 128 \\ 27128 \end{gathered}$ | $\begin{array}{\|c} \hline 27 C 64 \\ 2764 \end{array}$ | $\begin{gathered} 27 \mathrm{C} 16 \\ 2716 \end{gathered}$ |
| :---: | :---: | :---: | :---: |
| VPP | VPP | VPP |  |
| A12 | A12 | A12 |  |
| A7 | A7 | A7 | A7 |
| A6 | A6 | A6 | A6 |
| A5 | A5 | A5 | A5 |
| A4 | A4 | A4 | A4 |
| A3 | A3 | A3 | A3 |
| A2 | A2 | A2 | A2 |
| A1 | A1 | A1 | A1 |
| AO | AO | A0 | A0 |
| $0_{0}$ | 00 | 00 | $0_{0}$ |
| $0_{1}$ | 01 | 01 | 01 |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $0_{2}$ |
| GND | GND | GND | GND |

Dual-In-Line Package


| $27 \mathrm{C16}$ | $\mathbf{2 7 C 6 4}$ | $\mathbf{2 7 C 1 2 8}$ | $\mathbf{2 7 C 2 5 6}$ |
| :---: | :---: | :---: | :---: |
| $\mathbf{2 7 1 6}$ | $\mathbf{2 7 6 4}$ | $\mathbf{2 7 1 2 8}$ | $\mathbf{2 7 2 5 6}$ |
|  | $\mathrm{~V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
|  | $\overline{\mathrm{PGM}}$ | $\overline{\mathrm{PGM}}$ | A 14 |
| $\mathrm{~V}_{\mathrm{CC}}$ | NC | A 13 | A 13 |
| A 8 | A 8 | A 8 | AB |
| A 9 | A 9 | A 9 | A 9 |
| VPP | A 11 | A 11 | A 11 |
| $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}}$ |
| A 10 | A 10 | A 10 | A 10 |
| $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ |
| $0_{7}$ | $0_{7}$ | $0_{7}$ | $0_{7}$ |
| $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ |
| $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ |
| $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ |
| $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ |

Top View
Note: National's socket compatible EPROM pin configurations are shown in the blocks adjacent to the NMC27C32B pins.
See NS Package Number J24A-Q

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

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NMC27C32BQ200 | 200 |
| NMC27C32BQ350 | 350 |

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

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

Absolute Maximum Ratings (Note 1)
Speciflcations for Military/Aerospace products are not contalned in this datasheet. Refer to the assoclated rellability electrical test specifications document.
$\begin{array}{lr}\text { Temperature Under Bias } & -10^{\circ} \mathrm{C} \text { to }+80^{\circ} \mathrm{C} \\ \text { Storage Temperature } & -65^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\ \text { All Input Voltages with } & \\ \quad \text { Respect to Ground } & +6.5 \mathrm{~V} \text { to }-0.3 \mathrm{~V} \\ \text { All Output Voltages with } & \\ \text { Respect to Ground } & V_{\mathrm{CC}}+0.3 \mathrm{~V} \text { to GND }-0.3 \mathrm{~V}\end{array}$

## READ OPERATION

## DC Electrical Characteristics

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

## AC Electrical Characteristics

| Symbol | Parameter | Conditions | $\begin{gathered} \text { NMC27C32B } \\ \text { 200, E200 } \end{gathered}$ |  | $\begin{gathered} \text { NMC27C32B } \\ 350, \text { E350 } \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\overrightarrow{C E}=\overrightarrow{O E}=V_{\text {IL }}$ |  | 200 |  | 350 | ns |
| tce | $\overline{\mathrm{CE}}$ to Output Delay | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 200 |  | 350 | ns |
| toe | $\overline{\overline{O E}}$ to Output Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 60 |  | 150 | ns |
| $t_{\text {DF }}$ | $\overline{\mathrm{OE}}$ High to Output Float | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ | 0 | 60 | 0 | 130 | ns |
| tor | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ | 0 |  | 0 |  | ns |

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

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

## AC Test Conditions

$\begin{array}{lr}\text { Output Load } \quad 1 \mathrm{TTL} \text { Gate and } C_{L}=100 \mathrm{pF} \text { (Note 9) } \\ \text { Input Rise and Fall Times } & \leq 20 \mathrm{~ns} \\ \text { Input Pulse Levels } & 0.45 \mathrm{~V} \text { to } 2.4 \mathrm{~V}\end{array}$
Timing Measurement Reference Level
Inputs
Outputs

1 V and 2 V 0.8 V and 2 V

## AC Waveforms



TL/D/8827-3
Note 1: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal supply voltages.
Note 3: This parameter is only sampled and is not $100 \%$ tested.
Note 4: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without inpacting $t_{A C C}$.
Note 5: The tDF compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V
Low to TRI-STATE, the measured $V_{O L 1}(D C)+0.10 \mathrm{~V}$
Note 6: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 7: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $\mathrm{V}_{\mathrm{CC}}$ and GND.
Note 8: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ to avoid latch-up and device damage.
Note 9: 1 TTL Gate: $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$, $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
$C_{L}: 100 \mathrm{pF}$ includes fixture capacitance.

Programming Characteristics $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V} \pm 0.25 \mathrm{~V} \mathrm{~V}_{\mathrm{PP}}=12.2-13.3 \mathrm{~V}$ (Notes 2, 3, \& 4)

| Symbol | Parameter | Condltions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A S}$ | Address Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| toes | OE Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| ${ }_{\text {t }}$ D | Data Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DH }}$ | Data Hold Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| tVR | $V_{\text {PP }}$ Recovery Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| toen | OE Hold Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DV }}$ | Data Valid From $\overline{\text { CE }}$ | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ |  |  | 1 | $\mu \mathrm{s}$ |
| tPRT | $\overline{\text { OE Pulse Rise Time }}$ During Programming |  | 50 |  |  | ns |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{C E}=V_{\mathbb{L}}$ | 0 |  | 130 | ns |
| $t_{\text {PW }}$ | Program Pulse Width |  | 0.5 | 0.5 | 10 | ms |
| IPP | VPP Supply Current During Programming Pulse | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 30 | mA |
| Icc | V CC Supply Current |  |  |  | 10 | mA |

## AC Test Conditions

$V_{C C}$

$$
6 \mathrm{~V} \pm 0.25 \mathrm{~V}
$$

$V_{P P}$
Input Rise and Fall Times

$$
\begin{array}{r}
12.2-13.3 \mathrm{~V} \\
\leq 20 \mathrm{~ns} \\
0.45 \mathrm{~V} \text { to } 2.4 \mathrm{~V}
\end{array}
$$

Timing Measurement Reference Level

Inputs
1 V and 2 V
0.8 V and 2 V

## Programming Waveforms (Note 3)



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


## Functional Description

## DEVICE OPERATION

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

## Read Mode

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

## Standby Mode

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

## Output OR-Tying

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

## Programming

CAUTION: Exceeding 14 V or pin $1\left(\mathrm{~V}_{\mathrm{PP}}\right)$ will damage the NMC27C32B.
Initially, and after each erasure, all bits of the NMC27C32B are in the " 1 " state. Data is introduced by selectively programming " $0 s$ " into the desired bit locations. Although only " $0 s$ " will be programmed, both " 1 s " and " 0 s " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The NMC27C32B is in the programming mode when $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ is at 13 V . It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ and ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{CE}}$ input. A program pulse must be applied at each address location to be programmed. Any location may be programmed at any timeeither individually, sequentially, or at random. The NMC27C32B is designed to be programmed in either of two ways: single pulse programming, where each address is programmed with a 10 ms pulse; or interactive programming, where each address is programmed with a series of 0.5 ms pulses until it verifies (up to a maximum of 20 pulses or 10 ms ). Only the interactive programming method has been tested. The NMC27C32B must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}}$ input.
Programming multiple NMC27C32Bs in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NMC27C32B may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\mathrm{CE}}$ input programs the paralleled NMC27C32B.

## Functional Description (Continued)

## Program Inhlblt

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

## Program Verify

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

## MANUFACTURER'S IDENTIFICATION CODE

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

## ERASURE CHARACTERISTICS

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

## SYSTEM CONSIDERATION

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

TABLE II. Manufacturer's Identification Code

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

TABLE III. Minimum NMC27C32B Erasure Time

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

National Semiconductor Corporation

NMC27C64
65,536-Bit (8k x 8) UV Erasable CMOS PROM

## General Description

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

## Features

- Access time down to 150 ns , microCMOS technology
- Low CMOS power consumption - Active Power: 55 mW max
- Standby Power: 0.55 mW max
- Performance compatible to NSC800 ${ }^{\text {TM }}$ CMOS microprocessor
- Single 5 V power supply
- Extended temperature range ( $\mathrm{NMC27C64E}$ ), $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$, and military temperature range ( $\mathrm{NMC27C64M}$ ), $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$, available
- Pin compatible with NMOS 64k EPROMS
- Fast and reliable programming
- Static operation-no clocks required
- TTL, CMOS compatible inputs/outputs
- TRI-STATE ${ }^{@}$ output


## Block Diagram



## Connection Diagram

| 27 C 512 | 27C256 | 27C128 | 27C32 | 27C16 |
| :---: | :---: | :---: | :---: | :---: |
| 27512 | 27256 | 27128 | 2732 | 2716 |
| A15 | VPP | $V_{\text {PP }}$ |  |  |
| A12 | A12 | A12 |  |  |
| A7 | A7 | A7 | A7 | A7 |
| A6 | A6 | A6 | A6 | A6 |
| A5 | A5 | A5 | A5 | A5 |
| A4 | A4 | A4 | A4 | A4 |
| A3 | A3 | A3 | A3 | A3 |
| A2 | A2 | A2 | A2 | A2 |
| A1 | A1 | A1 | A1 | A1 |
| AO | AO | A0 | A0 | A0 |
| $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ |
| $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ |
| GND | GND | GND | GND | GND |


| Dual-In-Line Package |  |  |
| :---: | :---: | :---: |
| $V_{\text {PP }} \rightarrow 1$ | 28 | $-V_{\text {cc }}$ |
| A12 -2 | 27 | - $\overline{\mathrm{PGM}}$ |
| A7 -3 | 26 | - NC |
| A6 -4 | 25 | - A8 |
| $A 5-5$ | 24 | - A9 |
| $\mathrm{A}_{4}-6$ | 23 | - A11 |
| A3-7 | 22 | - $\overline{\mathbf{O E}}$ |
| A2-8 | 21 | - A10 |
| $A_{1}-9$ | 20 | - $\overline{C E}$ |
| $A 0=10$ | 19 | -07 |
| $\mathrm{O}_{0}-11$ | 18 | $-0_{6}$ |
| $\mathrm{O}_{1}-12$ | 17 | - $0_{5}$ |
| $\mathrm{O}_{2}-13$ | 15 | $0_{4}$ |
| GND 14 | 15 | $-\mathrm{O}_{3}$ |


| $\begin{gathered} 27 C 16 \\ 2716 \end{gathered}$ | $\begin{gathered} 27 \mathrm{C} 32 \\ 2732 \end{gathered}$ | $\begin{array}{\|c} 27 \mathrm{C} 128 \\ 27128 \end{array}$ | $\begin{gathered} 27 \mathrm{C} 256 \\ 27256 \end{gathered}$ | $\left\|\begin{array}{c} 27 C 512 \\ 27512 \end{array}\right\|$ |
| :---: | :---: | :---: | :---: | :---: |
|  |  | $V_{C C}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
|  |  | $\overline{\text { PGM }}$ | A14 | A14 |
| $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | A13 | A13 | A13 |
| A8 | A8 | A8 | A8 | A8 |
| A9 | A9 | A9 | A9 | A9 |
| Vpp | A11 | A11 | A11 | A11 |
| $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ |
| A10 | A10 | A10 | A10 | A10 |
| $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | $\overline{\mathrm{CE}}$ | $\overline{C E}$ | $\overline{\mathrm{CE}} / \overline{\text { PGM }}$ | $\overline{\mathrm{CE}}$ |
| $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ |
| $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ |
| $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ |
| $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ |
| $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ |

TL/D/8634-2
Note: National's socket compatible EPROM pin configurations are shown in the blocks adjacent to the NMC27C64 pins.
Order Number NMC27C64Q
See NS Package Number J28A-Q

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

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NMC27C64Q150 | 150 |
| NMC27C64Q200 | 200 |
| NMC27C64Q250 | 250 |
| NMC27C64Q300 | 300 |


| Extended Temp Range$\left(-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}\right)$ |  |
| :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ |  |
| Parameter/Order Number | Access Time (ns) |
| NMC27C64QE200 | 200 |

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

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

## Absolute Maximum Ratings (Note 1)

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the assoclated rellability electrical test specifications document.

Temperature Under Bias
Storage Temperature
All Input Voltages with Respect to Ground All Output Voltages with

Respect to Ground
$-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

$$
+6.5 \mathrm{~V} \text { to }-0.3 \mathrm{~V}
$$

$V_{C C}+0.3 V$ to GND $-0.3 V$

VPP Supply Voltage with Respect to Ground During Programming $\quad+14.0 \mathrm{~V}$ to -0.3 V
Power Dissipation 1.0W

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

| NMC27C64Q150, 200, 250, 300 | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| NMC27C64QE200 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| NMC27C64QM200, M250 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| V CC $^{\text {Power Supply }}$ | $+5 \mathrm{~V} \pm 10 \%$ |

## READ OPERATION

DC Operating Characteristics

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

AC Electrical Characteristics

| Symbol | Parameter | Conditions | $\begin{gathered} \text { NMC27C64 } \\ 150 \end{gathered}$ |  | $\begin{gathered} \text { NMC27C64 } \\ 200 \text { E200 } \\ \text { M200 } \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { NMC27C64 } \\ 250 \\ \text { M250 } \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { NMC27C64 } \\ 300 \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\begin{aligned} & \overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IH}} \end{aligned}$ |  | 150 |  | 200 |  | 250 |  | 300 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay | $\begin{aligned} & \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IH}} \end{aligned}$ |  | 150 |  | 200 |  | 250 |  | 300 | ns |
| toe | $\overline{\text { OE }}$ to Output Delay | $\begin{aligned} & \overline{\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IH}} \\ & \hline \end{aligned}$ |  | 60 |  | 60 |  | 70 |  | 150 | ns |
| $t_{\text {bF }}$ | $\overline{O E}$ High to Output Float | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IH}} \\ & \hline \end{aligned}$ | 0 | 60 | 0 | 60 | 0 | 60 | 0 | 130 | ns |
| ${ }^{\text {toh }}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | $\begin{aligned} & \overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IH}} \end{aligned}$ | 0 |  | 0 |  | 0 |  | 0 |  | ns |

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

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

## AC Test Conditions

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

## AC Waveforms



Note 1: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: Typical values are for $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and nominal supply voltages.
Note 3: This parameter is only sampled and is not $100 \%$ tested.
Note 4: $\overline{O E}$ may be delayed up to $t_{A C C}{ }^{-t_{O E}}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 5: The tDF compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V
Low to TRI-STATE, the measured $\mathrm{VOLI}_{\mathrm{OL}}$ (DC) +0.10 V
Note 6: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 7: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 8: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ to avoid latch-up and device damage.
Note 9: 1 TTL Gate: $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
CL: 100 pF includes fixture capacitance.
Note 10: $V_{P P}$ may be connected to $V_{C C}$ except during programming.

Programming Characteristics $T_{A}=+25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=6 \mathrm{~V} \pm 0.25 \mathrm{~V} \mathrm{~V}_{\mathrm{PP}}=12.2-13.3 \mathrm{~V}$ (Notes 2, 3, \& 4)

| Symbol | Parameter | Condltions | MIn | Typ | Max | Unlts |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| toes | OE Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| tCes | CE Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {D }}$ | Data Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {DH }}$ | Data Hold Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {dF }}$ | Output Enable to Output Float Delay | $\overline{C E}=V_{\text {IL }}$ | 0 |  | 130 | ns |
| toe | Output Enable to Output Delay | $\overline{C E}=V_{I L}$ |  |  | 150 | ns |
| tpw | Program Pulse Width |  | 0.5 | 0.5 | 10 | ms |
| Ipp | VPp Supply Current During Programming Pulse | $\overline{C E}=V_{\text {IL }}$ |  |  | 30 | mA |
| Icc | $V_{\text {CC }}$ Supply Current |  |  |  | 10 | mA |

## AC Test Conditions

| $V_{C C}$ | $6 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |
| :--- | ---: |
| $V_{P P}$ | $12.2-13.3 \mathrm{~V}$ |
| Input Rise and Fall Times | $\leq 20 \mathrm{~ns}$ |
| Input Pulse Levels | 0.45 V to 2.4 V |

## Timing Measurement Reference Level

Inputs
Outputs

1 V and 2 V
0.8 V and 2 V

## Programming Waveforms (Note 3)



TL/D/8634-4
Note: All times shown in parentheses are minimum and in $\mu \mathrm{s}$ unless otherwise specified.
The input timing reference level is 1 V for a $\mathrm{V}_{\mathrm{IL}}$ and 2 V for a $\mathrm{V}_{\mathrm{IH}}$.
$t_{O E}$ and $t_{D F}$ are characteristics of the device but must be accommodated by the programmer.

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

INTERACTIVE PROGRAMMING FLOW CHART


## Functional Description

## DEVICE OPERATION

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

## Read Mode

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

## Standby Mode

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

## Output OR-Tying

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

## Programming

CAUTION: Exceeding 14 V on pin $1\left(\mathrm{~V}_{\mathrm{Pp}}\right)$ will damage the NMC27C64.
Initially, and after each erasure, all bits of the NMC27C64 are in the " 1 " state. Data is introduced by selectively programming " $0 s$ s" into the desired bit locations. Although only "Os" will be programmed, both " $1 s$ " and " $0 s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The NMC27C64 is in the programming mode when the VPP power supply is at 13.0 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{1 \mathrm{H}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
For programming, $\overline{C E}$ should be kept TTL low at all times while $V_{P P}$ is kept at 13.0 V
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{PGM}}$ input. A program pulse must be applied at each address location to be programmed. You can program any location at any time-either individually, sequentially, or at random. The NMC27C64 is designed to be programmed in either of two ways: single pulse programming, where each address is programmed with a 10 ms pulse; or interactive programming, where each address is programmed with a series of 0.5 ms pulses until it verifies (up to a maximum of 20 pulses or 10 ms ). Only the interactive programming method has been tested. The NMC27C64 must not be programmed with a DC signal applied to the $\overline{\text { PGM }}$ input.
Programming multiple NMC27C64s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NMC27C64s may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\mathrm{PGM}}$ input programs the paralleled NMC27C64s.

TABLE I. Mode Selection

| Pins <br> Mode | $\begin{aligned} & \overline{C E} \\ & \text { (20) } \end{aligned}$ | $\begin{aligned} & \overline{O E} \\ & (22) \end{aligned}$ | $\overline{\text { PGM }}$ <br> (27) | $V_{\text {PP }}$ <br> (1) | $V_{C C}$ <br> (28) | $\begin{aligned} & \text { Outputs } \\ & (11-13,15-19) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\text {IL }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 5 | 5 | DOUT |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 5 | 5 | Hi-Z |
| Program | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{1 H}$ | Pulsed $\mathrm{V}_{\text {IH }}$ to $\mathrm{V}_{\text {IL }}$ | 13.0 | 6 | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $\mathrm{V}_{\text {It }}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | 13.0 | 6 | DOUT |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | X | X | 13.0 | 6 | $\mathrm{Hi}-\mathrm{Z}$ |

$X$ can be either $V_{I L}$ or $V_{I H}$

## Functional Description (Continued)

## Program Inhiblt

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

## Program Verify

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

## MANUFACTURER'S IDENTIFICATION CODE

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

## ERASURE CHARACTERISTICS

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

## SYSTEM CONSIDERATION

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

TABLE II. Manufacturer's Identification Code

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

TABLE III. Minimum NMC27C64 Erasure Time

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

## NMC27C256

## 262,144-Bit (32k x 8) UV Erasable CMOS PROM

## General Description

The NMC27C256 is a high-speed 256 k UV erasable and electrically reprogrammable CMOS EPROM, ideally suited for applications where fast turnaround, pattern experimentation and low power consumption are important requirements.

The NMC27C256 is designed to operate with a single +5 V power supply with $\pm 5 \%$ or $\pm 10 \%$ tolerance. The CMOS design allows the part to operate over Extended and Military Temperature Ranges.
The NMC27C256 is packaged in a 28 -pin dual in-line package with transparent lid. The transparent lid allows the user to expose the chip to ultraviolet light to erase the bit pattern. A new pattern can then be written electrically into the device by following the programming procedure.
This EPROM is fabricated with National's proprietary, time proven microCMOS double-poly silicon gate technology which combines high performance and high density with low power consumption and excellent reliability.

## Features

- Access time down to 170 ns , microCMOS technology
- Low CMOS power consumption - Active Power: 55 mW max
- Standby Power: 0.55 mW max

■ Performance compatible to NSC800TM CMOS microprocessor

- Single 5V power supply
- Extended temperature range ( NMC 27 C 256 E ), $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$, and military temperature range (NMC27C256M), $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$, available
- Pin compatible with NMOS 256 k EPROMS
- Fast and reliable programming ( 0.5 ms for most bytes)
- Static operation-no clocks required
- TTL, CMOS compatible inputs/outputs
- TRI-STATE ${ }^{\circledR}$ output


## Block Diagram



| Pin Names |  |
| :--- | :--- |
| $\mathrm{AO}-\mathrm{A} 14$ Addresses <br> $\overline{\mathrm{CE}}$ Chip Enable <br> $\overline{\mathrm{OE}}$ Output Enable <br> $\mathrm{O}_{0}-\mathrm{O}_{7}$ Outputs <br> $\overline{\mathrm{PGM}}$ Program <br> NC No Connect |  |

Connection Diagram

| $\left.\begin{gathered} 27 C 512 \\ 27512 \end{gathered} \right\rvert\,$ | 27C128 | $27 \mathrm{C64}$ | $\begin{gathered} 27 \mathrm{C} 32 \\ 2732 \end{gathered}$ | $\left\|\begin{array}{r} 27 C 16 \\ 2716 \end{array}\right\|$ | Dua | age |  | $\begin{gathered} 27 \text { C16 } \\ 2716 \end{gathered}$ | $\begin{gathered} 27 \mathrm{C} 32 \\ 2732 \end{gathered}$ | $\begin{gathered} 27 C 64 \\ 2764 \end{gathered}$ | $\begin{array}{\|c} \hline 27 C 128 \\ 27128 \end{array}$ | $\begin{gathered} 27 C 512 \\ 27512 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A15 | $V_{\text {PP }}$ | VPP |  |  | $v_{P P}-1$ | 28 | $V_{\text {cc }}$ |  |  | $\mathrm{V}_{\mathrm{CC}}$ | $V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| A12 | A12 | A12 |  |  | A12 -2 | 27 | A14 |  |  | $\overline{\text { PGM }}$ | $\overline{\text { PGM }}$ | A14 |
| A7 | A7 | A7 | A7 | A7 | A7 -3 | 26 | A13 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | NC | A13 | A13 |
| A6 | A6 | A6 | A6 | A6 | $\mathrm{A}_{6}$ - $^{4}$ | 25 | A8 | A8 | A8 | A8 | A8 | A8 |
| A5 | A5 | A5 | A5 | A5 | AS -5 | 24 | - A9 | A9 | A9 | A9 | A9 | A9 |
| A4 | A4 | A4 | A4 | A4 | A4 | 23 | A11 | $V_{\text {PP }}$ | A11 | A11 | A11 | A11 |
| A3 | A3 | A3 | A3 | A3 | 7 | 22 | - $\overline{0}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ | $\overline{O E}$ | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ |
| A2 | A2 | A2 | A2 | A2 | 8 | 21 | A10 | A10 | A10 | A10 | A10 | A10 |
| A1 | A1 | A1 | A1 | A1 | ${ }^{9}$ | 20 | - प्ट/P/PM | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ | $\overline{C E}$ | $\overline{\mathrm{CE}}$ |
| AO | A0 | AO | A0 | A0 | ${ }^{10}$ | 19 | $0_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ |
| $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | - 11 | 18 | $-0_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ |
| $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $-12$ | 17 | $0_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | -13 | 16 | $0_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ |
| GND | GND | GND | GND | GND | GND-14 |  | $-\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ |

TL/D/7512-2
Note: National's socket compatible EPROM pin configurations are shown in the blocks adjacent to the NMC27C256 pins.
Order Number NMC27C256Q
See NS Package Number J28A-Q

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

$V_{C C}=5 \mathrm{~V} \pm 5 \%$

| Parameter/Order Number | Access Time |
| :--- | :---: |
| NMC27C256Q17 | 170 |

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

| Parameter/Order Number | Access Time |
| :--- | :---: |
| NMC27C256QE250 | 250 |

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

| Parameter/Order Number | Access Time |
| :--- | :---: |
| NMC27C256Q200 | 200 |
| NMC27C256Q250 | 250 |
| NMC27C256Q300 | 300 |

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

| Parameter/Order Number | Access Time |
| :--- | :---: |
| NMC27C256QM250 | 250 |
| NMC27C256QM350 | 350 |

## COMMERCIAL TEMPERATURE RANGE

Absolute Maximum Ratings (Note 1)
Temperature Under Bias
Storage Temperature All Input Voltages with Respect to Ground All Output Voltages with Respect to Ground
$V_{\text {Pp }}$ Supply Voltage with Respect to Ground During Programming Power Dissipation

$$
\begin{array}{r}
-10^{\circ} \mathrm{C} \text { to }+80^{\circ} \mathrm{C} \\
-65^{\circ} \mathrm{C} \text { to }+125^{\circ} \mathrm{C} \\
+6.5 \mathrm{~V} \text { to }-0.3 \mathrm{~V}
\end{array}
$$

$\mathrm{V}_{\mathrm{CC}}+0.3$ to $\mathrm{GND}-0.3 \mathrm{~V}$

Lead Temperature (Soldering, 10 sec. )

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

$$
1.0 \mathrm{~W}
$$

$300^{\circ} \mathrm{C}$

Operating Conditions (Note 7)

| Temperature Range | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| $V_{\text {CC }}$ Power Supply |  |
| NMC27C256Q17 | $5 \mathrm{~V} \pm 5 \%$ |
| NMC27C256Q200, 250,300 | $5 \mathrm{~V} \pm 10 \%$ |

## READ OPERATION

DC Electrical Characteristics

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

AC Electrical Characteristics (Note 11)

| Symbol | Parameter | Conditions | $\begin{gathered} \text { NMC27C256 } \\ 17 \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { NMC27C256 } \\ 200 \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { NMC27C256 } \\ 250 \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { NMC27C256 } \\ 300 \\ \hline \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 170 |  | 200 |  | 250 |  | 300 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay | $\overline{O E}=V_{\text {IL }}$ |  | 170 |  | 200 |  | 250 |  | 300 | ns |
| toe | $\overline{\text { OE }}$ to Output Delay | $\overline{C E}=V_{\text {IL }}$ |  | 75 |  | 75 |  | 100 |  | 120 | ns |
| tof | $\overline{\mathrm{OE}}$ High to Output Float | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 | 60 | 0 | 60 | 0 | 60 |  | 105 | ns |
| tOH | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 0 |  | 0 |  | 0 |  | ns |

## MILITARY AND EXTENDED TEMPERATURE RANGE

Absolute Maximum Ratings (Note 1)
Temperature Under Bias
Storage Temperature All Input Voltages with

Respect to Ground
All Output Voltages with Respect to Ground
$V_{C C}+0.3 \mathrm{~V}$ to $\mathrm{GND}-0.3 \mathrm{~V}$
$V_{\text {Pp }}$ Supply Voltage with Respect to Ground During Programming Power Dissipation Lead Temperature (Soldering, 10 sec .)
+14.0 V to -0.3 V
1.0 W
$300^{\circ} \mathrm{C}$

## Operating Conditions (Note 7)

Temperature Range

| NMC27C256QE250 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| :---: | ---: |
| NMC27C256QM250, M350 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| VCC Power Supply | $5 \mathrm{~V} \pm 10 \%$ |

## READ OPERATION

DC Operating Characteristics

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

## AC Electrical Characteristics

| Symbol | Parameter | Conditions | $\begin{gathered} \text { NMC27C256 } \\ \text { E250 } \\ \text { M250 } \\ \hline \end{gathered}$ |  | NMC27C256 M350 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |  | 250 |  | 350 | ns |
| $\mathrm{t}_{\text {CE }}$ | $\overline{C E}$ to Output Delay | $\overline{O E}=V_{\text {IL }}$ |  | 250 |  | 350 | ns |
| toe | $\overline{\text { OE to Output Delay }}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |  | 100 |  | 120 | ns |
| $t_{\text {DF }}$ | $\overline{\mathrm{OE}}$ High to Output Float | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 | 60 | 0 | 105 | ns |
| ${ }^{\text {toh }}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{O E}$, Whichever Occurred First | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 0 |  | ns |

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

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

## AC Test Conditions

| Output Load $\quad 1 \mathrm{TTL}$ Gate and $C_{L}=100 \mathrm{pF}($ Note 9$)$ |  |
| :--- | ---: |
| Input Rise and Fall Times | $\leq 20 \mathrm{~ns}$ |
| Input Pulse Levels | 0.45 V to 2.4 V |


| Timing Measurement Reference Level |  |
| :--- | ---: |
| Inputs | 1 V and 2 V |
| Outputs | 0.8 V and 2 V |

## AC Waveforms



Note 1: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: Typical values are for $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and nominal supply voltages.
Note 3: This parameter is only sampled and is not $100 \%$ tested.
Note 4: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 5: The tof compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} 1}$ (DC) +0.10 V
Note 6: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 7: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between VCC and GND.
Note 8: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ to avoid latch-up and device damage.
Note 9: 1 TTL Gate: $\mathrm{IOL}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
CL: 100 pF includes fixture capacitance.
Note 10: $\mathrm{V}_{\mathrm{PP}}$ may be connected to $\mathrm{V}_{\mathrm{CC}}$ except during programming.
Note 11: All parameters in nanoseconds.

## Programming Characteristics

$\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{PP}}=12.2 \mathrm{~V}$ to 13.3 V (Notes 2, 3, \& 4)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Set-Up Time }}$ |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Set-Up Time |  | 2 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 130 | ns |
| toe | Output Enable to Output Delay | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 150 | ns |
| tpW | Program Pulse Width |  | 0.5 | 0.5 | 10 | ms |
| Ipp | VPP Supply Current During Programming Pulse | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 30 | mA |
| ICC | $V_{\text {CC }}$ Supply Current |  |  |  | 10 | mA |

## AC Test Conditions

$V_{C C}$
$V_{P P}$
Input Rise and Fall Times
Input Pulse Levels
$6 \mathrm{~V} \pm 0.25 \mathrm{~V}$
12.2V to 13.3 V
$\leq 20 \mathrm{~ns}$
0.45 V to 2.4 V

Timing Measurement Reference Level Inputs

1 V and 2 V
0.8 V and 2 V

## Programming Waveforms (Note 3)



TL/D/7512-4
Note: All times shown in parentheses are minimum and in $\mu \mathrm{s}$ unless otherwise specified.

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


## Functional Description

## DEVICE OPERATION

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

## Read Mode

The NMC27C256 has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable (OE) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{C E}$ to output ( $\mathrm{t} C \mathrm{E}$ ). Data is available at the outputs 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 NMC27C256 has a standby mode which reduces the active power dissipation by $99 \%$, from 55 mW to 0.55 mW . The NMC27C256 is placed in the standby mode by applying a CMOS high signal to the $\overline{\mathrm{CE}}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{O E}$ input.

## Output OR-Tying

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

## Programming

CAUTION: Exceeding 14 V on pin 1 ( $\mathrm{V}_{\mathrm{PP}}$ ) will damage the NMC27C256.
Initially, and after each erasure, all bits of the NMC27C256 are in the " 1 " state. Data is introduced by selectively programming " $0 s$ " into the desired bit locations. Although only "Os" will be programmed, both " 1 s " and " $0 s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The NMC27C256 is in the programming mode when the VPP power supply is at 13.0 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $V_{P P}, V_{C C}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ input. A program pulse must be applied at each address location to be programmed. You can program any location at any time-either individually, sequentially, or at random. The NMC27C256 is designed to be programmed in either of two ways: single pulse programming, where each address is programmed with a 10 ms pulse; or interactive programming, where each address is programmed with a series of 0.5 ms pulses until it verifies (up to a maximum of 20 pulses or 10 ms ). Only the interactive programming method has been tested. The NMC27C256 must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ input.
Programming multiple NMC27C256s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NMC27C256s may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ input programs the paralleled NMC27C256s.

TABLE I. Mode Selection

| Pins <br> Mode | $\overline{\text { CE }} / \overline{\text { PGM }}$ <br> (20) | $\begin{array}{r} \overline{O E} \\ (22) \\ \hline \end{array}$ | $V_{\text {PP }}$ <br> (1) | $V_{c c}$ <br> (28) | $\begin{gathered} \text { Outputs } \\ (11-13,15-19) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}$ | 5 | Dout |
| Standby | $\mathrm{V}_{1}$ | Don't Care | $\mathrm{V}_{\mathrm{CC}}$ | 5 | $\mathrm{Hi}-\mathrm{Z}$ |
| Program | Pulsed $\mathrm{V}_{\text {IH }}$ to $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 13.0 | 6 | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $\mathrm{V}_{1 \mathrm{H}}$ | $\mathrm{V}_{\mathrm{IL}}$ | 13.0 | 6 | Dout |
| Program Inhibit | $\mathrm{V}_{1 H}$ | $\mathrm{V}_{\mathrm{IH}}$ | 13.0 | 6 | Hi-Z |

## Functional Description (Continued)

## Program Inhibit

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

## Program Verify

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

## ERASURE CHARACTERISTICS

The erasure characteristics of the NMC27C256 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range. Data shows that constant exposure to room-level fluorescent lighting could erase the typical NMC27C256 in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the NMC27C256 is to be exposed to these types of lighting conditions for extended periods of time, opaque lables should be placed over the NMC27C256's window to prevent unintentional erasure. Covering the window will also prevent temporary functional failure due to the generation of photo currents.
The recommended erasure procedure for the NMC27C256 is exposure to short wave ultraviolet light which has a wavelength of 2537 Angstroms ( $\AA$ ). The integrated dose (i.e., UV intensity $x$ exposure time) for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$.

The NMC27C256 should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure. Table II shows the minimum NMC27C256 erasure time for various light intensities.
An erasure system should be calibrated periodically. The distance from lamp to unit should be maintained at one inch. The erasure time increases as the square of the distance. (If distance is doubled the erasure time increases by a factor of 4.) Lamps lose intensity as they age. When a lamp is changed, the distance has changed or the lamp has aged, the system should be checked to make certain full erasure is occurring. Incomplete erasure will cause symptoms that can be misleading. Programmers, components, and even system designs have been erroneously suspected when incomplete erasure was the problem.

## SYSTEM CONSIDERATION

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

TABLE II. Minimum NMC27C256 Erasure Time

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



## NMC27C512

## 524,288-Bit (64k x 8) UV Erasable CMOS PROM

## General Description

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

## Features

- Access time down to 200 ns , microCMOS technology
- Low CMOS power consumption
- Active Power: 55 mW max
- Standby Power: 0.55 mW max
- Performance compatible to NSC800TM CMOS microprocessor
- Single 5 V power supply
- Extended temperature range (NMC27C512E), $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$, and military temperature range (NMC27C512M), $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$, available
- Pin compatible with NMOS 512k EPROMS
- Fast and reliable programming ( 0.5 ms for most bytes)
- Static operation-no clocks required
- TTL, CMOS compatible inputs/outputs
- TRI-STATE® output


## Block Diagram



| Pln Names |  |
| :--- | :--- |
| $\mathrm{AO}-\mathrm{A} 15$ Addresses <br> $\overline{\mathrm{CE}}$ Chip Enable <br> $\overline{\mathrm{OE}}$ Output Enable <br> $\mathrm{O}_{0}-\mathrm{O}_{7}$ Outputs <br> $\overline{\mathrm{PGM}}$ Program <br> NC No Connect |  |

## Connection Diagram

| $\begin{gathered} 27 C 256 \\ 27256 \end{gathered}$ | $\left\|\begin{array}{c} 27 C 128 \\ 27128 \end{array}\right\|$ | $27 \mathrm{C64}$ | $\begin{gathered} 27 \mathrm{C} 32 \\ 2732 \end{gathered}$ | $\begin{array}{r} 27 C 16 \\ 2716 \end{array}$ | Dua | age |  | $\begin{gathered} 27 C 16 \\ 2716 \end{gathered}$ | $\begin{gathered} 27 \mathrm{C} 32 \\ 2732 \end{gathered}$ | $\begin{gathered} 27 C 64 \\ 2764 \end{gathered}$ | $\left.\begin{array}{\|c} 27 C 128 \\ 27128 \end{array} \right\rvert\,$ | $\begin{gathered} 27 C 256 \\ 27256 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {PP }}$ | $V_{\text {PP }}$ | $V_{\text {PP }}$ |  |  | A15-1 | 28 | $V_{c c}$ |  |  | $V_{\text {cc }}$ | $V_{C C}$ | $V_{\text {CC }}$ |
| A12 | A12 | A12 |  |  | A12 - 2 | 27 | - A14 |  |  | $\overline{\text { PGM }}$ | $\overline{\text { PGM }}$ | A14 |
| A7 | A7 | A7 | A7 | A7 | $\mathrm{A}_{7} \mathrm{H}^{3}$ | 26 | A13 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{C C}$ | NC | A13 | A13 |
| A6 | A6 | A6 | A6 | A6 | $\mathrm{A}_{6}{ }^{4}$ | 25 | A8 | AB | A8 | A8 | A8 | A8 |
| A5 | A5 | A5 | A5 | A5 | $\mathrm{A}_{5}-5$ | 24 | - ${ }^{\text {a }}$ | A9 | A9 | A9 | A9 | A9 |
| A4 | A4 | A4 | A4 | A4 | - | 23 | - A11 | $V_{\text {PP }}$ | A11 | A11 | A11 | A11 |
| A3 | A3 | A3 | A3 | A3 | 7 | 22 |  | $\overline{\mathrm{OE}}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ | $\overline{O E}$ | $\overline{O E}$ | OE |
| A2 | A2 | A2 | A2 | A2 | -8 | 21 | - A10 | A10 | A10 | A10 | A10 | A10 |
| A1 | A1 | A1 | A1 | A1 | -9 | 20 | - CE | CE/PGM | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}} / \overline{\mathrm{PGM}}$ |
| AO | A0 | A0 | A0 | AO | ${ }^{10}$ | 19 | $-0_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ | $\mathrm{O}_{7}$ |
| $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | $\mathrm{O}_{0}$ | - 11 | 18 | $-0_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ | $\mathrm{O}_{6}$ |
| $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{1}$ | -12 | 17 | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ | $\mathrm{O}_{5}$ |
| $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{2}$ | ${ }^{13}$ | 16 | 04 | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ | $\mathrm{O}_{4}$ |
| GND | GND | GND | GND | GND | GND-14 | 15 | $-0_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ | $\mathrm{O}_{3}$ |

TL/D/8754-2
Note: National's socket compatible EPROM pin configurations are shown in the blocks adjacent to the NMC27C512 pins.
See NS Package Number J28A-Q

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

$V_{C C}=5 \mathrm{~V} \pm 5 \%$

| Parameter/Order Number | Access TIme |
| :--- | :---: |
| NMC27C512Q20 | 200 |

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

| Parameter/Order Number | Access Time |
| :--- | :---: |
| NMC27C512Q250 | 250 |
| NMC27C512Q300 | 300 |
| NMC27C512Q350 | 350 |


| Extended Temp Range <br> $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ <br> $V_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ |  |
| :--- | :---: |
| Parameter/Order Number |  |
| NMC27C512QE250 |  | Access Time $\quad$| 250 |
| :---: | :---: |


| Military Temp Range <br> $\left(-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$ |  |
| :--- | :---: |
| $V_{C C}=5 \mathrm{~V} \pm 10 \%$ |  | | Parameter/Order Number | Access Time |
| :---: | :---: |
| NMC27C512QM350 | 350 |


#### Abstract

Absolute Maximum Ratings (Note 1) Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document. Temperature Under Bias Operating Temp Range Storage Temperature $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ All Input Voltages with Respect to Ground All Output Voltages with Respect to Ground $V_{P P}$ and A9 Supply Voltage with Respect to Ground $V_{C C}+0.3$ to $G N D-0.3 \mathrm{~V}$ | Power Dissipation | +14.0 V to -0.3 V |
| :--- | ---: |
| Lead Temperature (Soldering, 10 sec.$)$ | 1.0 W |
|  | $300^{\circ} \mathrm{C}$ |


## Operating Conditions (Note 7)

Temperature Range

| NMC27C512Q20,250,300,350 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| NMC27C512QE250 | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| NMC27C512QM350 | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| V $_{\text {CC }}$ Power Supply | $5 \mathrm{~V} \pm 10 \%$ |
| except NMC27C572Q20 | $5 \mathrm{~V} \pm 5 \%$ |

## READ OPERATION

## DC Electrical Characteristics

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

## AC Electrical Characteristics

| Symbol | Parameter | Conditions | $\begin{gathered} \text { NMC27C512 } \\ 20 \end{gathered}$ |  | $\begin{aligned} & \text { NMC27C512 } \\ & 250, \text { E250 } \end{aligned}$ |  | $\begin{gathered} \text { NMC27C512 } \\ 300 \end{gathered}$ |  | $\begin{gathered} \text { NMC27C512 } \\ 350 \\ \text { M350 } \\ \hline \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 200 |  | 250 |  | 300 |  | 350 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay | $\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |  | 200 |  | 250 |  | 300 |  | 350 | ns |
| toe | $\overline{\text { OE }}$ to Output Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 75 |  | 100 |  | 120 |  | 120 | ns |
| $t_{\text {DF }}$ | $\overline{\mathrm{OE}}$ High to Output Float | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ | 0 | 60 | 0 | 60 |  | 105 |  | 105 | ns |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$, Whichever Occurred First | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 0 |  | 0 |  | 0 |  | ns |

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

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

## AC Test Conditions

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

## AC Waveforms



TL/D/8754-3
Note 1: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: Typical values are for $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ and nominal supply voltages.
Note 3: This parameter is only sampled and is not $100 \%$ tested.
Note 4: $\overline{O E}$ may be delayed $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 5: The tompare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}(\mathrm{DC})-0.10 \mathrm{~V}$
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} 1}$ (DC) +0.10 V
Note 6: TRI-STATE may be attained using $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$.
Note 7: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 8: The outputs must be restricted to $V_{C C}+0.3 \mathrm{~V}$ to avoid latch-up and device damage.
Note 9: 1 TTL Gate: $\mathrm{IOL}_{\mathrm{OL}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.

## Programming Characteristics

$\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{PP}}=12.2 \mathrm{~V}$ to 13.3 V (Notes 2, 3, \& 4)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Set-Up Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{\text { OE Set-Up Time }}$ |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Set-Up Time |  | 2 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 130 | ns |
| tpw | Program Pulse Width |  | 0.5 | 0.5 | 10 | ms |
| Ipp | VPp Supply Current During Programming Pulse | $\begin{aligned} & \overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}} \\ & \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{PP}} \end{aligned}$ |  |  | 30 | mA |
| ICC | $V_{C C}$ Supply Current |  |  |  | 10 | mA |
| toen | $\overline{\text { OE Hold Time }}$ |  | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{D V}$ | Data Valid from $\overline{\mathrm{CE}}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 1 | $\mu \mathrm{s}$ |
| $t_{\text {PRT }}$ | $\overline{\mathrm{OE}}$ Pulse Rise Time During Programming |  | 50 |  |  | ns |
| tVR | VPP Recovery Time |  | 2 |  |  | $\mu \mathrm{S}$ |

## AC Test Conditions

| VCC | $6 \mathrm{~V} \pm 0.25 \mathrm{~V}$ | Timing Measurement Reference Level |  |
| :--- | ---: | :---: | ---: |
| $V_{\text {PP }}$ | 12.2 V to 13.3 V | Inputs | 1 V and 2 V |
| Input Rise and Fall Times | $\leq 20 \mathrm{~ns}$ | Outputs | 0.8 V and 2 V |
| Input Pulse Levels | 0.45 V to 2.4 V |  |  |

## Programming Waveforms (Note 3)



Note: All times shown in parentheses are minimum and in $\mu \mathrm{s}$ unless otherwise specified.
Note 1: National's standard product warranty applies only to devices programmed to specifications described herein.
Note 2: $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The NMC27C512 must not be inserted into or removed from a board with voltage applied to $V_{P P}$ or $V_{C C}$.
Note 3: The maximum allowable voltage which may be applied to the $V_{P P}$ pin during programming is 14 V . Care must be taken when switching the $V_{P P}$ supply to prevent overshoot exceeding this 14 V maximum specification. At least a $0.1 \mu \mathrm{~F}$ capacitor is required across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ to GND to suppress spurious voltage transients which may damage the device.
Note 4: Programming and program verify are tested at nominal power supply voltages.


## Functional Description

## DEVICE OPERATION

The five modes of operation of the NMC27C512 are listed in Table I. It should be noted that all inputs for the five modes may be at TTL levels. The power supplies required are $V_{C C}$ and $\mathrm{V}_{\mathrm{Pp}}$. The $\mathrm{V}_{\mathrm{CC}}$ power supply must be at 6 V during the three programming modes, and at 5 V in the other two modes. The $\overline{O E} / V_{P P}$ pin must be at $13 V$ in the programming mode, and at $V_{\mathrm{IL}}$ in the read and verify mode.

## Read Mode

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

## Standby Mode

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

## Output OR-Tying

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

## Programming

CAUTION: Exceeding 14V on pin 22 (VPP) will damage the NMC27C512.
Initially, and after each erasure, all bits of the NMC27C512 are in the " 1 " state. Data is introduced by selectively programming "Os" into the desired bit locations. Although only " $0 s$ " will be programmed, both " 1 s " and " $0 s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The NMC27C512 is in the programming mode when $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ is at 13.0 V . It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\overline{O E} / V_{P P}, V_{C C}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the $\overline{C E}$ input. A program pulse must be applied at each address location that is to be programmed. Any location may be programmed at any timeeither individually, sequentially, or at random. The NMC27C512 is designed to be programmed in either of two ways: single pulse programming, where each address is programmed with a 10 ms pulse; or interactive programming, where each address is programmed with a series of 0.5 ms pulses until it verifies (up to a maximum of 20 pulses or 10 ms ). Only the interactive programming method has been tested. The NMC27C512 must not be programmed with a DC signal applied to the $\overline{C E}$ input.
Programming multiple NMC27C512s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled NMC27C512s may be connected together when they are programmed with the same data. A low level TTL puise applied to the $\overline{C E}$ input programs the paralleled NMC27C512s.

TABLE I. Mode Selection

| Plns | $\begin{aligned} & \overline{C E} \\ & (20) \end{aligned}$ | $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ <br> (22) | $V_{C C}$ <br> (28) | $\begin{aligned} & \text { Outputs } \\ & (11-13,15-19) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |
| Read | $\mathrm{V}_{\text {IL }}$ | $V_{\text {IL }}$ | 5 | Dout |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | 5 | Hi-Z |
| Program | Pulsed $\mathrm{V}_{\text {IH }}$ to $\mathrm{V}_{\text {IL }}$ | $V_{\text {PP }}$ | 6 | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | 6 | Dout |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $V_{\text {PP }}$ | 6 | Hi-Z |

## Functional Description (Continued)

## Program Inhibit

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

## Program Verify

A verify should be performed on the programmed bits to determine whether they were correctly programmed. The verify may be performed with $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ at $\mathrm{V}_{\mathrm{IL}}$.

## MANUFACTURER'S IDENTIFICATION CODE

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

## ERASURE CHARACTERISTICS

The erasure characteristics of the NMC27C512 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000 \AA-4000 \AA$ range. Data shows that constant exposure to room-level fluorescent lighting could erase the typical NMC27C512 in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight.

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

## SYSTEM CONSIDERATION

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

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

TABLE III. Minimum NMC27C512 Erasure Time

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



NMC27C1024
1,048,576-Bit (64k x 16) UV Erasable CMOS PROM

## General Description

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

## Features

■ Access time down to 90 ns , microCMOS technology

- Low CMOS power consumption
—Active Power: 275 mW max
- Standby Power: $550 \mu \mathrm{~W}$ max
- Performance compatible to 16 -bit and 32 -bit microprocessors
- Single 5 V power supply
n Pin compatible with NMOS 1024k EPROMS
- Fast and reliable programming ( 0.5 ms for most bytes)
- Static operation-no clocks required
- TTL, CMOS compatible inputs/outputs
- TRI-STATE ${ }^{\circledR}$ output


## Block Diagram



## Connection Diagram



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

| Parameter/Order Number | Access Time (ns) |
| :--- | :---: |
| NMC27C1024Q90 | 90 |
| NMC27C1024Q120 | 120 |
| NMC27C1024Q150 | 150 |
| NMC27C1024Q200 | 200 |

## Absolute Maximum Ratings (Note 1)

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Temperature Under Bias
$-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$
Storage Temperature
$-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
All Input Voltages except A9
Respect to Ground
+6.5 V to -0.3 V
All Output Voltages with
Respect to Ground $\quad \mathrm{V}_{\mathrm{CC}}+0.3$ to GND -0.3 V
$V_{\text {Pp }}$ Supply Voltage and A9 with

$$
\text { Respect to Ground }+12.0 \mathrm{~V} \text { to }-0.3 \mathrm{~V}
$$

Power Dissipation
1.0W

Lead Temperature (Soldering, 10 sec .)
$300^{\circ} \mathrm{C}$
ESD rating is to be determined.
Operating Conditions (Note 7)
Temperature Range
NMC27C1024Q90, 120, 150, $200 \quad 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$V_{C C}$ Power Supply $\quad 5 \mathrm{~V} \pm 10 \%$

## READ OPERATION

## DC Electrical Characteristics

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

## AC Electrical Characteristics

| Symbol | Parameter | Conditions | $\begin{gathered} \text { NMC27C1024 } \\ 90 \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { NMC27C1024 } \\ 120 \\ \hline \end{gathered}$ |  | $\begin{gathered} \text { NMC27C1024 } \\ 150 \end{gathered}$ |  | $\begin{gathered} \text { NMC27C1024 } \\ 200 \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ACC }}$ | Address to Output Delay | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |  | 90 |  | 120 |  | 150 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | $\overline{\mathrm{CE}}$ to Output Delay | $\overline{O E}=V_{\text {IL }}$ |  | 90 |  | 120 |  | 150 |  | 200 | ns |
| toe | $\overline{\text { OE to Output Delay }}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |  | 40 |  | 50 |  | 60 |  | 75 | ns |
| $t_{\text {DF }}$ | OE High to Output Float | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ | 0 | 40 | 0 | 40 | 0 | 50 | 0 | 60 | ns |
| $\mathrm{tOH}^{\text {t }}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{O E}$, Whichever Occurred First | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ | 0 |  | 0 |  | 0 |  | 0 |  | ns |

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

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

## AC Test Conditions

Output Load 1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ (Note 9) Input Rise and Fall Times Input Pulse Levels
$\leq 5 \mathrm{~ns}$
0.45 V to 2.4 V

| Timing Measurement Reference Level |  |
| :--- | ---: |
| Inputs | 1 V and 2 V |
| Outputs | 0.8 V and 2 V | 0.8 V and 2 V

## AC Waveforms



Note 1: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
Note 2: Typical values are for $T_{A}=+25^{\circ} \mathrm{C}$ and nominal supply voltages.
Note 3: This parameter is only sampled and is not $100 \%$ tested.
Note 4: $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$.
Note 5: The tDF compare level is determined as follows:
High to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OH} 1}$ (DC) -0.10 V
Low to TRI-STATE, the measured $\mathrm{V}_{\mathrm{OL} .1}(\mathrm{DC})+0.10 \mathrm{~V}$
Note 6: TRI-STATE may be attained using $\overline{O E}$ or $\overline{C E}$.
Note 7: The power switching characteristics of EPROMs require careful device decoupling. It is recommended that at least a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND.
Note 8: The outputs must be restricted to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ to avoid latch-up and device damage.
Note 9: 1 TTL Gate: $\mathrm{IOL}_{\mathrm{O}}=1.6 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
CL: 100 pF includes fixture capacitance.
Note 10: $V_{P P}$ may be connected to $V_{C C}$ except during programming.

## Programming Characteristics

$\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=6 \mathrm{~V} \pm 0.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{PP}}=11.5 \pm 0.3 \mathrm{~V}$ (Notes 2, 3, \& 4)

| Symbol | Parameter | Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Set-Up Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| toes | $\overline{O E}$ Set-Up Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DS }}$ | Data Set-Up Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {AH }}$ | Address Hold Time |  | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  | 1 |  |  | $\mu \mathrm{s}$ |
| tces | $\overline{\text { CE Set-Up Time }}$ |  | 1 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {ACC }}$ | Address to Output Delay |  |  |  | 250 | ns |
| $t_{\text {DF }}$ | Output Enable to Output Float Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ | 0 |  | 60 | ns |
| $\mathrm{t}_{\text {OE }}$ | Output Enable to Output Delay | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |  |  | 100 | ns |
| tpw | Program Pulse Width |  | 0.5 | 0.5 | 10 | ms |
| IPP | VPP Supply Current During Programming Pulse | $\overline{C E}=V_{I L}$ |  |  | 30 | mA |
| ICC | $V_{\text {CC }}$ Supply Current |  |  |  | 10 | mA |

## AC Test Conditions

| VCC | $6 \mathrm{~V} \pm 0.25 \mathrm{~V}$ |
| :--- | ---: |
| $V_{P P}$ | $11.5 \mathrm{~V} \pm 0.3 \mathrm{~V}$ |
| Input Rise and Fall Times | $\leq 20 \mathrm{~ns}$ |
| Input Pulse Levels | 0.45 V to 2.4 V |


| Timing Measurement Reference Level |  |
| :--- | ---: |
| Inputs | 1 V and 2 V |
| Outputs | 0.8 V and 2 V |

## Programming Waveforms (Note 3)



TL/D/8806-4
Note: All times shown in parentheses are minimum and in $\mu$ s unless otherwise specified. $T_{O E}$ and $T_{D F}$ are characteristics of the device but must be accomodated by the programmer.

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


## Functional Description

## DEVICE OPERATION

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

## Read Mode

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

## Standby Mode

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

## Output OR-Tying

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

## Programming

CAUTION: Exceeding 12V on the VPp or A9 pin will damage the NMC27C1024.
Initially, and after each erasure, all bits of the NMC27C1024 are in the " 1 " state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 ' $s$ " will be programmed, both " 1 's" and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The NMC27C1024 is in the programming mode when the $V_{P P}$ power supply is at 11.5 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{\mathrm{IH}}$. It is required that at least a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\mathrm{V}_{\mathrm{PP}}, \mathrm{V}_{\mathrm{CC}}$ to ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 16 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, an active low, TTL program pulse is applied to the PGM input. A program pulse must be applied at each address location to be programmed. Any location may be programmed at any timeeither individually, sequentially, or at random. The NMC27C1024 is designed to be programmed in either of two ways: single pulse programming, where each address is programmed with a 10 ms pulse; or interactive programming, where each address is programmed with a series of 0.5 ms pulses until it verifies (up to a maximum of 20 pulses or 10 ms ). Only the interactive programming method has been tested. The NMC27C1024 must not be programmed with a DC signal applied to the PGM input.
Programming multiple NMC27C1024s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallel NMC27C1024s may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{P G M}$ input programs the paralleled NMC27C1024s.

TABLE I. Mode Selection

| Pins | $\overline{C E}$ <br> (2) | $\overline{O E}$ <br> (20) | $\begin{aligned} & \overline{\text { PGM }} \\ & \text { (39) } \end{aligned}$ | VPP <br> (1) | $V_{C C}$$\qquad$ | Outputs$(3-10,12-19)$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mode |  |  |  |  |  |  |
| Read | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $V_{C C}$ | 5 | DOUT |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | Don't Care | $V_{C C}$ | 5 | Hi-z |
| Program | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | い | 11.5 | 6 | $\mathrm{DIN}^{\text {I }}$ |
| Program Verify | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 11.5 | 6 | DOUT |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | Don't Care | 11.5 | 6 | Hi-Z |

## Functional Description (Continued)

## Program Inhibit

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

## Program Verify

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

## Manufacturer's Identification Code

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

## ERASURE CHARACTERISTICS

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

## SYSTEM CONSIDERATION

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

TABLE II. Manufacturer's Identification Code

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

TABLE III. Minimum NMC27C1024 Erasure Time
\(\left.$$
\begin{array}{|c|c|}\hline \begin{array}{c}\text { Light Intensity } \\
\text { (Micro-Watts/cm }\end{array} \text { ) }\end{array}
$$ \quad \begin{array}{c}Erasure Time <br>

(Minutes)\end{array}\right]\)| 15,000 | 20 |
| :---: | :---: |
| 10,000 | 50 |
| 5,000 |  |

# DM54LS373/DM74LS373/DM54LS374/DM74LS374 TRI-STATE ${ }^{\circledR}$ Octal D-Type Transparent Latches and Edge-Triggered Flip-Flops 

## General Description

These 8-bit registers feature totem-pole TRI-STATE outputs designed specifically for driving highly-capacitive or relatively low-impedance loads. The high-impedance state and increased high-logic level drive provide these registers with the capability of being connected directly to and driving the bus lines in a bus-organized system without need for interface or pull-up components. They are particularly attractive for implementing buffer registers, I/O ports, bidirectional bus drivers, and working registers.
(Continued)

## Features

- Choice of 8 latches or 8 D-type flip-flops in a single package
■ TRI-STATE bus-driving outputs
- Full parallel-access for loading
- Buffered control inputs
- Clock/Enable input has hysteresis to improve noise rejection
- P-N-P inputs reduce D-C loading on data lines


## Connection Diagrams

## Dual-In-Line Packages



Absolute Maximum Ratings (See Note)
Specifications for Milltary/Aerospace products are not contalned in this datasheet. Refer to the assoclated rellability electrical test specifications document.

| Supply Voltage | 7 V |
| :--- | ---: |
| Input Voltage | 7 V |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Operating Free Air Temperature Range |  |
| DM54LS | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| DM74LS | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

Note: The "Absolute Maximum Ratings" are those values beyond which the safety of the device cannot be guaranteed. The device should not be operated at these limits. The parametric values defined in the "Electrical Characteristics" table are not guaranteed at the absolute maximum ratings. The "Recommended Operating Conditions" table will define the conditions for actual device operation.

Recommended Operating Conditions

| Symbol | Parameter |  | DM54LS373 |  |  | DM74LS373 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Nom | Max | Min | Nom | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{\text {IH }}$ | High Level Input Votage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low Level Input Voltage |  |  |  | 0.7 |  |  | 0.8 | V |
| $\mathrm{IOH}^{\text {l }}$ | High Level Output Current |  |  |  | -1 |  |  | -2.6 | mA |
| OL | Low Level Output Current |  |  |  | 12 |  |  | 24 | mA |
| $t_{W}$ | Pulse Width (Note 2) | Enable High | 15 |  |  | 15 |  |  | ns |
|  |  | Enable Low | 15 |  |  | 15 |  |  |  |
| tsu | Data Setup Time (Notes 1 \& 2) |  | 5 $\downarrow$ |  |  | 5 $\downarrow$ |  |  | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Data Hold Time (Notes 1 \& 2) |  | 20 $\downarrow$ |  |  | $20 \downarrow$ |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Free Air Operating Temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

Note 1: The symbol ( $\downarrow$ ) indicates the falling edge of the clock pulse is used for reference.
Note 2: $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$.
'LS373 Electrical Characteristics
over recommended operating free air temperature (unless otherwise noted)

| Symbol | Parameter | Conditions |  | Min | Typ <br> (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{l}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High Level Output Voltage | $\begin{aligned} & V_{C C}=\operatorname{Min} \\ & l_{O H}=\operatorname{Max} \\ & V_{I L}=\operatorname{Max} \\ & V_{I H}=\operatorname{Min} \end{aligned}$ | DM54 | 2.4 | 3.4 |  |  |
|  |  |  | DM74 | 2.4 | 3.1 |  | $\checkmark$ |
| V OL | Low Level Output Voltage | $\begin{aligned} & V_{C C}=\operatorname{Min} \\ & I_{O L}=M a x \\ & V_{I L}=M a x \\ & V_{I H}=\operatorname{Min} \end{aligned}$ | DM54 |  | 0.25 | 0.4 |  |
|  |  |  | DM74 |  | 0.35 | 0.5 | V |
|  |  | $\begin{aligned} & \mathrm{IOL}=12 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min} \end{aligned}$ | DM74 |  |  | 0.4 |  |
| 1 | Input Current © Max Input Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{I}}=7 \mathrm{~V}$ |  |  |  | 0.1 | mA |
| ${ }_{\text {IH }}$ | High Level Input Current | $V_{C C}=\operatorname{Max}, V_{1}=2.7 \mathrm{~V}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
| IIL | Low Level Input Current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  |  | -0.4 | mA |
| lozH | Off-State Output Current with High Level Output Voltage Applied | $\begin{aligned} & V_{C C}=\operatorname{Max}, V_{O}=2.7 \mathrm{~V} \\ & V_{I H}=\operatorname{Min}, V_{I L}=\operatorname{Max} \end{aligned}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
| lozL | Off-State Output Current with Low Level Output Voltage Applied | $\begin{aligned} & V_{C C}=\operatorname{Max}, V_{O}=0.4 \mathrm{~V} \\ & V_{\mathrm{IH}}=\operatorname{Min}, V_{\mathrm{IL}}=\operatorname{Max} \end{aligned}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
| los | Short Circuit Output Current | $\begin{aligned} & V_{c c}=M a x \\ & \text { (Note 2) } \end{aligned}$ | DM54 | -20 |  | -100 | mA |
|  |  |  | DM74 | -20 |  | -100 |  |
| Icc | Supply Current | $V_{C C}=M a x$ |  |  | 24 | 40 | mA |

'LS373 Switching Characteristics at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
(See Section 1 for Test Waveforms and Output Load)

| Symbol | Parameter | From (Input) To (Output) | $\mathrm{R}_{\mathrm{L}}=667 \Omega$ |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{C}_{\mathrm{L}}=45 \mathrm{pF}$ |  | $C_{L}=150 \mathrm{pF}$ |  |  |
|  |  |  | Min | Max | Min | Max |  |
| tplH | Propagation Delay Time Low to High Level Output | $\begin{gathered} \hline \text { Data } \\ \text { to } \\ Q \\ \hline \end{gathered}$ |  | 18 |  | 26 | ns |
| tPHL | Propagation Delay Time High to Low Level Output | $\begin{gathered} \text { Data } \\ \text { to } \\ Q \\ \hline \end{gathered}$ |  | 18 |  | 27 | ns |
| tplH | Propagation Delay Time Low to High Level Output | Enable to Q |  | 30 |  | 38 | ns |
| $t_{\text {PHL }}$ | Propagation Delay Time High to Low Level Output | Enable to Q |  | 30 |  | 36 | ns |
| tpZH | Output Enable Time to High Level Output | Output Control to Any Q |  | 28 |  | 36 | ns |
| $t_{\text {PZL }}$ | Output Enable Time to Low Level Output | Output <br> Control <br> to Any Q |  | 36 |  | 50 | ns |
| $t_{\text {PHZ }}$ | Output Disable <br> Time from High Level Output (Note 3) | Output Control to Any Q |  | 20 |  |  | ns |
| tplz | Output Disable <br> Time from Low Level Output (Note 3) | Output Control to Any Q |  | 25 |  |  | ns |

Note 1: All typicals are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
Note 2: Not more than one output should be shorted at a time, and the duration should not exceed one second.
Note 3: $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$.

## Recommended Operating Conditions

| Symbol | Parameter |  | DM54LS374 |  |  | DM74LS374 |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Nom | Max | Min | Nom | Max |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply Voltage |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{\text {IH }}$ | High Level Input Voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low Level Input Voltage |  |  |  | 0.7 |  |  | 0.8 | V |
| $\mathrm{lOH}^{\text {l }}$ | High Level Output Current |  |  |  | -1 |  |  | -2.6 | mA |
| lOL | Low Level Output Current |  |  |  | 12 |  |  | 24 | mA |
| $\mathrm{f}_{\mathrm{CLK}}$ | Clock Frequency (Note 2) |  | 0 |  | 35 | 0 |  | 35 | MHz |
| fCLK | Clock Frequency (Note 3) |  | 0 |  | 20 | 0 |  | 20 | MHz |
| tw | Pulse Width (Note 4) | Clock High | 15 |  |  | 15 |  |  | ns |
|  |  | Clock Low | 15 |  |  | 15 |  |  |  |
| tsu | Data Setup Time (Notes 1 \& 4) |  | $20 \uparrow$ |  |  | $20 \uparrow$ |  |  | ns |
| ${ }_{H}$ | Data Hold Time (Notes 1 \& 4) |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | ns |
| $\mathrm{T}_{\mathrm{A}}$ | Free Air Operating Temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

Note 1: The symbol ( $\uparrow$ ) indicates the rising edge of the clock pulse is used for reference.
Note 2: $\mathrm{C}_{\mathrm{L}}=45 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=667 \Omega, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$.
Note 3: $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=667 \Omega, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$.
Note 4: $T_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$.

## 'LS374 Electrical Characteristics

over recommended operating free air temperature (unless otherwise noted)

| Symbol | Parameter | Conditions |  | M n | Typ (Note 1) | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{1}$ | Input Clamp Voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, l_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High Level Output Voltage | $\begin{aligned} & V_{\mathrm{CC}}=\operatorname{Min} \\ & \mathrm{IOH}_{\mathrm{OH}}=\operatorname{Max} \\ & \mathrm{V}_{\mathrm{IL}}=\operatorname{Max} \\ & \mathrm{V}_{\mathrm{IH}}=\operatorname{Min} \end{aligned}$ | DM54 | 2.4 | 3.4 |  |  |
|  |  |  | DM74 | 2.4 | 3.1 |  | V |
| V ${ }_{\text {OL }}$ | Low Level Output Voltage | $\begin{aligned} & V_{\mathrm{CC}}=\operatorname{Min} \\ & \mathrm{IOL}_{\mathrm{OL}}=\mathrm{Max} \\ & \mathrm{~V}_{\mathrm{II}}=\mathrm{Max} \\ & \mathrm{~V}_{\mathrm{IH}}=\operatorname{Min} \end{aligned}$ | DM54 |  | 0.25 | 0.4 | V |
|  |  |  | DM74 |  | 0.35 | 0.5 |  |
|  |  | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min} \end{aligned}$ | DM74 |  | 0.25 | 0.4 |  |
| 1 | Input Current @ Max Input Voltage | $V_{C C}=\operatorname{Max}, V_{1}=7 \mathrm{~V}$ |  |  |  | 0.1 | mA |
| $\mathrm{IIH}^{\text {H }}$ | High Level Input Current | $V_{C C}=M a x, V_{1}=2.7 \mathrm{~V}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
| ILL | Low Level Input Current | $V_{C C}=\operatorname{Max}, V_{1}=0.4 \mathrm{~V}$ |  |  |  | -0.4 | mA |
| lozh | Off-State Output <br> Current with High <br> Level Output <br> Voltage Applied | $\begin{aligned} & V_{C C}=\operatorname{Max}, V_{O}=2.7 V \\ & V_{I H}=\operatorname{Min}, V_{I L}=\operatorname{Max} \end{aligned}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
| lozL | Off-State Output Current with Low Level Output Voltage Applied | $\begin{aligned} & V_{C C}=\operatorname{Max}, V_{O}=0.4 V \\ & V_{I H}=\operatorname{Min}, V_{I L}=\operatorname{Max} \end{aligned}$ |  |  |  | -20 | $\mu \mathrm{A}$ |
| los | Short Circuit Output Current | $\begin{aligned} & V_{C C}=M a x \\ & \text { (Note 2) } \end{aligned}$ | DM54 | -20 |  | -100 | mA |
|  |  |  | DM74 | -20 |  | -100 |  |
| Icc | Supply Current | $\mathrm{V}_{\text {CC }}=$ Max |  |  | 27 | 45 | mA |

'LS374 Switching Characteristics at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
(See Section 1 for Test Waveforms and Output Load)

| Symbol | Parameter | $R_{L}=667 \Omega$ |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{C}_{\mathrm{L}}=45 \mathrm{pF}$ |  | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |  |  |
|  |  | Min | Max | Min | Max |  |
| $\mathrm{f}_{\text {MAX }}$ | Maximum Clock Frequency | 35 |  | 20 |  | MHz |
| $t_{\text {PLH }}$ | Propagation Delay Time Low to High Level Output |  | 28 |  | 32 | ns |
| $\mathrm{t}_{\text {PHL }}$ | Propagation Delay Time High to Low Level Output |  | 28 |  | 38 | ns |
| ${ }_{\text {tPZH }}$ | Output Enable Time to High Level Output |  | 28 |  | 44 | ns |
| $t_{\text {PZL }}$ | Output Enable Time to Low Level Output |  | 28 |  | 44 | ns |
| $t_{\text {PHZ }}$ | Output Disable Time from High Level Output (Note 3) |  | 20 |  |  | ns |
| $t_{\text {PLL }}$ | Output Disable Time from Low Level Output (Note 3) |  | 25 |  |  | ns |

[^7]General Description (Continued)
The eight latches of the DM54/74LS373 are transparent Dtype latches meaning that while the enable $(G)$ is high the $Q$ outputs will follow the data ( $D$ ) inputs. When the enable is taken low the output will be latched at the level of the data that was set up.
The eight flip-flops of the DM54/74LS374 are edge-triggered D-type flip flops. On the positive transition of the clock, the Q outputs will be set to the logic states that were set up at the $D$ inputs.

## Function Tables

DM54/74LS373

| Output <br> Control | Enable <br> G | D | Output |
| :---: | :---: | :---: | :---: |
| L | H | H | H |
| L | H | L | L |
| L | L | X | $\mathrm{Q}_{0}$ |
| H | X | X | Z |

Schmitt-trigger buffered inputs at the enable/clock lines simplify system design as AC and DC noise rejection is improved by typically 400 mV due to the input hysteresis. A buffered output control input can be used to place the eight outputs in either a normal logic state (high or low logic levels) or a high-impedance state. In the high-impedance state the outputs neither load nor drive the bus lines significantly. The output control does not affect the internal operation of the latches or flip-flops. That is, the old data can be retained or new data can be entered even while the outputs are off.

DM54/74LS374

| Output <br> Control | Clock | D | Output |
| :---: | :---: | :---: | :---: |
| L | $\uparrow$ | H | H |
| L | $\uparrow$ | L | L |
| L | L | X | $\mathrm{Q}_{0}$ |
| H | X | X | Z |

$H=$ High Level (Steady State), $L=$ Low Level (Steady State), $X=$ Don't Care
$\uparrow=$ Transition from low-to-high level, $Z=$ High Impedance State
$Q_{0}=$ The level of the output before steady-state input conditions were established.

## Logic Diagrams

DM54/74LS373
Transparent Latches


DM54/74LS374
Positive-Edge-Triggered Flip-Flops


National
Semiconductor Corporation


## MM54HC373/MM74HC373 TRI-STATE ${ }^{\circledR}$ Octal D-Type Latch

## General Description

These high speed octal D-type latches utilize microCMOS Technology, 3.5 micron silicon gate $P$-well CMOS. They possess the high noise immunity and low power consumption of standard CMOS integrated circuits, as well as the ability to drive 15 LS-TTL loads. Due to the large output drive capability and the TRI-STATE feature, these devices are ideally suited for interfacing with bus lines in a bus organized system.
When the LATCH ENABLE input is high, the Q outputs will follow the D inputs. When the LATCH ENABLE goes low, data at the D inputs will be retained at the outputs until LATCH ENABLE returns high again. When a high logic level is applied to the OUTPUT CONTROL input, all outputs go to a high impedance state, regardless of what signals are pres-
ent at the other inputs and the state of the storage elements.
The $54 \mathrm{HC} / 74 \mathrm{HC}$ logic family is speed, function, and pin-out compatible with the standard 54LS/74LS logic family. All inputs are protected from damage due to static discharge by internal diode clamps to $V_{C C}$ and ground.

## Features

■ Typical propagation delay: 18 ns
■ Wide operating voltage range: 2 to 6 volts
■ Low input current: $1 \mu \mathrm{~A}$ maximum
■ Low quiescent current: $80 \mu \mathrm{~A}$ maximum ( 74 Series)
■ Output drive capability: 15 LS-TTL loads

## Connection Diagram

Dual-In-Line Package


## Truth Table

| Output <br> Control | Latch <br> Enable | Data | 373 <br> Output |
| :---: | :---: | :---: | :---: |
| L | H | H | H |
| L | H | L | L |
| L | L | X | $\mathrm{Q}_{0}$ |
| H | X | X | Z |

$H=$ high level, $L=$ low level
$Q_{0}=$ level of output before steady-state input conditions were established.
$Z=$ high impedance

| bsolute Maximum Ratings (Notes 1 \& 2) |  |
| :---: | :---: |
| Supply Voltage (VCC) | -0.5 to +7.0 V |
| DC Input Voltage ( $\mathrm{V}_{\mathbf{I N}}$ ) | -1.5 to $\mathrm{V}_{C C}+1.5 \mathrm{~V}$ |
| DC Output Voltage (VOUT) | -0.5 to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Clamp Diode Current ( $\mathrm{I}_{\mathrm{K}}, \mathrm{l}_{\mathrm{OK}}$ ) | $\pm 20 \mathrm{~mA}$ |
| DC Output Current, per pin (lout) | 35 mA |
| DC V ${ }_{\text {CC }}$ or GND Current, per pin (lcC) | $\pm 70 \mathrm{~mA}$ |
| Storage Temperature Range (TSTG) | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Power Dissipation ( $\mathrm{P}_{\mathrm{D}}$ ) | 500 mW |
| Lead Temp. ( $T_{\text {L }}$ ) (Soldering 10 seco | 26 |

DC Electrical Characteristics

## Operating Conditions

|  | Min | Max | Units |
| :--- | :---: | :---: | :---: |
| Supply Voltage $\left(V_{C C}\right)$ | 2 | 6 | V |
| DC Input or Output Voltage | 0 | $V_{C C}$ | V |
| $\left(V_{I N}, V_{\text {OUT }}\right)$ |  |  |  |
| Operating Temp. Range $\left(T_{A}\right)$ |  |  |  |
| MM74HC | -40 | +85 | ${ }^{\circ} \mathrm{C}$ |
| MM54HC | -55 | +125 | ${ }^{\circ} \mathrm{C}$ |
| Input Rise or Fall Times |  |  |  |
| $\left(t_{r}, t_{f}\right) \quad V_{C C}=2.0 \mathrm{~V}$ |  | 1000 | ns |
| $V_{C C}=4.5 \mathrm{~V}$ |  | 500 | ns |
| $V_{C C}=6.0 \mathrm{~V}$ |  | 400 | ns |


| Symbol | Parameter | Conditions | $V_{c c}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | $\begin{gathered} 74 \mathrm{HC} \\ T_{A}=-40 \text { to } 85^{\circ} \mathrm{C} \end{gathered}$ | $\begin{gathered} 54 \mathrm{HC} \\ T_{A}=-55 \text { to } 125^{\circ} \mathrm{C} \end{gathered}$ | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ | Guaranteed Limits |  |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Minimum High Level Input Voltage |  | $\begin{aligned} & \hline 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \\ & \hline \end{aligned}$ |  | $\begin{gathered} \hline 1.5 \\ 3.15 \\ 4.2 \\ \hline \end{gathered}$ | $\begin{gathered} 1.5 \\ 3.15 \\ 4.2 \end{gathered}$ | $\begin{gathered} 1.5 \\ 3.15 \\ 4.2 \\ \hline \end{gathered}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Maximum Low Level Input Voltage |  | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 0.3 \\ & 0.9 \\ & 1.2 \end{aligned}$ | $\begin{aligned} & 0.3 \\ & 0.9 \\ & 1.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0.3 \\ & 0.9 \\ & 1.2 \\ & \hline \end{aligned}$ | $\begin{aligned} & V \\ & v \\ & v \end{aligned}$ |
| V OH | Minimum High Level Output Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \left\|\mathrm{I}_{\text {OUT }}\right\| \leq 20 \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 2.0 \\ & 4.5 \\ & 6.0 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1.9 \\ & 4.4 \\ & 5.9 \end{aligned}$ | $\begin{aligned} & 1.9 \\ & 4.4 \\ & 5.9 \end{aligned}$ | $\begin{aligned} & 1.9 \\ & 4.4 \\ & 5.9 \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ |
|  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{1 \mathrm{H}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \left\|\left.\right\|_{\text {OUT }}\right\| \leq 6.0 \mathrm{~mA} \\ & \left\|{ }_{\text {lout }}\right\| \leq 7.8 \mathrm{~mA} \\ & \hline \end{aligned}$ | $\begin{aligned} & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 4.2 \\ & 5.7 \end{aligned}$ | $\begin{array}{r} 3.98 \\ 5.48 \end{array}$ | $\begin{aligned} & 3.84 \\ & 5.34 \end{aligned}$ | $\begin{aligned} & 3.7 \\ & 5.2 \end{aligned}$ | $\begin{aligned} & v \\ & v \end{aligned}$ |
| $\mathrm{V}_{\text {OL }}$ | Maximum Low Level Output Voltage | $\begin{aligned} & \mathrm{V}_{I N}=\mathrm{V}_{I H} \text { or } \mathrm{V}_{\mathrm{IL}} \\ & \left\|\left.\right\|_{\text {IOUT }}\right\| \leq 20 \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0.1 \\ & 0.1 \\ & 0.1 \end{aligned}$ | $\begin{aligned} & 0.1 \\ & 0.1 \\ & 0.1 \end{aligned}$ | $\begin{aligned} & 0.1 \\ & 0.1 \\ & 0.1 \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ |
|  |  | $\left\{\begin{array}{l} \mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{\mathrm{IH}} \text { or } \mathrm{V}_{\mathrm{IL}} \\ \mid \mathrm{I} \text { OUT } \mid \leq 6.0 \mathrm{~mA} \\ \mid \text { lout } \mid \leq 7.8 \mathrm{~mA} \end{array}\right.$ | $\begin{aligned} & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 0.2 \\ & 0.2 \end{aligned}$ | $\begin{aligned} & 0.26 \\ & 0.26 \\ & \hline \end{aligned}$ | $\begin{aligned} & 0.33 \\ & 0.33 \end{aligned}$ | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ |
| ${ }^{1 / N}$ | Maximum Input Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or GND | 6.0 V |  | $\pm 0.1$ | $\pm 1.0$ | $\pm 1.0$ | $\mu \mathrm{A}$ |
| loz | Maximum TRI-STATE <br> Output Leakage <br> Current | $\begin{aligned} & V_{I N}=V_{I H} \text { or } V_{I L}, O C=V_{I H} \\ & V_{\text {OUT }}=V_{\text {CC }} \text { or } G N D \end{aligned}$ | 6.0 V |  | $\pm 0.5$ | $\pm 5$ | $\pm 10$ | $\mu \mathrm{A}$ |
| ICC | Maximum Quiescent Supply Current | $\begin{aligned} & \mathrm{V}_{I N}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{I}_{\mathrm{OUT}}=0 \mu \mathrm{~A} \\ & \hline \end{aligned}$ | 6.0 V |  | 8.0 | 80 | 160 | $\mu \mathrm{A}$ |

Note 1: Absolute Maximum Ratings are those values beyond which damage to the device may occur.
Note 2: Unless otherwise specified all voltages are referenced to ground.
Note 3: Power Dissipation temperature derating - plastic " $N$ " package: $-12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ from $65^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$; ceramic " J " package: $-12 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$ from $100^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$.
Note 4: For a power supply of $5 \mathrm{~V} \pm 10 \%$ the worst case output voltages ( $\mathrm{V}_{\mathrm{OH}}$, and $\mathrm{V}_{\mathrm{OL}}$ ) occur for HC at 4.5 V . Thus the 4.5 V values should be used when designing with this supply. Worst case $\mathrm{V}_{I H}$ and $\mathrm{V}_{1 \mathrm{~L}}$ occur at $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ and 4.5 V respectively. (The $\mathrm{V}_{1 H}$ value at 5.5 V is 3.85 V .) The worst case leakage current ( $\mathrm{I}_{1 N}$, $\mathrm{I}_{\mathrm{CC}}$, and $\mathrm{I}_{\mathrm{OZ}}$ ) occur for CMOS at the higher voltage and so the 6.0 V values should be used.

AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=6 \mathrm{~ns}$

| Symbol | Parameter | Conditions | Typ | Guaranteed Limit | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{tpHL}^{\text {, }}$ tPLH | Maximum Propagation Delay, Data to Q | $\mathrm{C}_{\mathrm{L}}=45 \mathrm{pF}$ | 18 | 25 | ns |
| $\mathrm{tpHL}^{\text {t }}$ PLH | Maximum Propagation Delay, Clock to Q | $\mathrm{C}_{\mathrm{L}}=45 \mathrm{pF}$ | 21 | 30 | ns |
| $\mathrm{t}_{\text {PZH, }} \mathrm{t}_{\text {PZL }}$ | Maximum Output Enable Time | $\begin{aligned} & \mathrm{R}_{\mathrm{L}}=1 \mathrm{k} \Omega \\ & \mathrm{C}_{\mathrm{L}}=45 \mathrm{pF} \\ & \hline \end{aligned}$ | 20 | 28 | ns |
| $\mathrm{t}_{\text {PHZ }}, \mathrm{t}_{\text {PLZ }}$ | Maximum Output Disable Time | $\begin{aligned} & \mathrm{R}_{\mathrm{L}}=1 \mathrm{k} \Omega \\ & \mathrm{C}_{\mathrm{L}}=5 \mathrm{pF} \\ & \hline \end{aligned}$ | 18 | 25 | ns |
| ts | Minimum Set Up Time |  |  | 5 | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Minimum Hold Time |  |  | 10 | ns |
| tw | Minimum Pulse Width |  | 9 | 16 | ns |

AC Electrical Characteristics $\mathrm{V}_{\mathrm{CC}}=2.0-6.0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=6 \mathrm{~ns}$ (unless otherwise specified)

| Symbol | Parameter | Conditions | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$ |  | $\begin{gathered} 74 \mathrm{HC} \\ \mathrm{~T}_{\mathrm{A}}=-40 \text { to } 85^{\circ} \mathrm{C} \\ \hline \end{gathered}$ | $\begin{gathered} 54 \mathrm{HC} \\ \mathrm{~T}_{\mathrm{A}}=-55 \text { to } 125^{\circ} \mathrm{C} \\ \hline \end{gathered}$ | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Typ | Guaranteed Limits |  |  |  |
| $\mathrm{t}_{\text {PHL }}, \mathrm{tPLH}$ | Maximum Propagation Delay, Data to Q | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 2.0 \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & 50 \\ & 80 \\ & \hline \end{aligned}$ | $\begin{aligned} & 150 \\ & 200 \\ & \hline \end{aligned}$ | $\begin{aligned} & 188 \\ & 250 \end{aligned}$ | $\begin{aligned} & 225 \\ & 300 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
|  |  | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \\ & \hline \end{aligned}$ | $\begin{aligned} & 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 22 \\ & 30 \end{aligned}$ | $\begin{aligned} & 30 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 37 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 60 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
|  |  | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \\ & \hline \end{aligned}$ | $\begin{aligned} & 6.0 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 19 \\ & 26 \\ & \hline \end{aligned}$ | $\begin{aligned} & 26 \\ & 35 \end{aligned}$ | $\begin{array}{r} 31 \\ 44 \\ \hline \end{array}$ | $\begin{aligned} & 39 \\ & 53 \end{aligned}$ | ns |
| $\mathrm{t}_{\text {PHL }}, \mathrm{t}_{\text {PLH }}$ | Maximum Propagation Delay, Clock to Q | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 2.0 \mathrm{~V} \\ & 2.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} \hline 63 \\ 110 \end{gathered}$ | $\begin{aligned} & 175 \\ & 225 \end{aligned}$ | $\begin{aligned} & 220 \\ & 280 \end{aligned}$ | $\begin{aligned} & 263 \\ & 338 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
|  |  | $\begin{aligned} & C_{L}=50 \mathrm{pF} \\ & C_{L}=150 \mathrm{pF} \end{aligned}$ | $\begin{aligned} & 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 25 \\ & 35 \end{aligned}$ | $\begin{aligned} & 35 \\ & 45 \end{aligned}$ | $\begin{aligned} & 44 \\ & 56 \\ & \hline \end{aligned}$ | $52$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
|  |  | $\begin{aligned} & C_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ | $\begin{aligned} & \hline 6.0 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 21 \\ & 28 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 39 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 37 \\ & 49 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 45 \\ & 59 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| $t_{\text {PZH }}, t_{\text {PZL }}$ | Maximum Output Enable Time | $R_{L}=1 \mathrm{k} \Omega$ | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 2.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 50 \\ & 80 \\ & \hline \end{aligned}$ | $\begin{array}{r} 150 \\ 200 \\ \hline \end{array}$ | $\begin{array}{r} 188 \\ 250 \\ \hline \end{array}$ | $\begin{aligned} & 225 \\ & 300 \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |
|  |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}} & =50 \mathrm{pF} \\ \mathrm{C}_{\mathrm{L}} & =150 \mathrm{pF} \end{aligned}$ |  |  |  |  |  |  |
|  |  | $\begin{aligned} & C_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ | $\begin{aligned} & 4.5 \mathrm{~V} \\ & 4.5 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 21 \\ & 30 \\ & \hline \end{aligned}$ | $\begin{aligned} & 30 \\ & 40 \\ & \hline \end{aligned}$ | $\begin{aligned} & 37 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & 45 \\ & 60 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |
|  |  | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ | $\begin{aligned} & 6.0 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 19 \\ & 26 \\ & \hline \end{aligned}$ | $\begin{aligned} & 26 \\ & 35 \\ & \hline \end{aligned}$ | $\begin{aligned} & 31 \\ & 44 \\ & \hline \end{aligned}$ | $\begin{aligned} & 39 \\ & 53 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |
| $\mathrm{t}_{\text {PHZ }}$, tPLZ | Maximum Output Disable Time | $\begin{aligned} & R_{L}=1 \mathrm{k} \Omega \\ & C_{L}=50 \mathrm{pF} \end{aligned}$ | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 50 \\ & 21 \\ & 19 \\ & \hline \end{aligned}$ | $\begin{gathered} \hline 150 \\ 30 \\ 26 \\ \hline \end{gathered}$ | $\begin{gathered} 188 \\ 37 \\ 31 \\ \hline \end{gathered}$ | $\begin{gathered} \hline 225 \\ 45 \\ 39 \end{gathered}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |
| ts | Minimum Set Up Time |  | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & 5 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{gathered} 25 \\ 5 \\ 5 \end{gathered}$ | $\begin{gathered} \hline 31 \\ 6 \\ 6 \end{gathered}$ | $\begin{gathered} \hline 38 \\ 8 \\ 8 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ |
| $\mathrm{t}_{\mathrm{H}}$ | Minimum Hold Time |  | $\begin{aligned} & \hline 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} \hline 20 \\ 6 \\ 6 \end{gathered}$ | $\begin{aligned} & 50 \\ & 10 \\ & 10 \end{aligned}$ | $\begin{aligned} & \hline 60 \\ & 13 \\ & 13 \end{aligned}$ | $\begin{aligned} & 75 \\ & 20 \\ & 20 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \end{aligned}$ |
| tw | Minimum Pulse Width |  | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} \hline 30 \\ 10 \\ 9 \end{gathered}$ | $\begin{aligned} & \hline 80 \\ & 16 \\ & 14 \end{aligned}$ | $\begin{aligned} & 100 \\ & 20 \\ & 18 \end{aligned}$ | $\begin{gathered} 120 \\ 24 \\ 20 \end{gathered}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |
| $\mathrm{t}_{\text {THL }}, \mathrm{t}_{\text {TLH }}$ | Maximum Output Rise and Fall Time, Clock | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ | $\begin{aligned} & 2.0 \mathrm{~V} \\ & 4.5 \mathrm{~V} \\ & 6.0 \mathrm{~V} \end{aligned}$ | $\begin{gathered} 25 \\ 7 \\ 6 \end{gathered}$ | $\begin{aligned} & 60 \\ & 12 \\ & 10 \end{aligned}$ | $\begin{aligned} & 75 \\ & 15 \\ & 13 \end{aligned}$ | $\begin{aligned} & 90 \\ & 18 \\ & 15 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \end{aligned}$ |
| $\mathrm{C}_{\text {PD }}$ | Power Dissipation Capacitance (Note 5) | $\begin{aligned} & \text { (per latch) } \\ & O C=V_{C C} \\ & O C=G N D \end{aligned}$ |  | $\begin{aligned} & 30 \\ & 50 \\ & \hline \end{aligned}$ |  |  |  | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Maximum Input Capacitance |  |  | 5 | 10 | 10 | 10 | pF |
| COUT. | Maximum Output Capacitance |  |  | 15 | 20 | 20 | 20 | pF |

Note 5: $C_{P D}$ determines the no load dynamic power consumption, $P_{D}=C_{P D} V_{C C}{ }^{2} f+I_{C C} V_{C C}$, and the no load dynamic current consumption, $I_{S}=C_{P D} V_{C C} f+I_{C C}$.

## MM57409 Super Number Cruncher

## General Description

The Super Number Cruncher (SNC) is an MOS/LSI arithmetic processor (actually, a pre-programmed member of Na tional's single-chip microcontroller COPSTM family) intended for use in number processing applications. Scientific calculator functions, conditional output capability, internal number storage, and input/output instructions have been combined in this single chip device. Programming is done in calculator keyboard level language which simplifies software development. Data or instructions can be synchronous or asynchronous, I/O digit count, I/O notation mode, and error control are user programmable; a sense input and flag outputs are available for single bit control; and instructions and lines are available for $1 / O$ expansion.

## Applications

- Instruments
- Microprocessor/minicomputer peripheral
- Test Equipment

Process controllers

## Features

- Scientific calculator instructions (RPN)
- Up to 12-digit mantissa, 2-digit exponent
- 4-register stack, one memory register
- Trigonometric functions, logarithmic functions, Yx, $\mathrm{e}^{\mathrm{x}}, \pi$
- Error flag generation and recovery
- Flexible input/output
- Multidigit OUT instruction with foating-point or scientific notations
- Programmable mantissa digit count for OUT instruction
- Sense input and flag outputs
- Eight high-impedance I/O lines (TRI-STATE ${ }^{\circledR}$ ), six I/O lines, and four output lines for I/O expansion.
- Interface simplicity
- On-chip clock OSC
- Generates all I/O control signals
- MICROBUSTM interface


## Block Diagram



TL/DD/5173-1
FIGURE 1

## Absolute Maximum Ratings

Specifications for Military/Aerospace products are not contalned in thls datasheet. Refer to the assoclated rellability electrical test specificatlons document.

Voltage at Any Pin Relative to GND
Ambient Operating Temperature
Ambient Storage Temperature
Lead Temperature (Soldering, 10 sec .)

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

$$
0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}
$$

$$
-65^{\circ} \mathrm{C} \text { to }+50^{\circ} \mathrm{C}
$$

$300^{\circ} \mathrm{C}$

| Power Dissipation | 0.75 W at $25^{\circ} \mathrm{C}$ |
| :--- | ---: |
|  | 0.4 W at $70^{\circ} \mathrm{C}$ |
| Total Source Current | 80 mA |
| Total Sink Current | 75 mA |
| Note: Absolute maximum ratings indicate limits beyond |  |
| which damage to the device may occur. DC and AC electri- |  |
| cal specifications are not insured when operating the device |  |
| at absolute maximum ratings. |  |

DC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C} ; 4.5 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}} \leq 6.3 \mathrm{~V}$ unless otherwise noted.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Operating Voltage ( $\mathrm{V}_{\mathrm{CC}}$ ) | (Note 1) | 4.5 | 6.3 | V |
| Power Supply Ripple | (Peak to Peak) |  | 0.4 | V |
| Operating Supply Current | All inputs and outputs open $\begin{aligned} & T_{A}=0^{\circ} \mathrm{C} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & T_{A}=70^{\circ} \mathrm{C} \end{aligned}$ |  | $\begin{aligned} & 41 \\ & 35 \\ & 27 \\ & \hline \end{aligned}$ | mA |
| Input Voltage Levels CKI <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> Logic Low (VIL) <br> Logic High ( $\mathrm{V}_{\mathrm{IH}}$ ) <br> RESET <br> Logic High <br> Logic Low <br> All Other Inputs Logic High Logic High Logic Low | $\begin{aligned} & V_{C C}=5 V \pm 5 \% \\ & V_{C C}=5 \mathrm{~V} \pm 5 \% \\ & V_{C C}=M a x \end{aligned}$ $\begin{aligned} & V_{C C}=\operatorname{Max} \\ & V_{C C}=5 V \pm 5 \% \end{aligned}$ | $\begin{gathered} 2.0 \\ -0.3 \\ 2.5 \\ 0.7 \mathrm{~V}_{\mathrm{CC}} \\ -0.3 \\ \\ 2.5 \\ 2.0 \\ -0.3 \end{gathered}$ | 0.4 <br> 0.6 $0.8$ | V |
| Input Capacitance |  |  | 7.0 | pF |
| Input Leakage ( $\overline{\mathrm{RD}}, \overline{\mathrm{CS}}, \overline{\mathrm{WR}}$ ) |  | -1.0 | 1.0 | $\mu \mathrm{A}$ |
| Output Voltage Levels TTL Operation Logic High $\left(\mathrm{VOH}_{\mathrm{OH}}\right)$ Logic Low (VOL) CMOS Operation Logic High (VOH) Logic Low (VOL) | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-10 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mu \mathrm{~A} \end{aligned}$ | $V_{C C}-0.4$ | $\begin{aligned} & 0.4 \\ & 0.2 \end{aligned}$ | V |
| Output Current Levels Output Source Current <br> TRI-STATE Output Leakage Current (R, D Lines) <br> CKO Output <br> Output Source Current (IOH) <br> Output Sink Current (loL) <br> Input Current Levels Input Load Source Current (CI, RESET) <br> Total Sink Current Allowed All I/O Combined Each D, R Port Each, O, I/O, F1, F2 SYNC Line <br> Total Source Current Allowed All I/O Combined Each D Pin All Other Output Pins | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{aligned}$ $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IH}}=2.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}} 4.5 \mathrm{~V} \end{aligned}$ | $\begin{gathered} -100 \\ -2.5 \\ -0.2 \\ 0.4 \\ 14 \end{gathered}$ | $\begin{gathered} -650 \\ \\ 2.5 \\ \\ \\ 230 \\ \\ \hline 75 \\ 20 \\ 10 \\ 2.5 \\ \\ 80 \\ 5.0 \\ 1.6 \end{gathered}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> $\mu \mathrm{A}$ <br> mA <br> mA <br> mA <br> mA <br> mA |

AC Electrical Characteristics $0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C} ; 4.5 \mathrm{~V} \leq \mathrm{V}_{C C} \leq 6.3 \mathrm{~V}$, unless otherwise noted.

| Parameter | Conditions | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| Microcycle Time (tm) |  | 4.0 | 10 | $\mu \mathrm{s}$ |
| CKI Frequency ( $\mathrm{f}_{\mathrm{I}}$ ) Duty Cycle (Note 2) Rise Time Fall Time | $\mathrm{f}_{1}=4.0 \mathrm{MHz}$ | $\begin{aligned} & 1.6 \\ & 30 \end{aligned}$ | $\begin{aligned} & 4.0 \\ & 60 \\ & 60 \\ & 40 \end{aligned}$ | $\begin{gathered} \mathrm{MHz} \\ \% \\ \mathrm{~ns} \\ \mathrm{~ns} \end{gathered}$ |
| Inputs (Figure 3) ${ }^{\text {t }}$ SETUP thold |  | $\begin{aligned} & 1.7 \\ & 300 \end{aligned}$ |  | $\begin{aligned} & \mu \mathrm{s} \\ & \mathrm{~ns} \end{aligned}$ |
| Output Propagation Delay (Figure 3) CKO tpD1, tpD0 SYNC tpD1, tpD0 | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=50 \mathrm{PF} \\ & \mathrm{~V}_{\mathrm{OUT}}=1.5 \mathrm{~V} \\ & \mathrm{R}_{\mathrm{L}}=2.4 \mathrm{k} \Omega \end{aligned}$ |  | $\begin{array}{r} 0.17 \\ 1.0 \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~s} \end{aligned}$ |
| All Other Outputs | $\mathrm{R}_{\mathrm{L}}=5.0 \mathrm{k} \Omega$ |  | 1.4 | $\mu \mathrm{s}$ |
| MICROBUS Timing <br> Read Operation (Figure 4) $\overline{\mathrm{CS}}$ Stable Before RD-t CSR $\overline{\mathrm{CS}}$ Hold Time for RD- $\mathrm{t}_{\text {RCS }}$ RD Pulse Width-t $\mathrm{t}_{\text {RR }}$ Data Delay from $\overline{\mathrm{RD}}$ - $\mathrm{t}_{\text {RD }}$ $\overline{R D}$ to Data Floating-t ${ }_{D F}$ Write Operation (Figure 5) $\overline{\mathrm{CS}}$ Stable Before $\overline{W R}$ - $\mathrm{t}_{\mathrm{CSW}}$ $\overline{\mathrm{CS}}$ Hold Time for $\overline{W R}$ - ${ }^{\text {WWCS }}$ WR Pulse Width-tww Data Setup Time-tow Data Hold Time-twD INTD/RDY Transition Time from $\overline{W R}-t_{W I}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} \\ & \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% \end{aligned}$ | 65 <br> 20 <br> 400 <br> 65 <br> 20 <br> 400 <br> 320 <br> 100 | 375 $250$ $700$ | ns |

Note 1: $\mathrm{V}_{\mathrm{CC}}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
Note 2: Duty Cycle $=\mathrm{t}_{\mathrm{W}_{1}} /\left(\mathrm{t}_{\mathrm{W}_{1}}+\mathrm{t}_{\mathrm{w}_{0}}\right)$.

## Connection Diagram


*NC means no external connection allowed on these pins.

FIGURE 2
Molded Dual-In-Line Package ( N ) Order Number MM57409N See NS Package Number N40A

| PIn Name | Description |
| :--- | :--- |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 8-Bit Data Bus (bidirectional) |
| $1 \mathrm{O}_{0}-1 \mathrm{O}_{3}$ | 4-Bit I/O Lines (bidirectional) |
| $\mathrm{O}_{0}-\mathrm{O}_{3}$ | 4-Bit Output Lines |
| $\mathrm{R}_{0}-\mathrm{R}_{7}$ | 8-Bit Bidirectional I/O Lines with |
|  | TRI-STATE |
| ERROR | Error Flag Line |
| $V_{C C}, \mathrm{GND}$ | Power Supply |
| $\mathrm{FI}, \mathrm{F2}$ | Two Bidirectional Flags |
| INTR/RDY, $\overline{\text { WR }}$ | MICROBUS Handshake Signals |
| $\overline{R D}, \overline{\mathrm{CS}}$ |  |
| $\overline{R E S E T}$ | System Reset |
| SYNC | Microcycle Clock |
| $\mathrm{CKI}, \mathrm{CKO}$ | System Oscillator |
| CI | Test/Conditional Input |

## Functional Description

The MM57409 Super Number Cruncher (SNC) is intended for microprocessor number processing applications as a microcomputer peripheral device. The block diagram of the SNC is shown in Figure 1. Data paths are illustrated in simplified form to depict how the various logic elements communicate with each other. Positive logic is used, i.e., when a bit is set, it is a logic " 1 " (greater than 2 V ) and when a bit is reset, it is a logic " 0 " (less than 0.8 V ).

## INTERNAL LOGIC

The data register file, consisting of a 4-level stack and one memory location, is the source and destination register for all mathematic operations. The organization of an $x, y, z$, or $t$
level is shown in Figure 6. The structure of the M (memory) level is similar, lacking only the guard/link digit. The mantissa and the exponent each have a sign, which may be read or changed by SNC instructions. The guard/link digit in each of the $x, y, z$, and $t$ levels of the stack is used for the execution of the arithmetic instructions. Regardless of any operating mode, all data internal to the SNC is stored in scientific notation format with the mantissa rounded to 12 digits.
The arithmetic unit performs all mathematic operations of the MM57409, storing its results in the data register file.
The R port can be used as an 8 -bit high-impedance I/O port. If the R port is to be used, the first instruction the SNC must receive after a power up or reset is the RIO instruction. The state of the R port will be 03 hex. A host processor can then instruct the SNC to output an 8 -bit value to the R port or read the state of the R lines. Before reading the input state of the R lines, the lines must be put into a high-impedance mode. The $R$ lines are then high-impedance inputs and must be externally driven high or low.
An external processor may also cause a 4-bit value to be output to either the O or I/O ports. The input state of the I/O port or the present state of the output lines of the O port may be read from the SNC. If the I/O lines are to be used as inputs, the value F must first be written to the port using the I/O instruction.
Two flags are provided on the SNC-F1 and F2. These flags may be set high or pulsed high through the use of appropriate SNC instructions. When pulsed, the pulse width of F1 is four microcycles and the pulse width of F2 is three microcycles. (A microcycle is the external clock input divided by 16-see Oscillator section for further information.) These flags may also be tested by test/conditional output instructions if they are first set high. An external test input (Cl) is also provided for conditional output control and is tested by the TCl instruction.
There are four general purpose internal flags (IF1-IF4) in the SNC that can be reset, or tested using the appropriate instructions.

## OPERATING MODES

The SNC has several user controllable operating modes. Any combination of these modes may be selected. These modes are:

1. Angular mode-The SNC can be instructed to accept and return data in either degrees or radians.
2. Input/Output mode-The SNC will accept and output numerical data in either scientific notation (signed exponent and mantissa) or floating-point (decimal point position, signed mantissa). Note that only the input or output data can be in floating-point or scientific notation-the data internal to the SNC is always in scientific notation.
3. Rounding-The SNC can be instructed to round the output to the Mantissa Digit Count (MDC). This rounding may also be disabled. The rounding mode causes rounding on the output data only-the data internal to the SNC is still in scientific notation format with the mantissa rounded to 12 digits.
Note: If both the floating-point I/O mode and the rounding mode are selected, the output data is rounded to the MDC before it is converted to the floating-point mode. This means that fractional numbers ( $|x|<1$ ) may not appear to be rounded.
4. Mantissa Digit Counter (MDC)-The number of digits the SNC expects in the mantissa during the multiple digit OUT operation may be set anywhere between 1 and 12.

Functional Description (Continued)

## STATUS REGISTER

The SNC contains an 8-bit status register (Figure 7) which the host can read to determine the exact status of the SNC. The various status information is described below.
Bit 7: Scientific Notation/Floating-Point I/O mode
$(\mathrm{MSB})=1$ indicates floating-point $\mathrm{I} / \mathrm{O}$
$=0$ indicates scientific notation $1 / O$
Bit 6: Rounding
$=1$ indicates no rounding to MDC is performed
$=0$ indicates rounding to MDC is performed
Bit 5: Not Used
Bit 4: Angular Mode
$=1$ indicates angles are expressed in radians
$=0$ indicates angles are expressed in degrees
Bit 3: Status of $x$ stack level as fraction
$=1$ indicates the absolute value of $x$ is a non-zero fraction
$=0$ indicates the absolute value of $x$ is $\geq 1$
Bit 2: Polarity of $x$ register
$=1$ indicates $x<0$
$=0$ indicates $x>0$ or $x=0$
Bit 1: $x$ equivalence to 0
$=1$ indicates $x=0$
$=0$ indicates $x \neq$ zero
Bit 0: Error
$=1$ indicates an error has occurred
$=0$ indicates no error

## OSCILLATOR

An oscillator between 1.6 MHz and 4 MHz is required. This may be supplied from an external oscillator that is input to CKI or through the use of the external crystal network as shown in Figure 8. In either case, the frequency at CKI is divided by 16 to provide the basic timing reference (microcycle) for the SNC. This signal is available at the SYNC output. A single period of the SYNC signal (measured from rising edge to rising edge) corresponds to one microcycle. The microcycle will be between 5 and $10 \mu \mathrm{~s}$, depending on the CKI frequency.

## INITIALIZATION

The SNC is reset upon power up or upon application of a low going pulse to the RESET input. The reset pulse must be a minimum of three microcycles (three SYNC pulses) in duration in order to reliably reset the device. If the power supply rise time is greater than 1 ms , the circuit of Figure 9 must be used.
In the reset state, R and the D ports are in a high impedance state; SYNC is the CKI inut frequency divided by 16 ; and O , I/O, F1, F2, ERROR, and INTR/RDY are reset to 0 . The DMC is set to 10 , the angular mode is set to degrees, the input/output mode is set to scientific notation, and any data output will be rounded to the MDC.

## ERROR CONDITIONS

The error flag and error output are set upon detection of any of the error conditions listed in Table I. The resultant status of the SNC after an error condition is also shown in Table I. The error flag and error output are cleared only upon execution of any one of the following:

1. an ECLR (error clear) instruction
2. an MCLR (master clear) instruction
3. a hardware system reset

## Timing Diagram



Timing Diagrams (Continued)


FIGURE 4. MICROBUS Read Operation Timing


FIGURE 5. MICROBUS Write Operation Timing


FIGURE 6. Stack Level $x, y, z$ or $t$ Structure

Bit

| 7 | $\begin{aligned} 0= & \text { Scientific Notation I/O } \\ & \text { Mode } \\ 1= & \text { Floating Point I/O Mode } \end{aligned}$ |
| :---: | :---: |
| 6 | $\begin{aligned} & 0= \text { Round the Output to the } \\ & \text { MDC } \\ & 1= \text { Do Not Round the } \\ & \text { Output to the MDC } \\ & \hline \end{aligned}$ |
| 5 | Not Used |
| 4 | $\begin{aligned} 0= & \text { Angular Data is } \\ & \text { Expressed in Degrees } \\ 1= & \text { Angular Data is } \\ & \text { Expressed in Radians } \end{aligned}$ |
| 3 | $\begin{aligned} & 0=\|x\| \geq 1 \text { or }=0 \\ & 1=\|x\| \text { is a Non-Zero Fraction } \end{aligned}$ |
| 2 | $\begin{aligned} & 0=x \geq 0 \\ & 1=x<0 \end{aligned}$ |
| 1 | $\begin{aligned} & 0=x \neq 0 \\ & 1=x=0 \end{aligned}$ |
|  | $\begin{aligned} & 0=\text { No Error Has Occurred } \\ & 1=\text { Error Has Occurred } \end{aligned}$ |

FIGURE 7. SNC Status Register


FIGURE 8. Crystal Oscillator Configuration


FIGURE 9. Power-Up Reset Circuit

## Functional Description (Continued)

## MICROBUS COMMUNICATION

The SNC communicates via an 8-bit bidirectional bus ( $\mathrm{D}_{0}-$ $D_{7}$ ). The 8 -bit instruction opcodes are sent to the SNC on this bus and data is transferred between the SNC and its host on this bus. In addition to the bus, a chip select ( $\overline{\mathrm{CS}}$ ), read strobe ( $\overline{\mathrm{RD}}$ ), write strobe ( $\overline{\mathrm{WR}}$ ), and an interrupt/ready signal (INTR/RDY) complete the interface. The SNC will not respond to any signal on the bus or any of the control signals unless it has been selected (i.e., CS low) by the host. The SNY is ready to receive data or an instruction whenever the INTR/RDY is high. INTR/RDY high also indicates that the SNC has data available for the host. Pulsing the $\overline{\text { WR }}$ line (write strobe) transfers the information on the bus into the SNC. The write strobe going low forces INTR/RDY to go low. INTR/RDY will not return to the high state until the SNC has completed the operation required by the previous write. Pulsing the $\overline{\mathrm{RD}}$ line (read strobe) will cause an internal 8 -bit register of the SNC to be transferred to the external bus. INTR/RDY does not go low. Therefore, a read in this manner does not affect the readiness of the SNC. The SNC is in an idle condition when INTR/RDY is high. It is waiting for the next write and it will not proceed or escape from the idle loop until the device is selected and the WR is pulsed low. This characteristic makes the interface simple and allows the device to work with a host running at any speed.
Note: Do not pulse WF with the CS low when INTR/RDY is low. This can, in some cases, create errors in the SNC.

## INPUT/OUTPUT CONFIGURATIONS

The SNC input lines have the following configurations, illustrated in Figure 10:

1. $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}$-High-impedance (Figure 10a)
2. $\mathrm{Cl}, \overline{\text { RESET-Internal load device (Figure 10b) }}$

The output lines have the following configurations, illustrated in Figure 11:

1. $\mathrm{D}_{7}-\mathrm{D}_{0}$-TRI-STATE (Figure 11a)
2. $\mathrm{R}_{7}-\mathrm{R}_{0}$ —Push-pull with TRI-STATE (Figure 11b)
3. $\mathrm{O}_{3}-\mathrm{O}_{0}, \mathrm{I} / \mathrm{O}_{0}$, INTR/RDY, F1, F2, ERROR-Standard (Figure 11c)
4. SYNC—Push-pull (Figure 11d)

## Number Entry Mode Description

If the SNC is not in the number entry mode, the instructions AIN1, DP, BP, PI, or the numbers 0 through 9 will initiate number entry. This means that the stack is pushed $(z \rightarrow t$, $y \rightarrow z, x \rightarrow y$ ), the $x$ register is cleared, and the number entry mode established. If a number was entered to initiate the entry mode, that digit will go into the $x$ register; or, if EE was entered prior to the digit, that digit will go into the $x$ exponent. The subsequent entry of numbers, DP, EE, or PI does not again initiate number entry. Up to 12 mantissa digits may be entered, MSD entered first. Any digit entered after the 12th mantissa digit will simply be ignored. Up to two exponents digits may be entered, MSD entered first. If the user enters more than two exponent digits, only the last two entered will be accepted.
If number entry is initiated by the EE instruction, the $x$ mantissa is loaded with a " 1 ". Subsequent digits will go into the $x$ exponent.
The CS instruction does not initiate number entry. It normally toggles the sign of the $x$ mantissa. If, however, CS is entered after an EE instruction, the sign of the $x$ exponent will be toggled if the exponent is a non-zero number. CS may be mixed with the various digit entry instructions without interference.
Only mantissa digits may be entered through the use of the AIN1 instruction. This instruction causes the SNC to enter data into the x mantissa, starting at the MSD and ending at the LSD. One digit is entered for each AIN1 instruction. This instruction is actually a 2-byte instruction. The first byte is the instruction's opcode-OE hex. When INTR/RDY goes high, the SNC will respond with a digit address (ON, where N is a number from 0 to 11, MSD $\rightarrow$ LSD). The second byte writes the address N and the data for that address back to the SNC.
The following example illustrates the first time an AIN1 is entered:

| WRITE: | 0 O hex | (AIN1 opcode) |
| :--- | :--- | :--- |
| READ: | 00 hex | (SNC says write data to <br> mantissa address 0$)$ |
| WRITE: | 09 hex | $(9 \rightarrow$ mantissa digit 0$)$ |



TL/DD/5173-11

FIGURE 10. SNC Input Characteristics

## Input/Output Configuration (Continued)



TL/DD/5173-1
a. TRI-STATE Output


TL/DD/5173-13
b. Push-Pull Outputs with TRI-STATE

c. Standard Output

Standard Output
Source Current


Push-Pull Source
Current (Sync, R Pins)


Standard Output
Minimum Source Current


TRI-STATE Output Source Current (D Pins)



TL/DD/5173-15
d. Push-Pull Output

FIGURE 11. SNC Output Characteristics

The next example illustrates when AIN1 is entered immediately after the previous example:

| WRITE | OE hex | (AIN1 opcode) |
| :--- | :--- | :--- |
| AD: | 01 hex | (SNC says write data to <br> mantissa address 1) |
| WRITE: | 15 hex | $(5 \rightarrow$ mantissa digit 1) |

One exception to the number entry initiation is that the stack is not pushed if the instruction prior to an entered digit was EN (enter)-EN pushed the stack. However, the $x$ register is still cleared and the entered data put in x .
The number entry mode is terminated by any instruction except DP, EE, CS, PI, AIN1, NOP1, or any number.

## Data Input Description

The AIN2 instruction is a 2-byte, single digit asynchronous input instruction. This instruction does not initiate number entry mode and the $x$ level of the stack is not cleared. The first byte is the instruction's opcode: 91 hex. The second byte is of the form $n D$ where $n$ is the digit address and $D$ is the BCD digit. Since $\boldsymbol{n}$ is specified by the host, AIN2 can be used to write to any digit in the x register. Digits may only be entered in scientific notation format. This example will write a 7 to the MSD of the $x$ mantissa. Refer to Table IV.

| WRITE: | 91 hex | (AIN2 opcode) |
| :--- | :--- | :--- |
| WRITE: | 47 hex | (4 is the address of the |
|  |  | MSD mantissa digit, 7 |
|  | is data) |  |

## Data Output Description

The OUT instruction is a multidigit output instruction that will output all digits of the $x$ register. The host writes the OUT opcode (8F hex) and the SNC will respond with the address
of the data and the data in the form $n \mathrm{D}$ where n is the address and $D$ is the data. The host should then write the same information back to the SNC to indicate that it received the data. This procedure continues until all data has been read by the host. The data addresses are shown in Table III for scientific notation mode and in Table II for float-ing-point mode.
Table V contains data formats for other output instructions.

## Instruction Set Notes

Two of the TEST/CONDITIONAL OUTPUT instructionsIMNZ and DMNZ-deserve special comment. These instructions increment or decrement the memory mantissa and if the new value of the mantissa is $=0$, then $R$ will have the value contained in the operand field. The increment/ decrement portion affects the entire 12-digit mantissa, starting at digit 12 (LSD), regardless of the MDC and the decimal point. So, if the host wished to decrement the memory twice and then change $R$, the $x$ register would be cleared, AIN2 would be used to write a 2 to digit 12, and the memory and $x$ would be exchanged. The host could then expect the SNC to load $R$ upon the second execution of the DMNZ instruction.
If the host wished to observe the true results of the LSH (left shift $\times$ mantissa) and RSH (right shift $\times$ mantissa), rounding the output to the MDC should be disabled. Otherwise the shift might be obscured due to rounding.
Execution times for all SNC instructions are contained in Table VI. Typical instruction times are given for math and memory operation instructions, and worst case times given for all else. These times were found with the CKI input frequency equal to 4 MHz ( $4 \mu \mathrm{~s}$ microcycle time) and are measured from the rising edge of the $\overline{W R}$ signal to the rising edge of the INTR/RDY line.

TABLE I. SNC Error Conditions

| Error Condition | SNC Status |
| :---: | :---: |
| 1. In x or $\log \mathrm{x}$ when x is $\leq 0$ | $x, y, z, t, M$ unchanged |
| 2. $x+y, x-y, x^{*} y$, or $y / x$ when result is $\leq 10100$ or $<10^{-99}$ | Previous $x \rightarrow y$; $x$ is invalid data |
| 3. $M+x, M-x, M^{*} x$, or $M / x$ which result is $\geq 10^{100}$ or $<10^{-99}$ | $y, z, t, M$ unchanged; $x$ is invalid data |
| 4. Tan $90^{\circ}, 270^{\circ}, 450^{\circ}$, etc. | $y, z, t, M$ unchanged; $x$ is invalid data |
| 5. $\operatorname{Sin} x, \operatorname{Cos} x$, or Tan $x$ when the absolute value of $x$ is $\leq 9000^{\circ}$ (157.08 radians) | $y, z, t, M$ unchanged; $x$ is invalid data |
| 6. $\quad \arcsin \mathrm{x}$ or across x when the absolute value of $x$ is $>1$ or $\leq$ $10^{-50}$ | $y, z, t, M$ unchanged; $x$ is invalid data |
| 7. square root of $x$ when $x<0$ | $x, y, z, t, M$ unchanged |
| 8. $y / x$ when $x=0$ | $x, y$ swapped; $z, t, M$ unchanged |
| 9. $1 / \mathrm{x}$ when $\mathrm{x}=0$ | $1 \rightarrow x, y, z, t, M$ unchanged |
| 10. $M / x$ when $x=0$ | $M$ to $x ; y, z, t, M$ unchanged |
| 11. $\mathrm{y} \times$ when $\mathrm{y} \leq 0$ | $x$, y swapped; $z$, $t, M$ unchanged |
| 12. Floating-point OUT instruction when the number of mantissa digits to the left of the decimal point is $>12$ | $x, y, z, t, M$ unchanged |
| 13. Attempt to enter a number $\geq 10100 \text { or }<10^{-99}$ | Error occurs on termination of number entry mode. The stack push at initiation of number entry will occur normally. x contains invalid data. |

TABLE II. OUT Instruction-Floating-PoInt

| $D_{7}-D_{4}$ | DPX | $D_{3}$ | $D_{2}$ | $D_{1}$ |
| :---: | :---: | :--- | :--- | :--- |$\quad D_{0}$.

TABLE III. OUT Instruction-Sclentific Notation

| $D_{7}-D_{4}$ | $D_{3} \quad D_{2} \quad D_{1} \quad D_{0}$ |
| :--- | :--- |
| 0 | Most significant exponent digit. |
| 1 | Least significant exponent digit. |
| 2 | Sm $\quad 0 \quad 0 \quad \mathrm{Se}$ |
| 3 | Not used. |
| 4 | Most significant mantissa digit. Decimal point follows this digit. |
| 5 | Second most significant mantissa digit. |
| $\cdot$ | $\cdot$ |
| $\cdot$ |  |
| P |  |
| $M D C+3$ | Least significant mantissa digit. |

TABLE IV. AIN2 Instruction

| $D_{7}-D_{4}$ | $D_{3} \quad D_{2} \quad D_{1} \quad D_{0}$ |
| :--- | :--- |
| 0 | Most significant exponent digit. |
| 1 | Least significant exponent digit. |
| 2 | Sm $\quad 0 \quad 0 \quad$ Se |
| 3 | Not used. |
| 4 | Most significant mantissa digit. |
| 5 | Second most significant mantissa digit. |
| . | . |
| . |  |
| . | Second least significant mantissa digit. |
| 14 | Least significant mantissa digit. |

$\mathrm{Sm}=$ Sign of mantissa, $0=$ positive, $1=$ negative.
Se $=$ Sign of exponent, $0=$ positive, $1=$ negative.
MDC $=$ Mantissa digit count.
DP POS = Decimal point position indicator is a value in the range from 11 down to $12-\mathrm{MDC}$, which indicates a digit, as given by the DPX column in the table, after which the decimal point is located.

TABLE V. Output Instruction Data Formats

| Output Instruction | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OUT1 | (LSD+1) Digit 1 |  |  |  | (LSD) Digit 0 |  |  |  |
| OUT2 | (LSD+3) Digit 3 |  |  |  | (LSD+2) Digit 2 |  |  |  |
| OUT3 | (LSD+5) Digit 5 |  |  |  | (LSD+4) Digit 4 |  |  |  |
| OUT4 | (LSD+7) Digit 7 |  |  |  | (LSD+6) Digit 6 |  |  |  |
| OUT5 | (LSD+9) Digit 9 |  |  |  | (LSD + 8) Digit 8 |  |  |  |
| OUT6 | (MSD) Digit 11 |  |  |  | (MSD-1) Digit 10 |  |  |  |
| OUTSGN | Sign of Mantissa | 0 | 0 | Sign of Exponent |  | Link/ | d Digit |  |
| OUTEXP | MSD EXPONENT |  |  |  | LSD Exponent |  |  |  |
| OUTST | $\begin{aligned} & \text { I/P } \\ & \text { Mode } \end{aligned}$ | Round. <br> Mode | Not <br> Used | Angles <br> Mode | $x \text { As }$ <br> Fraction | Sign of <br> x | $\begin{gathered} \times \text { Comp. } \\ \text { to } 0 \end{gathered}$ | Error <br> Status |
| OUTIO | $1 \mathrm{O}_{3}$ | $1 \mathrm{O}_{2}$ | $1 \mathrm{O}_{1}$ | $1 \mathrm{O}_{0}$ | 1 | 0 | 0 | 1 |
| OUTO | $\mathrm{O}_{3}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{1}$ | $\mathrm{O}_{0}$ | 1 | 1 | 0 | 1 |
| OUTR | $\mathrm{R}_{7}$ | $\mathrm{R}_{6}$ | $\mathrm{R}_{5}$ | $\mathrm{R}_{4}$ | $\mathrm{R}_{3}$ | $\mathrm{R}_{2}$ | $\mathrm{R}_{1}$ | $\mathrm{R}_{0}$ |
| OUTFL | 0 | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | 0 | $\mathrm{IF}_{4}$ | $\mathrm{IF}_{3}$ | $\mathrm{IF}_{2}$ | $\mathrm{IF}_{1}$ |
| OUTMDC | MDC ${ }_{\text {MSB }}$ | $\mathrm{MDC}_{\text {MSB }-1}$ | MDC ${ }_{\text {MSB }-2}$ | MDCLSB | 1 | 1 | 0 | 0 |

TABLE VI. Instruction Execution Times
All times are measured with 4 MHz at CKI and are measured from the rising edge of $\overline{\mathrm{WR}}$ to the rising edge of INTR/RDY.

| Instruction | Worst Case Execution Time (ms) | Instruction |  | Worst Case Execution Time (ms) |
| :---: | :---: | :---: | :---: | :---: |
| 0-9 | 1.6 | TJC | 1st Byte | 3.0 |
| DP | 1.5 | a | 2nd Byte | 1.4 |
| EE | 1.5 | TX2 | 1st Byte | 3.0 |
| CS |  | a | 2nd Byte | 1.4 |
| PI | 1.8 | TXN | 1st Byte | 3.0 |
| AIN1 1st Byte | 0.3 | a | 2nd Byte | 1.4 |
| 2nd Byte | 0.9 | TXF | 1st Byte | 3.0 |
| NOP1 | 1.6 | a | 2nd Byte | 1.4 |
| NOP2 | 3.1 | TERR | 1st Byte | 3.0 |
| SMDC $n$ | 3.1 | a | 2nd Byte | 1.4 |
| 10 n | 3.1 | TMNZ | 1st Byte | 4.0 |
| On | 3.1 | a | 2nd Byte | 1.4 |
| LDR 1st Byte | 3.1 | TMZ | 1st Byte | 4.0 |
| 2nd Byte | 1.5 | a | 2nd Byte | 1.4 |
| AIN2 1st Byte | 3.1 | TFI | 1st Byte | 1.1 |
| 2nd Byte | 1.5 | a | 2nd Byte | 0.5 |
| OUT1-OUT6 | 3.0 | TFL | 1st Byte | 1.1 |
| OUTSGN | 3.0 | a | 2nd Byte | 0.5 |
| OUTEXP | 3.0 | IMNZ | 1st Byte | 3.0 |
| OUTST | 3.0 | a | 2nd Byte | 0.5 |
| OUTIO | 3.0 | DMNZ | 1st Byte | 4.4 |
| OUTO | 3.0 | a | 2nd Byte | 0.5 |
| OUTR | 3.0 | TIF1-4 | 1st Byte | 3.0 |
| OUTFL | 3.0 | a | 2nd Byte | 1.5 |
| OUTMDC | 3.0 |  |  |  |
| OUT 1st Byte | 3.0 |  |  |  |

TABLE VI. Instruction Execution Times (Continued)

| Instruction | Worst Case <br> Execution TIme (ms) | Instruction | Worst Case <br> Execution Time (ms) |
| :--- | :---: | :---: | :---: |
| RAD | 2.7 | MCLR | 5.1 |
| DEG | 2.7 | EN | 5.5 |
| NRND | 2.7 | ROLL | 8.4 |
| RND | 2.7 | POP | 8.6 |
| FLP | 2.7 | SIN | 820 |
| SCI | 2.7 | COS | 830 |
| ECLR | 2.7 | TAN | 540 |
| SIF1-4 | 2.7 | ARCSIN | 840 |
| RIF1-4 | 2.7 | ARCCOS | 700 |
| ROFF | 2.7 | ARCTAN | 410 |
| RON | 2.7 | RTD | 162 |
| RIO | 2.7 | DTR | 162 |
| SF1 | 2.7 | 2.9 |  |
| PF1 | 2.7 | EXY | 440 |
| SF2 | 2.7 | IOX | 100 |
| PF2 | 2.7 | SQ | 18 |
| Math/Memory | Typical | SQRT | 48 |
| Instructlon | Execution Time (ms) | LN | 210 |
| XXM | 4.2 | LOG | 140 |
| MS | 5.7 | I/X | 66 |
| MR | 7.0 | YX | 400 |
| M+ | 13.2 | + | 20 |
| M- | 13.2 | 20 | 20 |
| M* | 11.8 | $/$ | 66 |
| M/ | 60 | 5.2 |  |
| CLRM | 6.0 | 2.5 |  |
| CLRX | 3.0 | RSH |  |

Note 1: Add 0.3 ms to the execution time of any instruction which initiates number entry and is preceded by an enter instruction.
Note 2: Add 2.5 ms to the execution time of any instruction which lnitiates number entry and is not preceded by an enter instruction. Note 3: Add 2.0 ms to the execution time of any instruction which terminates number entry mode.

MM57409 Number Cruncher Instruction Set

| Mnemonic | Operand | Hex <br> Code | Description |
| :--- | :--- | :--- | :--- |

## BASIC NUMBER ENTRY INSTRUCTIONS

| 0 |  | 00 | Mantissa or exponent digits. If the previous code was EN (enter), |
| :---: | :---: | :---: | :---: |
| 1 |  | 01 | then the digit is placed in $x$. If the previous code was not EN, the |
| 2 |  | 02 | stack is pushed as follows: |
| 3 |  | 03 | digit $\rightarrow \mathrm{x}$ |
| 4 |  | 04 | $x \rightarrow y$ |
| 5 |  | 05 | $y \rightarrow z$ |
| 6 |  | 06 | $z \rightarrow t$ |
| 7 |  | 07 |  |
| 8 |  | 08 |  |
| 9 |  | 09 | See Number Entry Mode Description |
| DP |  | OA | Decimal point. Digits that follow will be mantissa fraction. |
| EE |  | OB | Enter exponent. Digits that follow will be exponent digits. If this is the first data entry, a "1" will be loaded into the mantissa. |
| CS |  | 0 C | Change sign. The mantissa's sign is changed unless EE was the last number entry initiation, in which case the exponent's sign is changed. |
| PI |  | OD | $3.14159265359 \rightarrow$ x. |
| AIN1 |  | OE | Single digit asynchronous input. See Number Entry Mode Description. |
| NOP1 |  | OF | No operation. |
| NOP2 |  | 22 | Terminate number entry, no other operation. |

MM57409 Number Cruncher Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Description |
| :---: | :---: | :---: | :--- |
| MANTISSA DIGIT COUNT (MDC) CONTROL INSTRUCTIONS |  |  |  |
| SMDC | $n$ | $7(n-1)$ | Set the MDC $=n . n=1,2,3,4,5,6,7,8,9, A, B, C$ hex |

I/O, O, AND PC PORT WRITE INSTRUCTIONS

| $\begin{gathered} 10 \\ 0 \\ \text { LDR } \end{gathered}$ | $\begin{aligned} & n \\ & n \\ & \mathrm{a} \end{aligned}$ | $A(n)$ <br> $B(n)$ <br> 92 <br> a | Write $n$ to the 4-bit general I/O port. $n=0$ through $F$ hex. Write $n$ to the 4-bit general $O$ port. $n=0$ through $F$ hex. Load the R port with " $a$ ", where " $a$ ", is 8 -bit value from 00 hex through FF hex. |
| :---: | :---: | :---: | :---: |
| DATA INPUT INSTRUCTIONS |  |  |  |
| AIN2 |  | 91 | Asynchronous input 2. See Data Input Description. |
| DATA OUTPUT INSTRUCTIONS |  |  |  |
| OUT1 <br> OUT2 <br> OUT3 <br> OUT4 <br> OUT5 <br> OUT6 <br> OUTSGN <br> OUTEXP <br> OUTST <br> OUTIO <br> OUTO <br> OUTR <br> OUTFI <br> OUTMDC OUT |  | 80 <br> 81 <br> 82 <br> 83 <br> 84 <br> 85 <br> 86 <br> 87 <br> 88 <br> 89 <br> 8D <br> 8A <br> 8B <br> 8 C <br> 8F | Output $x$ mantissa LSD and LSD +1 . <br> Output $x$ mantissa LSD +2 and LSD +3 . <br> Output $x$ mantissa LSD +4 and LSD +5 . <br> Output $x$ mantissa LSD +6 and LSD +7 . <br> Output $x$ mantissa LSD +8 and LSD +9 . <br> Output $x$ mantissa MSD -1 and MSD. <br> Output link/guard digit and mantissa/exponent sign digit. <br> Output x exponent digit. <br> Output 8-bit status register. <br> Output the state of the 4-bit general I/O port. <br> Output the state of the 4-bit general outut port. <br> Output the state of the 8 -bit R port. <br> Output F1, F2, and the four internal flags, IF1 through IF4. <br> Output the Mantissa Digit Count. <br> Multiple digit output instruction. See Data Output Description. |

TEST/CONDITIONAL OUTPUT INSTRUCTIONS

| TCl | a | $10$ | If external test input $C l=$ logic " 1 ", load R with " $a$ ", where " $a$ " is an 8 -bit value from 00 hex through $F F$ hex. |
| :---: | :---: | :---: | :---: |
| TXZ | a | 11 | If $x=0$, load $R$ with " $a$ ". |
| TXN | a | 12 | If $x$ is negative, load $R$ with " $a$ ". |
|  |  | a |  |
| TXF | a | 13 | If the absolute value of $x$ is a fraction, load $R$ with " $a$ ". |
|  |  | a |  |
| TERR | a | 14 | If the error flag is set, load R with "a". |
| TMNZ | a | 16 | If memory is not equal to 0 , load $R$ with " $a$ ". |
|  |  | a |  |
| TMZ | a | 17 | If memory equals 0 , load $R$ with " a ". |
| TF1 | a | a |  |
| TFi | a | $\begin{gathered} 18 \\ \mathrm{a} \end{gathered}$ | If the external flag input $1=\operatorname{logic}$ " 1 ", load R with " a ". |
| TF2 | a | 1 B | If the external flag input $2=\operatorname{logic}$ " 1 ", load R with " a ". |
|  |  | a |  |
| IMNZ | a | 19 | Increment the mantissa contained in memory, and if the new |
|  |  | a | value of the memory is not $=0$, load $R$ with " $a$ ". |
| DMNZ | a | 1A | Decrement the mantissa contained in memory, and if the new |
|  |  | $\stackrel{a}{a}$ | value of the memory is not $=0$, load R with "a". |
| TIF | $\mathrm{n}, \mathrm{a}$ | $\begin{gathered} 1(B+n) \\ a \end{gathered}$ | If the internal flag $n=$ logic " 1 ", load $R$ with " $a$ ". $n=1,2,3,4$. |

MM57409 Number Cruncher Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Description |
| :--- | :--- | :---: | :---: |

## MATH INSTRUCTIONS

| CLRX |  | 20 <br> MCLR | $0 \rightarrow x$. <br> Master clear: clear all internal registers and outputs; $10 \rightarrow$ <br> MDC. Scientific notation mode; round to MDC on output; $\rightarrow$ port <br> set to 03 hex and is enabled; I/O port unaffected. |
| :---: | :--- | :--- | :--- |
| EN | 21 | Enter and push stack. The same digit will be in $x$ and $y$. <br> ROLL. | 23 |



MM57409 Number Cruncher Instruction Set (Continued)

| Mnemonic | Operand | Hex <br> Code | Description |
| :---: | :---: | :---: | :---: |
| MODE AND FLAG INSTRUCTIONS |  |  |  |
| RAD |  | 50 | Set radian angular mode. |
| DEG |  | 51 | Set degrees angular mode. |
| NRND |  | 54 | Round to MDC on output disabled. |
| RND |  | 55 | Round to MDC on output enabled. |
| FLP |  | 56 | Set floating-point I/O mode. |
| SCl |  | 57 | Set scientific notation I/O mode. |
| ECLR |  | 2B | Clear error flag. |
| SIF1 |  | 58 | Set internal flag 1. |
| SIF2 |  | 5A | Set internal flag 2. |
| SIF3 |  | 5C | Set internal flag 3. |
| SIF4 |  | 5E | Set internal flag 4. |
| RIF1 |  | 59 | Reset internal flag 1. |
| RIF2 |  | 5B | Reset internal flag 2. |
| RIF3 |  | 5D | Reset internal flag 3. |
| RIF4 |  | 5F | Reset internal flag 4. |
| OUTPUT CONTROL INSTRUCTIONS |  |  |  |
| ROFF |  | 60 | TRI-STATE the R port. |
| RON |  | 61 | Enable the R port. |
| RIO |  | 52 | R port is enabled as high-impedance I/O. |
| SF1 |  | 67 | Set external flag 1 high. |
| PF1 |  | 68 | Pulse external flag 1 high. If F1 is already high, then it is reset. |
| SF2 |  | 69 | Set external flag 2 high. |
| PF2 |  | 6A | Pulse external flag 2 high. If F2 is already high, then it is reset. |

Section 4
COPS Applications

## Section 4 Contents

COP Brief 2 Easy Logarithms for COP400 ..... 4-3
COP Brief 4 L-Bus Considerations ..... 4-14
COP Brief 5 Software and Opcode Differences in the COP444L Instruction Set ..... 4-15
COP Brief 6 RAM Keep-Alive ..... 4-16
COP420-QRX/N Preprogrammed Single-Chip Microcontroller for Musical Organ ..... 4-17
COP Note 1 Analog to Digital Conversion Techniques with COPS Family Microcontrollers ..... 4-19
COP Note 4 The COP444L Evaluation Device 444L-EVAL ..... 4-51
COP Note 5 Oscillator Characteristics of COPS Microcontrollers ..... 4-56
COP Note 6 Triac Control Using the COP400 Microcontroller Family ..... 4-73
COP Note 7 Testing of COPS Chips ..... 4-81
AB-3 Current Consumption in NMOS COPS Controllers ..... 4-90
AB-4 Further Information on Testing of COPS Microcontrollers ..... 4-92
AB-6 COPS Interrupts ..... 4-94
AB-15 Protecting Data in the NMC9306/COP494 and NMC9346/COP495
Serial EEPROMS ..... 4-95
AB-28 COPS Peripheral Chips ..... 4-97
AN-326 A Users Guide to COPS Oscillator Operation ..... 4-99
AN-329 Implementing an 8-bit Buffer in COPS ..... 4-103
AN-338 Designing with the NMC9306/COP494 a Versatile Simple to Use E2PROM ..... 4-107
AN-400 A Study of the Crystal Oscillator for CMOS-COPS ..... 4-114
AN-401 Selecting Input/Output Options on COPS Microcontrollers ..... 4-118
AN-452 MICROWIRE Serial Interface ..... 4-128
AN-453 COPS Based Automobile Instrument Cluster ..... 4-139
AN-454 Automotive Multiplex Wiring ..... 4-144
AN-455 The COPS Programming Manual ..... 4-148

## Easy Logarithms for COP400

Logarithms have long been a convenient tool for the simpli－ fication of multiplication，division，and root extraction．Many assembly language programmers avoid the use of loga－ rithms because of supposed complexity in their application to binary computers．Logarithms conjure up visions of time consuming iterations during the solution of a long series． The problem is far simpler than imagined and its solution yields，for the applications programmer，the classical bene－ fits of logarithms：
1）Multiplication can be performed by a single addition．
2）Division can be performed by a single subtraction．
3）Raising a number to a power involves a single multiply．
4）Extracting a root involves a single divide．
When applied to binary computer operation logarithms yield two further important advantages．First，a broad range of values can be handled without resorting to floating point techniques（other than implied by the characteristic）．Sec－ ond，it is possible to establish the significance of an answer during the body of a calculation，again，without resorting to floating point techniques．
Implementation of base ${ }_{10}$ logarithms in a binary system is cumbersome and unnecessary since logarithmic functions can be implemented in a number system of any base．The techniques presented here deal only with logarithms to the base 2.
A logarithm consists of two parts：an integer characteristic and a fractional mantissa．


FIGURE 1．The Logarithmic Function and Some Example Values

In Figure 1 some points on the logarithmic curve are identi－ fied and evaluated to the base $e_{2}$ ．Notice that the characteris－ tic in each case represents the highest even power of 2 contained in the value of $X$ ．This is readily seen when binary notation is used．

| $\mathrm{X}_{10}$ | $\mathrm{X}_{2}$ |  |  |  |  | $\log _{2} X$ | $\log _{2} X \text { Where } X=$$\text { Even Power of } 2$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 24 | $2{ }^{3}$ | $2{ }^{2}$ | 21 | 20 | Characteristic |  |
| 3 | 0 | 0 | 0 | $1$ | 1 | 1 |  |
| 4 | 0 | 0 | 1 | 0 | 0 | 2 | 010.0000 |
| 8 | 0 | 1 | 0 | 0 | 0 | 3 | 011.0000 |
| 10 | 0 | $\begin{aligned} & 1 \\ & \mathbf{A} \end{aligned}$ | 0 | 1 | 0 | 3 |  |

FIGURE 2．Identification of the Characteristic
In Figure 2 each point evaluated in Figure 1 has been re－ peated using binary notation．An arrow subscript indicates the highest even power of 2 appearing in each value of $X$ ． Notice that in $X=3$ the highest even power of 2 is 21 ．Thus the characteristic of the $\log _{2} 3$ is 1 ．Where $X=10$ the characteristic of the $\log _{2} 10$ is 3 ．
To find the $\log _{2} X$ is very easy where $X$ is an even power of 2．We simply shift the value of $X$ left until a carry bit emerges from the high order position of the register．This procedure is illustrated in Figure 3．This characteristic is found by counting the number of shifts required and subtracting the result from the number of bits in the register．In practice it is easier to being with the number of bits and count down once prior to each shift．

| Counter for <br> Characteristic | Value of X in Binary |  |  |
| :---: | :---: | :---: | :--- |
| 1000 | 0000 | 1000 | Initial |
| 0111 | 0001 | 0000 | First Shift |
| 0110 | 0010 | 0000 | Second Shift |
| 0101 | 0100 | 0000 | Third Shift |
| 0100 | 1000 | 0000 | Fourth Shift |
| 0011 | 0000 | 0000 | Fifth Shift |
| Characteristic | Mantissa | Final |  |
| 011.0000 | 0000 | Log $_{2} X=3.00$ |  |

## FIGURE 3．Conversion to Base $_{2}$ Logarithm by Base Shift

Examination of the final value obtained in Figure 3 reveals no bits in the mantissa．The value 3 in the characteristic， however，indicates that a bit did exist in the $2^{3}$ position of the original number and would have to be restored in order to reconstruct the original value（antilog）．

The log of any even power of 2 can be found in this way:

| Decimal | Binary | $\log _{2}$ |
| :---: | :---: | :---: |
| 128 | 10000000 | 0111.00000000 |
| 64 | 01000000 | 0110.00000000 |
| 32 | 00100000 | 0101.00000000 |
| 4 | 00000100 | 0010.00000000 |
| 2 | 00000010 | 0001.00000000 |
| 1 | 00000001 | 0000.00000000 |

A simple flow chart, and program, can be devised for generating the values found in the table and, as will be apparent, a straight line approximation for values that are not even powers of 2. The method, as already illustrated in Figure 3, involves only shifting a binary number left until the most significant bit moves into the carry position. The characteristic is formed by counting. Since a carry on each successive shift will yield a decreasing power of 2 , we must start the characteristic count with the number of bits in the binary value ( x ) and count down one each shift.

FIGURE 4. Base $_{2}$ Logarithms of Even Powers of 2


FIGURE 5. Log Flowchart

COP CROSS ASSEMBLER LOGS
; TITLE LOGS
; BINARY LOGARITHMS


PAGE: 1 .
. LOCAL
; CH, HM, LM REPRESENT ANY THREE SEQUENTIAL MEMORY DIGITS. THEY
; MAY BE DEFINED IN ANY REGISTER. THE SYMBOLIC NOTATION CH, HM,
AND LM ARE USED FOR ADDRESSING TO ALLOW USER FLEXIBILITY
UPON ENTRY TO THE ROUTINE HM AND LM CONTAIN THE HI AND LO
OF SOME VALUE X. THE MEMORY POINTER MUST CONTAIN THE ADDRESS
; OF THE CHARACTERISTIC (CH). THE CONTENTS OF THIS LOCATION ARE
; IGNORED AND ARE LOST DURING EXECUTION.
; UPON EXIT CH, HM, LM CONTAIN A STRAIGHT LINE APPROXIMATION OF
; THE LOG BASE 2 OF X. CH = CHARACTERISTIC HM = HI ORDER MANTISSA
; LM = LO ORDER MANTISSA. AN 8 BIT MEMORY AREA (TEMP) IS USED IN
IHE REGISTER OPPOSITE DURING THE CORRECTION OF A STRAIGHT
; $\quad$ TEST IS MADE FOR $X=0$. IF THE VALUE OF $X$
AN INSTRUCTION IS SKIPPED UPON RETURN
TO THE CALLING ROUTINE.
; SUBROUTINE CALL
RETURN HERE IF $X=0 \rightarrow$
; RETURN HERE IF $\mathrm{X}>0$ - $\rightarrow$
;
;

OG2:
AISC
$X$
07
STORE IN MEMORY

PAGE: 2

| \$LP1: | JSRP | SDB2 |
| :--- | :--- | :--- |
|  | JSRP | SHLR |
|  |  |  |
| \$TS1: | SKC |  |
| \$LST: | JP | \$NO |
| \$NO: | RETSK |  |
|  | LD |  |
| \$TS2: | AISC | -1 |
|  | RET |  |
|  | X |  |
|  | JP | $\$ L P 1$ |

TL/DD/6942-5

[^8]; PROGRAM: SDB2, SHLR.

The program shown develops the $\log _{2}$ of any even power of 2 by shifting and testing as previously described. Examine what happens to a value of $X$ that is not an even power of 2. In Figure 7, the number 25 is converted to a base 2 log.

$$
\begin{aligned}
& 25_{10}=00011002_{2} \\
& \quad \text { Shift left until carry }=1
\end{aligned}
$$

## Characteristic Carry Mantissa $\log _{2}$ <br> $0100 \quad 1 \quad 100100000100.10010000$

Figure 7. Straight Line Approximation of Base $\mathbf{L}_{\mathbf{2}} \mathbf{L o g}$
The resulting number when viewed as an integer characteristic and a fractional mantissa is $4.5625_{10}$. The fraction 0.5625 is a straight line approximation of the logarithmic curve between the correct values for the base $e_{2}$ logs of 24 and $2^{5}$. The accuracy of this approximation is sufficient for many applications. The error can be corrected, as will be seen later in this discussion, but for now let's look at the problem of exponents or the conversion to an antilog.

To reconstruct the original value of $X$, find the antilog, requires only restoration of the most significant bit and then its alignment with the power of 2 position indicated by the characteristic. In the example, approximation $\left(\log _{2} 25=\right.$ 0100.1001 ) restoration of MSB can be accomplished by shifting the mantissa (only) one position to the right. In the process a one is shifted into the MSB position.

| Approximation of $\log _{2} X$ | Restoration of MSB |
| :---: | :---: |
| Char. Mantissa | Char. Mantissa |
| 0100.10010000 | 0100.11001000 |

The value of the characteristic is 4 so the mantissa must be shifted to the right until MSB is aligned with the $2^{4}$ position.

| $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The completion of this operation restores the value of $X$ $(X=25)$ and is the procedure used to find an antilog. Figure 8 is a flow chart for finding an antilog using this procedure. Ths implementation in source code is shown in Figure 9.


FIGURE 8. Flow Chart for Conversion to Antilog

```
COP CROSS ASSEMBLER PAGE }
```

LOGS


FIGURE 9

Using the linear approximation technique just described， some error will result when converting any value of $X$ that is not an even power of 2.
Figure 10 contains a table of correct base 2 logarithms for values of X from 1 through 32 along with the error incurred for each when using linear approximation．Notice that no error results for values of $X$ that are even powers of 2 ．Also notice that the error incurred for multiples of even powers of 2 of any given value of X is always the same．

| Value of $X$ | Error |
| ---: | ---: |
| 5 | 0.12 |
| $2 \times 5=10$ | 0.12 |
| $4 \times 5=20$ | 0.12 |
| 3 | 0.15 |
| $2 \times 3=6$ | 0.15 |
| $4 \times 3=12$ | 0.15 |
| $8 \times 3=24$ | 0.15 |


| X | Hexadecimal Log Base | Linear Approximation of Log Base 2 | Error Hexadecimal | $E_{M}-1+\frac{E M-E M-1}{2}$ |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 0.00 | 0.00 | 0.00 |  |
| 2 | 1.00 | 1.00 | 0.00 |  |
| 3 | 1.95 | 1.80 | 0.15 |  |
| 4 | 2.00 | 2.00 | 0.00 |  |
| 5 | 2.52 | 2.40 | 0.12 |  |
| 6 | 2.95 | 2.80 | 0.15 |  |
| 7 | 2.CE | $2 . \mathrm{CO}$ | 0.0E |  |
| 8 | 3.00 | 3.00 | 0.00 |  |
| 9 | 3.2 B | 3.20 | 0.0B |  |
| 10 | 3.52 | 3.40 | 0.12 |  |
| 11 | 3.75 | 3.60 | 0.15 |  |
| 12 | 3.95 | 3.80 | 0.15 |  |
| 13 | 3.83 | 3.40 | 0.13 |  |
| 14 | 3.CE | $3 . \mathrm{CO}$ | 0.0E |  |
| 15 | 3.58 | 3.E0 | 0.08 |  |
| 16 | 4.00 | 4.00 | 0.00 | 0.03 |
| 17 | 4.16 | 4.10 | 0.06 | 0.09 |
| 18 | 4.2 B | 4.20 | 0.08 | 0.00 |
| 19 | 4.3 F | 4.30 | 0.0F | 0.11 |
| 20 | 4.52 | 4.40 | 0.12 | 0.15 |
| 21 | 4.67 | 4.50 | 0.17 | 0.16 |
| 22 | 4.75 | 4.60 | 0.15 | 0.16 0.16 |
| 23 | 4.87 | 4.70 | 0.17 | 0.16 |
| 24 | 4.95 | 4.80 | 0.15 | 0.15 |
| 25 | 4.A4 | 4.90 | 0.14 | 0.14 |
| 26 | $4 . \mathrm{B3}$ | 4.1A0 | 0.13 | 0.12 |
| 27 | $4 . \mathrm{C1}$ | 4.80 | 0.11 | 0.12 |
| 28 | 4.CE; | $4 . \mathrm{CO}$ | 0.0E | 0.0 D |
| 29 | 4.DB | 4.D0 | 0.0B | 0.0A |
| 30 | 4.E8 | 4.E0 | 0.08 | 0.0A |
| 31 | 4.F4 | 4.F0 | 0.04 |  |
| 32 | 5.00 | 5.00 | 0.00 |  |
| 33 |  | 5.1- |  |  |

FIGURE 10. Error Incurred by Linear Approximation of Base 2 Logs

An error that repeats in this way is easily corrected using a look-up table. The greatest absolute error will occur for the least value of $X$ not an even power of $2, X=3$, is about $8 \%$. A 4 point correction table will eliminate this error but will move the greatest uncompensated error to $X=9$ where it
will be about $4 \%$. This process continues until at 16 correction points the maximum error for the absolute value of the logarithm is less than 1 percent. This can be reduced to 0.3 percent by distributing the error. Interpolated error values are listed in Figure 10 and are repeated in Figure 11 as a binary table.

| High Order <br> 4 Mantissa <br> Blts | Binary <br> Correction <br> Value | Hexadecimal <br> Correction <br> Value |
| :---: | :---: | :---: |
| 0000 | 00000000 | 00 |
| 0001 | 00001001 | 09 |
| 0010 | 00001101 | 03 |
| 0011 | 00010001 | 11 |
| 0100 | 00010101 | 15 |
| 0101 | 00010110 | 16 |
| 0110 | 00010110 | 16 |
| 0111 | 00010110 | 16 |
| 1000 | 00010101 | 15 |
| 1001 | 00010100 | 14 |
| 1010 | 00010010 | 12 |
| 1011 | 00010000 | 10 |
| 1100 | 00001101 | 0 D |
| 1101 | 00001010 | 0 A |
| 1110 | 00000110 | 06 |
| 1111 | 00000010 | 02 |

## FIGURE 11. Correction Table for $\mathbf{L}_{2} \mathbf{X}$ Linear Approximations

Notice in Figure 10 that left justification of the mantissa causes its high order four bits to form a binary sequence that always corresponds to the proper correction value. This works to advantage when combined with the COP400 LQID instruction. LQID implements a table look-up function using the contents of a memory location as the address pointer. Thus we can perform the required table look-up without disturbing the mantissa.
Figure 12 is the flow chart for correction of a logarithm found by linear approximation. Figure 13 is its implementation in COP400 assembly language. Notice that there are two entry points into the program. One is for correction of logs (LADJ:), the other is for correction of a value prior to its conversion to an antilog (AADJ:).


## Subroutines Used by the Log and Antilog Programs

| $\begin{aligned} & \text { COP CR } \\ & \text { LOGS } \end{aligned}$ | S AS | MBLEI | GE: 6 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 172 |  |  |  | . FORM |  |  |
| 173 |  | 0080 | . PAGE |  | ; ${ }^{\text {.... }} \rightarrow$ |  |
| 174 |  |  |  |  |  |  |
| 175 |  |  | ; THE F | NG ROU | AESIDE | AGE. THEY |
| 176 |  |  | ; ARE C | BY THE | OOGRAM | URPOSE IN |
| 177 |  |  | ; NATUR | FUNCTIO | TILITY |  |
| 178 |  |  |  |  |  |  |
| 179 |  |  |  |  |  |  |
| 180 |  |  |  |  |  |  |
| 181 |  |  |  | ; $\rightarrow$ - $\rightarrow$ - | ENT 8 |  |
| 182 |  |  |  |  |  |  |
| 183 |  |  |  | . LOCA |  |  |
| 184 |  |  |  |  |  |  |
| 185 |  |  | ; THIS R | FORMS | MORY T | F THE TWO |
| 186 |  |  | ; ADJAC | GITS IDE | BY TH |  |
| 187 |  |  | ; CONT | F THE A | POINTE |  |
| 188 |  |  |  |  |  |  |
| 189 |  |  | ; THERE | WO ENT | TS: |  |
| 190 |  |  | ; |  |  |  |
| 191 |  |  | ; COP: | MENT 8 |  |  |
| 192 |  |  | ; |  |  |  |
| 193 |  |  | ; CMPE | D THE C | MENT T |  |
| 194 |  |  | ; |  |  |  |
| 195 |  |  |  |  |  |  |
| 196 | 080 | 22 | COMP: | SC |  |  |
| 197 | 081 | 00 | CMPE: | CLRA |  | ; SET MINU |
| 198 | 082 | 06 |  | X |  | ; AND STOP |
| 199 | 083 | 10 |  | CASC |  |  |
| 200 | 084 | 44 |  | NOP |  | ; |
| 201 | 085 | 04 |  | XIS |  | ; |
| 202 | 086 | 00 |  | CLRA |  | ; SET MINU |
| 203 | 087 | 06 |  | X |  | ; AND STOR |
| 204 | 083 | 10 |  | CASC |  | ; |
| 205 | 089 | 44 |  | NOP |  |  |
| 206 | 08A | 04 |  | XIS |  | ; |
| 207 | 08B | 44 |  | NOP |  | ; AVOID SKI |
| 208 | 08C | A4 |  | JP | SDB2 | ; RETURN T |
| 209 |  |  |  |  |  | ; TO RESTO |
| 210 |  |  |  |  |  |  |
| 211 |  |  |  |  |  |  |
| 212 |  |  |  |  |  |  |
| 213 |  |  | $; \cdots$ | TS IN A | REGIS |  |
| 214 |  |  |  |  |  |  |
| 215 |  |  |  | . LOCA |  |  |
| 216 |  |  |  |  |  |  |
| 217 |  |  |  |  |  |  |
| 218 |  |  |  |  |  |  |
| 219 |  |  | ; THIS R | ADDS | ARY DI | Y REGISTER |
| 220 |  |  | ; TO TH | ESPOND | O BINA | EGISTER |
| 221 |  |  | ; IMMED | ADJAC | RE AR |  |
| 222 |  |  | ; |  |  |  |
| 223 |  |  | ; | LADR: | T CARR | IRS |



COP CROSS ASSEMBLER LOGS

## 281

282

## 283

284
285
286

## 287

288
289
290

## 291

292
293
294
295

COP CROSS ASSEMBLER PAGE: 9
LOGS

| 332 | OBO | 44 |
| :--- | :--- | :--- |
| 333 | OB1 | 04 |
| 334 | $0 B 2$ | 48 |


| 325 | OA9 | 32 | SHLR: | RC | ; CLEAR CARRY PRIOR TO SHIFT. |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 326 | OAA | 05 | SHLC: | LD | ; LOAD FIRST MEM DIGIT. |
| 327 | OAB | 30 |  | ASC | ; DOUBLE IT. |
| 328 | OAC | 44 |  | NOP | ; AVOID SKIP. |
| 329 | OAD | 04 |  | XIS | ; STORE SHIFTED DIGIT. |
| 330 | OAE | 05 | SHL1: | LD | LOAD NEXT MEM DIGIT. |
| 331 | OAF | 30 |  | ASC | ; DOUBLE IT TOO. |

PAGE: 8
. LOCAL
; THIS ROUTINE SUBTRACTS 2 FROM THE CONTENTS OF THE ; DIGIT POINTER (B REGISTER). THE CONTENTS OF THE
; ACCUMULATOR ARE LOST IN THE PROCESS. THE USE OF ; SDB2 ALLOWS ADDRESSING WITHIN THE LOGS SUB
; ROUTINE TO bE RELATIVE TO THE CONTENTS OF THE
; ADDRESS POINTER (B REGISTER) UPON ENTRY.
; SDB2 IS COMMONLY USED IN BYTE OPERATIONS TO RESTORE THE ; DIGIT POINTER TO THE LOW ORDER POSITION. ; THERE ARE TWO ENTRY POINTS:
;
; SDR2: SET DIGIT ADDRESS BACK 2 AND MOVE TO OPPOSITE REGISTER.
;
; SDB2: SET DIGIT ADDRESS BACK 2 RETAINING PRESENT REGISTER.

| SDR2: | LD | 03 | ; MOVE TO OPPOSITE REGISTER. |
| :--- | :--- | :--- | :--- |
| SDB2: | CBA |  | ; PLACE DIGIT COUNT IN ACC. |
|  | AISC | -2 | ; SUBTRACT 2. |
|  | NOP |  | SHOULD ALWAYS SKIP. |
|  | CAB |  | PUT DIGIT COUNT BACK. |
|  | RET |  | FINISHED - RETURN!! |

; .....- SHIFT LEFT …... ;
. LOCAL
; THIS ROUTINE SHIFTS LEFT THE CONTENTS OF TWO MEMORY ; LOCATIONS ONE BIT. THERE ARE THREE ENTRY POINTS:

SHLR: RESETS THE CARRY BEFORE SHIFIING IN ORDER TO FILL THE LOW ORDER BIT POSITION WITH A 0.

SHLC: SHIFTS THE STATE OF THE CARRY INTO THE LOW ORDER BIT POSITION.

SHL.1: SHIFTS LEFT THE CONTENTS OF ONLY ONE MEMORY LOCATION. THE STATE OF THE CARRY IS SHIFTED INTO THE LOW ORDER POSITION OF MEMORY.
; CLEAR CARRY PRIOR TO SHIFT.
; LOAD FIRST MEM DIGIT.
; DOUBLEIT.
AVOID SKIP.
LOAD NEXT MEM DIGIT.
; DOUBLE IT TOO.

> ; AVOID SKIP, IF ANY
> ; STORE SHIFTED DIGIT.
> ; FINISHED - RETURN!

National Semiconductor Corp. COP Brief 4
cluding the COP410L and COP411L may generate false states on $\mathrm{L}_{0}-\mathrm{L}_{7}$ during the execution of the CAMQ instruction. Figure 1 contains a short program to illustrate this. In this program the internal $Q$ register is enabled onto the $L$ lines and a steady bit pattern of logic highs is outpout on $L_{0}$, $L_{1}, L_{6}, L_{7}$, and logic lows on $L_{2}-L_{5}$ via the two-byte CAMQ instruction. Timing constraints on the device are such that the $Q$ register may be temporarily loaded with the second byte of the CAMQ opcode ( $X^{\prime} 3 C$ ) prior to receiving the valid data pattern. If this occurs, the opcode will ripple onto the $L$ lines and cause negative-going glitches on $L_{0}, L_{1}, L_{6}, L_{7}$, and positive glitches on $\mathrm{L}_{2}-\mathrm{L}_{5}$. Glitch durations are under 2 microseconds, although the exact value may vary due to data patterns, processing parameters, and $L$ line loading. These false states are peculiar only to the CAMQ instruction and the $L$ lines. The user should expeience no difficulty interfacing with other COP420 outputs such as $G_{0}-G_{3}$ and $D_{0}-D_{3}$ to edge sensitive components.

## Software and Opcode Differences in the COP444L Instruction Set

The COP444L is essentially a COP420L with double RAM and ROM. Because of this increased memory space certain instructions have expanded capability in the COP444L. Note that there are no new instructions in the COP444L and that all instructions perform the same operations in the COP444L as they did in the COP420L. The expanded capability is merely to allow appropriate handling of the increased memory space. The affected instructions are:

| JMP | a | $(a=$ address $)$ |
| :--- | :--- | :--- |
| JSR | a | $(a=$ address $)$ |
| LDD | $r, d$ | $(r, d=$ RAM address $B r, B d)$ |
| XAD | $r, d$ | $(r, d=$ RAM address $B r, B d)$ |
| LBI | $r, d$ | $(r, d=$ RAM address $B r, B d$; only two byte form of |
| XABR |  |  |
| the instruction affected $)$ |  |  |

The JMP and JSR instructions are modified in that the address a may be anywhere within the 2048 words of ROM space. The opcodes are as follows:

| JMP | 0110\|0 ${ }^{\text {a }}$ 10:9:8 | JSR | 0110\|1 ${ }^{\text {a }} 10: 9: 8 \mid$ |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{a}_{7: 0}$ |  | ${ }^{\text {a }}$ \% 0 |

National Semiconductor Corp.

The LDD, XAD, and two byte LBI are modified so that they may address the entire RAM space. The opcodes are as follows:


The XABR instruction change is transparent to the user. The opcode is not changed nor is the function of the instruction. The change is that values of 0 through 7 in $A$ will address registers in the COP444L-i.e. the lower three bits of A become the Br value following the instruction. In the COP420L, the lower two bits of A became the Br value following an XABR instruction.
Note that those instructions which have an exclusive-or argument (LD, X, XIS, XDS) are not affected. The argument is still two bits of the opcode. This means that the exclusive-or aspect of these instructions works within blocks of four registers. It is not possible to toggle Br from a value between 0 and 3 to a value between 4 and 7 by means of these instructions.
There are no other software or opcode differences between the COP444L and the COP420L. Examination of the above changes indicates that the existing opcodes for those instructions have merely been extended. There is no fundamental change.

## RAM Keep-Alive

A COPSTM application is a small scale computer system and the design of a power shut-down is not trivial. During the time that power is available, but out of the designed operating range, the system must be prevented from doing anything to harm protected data. This will typically involve some type of external protection of timing circuit.
There is an option on the COP420, 420L, and 410L parts called "RAM Keep-Alive" that provides a separate power supply to the RAM area of the chip via the CKO pin. The application of power to the RAM while the remainder of the chip has been powered down via $V_{C C}$ will keep the RAM "alive".
However, the integrity of data in the RAM is not only a function of power but is also influenced by transient conditions as power is removed and reapplied. During power-on, the Power On Reset (POR) circuit will keep transients from causing changes in the RAM states. The condition of power loss will have some probability of data change if external control is not used.
At some point below the minimum operating voltage certain gates will no longer respond properly while others may still be functional until a much lower voltage. During this transition time any false signal could cause a false write to one or more cells. Another effect could be to turn on multiple address select lines causing data destruction.
Testing the rate of data change is very difficult because it must be done on a statistical basis with many turn/on-turn/ off cycles. Two factors have a major bearing on the numbers derived by testing. One is to call any change in a related data block a failure, even though more than one bit in that block may have changed (this latter case may well be due to the "address select mode"). The second factor is that without massive instrumentation it is impossible to examine the data after each power cycle. Indeed, to do so might have caused errors!
By running the power cycle for a period of time and then looking for changes, one could overlook multiple changes thus reducing the error rate. This has been minimized by more frequent checking which indicates that the errors are spread out randomly over time.
With a power supply that drops from 4.5 to 2 V in approximately 100 ms , the drop-out rate is 1 in 5 k to 6 k power cycles. Reducing the voltage fall time will cause an improvement in the number of cycles per drop-out. This will reach a limit condition of a very high number ( 1 per 1 million?) when the power falls within one instruction cycle (4-10 $\mu \mathrm{s}$ for the $420,15-40 \mu \mathrm{~s}$ for the "L" parts). Attaining very rapid fall time may cause problems due to the lack of decoupling/bypass capacitance. By inserting an electronic switch between the regulator and $V_{C C}$ of the COP chip one might be able to meet this type of fall time. By implication some type of sensing is required to cause the switching.

## National Semiconductor Corp.

 COP Brief 6The desirable approach is to force the COP reset input to zero before the voltage falls below 4.5 V . This provides a drop out rate of approximately 1 in 50 k for the " $L$ " parts and 1 in 100k for the 420 . By also stopping the clock of the " L " parts they can achieve a drop-out rate similar to the 420. While not perfect, the number of cycles between data error should be considered with respect to the needs of the application.
The external circuitry to control the chip during the power transition has several implementations each one being a function of the application. The simplest hardware is found in a battery powered (automotive) application. The circuit must sense that the switched 12 V is falling (e.g., at some value much below 12 V and still greater than 5 V ). This can be done by using the unswitched 12 V as a reference for a divider to a nominal voltage of 8 V . As the switched 12 V drops below the reference a detector will turn on a clamp transistor to a series switch, the POR, and/or the clock circuit (Figure 1). It should be noted that this draws current during the absence of the switched 12 V circuit.
In non-automotive usage a similar circuit can be used where there is a stable reference voltage available to use with the comparator/clamp. Thus a 3.6 V rechargable Ni-Cad battery could be used as the reference voltage and $V_{\text {RAM }}$ if the appropriate divider is used to level shift to this operating range.
In AC line-powered applications, a similar method could be used with the raw DC being sensed for drop. Another method would be to sense that the line had missed 2-3 cycles either by means of a charge pump or peak detection technique. This will provide the signal to turn on the clamp. One must make this faster than the time to discharge the output capacitance of the power supply, thus assuring that the clamp has performed its function before the supply falls below spec value.
In conclusion, to protect the data stored in RAM during pow-er-off cycle, the POR should go low before the VCC power drops below spec and come up after $V_{C C}$ is within spec. The first item must be handled with an external circuit like Figure 1 and the latter by an RC per the data sheet.


TL/DD/6946-1
FIGURE 1

# COP420-QRX/N Preprogrammed Single-Chip Microcontroller for Musical Organ 

## Features and Functions

Play Mode: Twenty-five musical keys and 25 LEDs are provided to denote $F$ to $F$ with half notes in between. All the keys and LEDs are directly detected and driven by the microprocessor. Depression of the key will give the corresponding musical note and light up the corresponding LED.
Clear: Memory is provided to store a played tune. Depression of the CLEAR key erases the memory and the microprocessor is ready to store new musical notes. A maximum of 28 notes can be stored where each hote can be of one to eight musical beats. (Two bytes of memory are required to store one musical note. Any note longer than eight muscial beats will require additional memory space for storage.)

Playback: Depression of this button will playback the tune stored in the memory since last "clear."
Preprogrammed Tunes: There are ten preprogrammed tunes (each has an average of 55 notes) masked in the chip. Any tune can be recalled by depressing the "Tune Button" followed by the corresponding "Sharp Key."
Learn Mode: This mode is for the player to learn the ten preprogrammed tunes. By pressing the "Learn Button"
followed by the corresponding "Sharp Key," the LEDs will be lighted up one by one to indicate the notes of the selected tune. The LED will remain "on" until the player presses the correct musical key; the LED for the next note will then be lighted up.
Pause: In addition to the 25 musical keys, there is a special pause key. The depression of this key generates a blank note to the memory.
Note: In the Learn Mode when playing "Oh Susanna," the pause key must be used.
Tempo: This is a control input to the musical beat time oscillator for varying the speed of the musical tunes.
Vibrato: This is a switch control to vary the frequency vibration of the note.

Tune Listing: The following is a listing of the ten preprogrammed tunes: 1) Jingle Bells, 2) Twinkle, Twinkle Little Star, 3) Happy Birthday, 4) Yankee Doodle, 5) Silent Night, 6) This Old Man, 7) London Bridge Is Falling Down, 8) Auld Lang Syne, 9) Oh Susanna, 10) Clementine.

Circuit Diagram of COP420 Musical Organ



TL/DD/6923-2


Auto Power Shut-Off Circuit


TL/DD/6923-4
This circuit automatically turns off the musical organ if none of the keys are pressed within approximately 30 seconds.

TL/DD/6923-3
This additional circuit provides tinkling effect for the musical note.

# Analog to Digital Conversion Techniques With COPS ${ }^{\text {TM }}$ Family Microcontrollers 

## TABLE OF CONTENTS

### 1.0 INTRODUCTION

2.0 SIMPLE CAPACITOR CHARGE TIME MEASUREMENT<br>\subsection*{2.1 Basic Approach}<br>2.2 Accuracy Improvements<br>2.3 Conclusions

### 3.0 PULSE WIDTH MODULATION (DUTY CYCLE) TECHNIQUE

3.1 Mathematical Analysis
3.2 Basic Implementation
3.3 Accuracy Improvements
4.0 DUAL SLOPE INTEGRATION TECHNIQUES
4.1 Mathematical Background
4.2 Basic Dual Slope Technique
4.3 Modified Dual Slope Technique
5.0 VOLTAGE TO FREQUENCY CONVERTER, VCO'S
5.1 Basic Approach
5.2 The LM131/LM231/LM331
5.3 Voltage Controlled Oscillators
5.4 A Combined Approach
6.0 Successive Approximation
6.1 Basic Approcah
6.2 Some Comments on Resistor Ladders
7.0 "OFFBOARD" TECHNIQUES
7.1 General Comments
7.2 ADC0800 Interface
7.3 ADC0801/2/3/4 Interface (COP431/32/33/34)
8.0 CONCLUSION

### 9.0 REFERENCES

### 1.0 Introduction

A variety of techniques for performing analog to digital conversion are presented. The COP420 microcontroller is used as the control element in all cases. However, any of the COPS family of microcontrollers could be used with only minor changes in some component values to allow for different instruction cycle times.
Indirect analog to digital converters are composed of three basic building blocks:

- D/A Converter
- Comparator
- Control logic
relationship. This can be circumvented in several ways. First of all, a routine to calculate the exponential can be implemented. This, however, usually requires too much code if the exponential routine is not otherwise required in the program. Alternatively, the range of input voltages can be restricted so that only a portion of the capacitor charge curve - which can be approximated with a linear relationship or with some minor straight time curve fitting - is used. Finally, a look up table can be used which will effectively convert the measured time to the appropriate voltage. The look up table has the advantage that all the math can be built into the table, thereby simplifying matters significantly. If arithmetic routines are going to be used, it is clear that the relationship is simplified if VO is OV because it then drops out the equation. :


## BASIC CIRCUIT IMPLEMENTATION

The circuit in Figure 1 is the basic implementation of the capacitor charge method of A/D conversion. The selection of input and output used is arbitrary and is dictated by general system considerations. V0 is the " 0 " level of the G output and $V 1$ is the " 1 " level of the output. The technique is basically to discharge the capacitor to V0 (which is ideally ground) and then to apply V1 and increment an internal counter until the comparator changes state. The flow chart and code for this implementation are shown in Figure 2.

## ACCURACY CONSIDERATIONS

The levels reached by the microcontroller output constitute one of the more significant problems with this basic imple-
mentation. The levels of V 1 and V 0 are not $\mathrm{V}_{\mathrm{CC}}$ and ground as would be desired. The level is defined by the load on the output, the value of $\mathrm{V}_{\mathrm{CC}}$, and the device itself. Furthermore, these levels are likely to change from device to device and over temperature. To be sure, the output values will be at least those given in the data sheet, but it must be remembered that those values are minimum high voltages and maximum low voltages. Typically, the high value will be greater than the spec minimum and the low value will be lower than the spec maximum. In fact, with a light load the values will be close to $\mathrm{V}_{\mathrm{CC}}$ and ground. Therefore, in order to obtain any accurate result for a voltage measurement the exact values of V1 and V0 need to be measured and somehow stored in the microcontroller. Typical values of these voltages can be measured experimentally and an average could be used for final implementation.
The other problem associated with the levels is that the capacitive load on the output line is substantial and far in excess of the values used when specifying the characteristics of the various COP420 outputs. The significant effect of this is that it will take longer than "normal" for the output to reach its maximum value. In addition, it is likely that there will be dips in the output as it rises to its maximum value since the capacitor will start to draw charging current from the output. All of this will be fast relative to the other system times. Still it will affect the result since the level to which the capacitor is attempting to charge is not being applied uniformly and "instantaneously". It can be viewed as though the voltage $V 1$ is bouncing before it stabilizes.
4.


TL/DD/6935-01
Crystal oscillator values chosen to give $4 \mu$ s cycle time with divide by 16 option selected on COP 420 CKO/CKI Pins

FIGURE 1. Basic Capacitor Charge Technique

HGI 0 , TURN OFF $Q$ TO DISCHARGE CAPACITOR
INSERT SOME DELAY TO MAKE SURE CAPACITOR DISCHARGED
, USING 12 BIT COUNTER, BUT ONLY UPPER $日$ USED IN TABLE
HOOK UP DUE TO ACCURACY OF RC CHARGE METHOD. THE OTHER
IBITS COULD BE USED BUT THE COMPLICATIONS ARE NOT WORTH
, THE EFFORT FOR THIS PARTICULAR TECHNIGUE. ALSD. HERE THE
I THE EFFORT FOR THIS PARTICULAR TECHNIGUE. ALSO. HERE THE
I INPUT RANGE IS RESTRICTED SO THAT THE TOP 3 BITS ARE ZERO


FIGURE 2A. Typical RC Charge A/D Code


FIGURE 2B. Charge Flow Chart

A more general problem is that of the tolerance of RC time constant. The value of the voltage with respect to time is obviously related to the RC value. Therefore, a change in that value will result in a change in the voltage for a given time period t . The graph in Figure 3 illustrates the effect of a $\pm 10 \%$ variation in the RC value upon the voltage measured for a given time $t$. If one cares to work out the math, it comes out that the error is an exponential relationship in much the same manner as the capacitor voltage itself. The maximum error induced for $\pm 10 \%$ RC variation is $\pm 3.9 \%$.
Remember also that we are measuring time. Therefore variation in the RC value will have a direct, linear effect on the time required to measure a given voltage. It is also necessary that the time base for the COP420 be accurate. A variation in the accuracy in the operating frequency of the COP420 will have a direct impact on the accuracy of the result.
Given the errors mentioned so far and assuming that no changes are made in the hardware, the accuracy of the technique then is determined by the resolution of the time measurement. This is improved in two ways: increase the RC time constant so that there is a smaller change in capacitor voltage for a given time period or try to minimize the loop time required to increment the counter. Lengthening the RC time constant is easier but the cost is increased conversion time. The minimum time to increment a 5 to 8 bit binary counter and test an input is 13 cycle times. For a 9
to 12 bit binary counter this minimum time is 17 cycle times. Note also that the minimum time to perform the function does not necessarily correspond to the minimum number of code words required to implement the function. At a cycle time of $4 \mu \mathrm{~s}$, the 13 cycle times correspond to $52 \mu \mathrm{~s}$.

### 2.2 ACCURACY IMPROVEMENTS

Several options are available if it is desired to improve the accuracy of this method. Three such improvements are shown in Figure 4. Figure $4 A$ is the smallest change. Here a pullup resistor has been added to the G output line and the G line is run open drain internally, i.e., the internal pullup is removed. This improves the "bounce" problem mentioned earlier. The G line will go to the high state and remain there with this setup. However, the addition of the resistor does little more than eliminate the bounce. The degree of improvement is not great, but it is an easy way to eliminate a minor source of error.
Figure $4 B$ is the next step. A 74C04 is used as a buffer. The 74C04 was chosen because of its symmetric output characteristics. Any CMOS gate with such characteristics could be used. The software can easily be adjusted to provide the proper polarity. The COP420 output drives a CMOS gate which in turn drives the RC network. This change does make significant improvements in accuracy. With a light


FIGURE 3
load the CMOS gate will typically swing from ground to $V_{C C}$ and its output level is not as likely to be affected by the capacitor discharge.
Figure $4 C$ is the best approach, but it involves the greatest component cost. Here two $G$ outputs are controlling analog switches. Ground is connected to the RC network to discharge the capacitor, and a positive reference is used to charge the capacitor. This reference can be any suitable voltage source: zener diodes, $\mathrm{V}_{\mathrm{CC}}$, etc. The controlling voltage tolerance is now clearly the tolerance of the reference. Precise voltage references are readily obtainable. Figure $4 C$ also shows an analog switch connected directly across the capacitor to speed up the capacitor discharge time. When using this version of the basic scheme, remember to include the 'on' resistance of the analog switch connected to $\mathrm{V}_{\text {REF }}$ in the RC calculation. Failure to do so will introduce error into the result.
Note that the LM339 is a quad comparator. If these comparators are not otherwise needed in the system, they can be used in much the same manner as the CMOS gate mentioned above. They can be used to buffer the output of the COPS device and to reset the capacitor, or whatever other function is required. This has the advantage of fully utilizing
the components in the system and eliminates the need to add another package to the system.

### 2.3 CONCLUSIONS

This approach is an inexpensive way to perform an A/D conversion. However, it is not that accurate. With a $10 \%$ $V_{C C}$ supply and a $10 \%$ tolerance in the RC value and $10 \%$ variation in the oscillator frequency the best that can be hoped for is about $25 \%$ accuracy. If a $1 \%$ reference voltage is used, this accuracy becomes about $15 \%$.
Under laboratory conditions-holding all variables constant and using precise measured values in the calculations-the configuration of Figure 2 yielded 5 bit accuracy over an input range of 0 to 3.5 V . Over the same range and under the same conditions, the circuit of Figure $4 B$ yield 7 to 8 bit accuracy. It must be emphasized that these accuracies were obtained under controlled conditions. All variables were held constant and actual measured values were used in all calculations. It is unlikely that the general situation will yield these accuracies unless adjustments are provided and a calibration procedure is used. This could defeat the low cost objective.


FIGURE 4

### 3.0 Pulse Width Modulation (Duty Cycle) Technique

### 3.1 MATHEMATICAL ANALYSIS

 Figure 5. Figure 6, we have the following:$$
\begin{aligned}
V_{A} & =V 0+\left[V_{B}-V_{0}\right]\left[e^{* *}(-t 1 / R C)\right] \\
V_{B} & =V_{A}+\left[V_{1}-V_{A}\right]\left[1-e^{* *}(-t 2 / R C)\right] \\
& =V_{1}+\left[V_{A}-V_{1}\right]\left[e^{* *}(-t 2 / R C)\right]
\end{aligned}
$$

The pulse width modulation, or duty cycle, conversion technique is based on the fact that if a repetitive pulse waveform is applied to an RC network, the capacitor will charge to the average voltage of the waveform provided that the RC time constant is sufficiently large relative to the pulse period. See

In this technique, the capacitor voltage $V_{C}$ is compared to the voltage to be measured by means of an analog comparator. The duty cycle is then adjusted to cause $V_{C}$ to approach the input voltage. The COPS device reads the comparator output and then drives one of its outputs high or low depending on the result, i.e., if $V_{C}$ is lower than the input voltage, a positive voltage (V1) is applied to charge the capacitor; if $V_{C}$ is higher than the input voltage, a lower voltage (VO) is applied to discharge the capacitor. Thus the capacitor voltage will seek a point where it varies above and below the input voltage by a small amount. Figure 6 illustrates the capacitor voltage and the comparator output.
Some mathematical analysis here will be useful to help clarify the technique and to point out its restrictions. Referring to
solving for t 1 and t 2 we have:

$$
\begin{aligned}
& t 1=-R C \ln \left[\left(V_{A}-V_{0}\right) /\left(V_{B}-V_{0}\right)\right] \\
& t 2=-R C \ln \left[\left(V_{B}-V_{1}\right) /\left(V_{A}-V_{1}\right)\right]
\end{aligned}
$$

let:

$$
\begin{aligned}
& V_{A}=V_{I N}-d 1 \\
& V_{B}=V_{I N}-d 2
\end{aligned}
$$

substituting the above, the equations for t 1 and t 2 become:

$$
\begin{aligned}
t 1= & -R C \ln \left\{\left[1-\left(d 1 /\left(V_{\mathbb{N}}-V 0\right)\right)\right] /\right. \\
& {\left.\left.\left[1+d 2 /\left(V_{I N}-V_{0}\right)\right)\right]\right\} } \\
\mathbf{t} 2= & -R C \ln \left\{\left[1-\left(d 2 /\left(V_{I N}-V_{1}\right)\right)\right] /\right. \\
& {\left.\left.\left[1 \cdot-d 1 /\left(V_{\mathbb{N}}-V_{1}\right)\right)\right]\right\} }
\end{aligned}
$$

the equations reduce by means of the following assumptions:

$$
\begin{aligned}
& \text { 1. } d 1=d 2=d \\
& \text { 2. }\left|V_{\mathbb{N}}-V O\right|>d \\
& \left|V_{I N}-V 1\right|>d
\end{aligned}
$$

applying these assumptions, we get the following:
$t 1=-R C \ln [(1+x) /(1-x)]$ where $x=-d /\left(V_{\mathbb{N}}-V 0\right)$
$t 2=-R C \ln \left[(1+x) /(1-y)\right.$ where $y=d /\left(V_{\mathbb{N}}-V_{1}\right)$
because of the assumptions above, the $x$ and $y$ terms in the preceding equations are less than 1 , therefore the following expansion can be used:

$$
\ln [(1+z) /(1-z)]=2\left[z+\left(z^{* *} 3\right) / 3+\left(z^{* *} 5\right) / 5+\ldots\right]
$$



TL/DD/6935-8

TL/DD/6935-7

$$
V_{C}=\frac{\left(V 1-V_{0}\right) \times T 1}{T 1+T 2}
$$

FIGURE 5


## Comparator Output



FIGURE 6
substituting we have:

$$
\begin{aligned}
& \mathrm{t} 1=-2 \mathrm{RC}\left[\mathrm{x}+\left(\mathrm{x}^{* *} 3\right) / 3+\ldots\right] \\
& \mathrm{t} 2=-2 \mathrm{RC}\left[\mathrm{y}+\left(\mathrm{y}^{* *} 3\right) / 3+\ldots\right]
\end{aligned}
$$

under assumption 2 above, the linear term completely swamps the exponential terms yielding the following result (after substituting back into the equation):

$$
\left.t 1=2 d R C / V_{I N}-V 0\right) \quad t 2=-2 d R C /\left(V_{I N}-V_{1}\right)
$$

therefore:

$$
\begin{aligned}
& t 1 /(t 1+t 2)=\left(V 1-V_{\mathbb{N}}\right) /(V 1-V 0) \\
& t 2 /(t 1+t 2)=\left(V_{I N}-V 0\right) /(V 1-V 0)
\end{aligned}
$$

solving for $\mathrm{V}_{\mathrm{IN}}$ :

$$
\begin{aligned}
V_{\mathbb{I N}} & =[t 2 /(t 1+t 2)]\left[V_{1}-V_{0}\right]+V_{0} \\
\text { or } V_{I N} & =V_{1}-[t 1 /(t 1+t 2)]\left[V_{1}-V_{0}\right]
\end{aligned}
$$

It follows from the above results that by measuring the times t 1 and t 2 , the input voltage can be accurately determined. As will be seen the restrictions based upon the assumptions above do not cause any serious difficulty.

## General Accuracy Considerations

In the preceding calculations it was assumed that the differential output above and below the input voltage was the same. If the comparator output is checked at absolutely regular intervals, and if the intervals are kept as small as possible this assumption can be fairly easily guaranteed-at least to within the comparator offset which is only a few millivolts. As we shall see, this aspect of the technique presents few, if any, difficulties. In addition, there is an RC network at the input of the comparator. The time constant of this network must be long relative to the time between checks of the comparator output. This will insure that the capacitor voltage does not change very much between checks and thereby help to insure that the differences above and below the input voltage are the same.
The next major approximation has to do with the difference between the input voltage and either V1 or V0. We have relied on this difference being much greater than the amount the capacitor voltage changes above and below the input voltage. This approximation allows the nonlinear terms in the logarithmic expansion to be discarded. In practicality, the approximation means that the input voltage must not be "close" to either V1 or V0. Therefore, it becomes necessary to determine how closely the input voltage can approach V 1 or VO. It is obvious that the smaller the difference $d$ can be made, the closer the input voltage can approach either reference. The following calculations illustrate the method for determining that difference d. Note, using either V1 or V0 produces the same result. Thus $\mathrm{V}=\mathrm{V} 1=\mathrm{V} 0$.
For at least $1 \%$ accuracy

$$
\begin{gathered}
x+\left(x^{* *} 3\right) / 3<1.01 x \\
\text { therefore } x<0.173
\end{gathered}
$$

since $x=d /\left|\left(V_{I N}-V\right)\right|$ we have $d<0.173\left|\left(V_{I N}-V\right)\right|$.
Using the same analysis for $0.1 \%$ accuracy in the approximation we get $d<0.0548\left|\left(\mathrm{~V}_{I N}-\mathrm{V}\right)\right|$. By applying this relationship, the RC time constant can be adjusted so that, within the time interval, the capacitor voltage does not change by more than $\mathrm{d} V$. The user may then select, within
reason, how close to the references he can allow the input voltage to go.
The next consideration is really just one of simplification. It is clear that if V0 is zero, it drops out of the first equation and the relationship is simplified. Therefore, it is desirable to use zero volts as the VO value. The equation then becomes:

$$
V_{I N}=V_{1} t 2 /(t 1+t 2)
$$

It is obvious by now that the heart of the technique lies in accurately measuring the times t 1 and t 2 . Clearly this requires that the time base of the COP420 be accurate. Short term variations in the COP420 time base will clearly impact the accuracy of the result. In addition to that there is a serious problem in being able to check the comparator output often enough to get any accuracy and resolution out of simply measuring the times $t 1$ and $t 2$. This problem is circumvented by measuring many periods of the waveform. Doing this gives a large average, which improves the accuracy and tends to eliminate any spurious changes. Of course, the trade off is increased time to do the conversion. However if the time is available, the technique becomes restricted only by the accuracy of the external components. Those of the comparator and the reference voltage are most critical.
It is clear from the equation above that the accuracy of the result is directly dependent upon the accuracy of the reference voltage V1. In other words, it is not possible to be more accurate than the reference voltage. If, however, all that is required is a ratio between the input voltage and the reference voltage, the accuracy of the reference will not be a controlling factor provided that the input voltage tracks the reference. This requires that the input voltage be generated from the reference voltage in some form, e.g., a voltage divider with $\mathrm{V}_{\mathrm{IN}}$ coming off a variable resistance.
Finally, we have noted that the difference d must be small. If the capacitor had to charge or discharge a long way toward $\mathrm{V}_{\mathbb{N}}$, the nonlinearity of the capacitor charge curve would be significant. This therefore requires that the conversion begin with the capacitor voltage close to the input voltage.
Note that the RC value is not part of the equation. Therefore the accuracy of the time constant has no effect on the result as long as the time constant is long relative to the time between checks of the comparator output.
The final point is that the reference voltages, whatever they may be, must be hard sources. Should these voltages vary or drift at all, they will directly affect the result. In those configurations where the references are being switched in and out, the voltage should not change when it is switched into the circuit.

### 3.2 BASIC IMPLEMENTATION

## General

The objective, then, is to measure the times t 1 and t 2 . This is accomplished in the software by means of two counters. One of the two counters counts the t2 time; the other counter counts the total time $\mathrm{t} 1+\mathrm{t} 2$.
It is necessary to check the comparator output at regular intervals. Thus the software must insure that path lengths
through the test and increment loops are equal in time. Further it is desirable to keep the time required to increment the counters as short as possible. A trade off usually comes into play here. The shortest loop in terms of code required to implement the function is rarely the shortest loop in terms of time required to execute the function. The user has to decide which implementation is best for him. The choice will frequently be governed by factors other than the A/D conversion limits.
It must be remembered that we are now dealing with analog signals. If significant accuracy is required, we are handling very small analog signals. This requires the user to take precautions that are normally required when working with linear circuits, e.g., power supply decoupling and bypassing, lead length restrictions, crosstalk, op amp and comparator stabilization and compensation, desired and undesired feedback, etc. As greater accuracy is sought these factors are more and more significant. It is suggested that the reader refer to the National Semiconductor Linear Applications Handbook and to the data sheets for the various components involved to see what specific precautions should be taken both in general and for a specific device.

## The Base Circult

Figure 7 shows the diagram for the basic circuit required to implement the duty cycle conversion scheme. The flow chart and code required to implement the function are shown in Figure 8. Note that the flow chart and code do not change-except for possible polarity change on output to allow for an inverting buffer-for any of the improvements in accuracy discussed later. The only exception to this is the technique illustrated in Figure 10 and the variations there are minor.
The code and flow chart in Figure 8 implement the technique as described above. The large averaging technique is
used as it would be too difficult to measure the times $\mathrm{t1}$ and $t 2$ in a single period. The total time, $t 1+\mathrm{t} 2$, is the viewing window under complete control of the software. This window is a time equal to the total number of counts, determined by desired accuracy, multiplied by the loop time for a single count. A second counter is counting the t2 time. Special care is taken to insure that all paths through the code take the same length of time since the integrity of the time count is the essence of the technique. The full conversion scheme would use the subroutine in Figure 8. Normally the subroutine would be called first just to get the capacitor charged close to the input voltage. The result obtained here would be discarded. Then the routine would be called a second time and the result used as required.
In the configuration in Figure 7, there is an RC network in both input legs of the comparator. This is to balance the inputs of the device. For this reason, R1 = R2. C1 is the capacitor whose voltage is being varied by the pulse waveform. C2 is in the circuit only for stabilization and symmetry and is not significant in the result. The comparator tends to oscillate when the + and - inputs are nearly equal without capacitor C 2 in the circuit.
As would be expected, the basic circuit has some difficulties. By far the most serious of these difficulties is the output level of the $\mathbf{G}$ line. To be sure of the high and low level of this output the levels should be measured. The " 1 " level will be between the spec minimum of 2.4 V and $\mathrm{V}_{\mathrm{CC}}$ (here assumed to be 5 V ). The " 0 " level will be between the 0.4 V spec maximum and ground. With light loads, these levels are likely to vary from device to device. Furthermore, we have the same " 1 " level problem that was mentioned in the simplest technique: the capacitive load is large and the capacitor is charging while the output is trying to go to the high level.


TL/DD/6935-11
FIGURE 7. Basic Duty Cycle A/D

There is also a problem with the low level. When the output goes low, the capacitor begins to discharge through the output device of the COP420. This discharge current has the effect of raising the " 0 " level and thereby introducing error. Note that we are not talking about large changes in the voltages, especially the low level. Typically, the change will only be a few millivolts but that can translate into a loss of accuracy of several bits.
Under laboratory conditions-holding all variables constant and using precise measured values in the calculations-the circuit of Figure 7 yielded 5 bit $\pm 1$ bit accuracy over
the range of Vo (here measured to be 0.028 V ) to 3.5 V (the maximum specified input voltage for the comparator with $\mathrm{V}_{\mathrm{S}}$ $=5 \mathrm{~V}$ ). Increasing the number of total counts had very little effect on the result. In the general case, the basic scheme should not be relied upon for more than 4 bits of accuracy, especially if one assumes that $\mathrm{V} 1=\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V} 0=0$. As shall be seen, it is not difficult to improve this accuracy considerably.

| $\begin{aligned} & \text {; Ar(11) } \\ & \text { Ail(1): } \end{aligned}$ | 25 THE | FULL CONVER | RSION SCHEME WRITTEN AS A SUBROUTINE |
| :---: | :---: | :---: | :---: |
|  | LBI | 1,10 | ; MAKE SURE COUNTERS CLEARED |
|  | JSRP | CLEAR |  |
|  | LBI | 2.10 |  |
|  | JSRP | CLEAR |  |
|  | LBI | 1,13 | ; PRELOAD FOR TOTAL COUNT $=2049$ |
|  | STII | 0 |  |
|  | STII | 0 |  |
|  | STII | 8 |  |
| Allill : | ININ |  | ; READ COMPARATOR-INPUT TO $420=$ IN3 |
|  | AISC | 8 |  |
|  | , JP | SNDO1 |  |
| SMDIA: | LBI | $3,0$ <br> ; VALUES | iUSING OMG BELOW TO SAVE STATE OF OTHER G If IT WAS NECESSARY TO DO SO, ELSE USE DGI |
|  | SMB | 2 | ; UIN > VG, DRIVE VG HIGHER |
|  | OMG |  | ; THIS CODE STRAIGHT LINED FOR SPEED |
|  | SC |  | ; APPLY POSITIVE REFERENCE |
|  | CLRA |  | ; INCREMENT THE SUB COUNTER |
|  | LDI | 2.13 |  |
|  | ASC |  |  |
|  | NOP |  |  |
|  | XIS |  |  |
|  | CLRA |  |  |
|  | ASC |  |  |
|  | NOP |  | ; BINARY INCREMENT |
|  | $\times 15$ |  | ; WOULD ELIMINATE THESE 4 WORDS IF B BIT |
|  | CLRA |  | ; COUNTER OR LESS-HERE SET UP FOR UP TO 12 BIT |
|  | ASC |  | ; COUNTER |
|  | NOP |  |  |
|  | $X$ |  |  |
|  | JP | TOTAL |  |
| SNIJOI: | LBI | 3. 0 |  |
|  | RMB | 2 |  |
|  | OMG |  |  |
|  | CLRA |  |  |
|  | AISC | 10 | ; THIS PART OF THE CODE MERELY INSURES THAT |
|  | NDP |  | ; ALL PATHS THRQUGH THE ROUTINE ARE EQUAL IN TI |
| DI $Y$ : | AISC | 1 |  |
|  | JP | DLY |  |
| THIN: | CLRA |  |  |
|  | L. 13 I | 1. 13 |  |
|  | SC |  |  |
|  | ASC |  | ; INCREMENT THE TOTAL LOOP COUNTER |
|  | NOP |  | ; WHEN QVERFL.OW, DONE SO EXIT |
|  | XIS |  |  |
|  | CLRA |  |  |
|  | ASC |  |  |
|  | NOP |  |  |
|  | XIS |  |  |
|  | CLRA |  |  |
|  | ASC |  |  |
|  | JP | ATODE |  |
|  | RL:T |  |  |
| Aldiná: | X |  |  |
|  | $J P$ | ATOD 1 |  |
|  | .PAGE |  |  |
| CLEAR: | CLRA |  |  |
|  | XIS |  |  |
|  | J | CLEAR |  |
|  | RE:T |  |  |

FIGURE 8A. Duty Cycle A/D Code
COP NOTE 1


TL/DD/6935-12
FIGURE 8B. Duty Cycle A/D Flow Chart

### 3.3 ACCURACY IMPROVEMENTS

## General Improvements

Figure 9 illustrates circuit changes that will make significant improvements in the accuracy of the technique. In Figure 9A a CMOS buffer is used to drive the RC network. The output of the COP420 drives the CMOS gate, which here is a 74C04 because of its output characteristics. The main thing that this technique does is to reduce the difficulties with the output levels. Typically, V 0 is V and V 1 is $\mathrm{V}_{\mathrm{Cc}}$. We also have a "harder" source for the voltages - the levels don't change while the capacitor is charging or discharging. Now, even more clearly than before, the accuracy of $\mathrm{V}_{\mathrm{CC}}$ is the controlling voltage tolerance. The accuracy of the result will be no better than the accuracy of $\mathrm{V}_{\mathrm{CC}}$ (for a system requiring absolute accuracy).

Under laboratory conditions, the circuit of Figure 9A yielded the accuracies as indicated below for various total counts. The accuracy increased with the total count until the count exceeded 2048. There was no significant increase in accuracy with this circuit for counts in excess of 2048. (Remember that these results were obtained under controlled conditions). We may then view the results obtained with 2048 counts as the upper limit of accuracy with the circuits of Figure 9A. The results were as follows:

| Total <br> Count | Resultant Accuracy |
| :---: | :---: |
| 512 | $8 \pm 1 / 2$ bits |
| 1024 | $9 \pm 1$ bits |
| 2048 | $9 \pm 1 / 2$ bits |
| 4096 | $9 \pm 1 / 2$ bits |



FIGURE 9. Improvements to Duty Cycle A/D

The circuit of Figure $9 B$ makes a significant change to improve accuracy. Now the COP420 is controlling analog switches and switching in positive and negative references. Therefore the accuracy of the reference voltages is the controlling factor. Generally this will improve the accuracy over that obtained with Figure 9A. With the circuit of Figure 9B, with V0 $=1 \mathrm{~V}$ (negative reference), and V1 $=3 \mathrm{~V}$ (positive reference), 9 bit accuracy was achieved with a total count of 1024. V0 and V1 were arbitrarily chosen to place the input voltage approximately in the center of the allowable comparator input range with $\mathrm{V}_{\mathrm{S}}=5 \mathrm{~V}$. Remember, the accuracy of the references is controlling. The result can be no more accurate than the references. Furthermore, these references must be hard sources; i.e., they must not change when they are switched into the circuit as that contributes error into the result.
In Figure 9C, capacitive feedback was added to the comparator circuit and the series resistance to $\mathrm{V}_{\mathrm{IN}}$ was decreased. The feedback added hysteresis and forced the comparator to slew at its maximum rate (significant errors are introduced if the comparator does not change state in a time shorter than the cycle time of the controller). Both of these changes resulted in increased accuracy of the result. With $\mathrm{V} 0=0$, $\mathrm{V} 1=5 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{CC}}\right)$ and $\mathrm{V}_{\mathrm{CC}}$ held steady at 5.000 V , an accuracy of 10 bits $\pm 1$ bit was achieved over the input range of 0 to 3.5 V .

It is obviously possible to use any combination of the configurations in Figure 9 for a given application. What is used will depend on the user and his specific requirements.

Figure 10 illustrates a further refinement of the basic approach. This configuration can be used if greater accuracies are needed. The major change is the addition of a summing amplifier to the circuit for the purpose of adding a fixed offset voltage to the input voltage. This has the effect of moving the input voltage away from the negative reference (which is OV here). This offset voltage should be stable as the changes in it will directly affect the result. The offset voltage should be chosen so as to place the effective input voltage (the voltage at the comparator input) approximately in the center of the range between the two references. The precise value of the offset is not critical nor is its source. The forward voltage drop across a germanium diode is used as the offset in Figure 10, but this offset can be generated in any convenient manner. The forward voltage drop of the germanium diode is approximately 0.3 V . Given this and the negative reference of $O \mathrm{~V}$ and a positive reference of 2.5 V , the input voltage is restricted to a range of 0 to 2 V . Therefore, the effective input voltage (at the comparator input) is approximately 0.3 V to 2.3 V - well within the limits of the two references. The circuit also includes provision for an autozero self calibration procedure.
Note that the resistors in the summing amplifier should be matched. The absolute accuracy of these resistors is not significant, but their accuracy relative to one another can have a significant bearing on the result. The restriction is imposed so that the output of the summing amplifier is exactly the sum of the input voltage and the offset voltage. This requires unity gain through the amplifier and that the


FIGURE 10. Improved Duty Cycle A/D with Autozero
impedance in each summing leg be the same. These effects can become very serious if one is trying for significant accu-racy-e.g., if 12 bit accuracy is being sought $1 \%$ matching of those resistors can introduce an error of $1 \%$ maximum. While $1 \%$ accurate is fairly good, it is significantly less than 12 bit accuracy. Related to this effect is a possible problem with the source impedance of the input voltage. If that impedance is significant in terms of its ratio to the summing resistor, errors are introduced just as if the resistors are mismatched. "Significant" is determined in terms of the desired system accuracy and the relative impedance values. The comparator section is using some feedback to provide hysteresis for stability and a low series resistance is used for the input to the comparator.
Most significantly, this configuration allows a true zeroing of the system. Through the additional analog switches shown, the COP420 can easily perform an autozero function by
tying the input to ground and measuring the result. Thus the system offsets can be calculated, stored and subtracted from the result. This improves the accuracy and is also more forgiving on the choice of the comparator and op amp selected. Furthermore, the offset can be periodically recomputed by the COP420 thereby compensating for drift in system offsets. Nonetheless, the accuracy of the reference is the controlling factor. It is NOT possible to obtain an absolute (as opposed to ratiometric) accuracy of 12 bits without a reference that is accurate to 12 bits. The LM136 used in Figure 10 is a $1 \%$ reference. Although not inherently accurate to 12 bits, the voltage of the LM136 may be trimmed to exact value by means of a variable resistor. The data sheet of the LM136 illustrates this connection. Under laboratory conditions, the circuit of Figure 1 yielded 11 bit $\pm 1$ bit accuracy with a total count of 4096 over the input range of 0 to 2 V . Figure 11 indicates the flow chart and the code required to implement the technique of Figure 10.


FIGURE 11A. Duty Cycle A to D, Improved Method


TL/DD/6935-17
FIGURE 11B. Flow Chart for Improved Duty Cycle A/D

### 4.0 Dual Slope Integration Techniques

### 4.1 Mathematical Background

(Some of this background information is taken from National Semiconductor Linear Applications Note AN-155. The reader is referred to that document for other related general information.)
The basic approach of dual slope integration conversion techniques is to integrate a voltage across a capacitor for a fixed time, and then to integrate in the other direction with a known voltage until the starting point is reached. The ratio of the two times then represents the unknown voltage. Some of the math below in conjunction with Figure 12 will illustrate the approach.


TL/DD/6935-19
FIGURE 12. Dual Slope Integration-Basic Concept

$$
\begin{gathered}
I_{X}=C \frac{d V}{d t}=V_{X} / R \\
V_{X}=R C \frac{d v}{d t} \\
\int_{0}^{T 1} V_{X} d t=\int_{0}^{V} R C d V \\
V_{X} T 1=R C V \\
V=V_{X} T 1 / R C=I_{X} T 1 / C
\end{gathered}
$$

Similarly:

$$
\begin{gathered}
I_{R E F}=C \frac{d V}{d t}=V_{R E F} / R \\
V_{\text {REF }}=R C \frac{d V}{d t} \\
\int_{T 1}^{T 1}+T_{X} V_{R E F} d t=\int_{V}^{0} R C d V \\
V_{R E F} T_{X}=-R C V \\
V=-V_{R E F} T_{X} / R C \\
-V_{R E F} T_{X} / R C=V_{X} T 1 / R C \\
V_{X}=-V_{R E F} T_{X} / T 1
\end{gathered}
$$

Two important facts arise from the preceding mathematics. First of all, there is a linear relationship involved in determining the unknown voltage. Secondly, the negative sign in the final equation indicates that the reference and the unknown, relative to some point (which may be OV or some bias voltage), have opposite polarity. Thus, if it is desired to measure 0 to +5 V , the reference voltage must be -5 V . If the input is restricted to 2.5 to 5 V , the reference can be 0 V as the integrator and comparator are biased at +2.5 V (then the 0 V is in fact -2.5 V relative to the biasing voltage, and the input range is 0 to 2.5 V relative to the same bias voltage).
There are some difficulties with dual polarity conversion using the dual slope method. It is clear from the math above that if the input voltage will be dual polarity, it is necessary to have two references-one of each polarity. The midrange biasing arrangement briefly described above eliminates
the need for two different polarities but does not help very much since two references are still required-one at the positive value and one at the bias value. Ground is the other reference. Further, the need to select one of two references further complicates the circuitry involved to implement the approach. Also, the dual requirement brings up a difficulty with the bias currents of the integrator and comparator. They could add to the slope in one polarity and subtract in the other.
The only real operational difficulty in dual slope systems is establishing the initial conditions on the integrating capacitor. If this capacitor is not at the proper initial conditions, accuracy will be severely impaired. Figure 12 indicates a switch across the capacitor as a means of initializing it. In a software driven system, the initialization can be accomplished by doing two successive conversions. The result of the first conversion is discarded. It is performed only to initialize the capacitor. The second conversion produces the valid result. One need only insure that țere is not significant time lapse between the two conversions. They should take place immediately after one another.
This approach obviously lengthens conversion time but it eliminates many problems. The alternative to this approach of two successive conversions is to take a great deal of care in insuring the initial state of the integrating capacitor and in selecting op amps and comparators with low offsets.

### 4.2 THE BASIC DUAL SLOPE TECHNIQUE

Figure 13 indicates an implementation of the basic dual slope technique. This is a single polarity system and thus requires only the single reference voltage. The circuit of Figure 13 is perhaps not the cheapest way to implement such a scheme but it is representative and illustrates the factors that must be considered.
Consider first the means of initializing the integrating capacitor C 1 . The routine here connects the input to ground and does a conversion on zero volts as a means of initialization. Subsequently-and this is typical of the more usual tech-nique-two conversions are performed. The first conversion is to initialize the capacitor. The second conversion yields the result. Some form of initialization or calibration procedure is required to achieve optimum accuracy from dual slope conversion schemes.
The comparator in this circuit is used in the inverting mode and has positive feedback as recommended in the LM111 data sheet. The voltage reference is the LH0070, which is a $0.01 \%$ reference. A resistive voltage divider on the IH0070 creates the 5 V value. The use of the voltage divider brings up two difficulties (which can be overcome if the LH0070 is used at its full value, thus eliminating the divider, and the result properly scaled in the microcontroller or series integrating resistor increased). First, the impedance of the reference must be small relative to the series resistance used in the integrator. If this were not the case, the slopes would


TL/DD/6935-20
FIGURE 13. Basic Dual Slope Integration A/D Scheme
show an effect due to the difference in the $R$ value between the applied reference voltage and the unknown input. (By the same token, the output impedance of the source supplying the unknown must also be small relative to that series integrating resistor). Secondly, the bias currents of the integrator may be such as to affect the reference voltage when it is coming from a simple resistor divider. Both problems are reduced if small resistor values are used in the divider. Note also that current mode switching would reduce the problem as well. It should be pointed out that the errors introduced by these problems are not gross deviations from the expected value. They are small errors that will not make much difference in the majority of applications. They are, however the kind of errors that can make the difference between a system accurate to 10 bits and one accurate to 12 bits (assuming all other factors are the same).

Figure 14 shows the flow chart and code required to implement the basic dual slope technique as shown in Figure 13. Under laboratory conditions an accuracy of 12 bits $\pm 1$ bit was achieved. The method is slow, with the maximum conversion time equal to $2 \times T_{\text {REF }}$. Notice that the accuracy of $V_{C C}$ and that of the integrating resistor and capacitor are not involved in the accuracy of the result. The accuracy of $V_{\text {REF }}$ is, of course, controlling if absolute accuracy-rather than ratiometric accuracy-is desired. The absolute accuracy of the circuit can be no better than the accuracy of the reference. If ratiometric accuracy is all that is required, there is no particular problem. The accuracy is merely relative to the reference. The R and C values do not impact the accuracy because the integration in both directions is being done through the same R and C . Results would be quite different if a different value of $R$ or $C$ was used for one of the slopes.


FIGURE 14A. Dual Slope A/D Code


TL/DD/6935-21
FIGURE 14B. Basic Dual Slope A/D Flow Chart

### 4.3 MODIFIED DUAL SLOPE TECHNIQUE

## General

The basic idea of the modified dual slope technique is the same as that of the basic approach. The modified approach eliminates the need for dual polarity references and is also more forgiving in the selection of the op amp and comparator required. Figure 15 illustrates the basic idea.


TL/DD/6935-23
FIGURE 15. Modified Dual Slope - Basic Concept The math analysis is much the same:

$$
\begin{gathered}
I_{X}=C \frac{d V}{d t}=\left(V_{X}-V_{M A X}\right) / R \\
V_{X}-V_{M A X}=R C \frac{d V}{d t} \\
\left(V_{X}-V_{M A X}\right) T 1=R C \\
V=\left(V_{X}-V_{M A X}\right) T 1 / R C
\end{gathered}
$$

Similarly:

$$
\begin{gathered}
I_{\text {REF }}=C \frac{d V}{d t}=\left(V_{\text {REF }}-V_{M A X}\right) / R \\
\left(V_{R E F}-V_{M A X}\right) T_{X}=-V R C \\
V=-\left(V_{R E F}-V_{M A X}\right) T_{X} / R C \\
\left(V_{\text {MAX }}-V_{\text {REF }}\right) T_{X}=\left(V_{X}-V_{M A X}\right) T 1 \\
V_{X}=V_{M A X}+\left(V_{M A X}-V_{\text {REF }}\right) T_{X} / T 1
\end{gathered}
$$

The main difference between this and the basic approach is the offset voltage $V_{\text {MAX }}$. The main restriction is that all input voltage values $\left(\mathrm{V}_{\mathrm{X}}\right)$ are less than $\mathrm{V}_{\text {MAX }}$. It is also apparent that the total count is proportional to the difference between $V_{\text {MAX }}$ and $V_{X}$. The only significant effect of this is, however, to slightly complicate the arithmetic required to arrive at a value for $V_{X}$.
Given that the input voltage $V_{X}$ is always less than $V_{M A X}$, the modified dual slope technique is automatic polarity. This fact comes straight out of the equation above. Thus dual polarity references are not required. However, two precise voltages are required: $\mathrm{V}_{\text {MAX }}$ and $\mathrm{V}_{\text {REF }}$. However, the $\mathrm{V}_{\text {MAX }}$ value can be used for a zero adjust as indicated in Figure 16. This means that the $V_{\text {MAX }}$ value need not be so precise as it will be adjusted in a calibration procedure to produce a zero output. This adjustment amounts to a compensation for the bias currents and offsets. Thus the COP420 can use the supposed value of $\mathrm{V}_{\text {MAX }}$ with $\mathrm{V}_{\text {MAX }}$ later being "tweaked" to give the proper result at zero input. In addition, the initialization loop for the integrating capacitor includes the comparator. Thus the intial condition on the capacitor becomes
not zero but the sum of the offset voltages of the comparator and op amp. Thus the choice of these components is not critical in a modified dual slope approach.

## An Example of the Modified Dual Slope Approach

Figure 16 illustrates an implementation of the modified dual slope technique. The system is calibrated by holding $\mathrm{V}_{\mathbb{I}}$ to ground and then adjusting $V_{\text {MAX }}$ for a " 0 " result. Capacitor C 1 is the integrating capacitor. Capacitor C 2 is used only to cause a rapid transition on the comparator output. C2 is especially useful if an op amp is being used as the comparator stage. Resistor R1 is just part of the capacitor initializing loop. An LH0070 is being used to generate the reference voltage and the $\mathrm{V}_{\text {MAX }}$ value. The discussion previously about these being hard sources is equally relevant here. In fact, this problem was much more significant in this particular implementation and made the difference between a 10 and 12 bit system. As shown, the technique was accurate to 10 bits. Another bit was obtained when the $\mathrm{V}_{\text {MAX }}$ and $\mathrm{V}_{\text {REF }}$ values were buffered. It must be remembered that when trying to achieve accuracies of this magnitude board layout, parts placement, lead length, etc. become significant factors that must be specifically addressed by the user.
There are some other considerations in using this technique. The amount of time required to count the specified number of counts starts to become a significant factor. If it takes "too long" to do the counting, the capacitor can charge to either supply voltage depending on which direc-
tion it is integrating. This causes the wave shape shown in Figure 15 to flatten out. This effectively limits the input range for all accuracy is lost once that waveform flattens out. In fact, this was the limiting factor on the accuracy in Figure 16 as shown. Given the amount of time required for an increment of the counter for $T_{\text {REF }}$ (or $T_{X}$ ), it was not possible to reach the 4096 counts required for 12 bit accuracy before the waveform flattened out. Decreasing the total count solves the problem at the expense of accuracy. It is therefore desirable to keep the loop time required for an increment as fast as possible. The code to implement Figure 16 is shown in Figure 17 and reflects that concern. The other way to solve the problem is to use a large value for $R$ and $C$. This is the easiest solution and preserves accuracy. Its cost is increased conversion time.
Both the basic and modified dual slope schemes can be very accurate and are commonly used. They tend to be relatively slow. In many applications, however, speed is not a factor and these approaches can serve very well. There are various approaches to dual slope analog to digital conversion which try to improve speed and/or accuracy. These are usually multiple ramping schemes of one form or another. The heart of the approach is the basic scheme described above. It is not the purpose here to delve into all the possible ways that dual slope conversion may be accomplished. The control software is not significantly different regardless of which particular variation is used. The basic ramping control is the same as that indicated here.


FIGURE 16. Modified Dual Slope Integration

The number of components required to implement a dual slope scheme is not related to the desired accuracy. The approach is generally tolerant as to the op amps and comparators used as long as proper care is given to the initialization of the integrating capacitor.

Precise references are not required if a ratiometric system is all that is required. Cheaper switches can be safely used. The dual slope scheme controlled by a COPS microcontroller can be a very cost effective solution to an analog to digital conversion problem.


FIGURE 17A. Modified Dual Slepe Code


TL/DD/6935-25
FIGURE 17B. Modified Dual Slope Flow Chart

### 5.0 Voltage to Frequency Converters, VCO's

### 5.1 BASIC APPROACH

The basic idea of this scheme is simply to use the COP420 to measure the frequency output of a voltage to frequency converter or VCO. This frequency is in direct relation to the input voltage by the very nature of such devices. There are really only two limiting factors involved. First of all, the maximum frequency that can be measured is defined in the microcontroller by the amount of time required to test an input and increment a counter of the proper length. With the COP420 this upper limit is typically 10 to 15 kHz . The other limiting factor is simply the accuracy of the voltage to frequency converter or VCO. This accuracy will obviously affect the accuracy of the result.
Two basic implementations are possible and their code implementation is not significantly different. First, the number of pulses that occur within a given time period may be counted. This is straightforward and fairly simple to implement. The crucial factor is how long that given time period should be. To get the maximum accuracy from this implementation the time period should be one second. Such a time period would allow the distinction between the frequencies of 5000 Hz and 5001 Hz for example (assuming the V to F converter was that accurate or precise). Decreasing the amount of time will decrease the precision of the result. The alternate approach is to measure (by means of a counter) the amount of time between twa successive pulses. This period measurement is only slightly more complicated than the pulse counting approach. The approach also makes it possible to do averaging of the measurement during conversion. This will smooth out any changes and add stability to the result. The time measurement technique is also faster than the pulse counting approach. Its accuracy is governed by how finely the time periods can be measured. The greater the count that can be achieved at the fastest input frequency - shortest period - the more accurate the result.
Figure 18 illustrates the basic concept. Figure 19A shows the flow charts and code implementation for both of the approaches discussed above. Note that whatever type of $V$ to F converter is used, the code illustrated in Figure 19A is not significantly changed. In the code of Figure 19A, the interrupt is being used to test an input and thereby decreases the total time loop.


FIGURE 18. V to F Converter - Basic Concept

| MI-Atidg: | 1 MEASURE EY COUNTING PULSES OF $\checkmark$ TO F |  |  |
| :---: | :---: | :---: | :---: |
| 1 |  |  |  |
|  | LEI | 2 | ; ENABLE INTERRUPT |
|  | LBI | 1. 14 | ; PRESET TIME FOR 122 COUNTS |
|  | STII |  | ; APPROX ONE HALF SECOND |
|  | STII | 8 |  |
| TIMH: | SKT |  | IUSE INTERNAL TIMER TO FIND |
|  | JP | TIME | 1 THE $1 / 2$ SECOND |
| B2NJ1: | LBI | 1.14 | ; HAVE GOT IT, INCREMENT COUNTER |
|  | SC |  |  |
| DINAIII: | CLRA |  |  |
|  | ASC |  |  |
|  | NOP |  |  |
|  | XIS |  |  |
|  | JP | EINADD |  |
|  | SKC | TIME NOW SEE IF DONE |  |
|  | JP | time | , NO COUNTER OVERFLOW, CONTINUE |
|  | LEI |  | - DONE, DISABLE INTERRUPT |
| FIN: | ; AT THIS POINT |  | HAVE THE VALUE--CONVERT IT TO DECIMAL OR |
|  | ; SEND IT DUT OR |  | PROCESS IT FURTHER, WHATEVER IS REQUIRED |
|  |  |  | TION. ARITHMETIC IS REQUIRED TO CREATE THE |
|  | ; VOlttage value, |  | USUALLY A SIMPLE MULTIPLY |
|  | - May mave to dou |  | Uble the result to compensate looking for |
|  | - ONLY 1/2 SECOND |  | D IN THIS CASE . |
|  | 1 , |  |  |
|  | $J P$ | MEASUR |  |
|  | =x'OFF |  | ; SET ADDRESS TO OFF FOR INTERRUPT |
| [NIENT: | NOP |  | ; ADDRESS OFF MUST BE NOP FOR INTERRUPT |
| INIIかI: | LGI | 2,12 | ; DO ADD DF THE VALUE FOR FREQ CNT |
|  | SC |  |  |
| INIKI: |  |  | ; STRAIGHT LINE THE CODE FOR SPEED |
|  |  |  |  | ASC |
|  | NOP |  |  |
|  | XIS |  |  |
|  | CLRA |  |  |
|  | ASC |  |  |
|  | NBP |  |  |
|  | XIS |  |  |
|  | CLRA |  |  |
|  | ASC |  |  |
|  | NOP |  |  |
|  | XIS |  |  |
|  | CLRA |  |  |
|  | ASC |  |  |
|  | NOP |  |  |
|  | X |  |  |
|  | LEI | 2 | ; ENABLE THE INTERRUPT AGAIN |
|  | RET |  |  |

TL/DD/6935-49
FIGURE 19A. V to F by Counting Pulses


TL/DD/6935-27
FIGURE 19B. V to F by Counting Pulses


TL/OD/6935-28

## FIGURE 19D. V to F-Measure Perlod

### 5.2 THE LM131/LM231/LM331

The LM131 is a standard product voltage to frequency converter with a linear relationship between the input voltage and the resultant frequency. The reader should refer to the data sheet for the LM131 for further information on the device itself and precautions that should be taken when using the device. Figure 20 is the basic circuit for using the LM131. Figure 21 represents improvements that increase the accuracy (by increasing the linearity) of the result. Note that these circuits have been taken from the data sheet of the LM131 and the user is referred there for a further discussion of their individual characteristics. With the LM131 the frequency output is given by the relationship:

$$
\text { FOUT }=\left(V_{\mathbb{I N}} / 2.09\right)\left(1 / R_{T} C_{T}\right)\left(R_{S} / R L\right)
$$

It is clear from the expression above that the accuracy of the result depends upon the accuracy of the external com-
ponents. The circuit may be calibrated by means of a variable resistance in the $\mathrm{R}_{\mathrm{S}}$ term (a gain adjust) and an offset adjust. The offset adjust is optional but its inclusion in the circuit will allow maximum accuracy to be obtained. The standard calibration procedure is to trim the gain adjust ( $\mathrm{R}_{\mathrm{S}}$ ) until the output frequency is correct near full scale. Then set the input to 0.01 or 0.001 of full scale and trim the offset adjust to get FOUT to be correct at 0.01 or 0.001 of full scale. With that calibration, the circuit of Figure 20 is accurate to within $\pm 0.03 \%$ typical and $\pm 0.14 \%$ maximum. The circuit of Figure 21 attains the spec limit accuracy of $\pm 0.01 \%$.

### 5.3 VOLTAGE CONTROLLED OSCILLATORS (VCO's)

A VCO is simply another form of voltage to frequency converter. It is an oscillator whose oscillation frequency is dependent upon the input voltage. Numerous designs for VCO's exist and the reader should refer to the data sheets and application notes for various op-amps and VCO devices. The code in Figure 19 is still applicable if a VCO is used. The only possible difficulty that might be encountered is if the relationship between frequency and input voltage is non-linear. This does not affect the basic code but would affect the processing to create the final result. A sample circuit, taken from the data sheet of the LM358, is shown in Figure 22. The accuracy of the VCO is the controlling factor.

### 5.4 A COMBINED APPROACH

Elements of the period measurement and pulse counting techniques can be combined to produce a system with the advantages of both schemes and with few problems. Such a system is only slightly more complicated in terms of its software implementation than the approaches mentioned above. Note that in a microcontroller driven system, no additional hardware beyond the voltage to frequency converter is required to implement this approach. Basically, the microcontroller establishes a viewing window during which time the microcontroller is both measuring time and counting pulses. The result can be very precise if two conditions are met. First, when the microcontroller determines that it needs the conversion information, the microcontroller does not begin counting time or pulses until the first pulse is received from the VFC (first pulse after the microcontroller "ready"). Note, the COPS microcontroller could provide a "start conversion" pulse to enable the VFC if such an arrangement were desirable. The time would be counted for a fixed period and the number of pulses would be counted. After the fixed period of time the controller would wait for the next pulse from the VFC and continue to count time until that pulse is received. The ratio of the total time to the number of pulse is a very precise result provided that all the system times are slow enough that the microcontroller can do its job. The speed limits mentioned previously apply here. It is clear that the total time is not fixed. It is some basic time period plus some variable time. This is a little more complicated than simply using a fixed time, but it allows greater accuracies to be achieved. Also, the approach takes approximately the same amount of time for all conversions. It is also faster than the simple pulse counting scheme.


FIGURE 20. Basic LM331 Connection


FIGURE 21. A to D with Precision Voltage to Frequency Converter


FIGURE 22. A to D with VCO

### 6.0 Successive Approximation

### 6.1 BASIC APPROACH

The successive approximation technique is one of the more standard approaches in analog to digital conversion. It requires a counter or register (here provided by the COP420), a digital to analog converter, and a comparator. Figure $23 A / B$ illustrates the basic idea with the COP420. In the most basic scheme, the counter is reset to zero and then incremented until the voltage from the digital to analog converter is equal to the input voltage. The equality is determined by means of the comparator. Figure $24 B$ illustrates the flow chart and code for this most basic approach. The preferred approach is illustrated in Figure 25A/B. This is the standard binary search method. The counter or register is set at the midpoint and the "delta" value set at one half the midpoint. The "delta" value is added or subtracted from the initial guess depending on the output of the comparator. The "delta" value is divided by 2 before the next increment or decrement. The method repeats until the desired resolution is achieved. While this approach is somewhat more complicated than the basic approach it has the advantage of always taking the same amount of time for the conversion

FIGURE 23A. Basic Parallel Implementation

regardless of the value of the input voltage. The conversion time for the basic approach increases with the input voltage. The preferred approach is almost always faster than the basic approach. The basic approach is faster only for those voltages near zero where it has only a few increments to perform.
The accuracy of the approach is governed by the accuracy of the digital to analog converter and the comparator. Thus, the result can be as accurate as one desires depending on the choice of those components. Digital to analog converters of various accuracies are readily available as standard parts. Their cost is usually in direct relation to their accuracy. The reader should refer to the National Semiconductor Data Acquisition Handbook for some possible candidates for digital to analog converters. It is not the purpose here to compare those parts. The COPS interface to these parts is generally straightforward and follows the basic schematics shown in Figure 23. The user should take note and make sure the input and output ports of the converter are compatible - in terms of voltages and currents - with the COPS device. This is generally not a problem as most of the parts are TTL compatible on input and output. The precautions and restrictions as to the use of any given device are governed by that device and are indicated in the respective data sheets.


TL/DD/6935-33

FIGURE 23B. Basic Serial Implementation


FIGURE 24A. Code for Basic Approach of Successive Approximation


TL/DD/6935-34
FIGURE 24B. Basic Approach, Successive Approximation

|  | $\begin{aligned} & ; 8 \mathrm{BI} \\ & \text { i INPu } \\ & : \mathrm{GOMP} \end{aligned}$ | INARY <br> COP <br> ATDR $=0$ | SEARCH SUCCESSIVE APPROXIMATION IS INJ, L EUS IS OUTPUT TO D TO A,L7=MSB, LO $=$ LSB WHEN D TO A VOLTAGE 3 VIN, OTHERWISE $=1$ |
| :---: | :---: | :---: | :---: |
| B) Mtikll: | LbI | 3. 14 | : SEt increment = Max value/z<will become |
|  | STII | 0 | : MAX VALUE/4 BEFORE FIRST USE) |
|  | Sili | 8 |  |
|  | LBI | 2. 14 | iSEt initial value of result to max value/z |
|  | STII | 0 |  |
|  | STII | 8 |  |
|  | LEI | 4 | , ENA日LE THE L BUS AS DUTPUTS |
|  | LDI | 1,15 | indw Set up the bit counter-overflow when a bits |
|  | CLRA |  |  |
|  | AISC | 9 | ido it this way for compatibility with increment |
|  | X | 3 | isave the bit counter value and point to result |
|  | I-D |  |  |
|  | XDS |  | ; SEND THE RESULT TO Q AND HENCE TO L |
|  | CAMO |  |  |
| DIVIDE: <br> D) VA: | LB1 | 3,15 | - DIVIde the increment value by 2, CAN de done |
|  | LD |  | ; IN SEVERAL WAYS SINCE THIS IS A VERY SPECIAL |
|  | AISC | 8 | ; PURPOSE DIVIDE FUNCTION |
|  | JP | DIVI | ; ALSD, DO THE DIVIDE HERE TO qIVE THE D TO A TIME |
|  | STII |  | : TO DO THE DIGITAL TO ANALOG CONVERSION |
|  | JP | TEST |  |
| DIV1: | AISC |  |  |
|  | JP | DIV2 |  |
|  | STII |  |  |
|  | JP | TEST |  |
| Divi?: | AISC | 2 |  |
|  | JP | DIV3 |  |
|  | STII | 1 |  |
|  | JP | test |  |
| DIVA: | L. BI | 3.14 |  |
|  | AISC | 1 |  |
|  | JP | DIVA |  |
|  | STII | 8 |  |
|  | STII | 0 |  |
|  | - DEPE | NG ON | THE D TO A USED, MAY NEED MORE DELAY HERE |
|  | 1 MUST | SURE | THE RESULT is steady before test the comparator |
| T+31: | LBI | 3. 14 |  |
|  | ININ |  |  |
|  | AISC |  | I COULD SAVE A WORD If USED G LINE AS INPUT |
|  | JP | INCR |  |
| DECH: SUA: | SC |  | I INPUT LESS THAN D TO A CONVERTED VOLTAGE |
|  | LD | 1 | I SUBTRACT THE INCREMENT VALUE FROM RESULT |
|  | CASC |  |  |
|  | NOP |  |  |
|  | XIS | 1 |  |
|  | JP | SUB |  |
|  | JP | EITPL1 |  |
| JNC: All): | RC |  | 1 INPUT $>$ D TO A CONVERTED VOLTAGE |
|  | LD | 1 | i add the increment value to result value |
|  | ASC |  |  |
|  | NOP |  |  |
|  | XIS | 1 |  |
|  | JP | ADD |  |
| 日1า11: | LBI | 1, 15 | ; NOW Increment bit counter to see if done |
|  | LD |  |  |
|  | AISC | 1 |  |
|  | JP | OUTPUT |  |
|  | , CONVERSIDN done at this point |  |  |



FIGURE 25B. Binary
Search Successive Approximation Flow Chart

FIGURE 25A. Binary Search Successive Approximation Code

### 6.2 SOME COMMENTS ON RESISTOR LADDERS

If the user does not wish to use one of the standard digital to analog converters, he can always build one of his own. One of the most standard methods of doing so is to use a resistor ladder network of some form. Figure 26 illustrates the basic forms of binary ladders for digital to analog converters. The figures also show the transition from the basic binary weighted ladder in Figure $26 A$ to the standard R-2R ladder Figure 26C.
Consider Figure 26A. The choice of the terminating resistor is made by hypothesizing that the ladder were to go on ad infinitum. It can then be shown that the equivalent resistance at point $X$ in that figure would be equal to 128R, the same value as the resistor to the least significant bit output. This fact is used to create the intermediate ladder of Figure $26 B$. This step is done because it is usually undesirable to have to find the multitude of resistor values required in the basic binary ladder. Thus, the modification in Figure 26B significantly reduces the number of resistor values required. As stated earlier, the resistance looking down the ladder at point X in Figure 2 is equal to the resistor connected to the binary output at that point; here the value is 2 R . Remembering the objective is to minimize the number of different values required, if we simply use the same R-2R arrangement as before with a termination of $2 R$ we get an effective resistance at point $Y$ of Figure 26B or 0.5R. This means that a serial resistance of 1.5 R is required to maintain the integrity of the ladder. If we carry this on through 8 bits, the circuit of

Figure $26 B$ results. From this it is only a small step to create the standard R-2R network. The analysis is the same as done previously.
There is absolutely no restriction that the ladders must be binary. A ladder for any type of code can be constructed with the same techniques. Ladders comparable to Figures 26A and 26B are shown in Figure 27 for a standard 8421 BCD code. With the BCD code, the input must be considered in groups of digits with four bits creating one digit. This is the direct analog of 1 binary digit per unit. We need four inputs to create one decimal digit. Thus the resistor values in each decimal digit are 10 times the values in the previous decimal digit just as the resistor value for each successive binary digit was twice the value for the preceding binary digit. Note that this analysis can be easily extended to any code. The termination resistance is calculated in the same manner-assume the decimal digit groupings extend out to infinity. It can be shown that the resistance of the ladder at point X in Figure 27A is 480R. Thus Figure 27A represents the basic 8241 BCD ladder for three digit BCD number. This termination resistance will vary with where it is placed. Basically this resistance is equal to nine times (for a decimal ladder) the parallel resistance of the last digit implemented. (This relation can be shown mathematically if one desired, the multiplier is a function of the type of ladder used-multiplier $=1$ for binary systems, 9 for decimal systems, etc.) Thus the termination resistance would be 48R if the network were terminated after the 2nd digit and 4.8R if the network were terminated after the 1st digit implemented. In



A
B
C
FIGURE 26. Binary Ladders

Figure $27 B$ we are attempting to use only the resistor values for one decimal digit. This means that the last terminating resistor must be a 4.8R by the analysis above. Thus at point $X$ in Figure $27 B$ we must have an equivalent of resistance of 4.8R. The equivalent resistance at point $Y$ of Figure 27B, looking down from the ladder, is 0.48 R . Thus the other series resistance must be 4.32 R (4.8R-0.48R). Thus the network of Figure $27 B$ results.
Generally, ladders can be very effective tools when understood and used properly. They can be significantly more involved than indicated here. There are a number of texts and articles that cover the subject very nicely and the reader is referred to them if more information on ladder design, the use of ladders, and advanced techniques with ladders is desired.
One final note is of some interest. The ladders may be readily constructed for any type of code to create the analog voltage. Note that there is no restriction that the code, or the ladder network, be linear. Thus, effective use of ladder networks may significantly reduce system difficulties and
complexities caused by the fact that the analog to digital conversion is being performed on a voltage source that changes nonlinearly, for example a thermistor temperature probe. By using the properly designed ladder network, the nonlinearity can effectively be eliminated from consideration in the code implementation of the analog to digital conversion.
The accuracy of ladders is a direct function of the accuracy of the resistors and the accuracy of the voltage source inputs. This is obvious since the analog voltage is in fact created by means of equivalent voltage dividers created when the various inputs are on or off. It is also essential that the ladder sources be the precise same value at all inputs to the ladder network. If this is not the case, errors will be introduced. In addition, the output impedance of the voltage source should be as small as possible. The success of the ladder scheme depends on the ratios of the resistance values. Inaccuracies are introduced if those ratios are disturbed. Some possible implementations of the successive approximation approach with a ladder network used for the digital to analog conversion are indicated in Figure 28.


FIGURE 27. 8421 BCD Ladders

Note that these are functional diagrams. Feedback or hysteresis for comparator stabilization are not shown. The reader should be aware that his particular application may require that these factors be considered. Figure $28 A$ is the simplest scheme and also the least accurate. With little or no load, the high output level of the L buffer should be very close to $V_{C C}$ and the low level close to ground. Also the output impedance of the buffers must be considered. Therefore, rather large resistor values are used-both to keep the load very small and to dwarf the effect of the output imped-

ance. With the configuration in Figure 28A, four bit accuracy is about the best that can be achieved. By being extremely careful and using measured values, an additional bit of accuracy may be obtained but care must be used. However, the schematic of Figure $28 A$ is very simple. Figure $28 B$ represents the next step of improvement. Here we have placed CMOS buffers in the network. This eliminates the output impedance and reduces the level problems of the circuit of Figure 28A. The CMOS buffer will swing rail to rail, or nearly so. The accuracy of $V_{C C}$ and the resistor network is then


TL/DD/6935-39
B


TL/DD/6935-40

FIGURE 28. Interfaces to Ladder Networks
controlling. Using $1 \%$ resistors and holding $V_{C C}$ constant, the user should be able to achieve 7 to 8 bit accuracy without much difficulty. Remember, however, that $\mathrm{V}_{\mathrm{Cc}}$ is one of the controlling factors. If $V_{C C}$ is $\pm 5 \%$, there is no point in using $1 \%$ resistors since the $V_{C C}$ tolerance swamps their effect. Figure 28C is the final and most accurate approach. Naturally enough, it is the most expensive. However, one can get as accurate as one desires. Here, an accurate reference is required. That reference is switched into the network by means of the analog switch. Alternately, ground may be connected to the input. Now the user need only consider the accuracy of the reference and the accuracy of the resistors. However, the on impedance of the switches must be considered. It is necessary to make this on impedance as low as possible so as not to alter the effective resistor values.

## 7.0 "Offboard" Techniques

### 7.1 GENERAL COMMENTS

This section is devoted to a few illustrations of interfacing the COP420 to standard, stand alone analog to digital converters. These standard converters are used as peripherals to the COPS device. Whenever the microcontroller requires a new reading of some analog voltage, it simply initiates a read of the peripheral analog to digital converter. As a result, the accuracies and restrictions in using the converters are governed by those devices and not by the COPS device. These techniques are generally applicable to other A to D
converters not mentioned here and the user should not have difficulty in applying these principles to other devices. It should be pointed out that in almost every instance, the choice of COP420 inputs and outputs is arbitrary. Obviously, when there is an 8 -bit bus it is natural, and most efficient, to use the $L$ port to interface to the bus. Generally, the $G$ lines have been used as outputs rather than the $D$ lines simply because the $G$ lines are, in many instances, somewhat easier to control. The choice of input line is also free. If the interrupt is not otherwise being used, it may be possible to utilize this feature of IN1 for reading a return signal from the converter. However, this is by no means required. If there is a serial interface it is clearly more efficient to use the serial port of the COP420 as the interface. If a clock is required, SK is the natural choice.

### 7.2 ADC0800 INTERFACE

The ADC0800 is an 8-bit analog to digital converter with an 8 -bit parallel output port with complementary outputs. The ADC0800 requires a clock and a start convert pulse. It generates an end of conversion signal. There is an output enable which turns the outputs on in order to read the 8-bit result.
The reader is referred to the data sheet for the ADC0800 for more information on the device. The circuit of Figure 29 illustrates the basic implementation of a system with the ADC0800. The interface to the COP420 is straightforward. The appropriate timing restrictions on the control signals are easily met by the microcontroller.


TL/DD/6935-41
FIGURE 29. Simple A/D with ADC0800

Figure 30 is the flow chart and code required to do the interfacing. As can be seen, the overhead in the COP420 device is very small. The choice of inputs and outputs is arbitrary. The only pin that is more or less restricted is the use of SK as the clock for the converter. SK is clearly the output to use for that function as, when properly enabled, it provides pulses at the instruction cycle rate.

### 7.3 ADC0801/2/3/4 INTERFACE

The ADC0801 family of analog to digital converters is very easy to interface and is generally a very useful offboard con-
verter. The interface is not significantly different from that of the ADC0800, but the ADC0801 famliy are a much better device. The four control signals are somewhat different, although there are still four control lines. Here we have a chip select, a read, a write, and an interrupt signal. All are negative going signals. Start conversion is the ANDing of chip select and write. Output enable is the ANDing of chip select and read. The interrupt output is an end convert signal of sorts. The device may be clocked externally or an RC may be connected to it and it will generate its own clock for the conversion. In addition the device has differential inputs


FIGURE 30A. A to D with ADC0800


TL/DD/6935-42
FIGURE 30B. ADC0800 Interface Flow
which allow the 8 -bit conversion to be performed over a given window or range of input voltages. The reader should refer to the ADC0801 family data sheet for more information. Figure 31 indicates a basic interface of the ADC0801 family to the COP420. Again, the interface is simple and straightforward. The code required to interface to the device is minimal. Figure 32 illustrates the flow chart and code required to do the interface.


TL/DD/6935-43
FIGURE 31. COP420—ADC0801 Family Interface

|  | ; INTERFACE TD NAKED 8 |  |  |
| :---: | :---: | :---: | :---: |
| NAKI-ItS: | ; |  |  |
|  | OGI | 15 | ; SET ALL G LINES HIGH(USUALLY DONE AT ; POWER UP |
|  | LEI | 0 | ; TRI STATE THE L LINES FOR READING |
| Loult : | OGI | 14 | ; SEND CHIP SELECT LOW(CS BRACKETS OTHER SIGNAL) |
|  | OGI | 10 | ; CS LOW AND WR LOW = START CONVERSIION |
|  | OGI | 14 | ; RAISE WR |
|  | OGI | 15 | ; RAISE CS, NAKED 8 IS NDW CONVERTING |
| LIIH13': | ININ |  | ; WAIT FOR THE INTR SIGNAL--COULD SAVE THIS TES |
|  | AISC | 8 | ; IF USED IN1 AND THE INTERRUPT FEATURE DF COP 4 |
|  | JP | READ | ; INTR IS LOW, DATA IS READY |
|  | JP | LOOP2 |  |
| RI. A1): | LBI | 0,0 | ; SET UP RAM LOCATION FOR READ |
|  | OGI | 14 | ; SEND CS |
|  | OGI | 12 | ; SEND CS AND READ = OUTPUT ENABLE. |
|  | NOP |  | ; WAIT-NEED WAIT ONLY 125NS, BUT 1 cycle is MIN ; TIME WE CAN WAIT |
|  | INL |  | ; READ THE L LINES |
|  | OGI | 15 | ; TURN OFF THE NAKED B--CS AND RD HIGH |
|  |  |  |  |
|  | ; DONE AT THIS POINT, do Whatever is required with the resulu |  |  |

FIGURE 32A. COP420/ADC0801 Family Sample Interface Code


TL/DD/6935-44
FIGURE 32B. COP420/ADC0801 Family Interface Flow

### 8.0 Conclusion

Several analog to digital techniques using the COPS family have been presented. These are by no means the only techniques possible. The user is limited only by his imagination and whatever parts he can find. The COPS family of parts is extremely versatile and can readily be used to perform the analog to digital conversion in almost any method. Generally, those techniques where the COPS device is doing the counting or timekeeping are slow. However, those techniques are generally slow inherently. The fastest methods are those where the conversion is being done offboard and the COPS device is merely reading the result of the conversion when required. Also, an attempt has been made to illustrate the lower cost techniques of analog to digital
conversion. This, by itself, restricts most of the techniques described to about 8 -bits accuracy. As was mentioned several times, the greater the accuracy that is desired the more accurate the external circuits must be. Ten and twelve-bit accuracies, and more, require references that are accurate. These get very expensive very rapidly. There is nothing inherent in the COPS devices that prevents them from being used in accurate systems. The precautions are to be taken in the system regardless of the microcontroller. The only problem is that, in those accurate systems where the COPS device is doing the timekeeping and counting, this increased accuracy is paid for by increased time to perform the conversion.
Several devices have been used in conjunctions with the COPS device in the previous sections. It is again recommended that the user refer to the specific data sheets of those devices when using any of those circuits. It must again be mentioned that the standard precautions when dealing with analog signals and circuits must be taken. These are described in the National Semiconductor Linear Applications Handbook and in the data sheets for the various linear devices. These precautions are especially significant when greater accuracy is desired.
The COPS family of microcontrollers has shown itself to be very versatile and powerful when used to perform analog to digital conversions. Most techniques are code efficient and the microcontroller itself is almost never the limiting factor. It is hoped that this document will provide some guidance when it is necessary to perform analog to digital conversion in a COPS system.

### 9.0 References

1. "Digital Voltmeters and the MM5330", National Semiconductor Application Note AN-155.
2. Walker, Monty, "Exploit Ladder Network Design Potential'. Part One of two part article on ladder networks. Magazine and date unknown.
3. Wyland, David C., "VFC's give your ADC design high resolution and wide range". EDN, Feb. 5, 1978.
4. Redfern, Thomas P., "Pulse Modulation A/D Converter" Society of Automotive Engineers Congress and Exposition Technical paper \#780435, March 1978.
5. National Semiconductor Linear Applications Handbook, 1978.
6. National Semiconductor Linear Databook, 1980.
7. National Semiconductor Data Acquisition Handbook, 1978.

## The COP444L Evaluation Device 444L-EVAL

The $444 \mathrm{~L}-\mathrm{EVAL}$ is a preprogrammed COP444L intended to demonstrate operating characteristics and facilitate user familiarization and evaluation of the COP444L and the COPSTM family in general.
The 444L-EVAL has two mutually exclusive operating modes: an up/down counter/timer or a simple music synthesizer. The state of pin L7 at power up determines the operating mode.

### 1.0 THE 444L-EVAL AS A SIMPLE MUSIC SYNTHESIZER

Figure 1 indicates the connection of the 444L-EVAL as a simple music synthesizer. As the diagram indicates, the connections required for operation are minimal. The os-

National Semiconductor Corp. COP Note 4 Leonard A. Distaso
cillator may be a crystal circuit using CKI and CKO; an external oscillator to CKI; or an RC network using CKI and CKO. As should be expected, the crystal circuit provides the greatest frequency stability and precision. The RC network will provide an acceptable oscillation frequency but that frequency will be neither precise nor stable over temperature and voltage. The external oscillator, of course, is as good as its source. The frequencies for the various notes and delay times are set up assuming that the oscillator frequency is 2 MHz . Three modes of operation are available in the music synthesizer mode: play a note; play one of four stored tunes; or record a tune for subsequent replay.


## 1.A. PLAY A NOTE

Twelve keys, representing the twelve notes in one octave, are labeled " C " through " B ". Depressing a key causes a square wave of the corresponding frequency to output at GO. The user may drive a piezo-ceramic transducer directly with this signal. With the appropriate buffering, the user may use this signal to drive anything he wishes. A simple transistor driver is sufficient to drive a small speaker. The user can be as simple or as complex as he desires at this point-e.g. he can do some wave shaping, add an audio amplifier, and drive a high quality speaker.
The 444L-EVAL has a range of two and one-half octaves: the basic octave on the keyboard (which is middle $C$ and the 11 notes above it in the chromatic scale), one full octave above the basic octave and one-half octave below the basic octave. The notes in the basic octave are played by depressing the appropriate key (one key at a time-the keyboard has no rollover provisions). A note in the upper octave is played by first depressing and releasing the U SHIFT key and then depressing the note key. Similarly, a note in the lower one-half octave is played by first depressing and releasing the L SHIFT key and then depressing the note key. Two other shift keys are present: UPPER and LOWER. All notes played while the UPPER key is held down will be in the upper octave. Similarly, note F \# through B when played while the LOWER key is held down will be in the lower onehalf octave. The lower octave notes $C$ through $F$ are not present and depressing any of these 6 keys while the LOWER key is held down or after depressing the L SHIFT key will play the note in the basic octave.

## 1.B. PLAY STORED TUNE

The 444L-EVAL can play four preprogrammed tunes. Depressing PLAY followed by " $1 / 8$ ", " $1 / 4$ ", " $1 / 2$ ", or " 1 " will cause one of these tunes to be played. The tunes are:
PLAY 1 -Music Box Dancer
PLAY $1 / 2$-Santa Lucia
PLAY $1 / 4$-Godfather Theme
PLAY $1 / 8$-Theme from Tchaikowsky Piano Concerto \#1

## 1.C. RECORD A TUNE

Any combination of notes and rests up to a total of 48 may be stored in RAM for later replay. A note is stored by depressing the appropriate key(s), followed by the duration of the note ( $1 / 16$ note, $1 / 8$ note, $3 / 16$ note, $1 / 4$ note, $3 / 8$ note, $1 / 2$ note, $3 / 4$ note, whole(1) note), followed by STORE. A rest is stored by selecting the duration and depressing STORE. The rests or durations of $1 / 16,3 / 16,3 / 8$, and $3 / 4$ are obtained by first depressing L SHIFT and then $1 / 8,1 / 4,1 / 2$, or 1 respectively. When the tune is complete press PLAY followed by STORE. The tune will be played for immediate audition. Subsequent depression of PLAY and then STORE will play the last stored tune.
Only one tune may be stored, regardless of length. Attempts to store a new or second tune will erase the previously stored tune. There are no editing features in this
mode. (In a "real system" of this type some form of editing would be desirable. It would not be difficult to add editing features.)
Note: The accuracy of the tones produced is a function of the oscillator accuracy and stability. The crystal oscillator, or an accurate, stable external oscillator is recommended.

### 2.0. THE 444L-EVAL AS AN UP/DOWN COUNTER/TIMER

By connecting pin L 7 to $\mathrm{V}_{\mathrm{CC}}$ and providing power and oscillator the 444L-EVAL functions as an 8 digit binary/BCD up/ down counter. In addition, an approximate 1 Hz signal is produced by the device. The 444L-EVAL can drive a single digit LED display directly. With the appropriate driver (COP472, COP470, MM5450/5451) the device can drive a 4 digit LCD, VF, or LED display. Any combination of these displays can be connected at any given time.
The binary/BCD and and up/down modes are controlled by the states of input pins INO and IN2 as indicated below:

```
INO = 1 (Default state) -BCD counter
INO \(=0\)
-Binary Counter
IN2 = 1 (Default state) -Count Up
IN2 = \(0 \quad\)-Count Down
```

The up/down control may be changed at any time. Changing the binary-BCD control during operation clears the counter before counting begins in the new mode.
Pins G2 and G3 provide display control to the user. He can choose to view either the most significant 4 digits of the counter or the least significant 4 digits of the counter. Further, the user can disable the update of the 4 digit displays. The controls are as follows:

$$
\begin{array}{ll}
\text { G2 }=1 \text { (Default state) } \begin{array}{l}
\text { Enable update of } 4 \text { digit } \\
\text { displays }
\end{array} \\
\text { G2 }=0 & \begin{array}{c}
\text { Disable update of } 4 \text { digit } \\
\text { displays }
\end{array} \\
\text { G3 }=1 \text { (Default state) } \begin{array}{l}
\text { Display least significant } 4 \\
\text { digits of counter }
\end{array} \\
\text { G3 }=0 & \begin{array}{l}
\text { Display most significant } 4 \\
\text { digits of counter }
\end{array}
\end{array}
$$

The single digit LED display displays the least significant digit of the counter. (Note, the direct drive capability for the single digit LED display refers to a small LED digitNSA1541A, NSA1166k, or equivalent.)

## 2.A. I/O MODE

The 444L-EVAL has the capability to allow the user to read or write the 8 digit counter through the L port. In the I/O mode, the single digit LED display is disabled. The 4 digit displays are not affected. In this mode pins D0 and IN3 are used for the handshaking sequence. DO is a Ready/Write signal from the 444L-EVAL to the outside; IN3 is a Write/ Acknowledge from the outside to the 444L-EVAL. Data I/O is via LO-L3 with LO being the least significant bit. Data is standard BCD for the BCD counter mode or standard hex for the binary counter mode. The digit address is on pins L4-L6 with L4 being the least significant bit. Digit address


TL/DD/6937-2
FIGURE 2. 444L-EVAL in Counter Mode

0 is the least significant digit of the counter; digit address 7 is the most significant digit of the counter. The I/O modes are controlled by pins G0 and G1 as follows:

| G0 | G1 | Output data with handshake, single |
| :---: | :---: | :--- |
| 0 | 0 | digit LED off |
| 0 | 1 | Input data with handshake, single <br> digit LED off |
| 1 | 0 | Auto output, no handshake, single <br> digit LED on |
| 1 | 1 | Default condition, No I/O, single digit <br> LED displays least significant digit of <br> counter |

## 2.A.1. Output Data with Handshake

With this mode selected the 444L-EVAL will output data with a handshake sequence. Note that the outputting of data is relatively slow as the device is counting and updating displays between successive digit outputs.
Before data is output, or the next digit of the counter is output, the 444L-EVAL must see IN3 (Acknowledge or ready from the external world high). The Ready/Write pin (DO) is assumed to be high at this point. With DO high and IN3 high, the device will output the data and digit address. After the data and address are output, the D0 line-functioning as a write strobe here-goes low. The 444L-EVAL then expects the signal at IN3 to go low indicating that the external world has read the data. When the device sees IN3 go low, DO will be brought high indicating that the sequence
is ready to repeat as soon as IN3 goes high again. The counter digits are output sequentially from least significant digit (digit address 0 ) through most significant digit (digit address 7). The sequence will continuously repeat as long as this mode is selected.

## 2.A.2. Input Data with Handshake

The 444L-EVAL will take data supplied to it and load the counter. The sequence is similar to that described above for the output mode. The external device(s) supplies both the data and the digit address where that data is to be loaded.
When sending data to the 444L-EVAL, the external circuitry must test that the device is ready to receive data (D0 high). Then the data and address should be presented at the L port. Then the Write signal (IN3) should be driven low. The 444L-EVAL will read the data and then drive DO low. When DO goes low, the external circuitry should bring IN3 high. After IN3 returns high, the 444L-EVAL will signal it is ready to receive data by sending DO high. Note that this sequence is relatively slow. The $444 \mathrm{~L}-\mathrm{EVAL}$ is performing several operations between successive read operations.

## 2.A.3. Automatic Output Mode

In the automatic output mode, the single digit LED is on. It is not displaying the least significant digit of the counter in this mode. The display is on so that the user can connect this LED digit, select the automatic output mode, and observe the states of the $L$ lines without having to put more sophisticated equipment or circuitry external to the 444L-EVAL. Segments a through d are pins LO thorugh L3; segments,
$e, f, g$ are pins L4, L5, and L6. Thus the user can observe the digit address changing and observe the corresponding data.
In this mode, the state of pin IN3 is irrelevant. The 444LEVAL sequentially outputs the digits of the counter.

D0 goes high when the data and address is being changed. DO goes low when the data is valid. As in the other 1/O modes, the process is slow. There is about 4 to 5 milliseconds between the successive digit outputs.


FIGURE 3A. Relative Timing-Output Handshake


TL/DD/6937-4
FIGURE 3B. Relative Timing-Input Handshake


FIGURE 3C. Relative Timing-Automatic Output

| 3.0 SELECTED OPTIONS |  |  |
| :---: | :---: | :---: |
| The 444L-EVAL has the following options selected: |  |  |
| GND | Option $1=0$ |  |
| CKO | Option $2=0$ | CKO is clock generator output to crystal |
| CKI | Option $3=0$ | CKI oscillator input divide by 32 |
| RESET | Option $4=0$ | Load device to $\mathrm{V}_{\mathrm{CC}}$ on RESET |
| L7 | Option $5=0$ | Standard output on L7 |
| L6 | Option $6=2$ | High current LED direct segment drive on L6 |
| L5 | Option $7=2$ | High current LED direct segment drive on L5 |
| L4 | Option $8=2$ | High current LED direct segment drive on L4 |
| IN1 | Option $9=0$ | Load device to $\mathrm{V}_{\mathrm{CC}}$ on IN1 |
| IN2 | Option $10=0$ | Load device to $\mathrm{V}_{C C}$ on IN2 |
| $\mathrm{V}_{\mathrm{CC}}$ | Option $11=1$ | 4.5 V to 9.5 V operation |
| L3 | Option $12=2$ | High current LED direct segment drive on L3 |
| L2 | Option $13=2$ | High current LED direct segment drive on L2 |
| L1 | Option $14=2$ | High current LED direct segment drive on L1 |
| LO | Option 15 = 2 | High current LED direct segment drive on LO |
| SI | Option $16=0$ | Load device to $\mathrm{V}_{\mathrm{CC}}$ on SI |
| SO | Option $17=2$ | Push-pull output on SO |
| SK | Option $18=2$ | Push-pull output on SK |
| INO | Option $19=0$ | Load device to $\mathrm{V}_{C C}$ on INO |
| IN3 | Option $20=0$ | Load device to $\mathrm{V}_{\mathrm{CC}}$ on IN3 |
| G0 | Option $21=0$ | Very high current standard output on GO |
| G1 | Option $22=2$ | High current standard output on G1 |
| G2 | Option $23=4$ | Standard LSTTL output on G2 |
| G3 | Option $24=4$ | Standard LSTTL output on G3 |
| D3 | Option $25=0$ | Very high current standard output on D3 |

D2 Option $26=0$
D1 Option $27=0$
DO
Option $28=0$
Option $29=0 \quad$ Standard TTL input levels on L
Option $30=0 \quad$ Standard TTL input levels on IN
Option $31=0 \quad$ Standard TTL input levels on $\mathbf{G}$ Option $32=0 \quad$ Standard TTL input levels on SI Option $33=1 \quad$ Schmitt trigger inputs on RESET Option $34=0 \quad$ CKO input levels, not used here Option $35=0 \quad$ COP444L Option $36=0 \quad$ Normal RESET operation

### 4.0 CONCLUSION

The 444L-EVAL demonstrates much of the capability of the COP444L. It does not indicate the limits of the device by any means. The I/O features were included to demonstrate that capability. The fact that they are slow is due strictly to the program. If such I/O capability were a necessary part of an application it could be accomplished much much faster than was done here. The counter modes are quite versatile and are generally self explanatory. It was fairly easy to provide a counter with the versatility of that included here. The music synthesis mode demonstrates clearly the program efficiency of the device.
The 444L-EVAL is intended for demonstration. There is no question that aspects of its operation could be improved and tailored to a specific application. It is unlikely that this particular combination of features would be found in any one application. It is also interesting to note that the program memory in the device is not full. There is still a significant amount of room left in the ROM. This should serve to make it clear that the capabilities of the device have not been stretched at all in order to include these demonstration functions.

## Oscillator Characteristics of COPS ${ }^{\text {TM }}$ Microcontrollers

## National Semiconductor Corp.

 COP Note 5
## Table of Contents

### 1.0 INTRODUCTION

### 2.0 RC OSCILLATOR OPTION

### 3.0 CRYSTAL OR INVERTER OPTION

3.1 COP420/COP402
3.1.1 L, LC, and RLC Networks
3.2 COP420L
3.3 COP410L
3.4 General Notes

### 4.0 CONCLUSION

### 1.0 INTRODUCTION

COPS microcontrollers will operate with a wide variety of oscillator circuits. This paper focuses on two of the oscillator options available on COPS microcontrollers: the internal RC oscillator, and the crystal or inverter oscillator. The typical behavior of the RC oscillator with temperature and voltage (and typical values of $R$ and $C$ ) is documented. For the crystal or inverter option, circuit configurations (RC, RL, RLC, R, LC, L) are presented which will allow the microcontroller to operate properly without the use of ceramic resonator or crystal.
The passive components used were inexpensive, uncompensated devices: standard carbon resistors, ceramic or foil capacitors, and air core or iron core inductors. To provide reasonably clear data on the characteristics of the microcontroller itself, no attempt at compensation for the external components was made.

### 2.0 RC OSCILLATOR OPTION

With the RC oscillator option selected, the graphs in Figures 1 through 6 indicate the variation of the instruction cycle time of the microcontroller with temperature and voltage. Typical $R$ and $C$ values, as recommended in the respective device data sheets, were used. The graphs are composite graphs reflecting the worst case variations of the devices tested. Therefore, the graphs show a percentage change of the instruction cycle time from a base or reference value. Where the results are plotted against voltage the reference is the value at $V_{C C}=5 \mathrm{~V}$. Where the results are plotted against temperature, the reference is the value at $T=20^{\circ} \mathrm{C}$. A positive percent variation indicates a longer instruction cycle time and therefore a slower oscillator frequency. Similarly, a negative percent variation indicates a shorter instruction cycle time and therefore a faster oscillator frequency.

The measurements were taken by holding the RESET pin of the device low and measuring the period of the waveform at pin SK. In this mode the SK period is the instruction cycle time. For divide by 4 the oscillator frequency is given by the following:

$$
\text { frequency }=\frac{4}{\text { SK period }}
$$

Measurements were taken at temperatures between $-40^{\circ} \mathrm{C}$ and $+85^{\circ} \mathrm{C}$ and at $\mathrm{V}_{\mathrm{CC}}$ values between 4.5 V and 9.5 V . However, the reader must remember that the COP400 series is specified only between $0^{\circ} \mathrm{C}$ and $+70^{\circ} \mathrm{C}$. The reader must also remember that the COP420 is specified at $V_{C C}$ levels between 4.5 V and 6.3 V only. The data here is usable temperature range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$. However, the reader must keep in mind the generally more restricted $V_{C C}$ range for some of the various COP300 series microcontrollers.
The graphs in Figures 1 through 6 reflect the variation of the microcontroller only. The resistor and capacitor were not in the temperature chamber with the COPS device. Obviously, the results will be affected by the variation of the $R$ and $C$ with temperature. However, this can vary dramatically with the type of components used. The user will have to combine the data here with the characteristics of the external components used to determine what type of variation may be expected in his system.

### 3.0 CRYSTAL OR INVERTER OPTION

With the crystal or inverter option selected on the COPS microcontroller there is, effectively, an inverter between the CKI and CKO pins. CKI is the input to the inverter and CKO is the output. Various passive circuits were connected between CKI and CKO and the results documented. Of the operational circuits, a subset was tested over temperature with the microcontroller only in the temperature chamber. A smaller subset was tested over temperature with both the microcontroller and the oscillator network in the temperature chamber.
The data with the oscillator network in the temperature chamber is obviously highly dependent on the particular components used. This data was taken with standard, inexpensive, uncompensated components. Neither high precision nor high stability components were used. This data is included only to provide the user with some very general indication of how the oscillator frequency may vary with temperature in a real system.

### 3.1 COP420/COP402

Except for the ROM, the COP420 and COP402 are equivalent devices. The internal circuitry of each device is identical. Therefore, data taken for one of the devices is equally
applicable to the other. The following discussion will refer to the COP420 but all such references apply equally well to the COP402. Similarly, the graphs for the COP420 apply to the COP402 and vice versa.

With the crystal option selected, the COP420 oscillator circuitry will readily oscillate with almost any circuit configuration between CKI and CKO. What difficulty there is lies in finding the network of the device. With the appropriate divide option selected, oscillator frequencies between 800 kHz and 4 MHz are valid for the COP420. No data was taken for any network that produced an oscillation frequency outside the valid range.

### 3.1.1 L, LC, and RLC Networks

Various L, LC, and RLC networks were connected with varying results. Certain networks produced results much more stable than the RC networks; others were no better than the RC networks. With a single inductor connected between CKI and CKO, frequencies between 1 MHz and 4 MHz were easily obtained. However, the input gate capacitance at CKI (typically 5 pF to 10 pF ) and the series resistance of the inductance become factors that impact the oscillation frequency and its stability over temperature.
The addition of a capacitor between CKI and ground tends to reduce the effects of the internal gate capacitance. For the single L , single C network of this type, the capacitor value should be greater than about 50 pF to begin to effectively swamp out the effects of the input gate capacitance. As might be expected, LC combinations which had their resonant frequencies within the valid COP420 frequency range produced the best results.
The addition of another capacitor(s) to the basic two-component LC network, as shown in Figure III.1, produced very good results. Varying the capacitor values in these networks - especially those capacitors between CKI and ground and CKO and ground - provided a great deal of control over the oscillation frequency. In Figure III.1, varying C1 from 25 pF to $0.01 \mu \mathrm{~F}$ produced oscillation frequencies between about 3 MHz and $1.6 \mathrm{MHz}(\mathrm{C} 2=25 \mathrm{pF}, \mathrm{L}=56 \mu \mathrm{H})$. In Figure III.2, with $\mathrm{C} 1=330 \mathrm{pF}, \mathrm{L}=56 \mu \mathrm{H}$, and $\mathrm{C} 2=27 \mathrm{pF}$, varying C 3 between 10 pF and $0.003 \mu \mathrm{~F}$ produced oscillation frequencies between about 2 MHz and 1.1 MHz . Varying C 2 in Figure 111.3 produced a similar kind of control.
As the graphs indicate, various types of RLC networks were also tried. The range of possible usable circuits here is limited only by the user's imagination and his favorite type of RLC oscillator circuit. When their resonant frequency is
within the valid frequency range of the COP420, LC and RLC networks can be a very effective substitute for a crystal. The only potential problem is that a good RLC, or even LC, oscillator circuit may not be a cost-effective substitute for a crystal in a COP420 system. The user will have to make that determination.

### 3.2 COP420L

The valid input frequency range for the COP420L, with the appropriate divide option selected, is between 200 kHz and 2.097 MHz . With the crystal option selected the COP420L oscillated much less readily than the COP420.
The LC networks gave outstanding results with the COP420L. With the simple two-component LC network shown in the graphs, holding C at 50 pF and varying L from $200 \mu \mathrm{H}$ to $700 \mu \mathrm{H}$ gave oscillation frequencies from about 2 MHz to 1 MHz . Holding L at $390 \mu \mathrm{H}$ and varying C from 10 pF to 700 pF gave oscillation frequencies of about 2 MHz to 1.6 MHz . Similar results were obtained when a capacitor was placed in parallel with the inductance.

### 3.3 COP410L

The COP410L has a valid input frequency range of 200 kHz to 530 kHz .
The LC networks also gave very good results. With the simple LC network shown in the graphs, holding L at $4700 \mu \mathrm{H}$ and varying C from 25 pF to $0.003 \mu \mathrm{~F}$ gave oscillation frequencies of about 460 kHz to 225 kHz .

### 3.4 GENERAL NOTES

With the crystal or inverter option selected on COPS microcontrollers, a wide variety of networks may be used in place of the ceramic resonator or crystal.
LC and RLC networks can be used in any of the devices. Appropriately designed, these networks will provide a stable oscillation frequency for the microcontroller. The user will have to allow for the variation of the external components with temperature when using these networks. The problems with networks such as these is that they may not be cost-effective alternatives to the crystal or resonator, especially if high stability, temperature compensated components are used. The user will have to make the determination of costeffectiveness.

A final note is that all of these networks place a load on the CKO output. If the signal from CKO is needed elsewhere in the system and a circuit similar to one of those discussed in this document is used, it will probably be necessary to buffer the CKO output.

### 4.0 Conclusion

The networks described are generally simple and inexpensive and have all been observed to be functional.
The results obtained provide greater flexibility in the oscillator selection in a COPs system and gives the user some general indication as to what may be expected with the various circuits described.

## COP Microcontroller Pinouts




Note 1: Base period at $V_{C C}=5.0 \mathrm{~V}$.
Note 2: Device variation only. Graph does not include RC variation with temperature.
Note 3: SK period = instruction cycle time.
FIGURE 1. COP310L/COP410L RC Oscillator Variation with VCC

Note 1: $20^{\circ} \mathrm{C}=$ base poriod.


Note 2: Device variation only. Graph does not include RC variation with temperature.
Note 3: SK period = instruction cycle time.
FIGURE 2. COP310L/COP410L RC Oscillator Variation with Temperature


Note 2: Device variation only. Graph does not include RC variation with temperature.
Note 3: SK period $=$ instruction cycle time.
FIGURE 3. COP320/COP420 RC Oscillator Variation with VCC


TL/DD/6938-5
Note 1: $20^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include RC variation with temperature.
Note 3: SK period = instruction cycle time.
FIGURE 4. COP320/COP420 RC Oscillator Variation with Temperature


Note 1: Base period at $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
Note 2: Device variation only. Graph does not include RC variation with temperature.
Note 3: SK period = instruction cycle time.
FIGURE 5. COP320L/COP420L RC Oscillator Varlation with $V_{\text {CC }}$


TL/DD/6938-7
Note 1: $20^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include RC variation with temperature.
Note 3: SK period = instruction cycle time.
FIGURE 6. COP320L/COP420L RC Oscillator Variation with Temperature


FIGURE III. 1


FIGURE III. 2


TL/DD/6938-8
FIGURE III. 3



Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include LC variation with temperature.
No measurable variation over temperature.
FIGURE 9
COP420


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include LC variation with temperature.


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include LC variation with temperature.
FIGURE 11


Note 1: $\mathbf{2 5 ^ { \circ }}{ }^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include LC variation with temperature.


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include LC variation with temperature.
FIGURE 13
COP402


TL/DD/6938-16
Note 1: $25^{\circ} \mathrm{C}=$ base period
Note 2: Device variation only. Graph does not include LC variation with temperature.


TL/DD/6938-17
Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include LC variation with temperature.
*No variation at 6 V .
FIGURE 15


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include RL variation with temperature.


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include RLC variation with temperature.
FIGURE 17
COP402


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include RLC variation with temperature.

COP402


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include RLC variation with temperature.
FIGURE 19
COP402


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: RL in oven with COP402.


Note 1: $25^{\circ} \mathrm{C}=$ base period. Note 2: LC in oven with COP402.

FIGURE 21
COP420L


TL/DD/6938-26
Note 1: No measurable variation for all three circuits above.
Note 2: $25^{\circ} \mathrm{C}=$ base period.
Note 3: Device variation only. Graph does not include LC variation with temperature.


TL/DD/6938-28
Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: LC in oven with COP420L.
FIGURE 23
COP410L


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include LC variation with temperature.


Note 1: $25^{\circ} \mathrm{C}=$ base period.
Note 2: Device variation only. Graph does not include LC variation with temperature.
FIGURE 25
COP410L


## Triac Control Using the COP400 Microcontroller Family

## Table of Contents

### 1.0 TRIAC CONTROL

1.1 Basic Triac Operation
1.2 Triggering
1.3 Zero Voltage Detection
1.4 Direct Couple
1.5 Pulse Transformer Interface
1.6 False Turn-on

### 2.0 SOFTWARE TECHNIQUES

### 2.1 Zero Voltage Detection

2.2 Processing Time Allocations

Half Cycle Approach
Full Cycle Approach
2.3 Steady State Triggering
3.0 TRIAC LIGHT INTENSITY CONTROL CODE
3.1 Triac Light Intensify Routine

National Semiconductor Corp. COP Note 6


### 1.0 Triac Control

The COP400 single-chip controller family members provide computational ability and speed which is more than adequate to intelligently manage power control. These controllers provide digital control while low cost and short turnaround enhance COPSTM desirability. The COPS controllers are capable of $4 \mu \mathrm{~s}$ cycle times which can provide more than adequate computational ability when controlling 60 Hz line voltage. Input and output options available on the COPS devices can contour the device to apply in many electrical situations. A more detailed description of COPS qualifications is available in the COP400 data sheets.

The COPS controller family may be utilized to manage power in many ways. This paper is devoted to the investigation of low cost triac interfaces with the COP400 family microcontroller and software techniques for power control applications.

### 1.1 BASIC TRIAC OPERATION

A triac is basically a bidirectional switch which can be used to control AC power. In the high-impedance state, the triac blocks the principal voltage across the main terminals. By pulsing the gate or applying a steady state gate signal, the triac may be triggered into a low impedance state where conduction across the main terminals will occur. The gate signal polarity need not follow the main terminal polarity; however, this does affect the gate current requirements. Gate current requirements vary depending on the direction of the main terminal current and the gate current. The four trigger modes are illustrated in Figure 1.



TL/DD/6939-1

FIGURE 1. Gate Trigger Modes. Polarities Referenced to Main Terminal 1.

The breakover voltage $\left(V_{B O}\right)$ is specified with the gate current ( $\mathrm{I}_{\mathrm{GT}}$ ) equal to zero. By increasing the gate current supplied to the triac, $V_{B O}$ can be reduced to cause the triac to go into the conduction or on state. Once the triac has entered the on state the gate signal need not be present to sustain conduction. The triac will turn itself off when the main terminal current falls below the minimum holding current required to sustain conduction ( 1 H ).
A typical current and voltage characteristic curve is given in Figure 2. As can be seen, when the gate voltage and the main terminal 2 (MT2) voltages are positive with respect to MT1 the triac will operate in quandrant 1. In this case the trigger circuit sources current to the triac ( $1+\mathrm{MODE}$ ).


TL/DD/6939-2
FIGURE 2. Voltage-Current Characteristics
After conduction occurs the main terminal current is independent of the gate current; however, due to the structure of the triac the gate trigger current is dependent on the direction of the main terminal current. The gate current requirements vary from mode to mode. In general, a triac is more easily triggered when the gate current is in the same direction as the main terminal current. This can be illustrated in the situation where there is not sufficient gate drive to cause conduction when MT2 is both positive and negative. In this case the triac may act as a single direction SCR and conduction occurs in only one direction. The trigger circuit must be designed to provide trigger currents for the worst case trigger situation. Another reason ample trigger current must be supplied is to prevent localized heating within the pellet and speed up turn-on time. If the triac is barely triggered only a small portion of the junction will begin to conduct, thus causing localized heating and slower turn-on. If an insufficient gate pulse is applied damage to the triac may result.

### 1.2 TRIGGERING

Gate triggering signals should exceed the minimum rated trigger requirements as specified by the manufacturer. This is essential to guarantee rapid turn-on time and consistent operation from device to device.

Triac turn-on time is primarily dependent on the magnitude of the applied gate signal. To obtain decreased turn-on times a sufficiently large gate signal should be applied. Faster turn-on time eliminates localized heat spots within the pellet structure and increases triac dependability.
Digital logic circuits, without large buffers, may not have the drive capabilities to efficiently turn on a triac. To insure proper operation in all firing situations, external trigger circuitry might become necessary. Also, to prevent noise from disturbing the logic levels, AC/DC isolation or coupling techniques must be utilized. Sensitive gate triacs which require minimal gate input signal and provide a limited amount of main terminal current may be driven directly. This paper will focus on $120 V_{\text {AC }}$ applications of power control.

### 1.3 ZERO VOLTAGE DETECTION

In many applications it is advantageous to switch power at the AC line zero voltage crossing. In doing this, the device being controlled is not subjected to inherent AC transients. By utilizing this technique, greater dependability can be obtained from the switching device and the device being switched. It is also sometimes desirable to reference an event on a cyclic basis corresponding to the AC line frequency. Depending on the load characteristics, switching times need to be chosen carefully to insure optimal performance. Triac controlled AC switching referenced to the AC 60 Hz line frequency enables precise control over the conduction angle at which the triac is fired. This enables the COPS device to control the power output by increasing or decreasing the conduction angle in each half cycle.
A wide variety of zero voltage detection circuits are available in various levels of sophistication. COPS devices, in most cases, can compensate for noisy or semi-accurate ZVD circuits. This compensation is utilized in the form of debounce and delay routines. If a noisy transition occurs near zero volts the COPS device can wait for a valid transition period specified by the maximum amount of noise present. Some software considerations are presented in the software section and are commented upon. The minimal detection circuit is shown in Figure 9.

### 1.4 DIRECT COUPLE

Isolation associated problems can be overcome by means of direct AC coupling. One such method is illustrated in Figure 3. This circuit incorporates a half-wave rectifier in conjunction with a filter capacitor to provide the logic power supply. The positive half-cycle is allowed to drop across the zener diode and be filtered by the capacitor. This creates a low cost line interface; however, only a limited supply current is available. In order to control the current capabilities of this circuit the series resistor must be modified. However, as more current is required, the power that must be dissipated in the series resistor increases. This increases the power dissipation requirements of the series resistor and the system cost. For applications which require large current sources an alternative method is advisable. In order to assure consistent operation, power supply ripple must be mini-
mized. COPS devices can be operated over a relatively wide power supply range. However, excessive ripple may cause an inadvertent reset operation of the device.


TL/DD/6939-3
FIGURE 3. AC Direct Couple

### 1.5 PULSE TRANSFORMER INTERFACE

Digital logic control of triacs is easily accomplished by triggering through pulse transformers or optical coupling. The energy step-up gained by using a pulse transformer should provide a more than adequate gate trigger signal. This complies with manufacturers' suggested gate signal requirements. Pulse transformers also provide AC/DC isolation necessary in control logic interfaces. Minimal circuit interface to the pulse transformer is required as shown in Figure 4. Optical coupling circuits provide isolation, and in some cases adequate gate drive capabilities.


TL/DD/6939-4
FIGURE 4. Pulse Transformer Interface
A logic controlled pulse is applied to the base of the transistor to switch current through the primary of the pulse transformer. The transformer then transfers the signal to the secondary and causes the triac to fire. The energy transfer that is now available on the secondary is more than adequate to turn on the triac in any of its operating modes. When the pulse transformer is switched off a reverse EMF is generated in the primary coil which may cause damage to the transistor. The diode across the primary serves to protect the collector junction of the switching transistor. Another major advantage is AC isolation; the gate of the triac is now completely isolated from the logic portion of the circuit.

### 1.6 FALSE TURN-ON

When switching an inductive load, voltage spikes may be generated across the main terminals of the triac which have
the potential of a non-gated turn-on of the triac. This creates the undesirable situation of limited control of the system. In a system with an inductive load the voltage leads the current by a phase shift corresponding to the amount of inductance in the motor. As the current passes near zero, the voltage is at a non-zero value, offset due to the phase shift. When the principal current through the triac pellet decreases to a value not capable of sustaining conduction the triac will turn off. At this point in time the voltage across the terminals will instantaneously attain a value corresponding to the phase shift caused by the inductive load. The rapid decay of current in the inductor causes an $\mathrm{L} \mathrm{dI} / \mathrm{dT}$ voltage applied across the terminals of the triac. Should this voltage exceed the blocking voltage specified for the triac, a false turn-on will occur.
In order to avoid false turn-on, a snubber network must be added across the terminals to absorb the excess energy generated by this situation. A common form of this network is a simple RC in series across the terminals. In order to select the values of the network it is necessary to determine the peak voltage allowable in the system and the maximum $\mathrm{dV} / \mathrm{dT}$ stress the triac can withstand. One approach to obtaining the optimal values for $R_{S}$ and $C_{S}$ is to model the effective circuit and solve for the triac voltage. The snubber in conjunction with the load can now be modeled as an RLC network. Due to the two storage elements ( L motor, C snubber) a second order differential equation is generated. Rather than approach this problem from a computer standpoint it becomes much easier to obtain design curves generated for rapid solution of this problem. These design curves are available in many triac publications. (For instance, see RCA application note AN 4745.)

### 2.0 Software Techniques

### 2.1 ZERO VOLTAGE DETECTION

In order to intelligently control triacs on a cyclic basis, an accurate time base must be defined. This may be in the form of an $A C, 60 \mathrm{~Hz}$ sync pulse generated by a zero voltage detection circuit or a simple real time clock. The COP400 series microcontrollers are suited to accommodate either of these time base schemes while accomplishing auxiliary tasks.
Zero voltage detection is the most useful scheme in AC power control because it affords a real time clock base as well as a reference point in the $A C$ waveform. With this information it is possible to minimize RFI by initiating poweron operations near the AC line voltage zero crossing. It is also possible to fire the triac for only a portion of the cycle, thus utilizing conduction angle manipulation. This is useful in both motor control and light intensity control.
Sophisticated zero voltage detection circuits which are capable of discriminating against noise and switch precisely at zero crossing are not necessary when used in conjunction with a COPS device. COPS software is capable of compensating for noisy or semi-accurate zero voltage detection circuits. This can be accomplished by introducing delays and debounce techniques in the software routines. With a given reference point in the AC waveform it now becomes easy
to divide the waveform to efficiently allocate processing time. These techniques are illustrated in the code listing at the end of this paper.


TL/DD/6939-5
FIGURE 5. Current Lag Caused by Inductive Load, Snubber Circuit

### 2.2 PROCESSING TIME ALLOCATIONS

## Half Cycle Approach

In order to accomplish more than triac timing, dead delay time must be turned into computation time. It appears that the controller is occupied totally by time delays, which leaves a very limited amount of additional control capability. There are, however, many ways to accomplish auxiliary tasks simultaneously.
On each half cycle an initial delay is incorporated to space into the cycle. This dead time may be put to use and very little voltage to the load is sacrificed. For example, if the load is switched on at $\pi / 4$ RAD, the maximum applied RMS voltage to the load is $114 \mathrm{~V}_{\text {RMS }}$ (assuming $\mathrm{V}_{\text {SUPPLY }}=$ $120 V_{\text {RMS }}$ ). This is illustrated in the figure below.


TL/DD/6939-6
FIGURE 6. Full Cycle Approach

If a delay of $\pi / 4$ RAD ( 45 degrees) is inserted after each zero crossing detection the RMS voltage to the load can be determined in the following manner:

$$
\begin{aligned}
& V_{\text {LOAD }}=\sqrt{\frac{(120 \sqrt{2})^{2}}{(2) \pi}}(2) \int_{\pi / 4}^{\pi} \sin ^{2}(\mathrm{a}) \mathrm{da} \\
& V_{\text {LOAD }}=\sqrt{\frac{(120 \sqrt{2})^{2}}{(2) \pi}}(2)(1.428) \\
& V_{\text {LOAD }}=114.4 V_{\text {RMS }} \\
& \pi / 4 \text { RAD }=45 \text { degrees } @ 60 \mathrm{~Hz} \quad \mathrm{t}=2.08 \mathrm{~ms}
\end{aligned}
$$

As can be seen the dead time on each half cycle can be 2.08 ms and the load will still see $114.4 \mathrm{~V}_{\text {RMS }}$ of a $V_{\text {SUPPLY }}$ of $120 \mathrm{~V}_{\text {RMS }}$. If this approach is implemented the initial delay of 2.08 ms can be used as computation time. The number of instructions which can be executed when operating at $4 \mu \mathrm{~s}$ instruction cycle time is:

$$
2.08 \mathrm{~ms} / 4 \mu \mathrm{~s}=520 \text { instructions }
$$

(130 instructions at $16 \mu \mathrm{~s}$ cycle time)

## Full Cycle Approach

The methods of half cycle and full cycle triggering are very similar in procedure. The main difference is that all timing is referenced from only one (of the two) zero voltage detection transition in each full AC cycle. For most all applications, when varying the conduction angle it is desirable to fire at the same conduction angle each half cycle to maintain a symmetric applied voltage. In order to accomplish this the triac may be fired twice from one reference point. When applying this technique an 8.33 ms delay must be executed to maintain the symmetric applied voltage. This approach provides the most auxiliary computation time in that the 8.33 ms delay may be turned into computational time. The basic flow for this technique is illustrated below.


FIGURE 7. Full Cycle Approach
In the above example the zero crossing pulse is debounced on the one-to-zero transition, thus marking the beginning of a full cycle. Once this transition has been detected, an ini-

tial delay of $\pi / 4$ RAD is incorporated and the triac is fired. At this time exactly 8.33 ms is available until the triac need be triggered again. This will provide a symmetric voltage to the load only if the delay is 8.33 ms . During this period the number of instructions which can be executed when operating at $4 \mu \mathrm{~s}$ is:

$$
8.33 \mathrm{~ms} / 4 \mu \mathrm{~s}=2082
$$

( 520 instructions at $16 \mu \mathrm{~s}$ )
An alternative approach may be to take the burden from the COPS device by using peripheral devices such as static display controllers, external latches, etc.

### 2.3 STEADY STATE TRIGGERING

It is possible to trigger a triac with a steady state logic level. This is accomplished by allowing the triac gate to sink or source current during the desired on-time. When utilizing this method it becomes easier to trigger the triac and leave it on for many cycles without having to execute code to retrigger. This approach is advantageous when the triac must be fired is for relatively long periods and conduction angle firing is not desired, thus more time is available to accomplish auxiliary tasks. A steady state on or off signal and external circuitry can accomplish triac firing and free the processor for other tasks. If it is desired to use a pulse
transformer, an external oscillator must be gated to the triac to provide the trigger signal. A pulse train of 10 to 15 kHz is adequate to fire the triac each half cycle. This calls for external components and is relatively costly. If isolation associated problems can be tolerated or overcome (dual power supply transformers, direct AC coupling, etc.), a simple buffer may be utilized in triggering the triac. This method is illustrated in Figure 8. The National Semiconductor DS8863 display driver is capable of steady state firing of the triac. National offers many buffers capable of driving several hundred milliamps, which are suitable for driving triacs. On the market today there are many suppliers of sensitive gate triacs which may be triggered directly from a COPS device or in conjunction with a smaller external buffer.
The DS8863 display driver is capable of sinking up to 500 mA , which is adequate to drive a standard triac. In the off state the driver will not sink current. When a logic "1" is applied to the input the device will turn on. Keeping the device off (output " 1 ") will prevent the triac from turning on because the buffer does not have the capability of sourcing current. A series resistor limits the current from the triac gate and the diode isolates the negative spikes from the gate. Since the drive circuit will only sink current in this configuration, the triac will be operating in the I- and III- modes.

### 3.0 Triac Light Intensity Control Code

The following code is not intended to be a final functional program. In order to utilize this program, modifications must be made to specialize the routines. This is intended to illustrate the method and is void of control code to command a response such as intensify or deintensify. The control is up to the user and full understanding of the program must be attained before modifications can be implemented.
This program is a general purpose light intensifying routine which may be modified to suit light dimmer applications. The delay routines require a $4.469 \mu \mathrm{~s}$ cycle time which can be attained with a 3.578 MHz crystal (CKI/16 option). This program divides the half cycle of a 60 Hz power line into 16 levels. Intensity is varied by increasing or decreasing the conduction angle by firing the triac at various levels. The program will increase the conduction angle to a maximum specified intensity in a fixed amount of time. The time required to intensify to the maximum level is dependent on the number of fire-times per level that is specified (FINO). This code illustrates a half cycle approach arid relies on the parameters specified by the programmer in the control selection.
Zero crossings of the 60 Hz line are detected and software debounced to initiate each half cycle; thus the triac is serviced on every half cycle of the power line. A level/sublevel approach is utilized to vary the conduction angle and provide a prolonged intensifying period. The maximum intensity is specified by the "LEVEL" RAM location and time required to get to that level is specified by the "FINO" RAM location.

Once a level has been specified, the remaining time in the half cycle is then divided into sublevels. The sublevels are increased in steps to the maximum level. The "FINO" RAM location contains the number of times that the triac will be fired per sublevel, thus creating the intensity time base. There are 15 valid sublevels and up to 15 fire-times per sublevel. Both these parameters may be increased to provide better resolution and longer intensify periods. To make the triac de-intensity (dim) the sublevels need only to be decremented rather than incremented. If this is done, the conduction angle will start out at the maximum level and dim by means of stepping down the sublevels. When modifying this routine to incorporate more resolution or increased versatility, care must be taken to account for transfer of control instructions to and from the delay routines.
The following is a schematic diagram of the COPS interface to $120 V_{\text {AC }}$ lamps. The program will intensify or de-intensify the lamps under program control.

### 3.1 TRIAC LIGHT INTENSIFY ROUTINE

This program intensifies a light source by varying the conduction angle applied to the load. The maximum level of intensity is stored in "LEVEL," and the time to get to that level is specified by "FIND." Both these parameters may be altered to suit specific applications. To cause the program to de-intensify the light source, the sublevels must be decremented rather than incremented.


TL/DD/6939-9
FIGURE 9. Triac Interface for COPS Program

| ; TRIAC LIGHT INTENSIFY ROUTINE |  |  |  |  | JP | LO | ; FALSE ALARM, TRY AGAIN | Q |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ; |  |  |  | DELL: | CLRA |  | ; DO A DELAY TOCOMPENSATE | E |
| ; |  |  |  | DEL: | NOP |  |  | 2 |
| ; THIS PROGRAM INTENSIFIES A LIGHT SOURCE BY VARYING THE |  |  |  |  | NOP |  | ; FOR NON SYMMETRIC ZC | - |
| ; CONDUCTION ANGLE APPLIED TO THE LOAD. THE MAX LEVEL |  |  |  |  | NOP |  |  | $\Pi$ |
| ; OF INTENSITY IS STORED IN 'LEVEL' AND THE TIME TO GET TO |  |  |  |  | AISC |  |  | O |
| : THAT LEVEL IS SPECIFIED BY 'FIND'. BOTH THESE PARAMETERS |  |  |  |  | JP | DEL | ; KEEP DELAY GOING |  |
| ; MAY BE ALTERED TO SUIT SPECIFIC APPLICATIONS. TO CAUSE |  |  |  |  | JP | DOIT | ; GO TO MAIN ROUTINE |  |
| ; THE PROGRAM TO DE-INTENSIFY THE LIGHT SOURCE, THE |  |  |  |  |  |  |  |  |
| ; SUBLEVELS MUST BE DECREMENTED RATHER THAN |  |  |  |  | .FORM |  |  |  |
| ; INCREMENTED. |  |  |  |  | .PAGE | 1 |  |  |
| ; |  |  |  | ; |  |  |  |  |
| ; |  |  |  | ; |  |  |  |  |
|  | TEMP1 | $=1,0$ | ; TEMPORARY DELAY COUNTER | ; THIS IS THE MAIN ROUTINE FOR THE INTENS:FY/DE-INTENSIFY |  |  |  |  |
|  | FIND | $=0,9$ | ; NUMBER OF FIRE TIMES | ; OPERATIONS. TRANSFER OF CONTROL TO THIS SECTION |  |  |  |  |
|  | LEVEL | $=0,0$ | ; MAX LEVEL | ; OCCURS AFTER ZERO VOLTAGE CROSSING EACH HALF CYCLE. |  |  |  |  |
|  | SUBLEV | $=1,10$ | ;SUBLEVEL COUNT | ; THIS MAKE USE OF TEMP REGISTERS THUS PARAMETERS |  |  |  |  |
|  | TEMP | $=1,11$ | ; TEMPORARY DELAY COUNTER | ; NEED NOT BE REDEFINED FOR EACH OPERATION. |  |  |  |  |
| ; |  |  |  | ; |  |  |  |  |
| : HERE THE OPERATING PARAMETERS ARE DEFINED AND LEVEL |  |  |  | ; |  |  |  |  |
| ; INITIATION IS SPECIFIED |  |  |  | INT: | CLRA |  |  |  |
| ; |  |  |  |  | ADT |  | ; DELAY INTO WAVEFORM |  |
|  | .FORM |  |  |  | LBI | TEMP | ; USE TEMP REG |  |
|  | .PAGE | 0 |  |  | X |  |  |  |
|  | CLRA |  | ; REQUIRED |  | JSRP | PORT | ; DODELAY |  |
| CLRAM: | LBI | 3,15 | ; ROUTINE TO CLEAR ALL RAM | POINT: | LDD | LEVEL | ; POINT TO LEVEL TO INITIATE |  |
| CLR; | CLRA |  |  |  |  |  | ; DELAY |  |
|  | XDS |  |  |  |  |  | ; DELAY TO MAX LEVEL |  |
|  | JP | CLR |  |  | XAD | TEMP | ; USE TEMP DIGIT TO DELAY |  |
|  | XABR |  |  | TAMP: | LBI | TEMP |  |  |
|  | AISC | 15 |  |  | LD |  |  |  |
|  | JP | BEGG |  |  | AISC | 15 | ; ARE WE AT THE LEVEL? |  |
|  | XABR |  |  |  | JP | ATLEV | : MADE IT TO THE LEVEL |  |
|  | JP | CLR |  |  | X |  | ; NO |  |
| ; THIS SECTION INITIATES CONTROL ON POWER UP OR RESET |  |  |  |  | JSRP | DE5 | ; DO SERIES OF .5MS TO GET |  |
|  |  |  |  |  |  |  | ; THERE |  |
| ; AND SYNCHRONIZES THE COPS DEVICE TO THE 60 HZ AC LINE |  |  |  |  | JP | TAMP | : KEEP DOING IT |  |
| ; |  |  |  | ATLEV: | LDD | SUBLEV | ; AT MAX FIRE LEVEL |  |
| BEGG: | OGI | 15 | ; OUTPUT 15 TO G PORTS TO PULL |  | XAD | TEMP | ; INIT FOR SUBLEVEL DELAY |  |
|  |  |  | ; UP ZERO CROSSER INPUT | JK: | LBI | TEMP |  |  |
|  | LB1 | LEVEL | ; SPECIFY MAX LEVEL |  | LD ${ }^{\text {- }}$ |  |  |  |
|  | STII | 7 |  |  | AISC | 1 | ; AT SUB LEVEL? |  |
|  | JSR | OUT | ; COPY TO TEMP1 |  | JP | TRE | ; NODO DELAY |  |
| BEG: | SKGBZ | 0 | ; SYNCUP TO 60 HZ |  | JP | SBLEV | ;YES |  |
|  | JP | H | ; READY NOW | TRE: | X |  |  |  |
|  | JP | BEG | ; WAIT TILL G IS 1 |  | JSRP | SPDL | ; VARIABLE delay |  |
| ; |  |  |  |  | JP | JK |  |  |
| ; THIS SECTION PROVIDES THE DEBOUNCE FOR THE ZERO |  |  |  | SBLEV: | LBI | FIND |  |  |
| ; VOLTAGE DETECTION INPUT AND COMPENSATES FOR THE |  |  |  |  | JSRP | DEC | ; DEC FIRE NUMBER |  |
| ; OFFSET OF THE DETECTION CIRCUIT |  |  |  |  | AISC | 1 | ; TEST IF FIND AT 15 |  |
| ; |  |  |  | MAXLEV: | JMP | FIRE | ; NO KEEP FIRING AT THAT LEVEL |  |
|  | SKGBZ | 0 | ; TEST GO FOR ZERO CROSS |  | LBI | SUBLEV | ; YES INC SUBLEVEL |  |
|  | JP | HI | ; HIGH LEVEL |  | CLRA |  |  |  |
| ; GETS HERE ON FIRST TRANSITION |  |  |  |  | AISC | 14 | ; IS MAX SUBLEV REACHED |  |
|  | CLRA |  | ; START OF DEBOUNCE DELAY |  | SKE |  |  |  |
|  | AISC | 1 |  |  | JP | there | ; NO INC SUBLEV |  |
|  | JP | .-1 |  |  | JP | MAXLEV | ; YES FIREIT |  |
| ; DID A LITTLE DELAY, IS IT STILL 0 |  |  |  | THERE: | JSRP | INC | ; GOTO NEXT SUBLEVEL |  |
|  | SKGBZ | 0 | ; TEST FOR 0 |  | LBI | FIND |  |  |
|  | JP | Hi | ; FALSE ALARM |  | STII | 14 | ; SET FIRE TIME |  |
| ; MUST HAVE HAD SOME NOISE GO BACK AND WAIT FOR TRUE ZC |  |  |  |  | JP | maxlev | ; GOFIRE |  |
| DOIT: | JMP | INT | ; VALID TRANSITION, SERVICE |  |  |  |  |  |
|  |  |  | ; TRIAC |  | .FORM |  |  |  |
| LO: | SKGBZ | 0 | ; DEBOUNCE INO TO 1 |  | .PAGE | 2 |  |  |
|  | JP | DDD | ; MAY HAVE SOMETHING THERE |  |  |  |  |  |
|  | JP | LO | ; NO WAIT HERE FOR A BIT |  |  |  |  |  |
| DDD: | CLRA |  | ; GOING TO WAIT AND SEE |  |  |  |  |  |
|  | AISC | 1 |  |  |  |  |  |  |
|  | JP | .-1 |  |  |  |  |  |  |
|  | SKGBZ | 0 | ; WELL, DO WE HAVE A CLEAN <br> ; TRANSITION |  |  |  |  |  |
|  | JP | DELL | ; YES, GO TO MAIN ROUTINE |  |  |  |  |  |

## Testing of COPSTM Chips

## Table of Contents

### 1.0 INTRODUCTION

### 2.0 PHILOSOPHY

### 3.0 BUILT-IN TEST FEATURES

3.1 Sync between DUT and Tester
3.2 Internal Logic Test
3.3 RAM Test
3.4 ROM Dump

This note will provide some insight into the test mode, the mechanics of testing, and the philosophy of how to implement a test of the COP-400 microcontrollers. Other than the obvious, (verifying that the part meets the specifications), the reason for the test must be considered. Somewhat different criteria may hold, depending on the objective. The manufacturer wafer sort or final test can differ from an incoming inspection at the user's plant, or a field reject test. The first two tests have limited interest as this is not a justification of the testing done on the part during manufacture. Rather, this is a guide for those doing user functional testing.

### 1.0 INTRODUCTION

Since the introduction of the very first semiconductor devices, testing has been a major problem and expense in their production and use. As the complexity has risen, testing has become a more significant factor. With today's single chip microcontrollers like the COPS devices this is particularly true as one has a complete computer system in a chip. In order to reduce the testing burden, the facilities to ease the testing have been built into the COPS devices. With the test ability built into the device for production test, the user need only follow set procedures to verify the chip at incoming inspection or field test.

### 2.0 PHILOSOPHY

The basic test philosophy requires that four major areas be exercised. These areas are:

1) Synchronize the device and tester.
2) Test the internal logic and I/O.
3) Test the RAM.
4) Verify the ROM program.

If the devices perform all of these four properly, the device is good. This is a reasonable assumption with a standard device that has a debugged test routine and is ROM programmed. A custom circuit just going into production might not have the accumulated test background. By attacking the problem on a "sum of the parts" approach, one need not do any exhaustive functional test on routine production parts. This will be a major gain where lengthy time consuming or time dependent routines are involved. If one attempts to do a functional test of the chip, a sequence that is unique to the application is needed. Thus, a test program must be written and debugged for each ROM pattern. Further, a test box/board must be designed, built, debugged, documented, and maintained for each one. If testing has been considered from the beginning, the chip will have built-in capabilities to exercise the various parts of it. The different functional parts and instructions are tested to verify proper operation at the voltage and frequency limits.

### 3.0 BUILT-IN TEST FEATURES

The first step in testing the COP400 devices is to understand the built-in test control features. This will involve the SI/O and the L lines. The SO pin has been designed to be the control node for testing. The pin will normally be in an active low state and when forced high externally, places the chip in the test mode. It should be noted that this output can sink considerable current and one should not force the pin to the $\mathrm{V}_{\mathrm{CC}}$ rail. By limiting the voltage to the 2.0/3.0V range one can not damage the device where the application of a higher voltage could. When forced into the test mode the SI pin controls the sub mode of the chip. With SI high the data placed on the $L$ port is used as an instruction. When $S I$ is low (and the L output is enabled) the contents of the ROM will be dumped out through the L port. Certain other internal functions have been implemented to allow these modes but these are not part of the basic operation. Included in this category is the activation of the skip signal to prevent the program counter from jumping out of sequence by executing a program control instruction.

### 3.1 Sync Between Tester and DUT

In order to be able to test a COPS chip, the tester must be in sync with the device under test (DUT). By using an external oscillator the two may be run at the same frequency. This is true regardless of the option or type of oscillator chosen for the chip. Even the RC configuration may be overridden with an external signal that meets the level requirements. In addition to running at the same frequency, the chip and tester must be in sync on a bit basis. See Figure 1. The supportive features mentioned above include the condition of the SK signal being a bit (instruction) clock until stopped by software in the program. Hence, one can start the tests based on an edge change of SK. It is important that this be accurate because all data I/O changes will be relative to the SK timing (see the appropriate device data sheet).
It should also be noted that the oscillator frequency is programmed to a rate of 4-32 higher than SK. If one is building a test fixture for more than one device, some method must be available to enter this number. If one is testing a COP420 or COP421 near its upper limit it would be wise to do the SK sync operation at a lower rate and then increase the input frequency. This is desirable because the phase relationship is close to TTL propagation delays at the upper limit. Implementation of the area could be a preset counter that is gated on after a zero to one transition is seen on SK. Continual comparison could be made but once in sync, there should not be any need for the comparison as they should remain in sync.
The basic use of this "sync counter" is to derive the proper timing for loading data and instructions into the chip and verify the outputs. The COP402 data sheet should be used as a guide for these times, modified properly for the $L$ and $C$ parts. For those designing testers, it is suggested that one not attempt to test worse case timing changes as these could be very difficult to implement. Like other parametric tests these should in general be left to the professional test equipment.

### 3.2 Internal Logic Test

With the device and the tester in sync, actual testing may begin. See the sequence control circuit of Figure 2. To place the chip into the test mode the SO output is pulled to a one level (between 2.0 and 3.0 volts). It should be pulled with a circuit that will limit the upper voltage to 3 V as this output can have a significant current sink capability. On power up (or after reset) the SO line is set to a zero by the internal logic. An internal sense line will detect the forced condition and provide test control. A delay of 10 ms should be taken after power-up to allow the power on reset circuit to time out before instructions can be executed. If the reset pin is activated in mid-program for some reason, several instructions cycle times should be ignored to insure complete operation.
The tester should at this point force instructions into the L port. These instructions will be executed as if they were from the ROM. The sequence of the instructions is not particularly critical. Table I gives an example sequence. The main steps are to be able to detect an output change (OGI) early to verify connection/operation. It is much better to find a problem before going through the steps of loading RAM and then finding that the chip doesn't work. All instructions should be exercised although certain ones should be postponed. Enabling the $Q$ register to the $L$ port is an example. This would interfere with the insertion of instructions on the L port. Another problem is the SO test which could be set up with an XAS and then released from the test mode to check proper data output.
Certain commands will require more effort than others. To check the program counter during JMP's and sub-routine operation will require that known info at the new address be available. One should execute a JSRP at some known address and release the test mode to see that the operation in the subroutine (e.g., SC) is done and that a return is made to $N+1$. At this point test mode can be re-established to continue the test. The main point to remember is to provide a positive indication of the success of that specific test.


TL/DD/6940-1
FIGURE 1. Tester Clock Generation and Synchronizatlon Circuit


TL/DD/6940-2
FIGURE 2. Tester Mode Sequencer

### 3.3 RAM Test

The verification of RAM is a part of the internal logic test, but is treated separately here. One must check both the RAM and its address register to find all faults. An example of this testing would be to load RAM with a string of STII commands. By then going back and reading this data to the outside (through an OMG instruction in a loop) the tester could verify both RAM and address were functional. One could then load RAM with all 6's and 9's (or 5's and 10's) sequentially to insure that all bits were functional and adjacent bits not shorted. Other similar tests could be run at the discretion of the user to do further testing. All of these tests would utilize the output of data via the $G$ ports to validate the data. See the comparator circuit Figure 3.

### 3.4 ROM Dump

Successful operation of the internal logic tests and RAM will lead to the final test phase, ROM comparison. In order to
check the ROM contents, the ROM dump mode must be entered. One should force a JMP to an address near the end of the ROM space (3FF for a 420 chip, $1 F F$ for a 410 ). A desirable point might be 3FA. The program counter will step ahead on each instruction cycle unless a program control is executed. The next step is to load the $Q$ register with a non-conflicting value so that the enabling of the L outputs will not destroy the second byte of the LEI instruction as control is passed into the ROM dump mode. After going to this address, one should execute an enable of the $L$ lines to the output port (LEI 4). Having done this the external buffers should be disabled and the SI pin taken low. This will allow data out and remove potential level conflicts. By letting the PC step ahead to address zero one can then begin the byte by byte comparison of data. In this mode the controller is not executing the code because the skip line is enabled throughout the sequence. By halting a counter on a failure, one could determine the questionable address.


TL/ DD/6940-3
FIGURE 3. Functional Logic and RAM Comparison Circuit

| TABLE I. Typlcal Test Sequence |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| NOP | NO CHANGE | CHECK NOP \& ALLOW TRANSIENT CYCLE FOR MODE | CLRA ASC |  | CHECK ADD WITH CARRY |
| OGI 9 | $\mathrm{G}(0>9)$ | NOTON 410L/411L | SC |  | CHECK SET CARRY |
| OGI 6 | $\mathrm{G}(9>6)$ | REVERSE ALL G STATES | SKC |  | CHECK SKIP ON CARRY |
| STII 8 |  | SET UP 0,0 FOR FUTURE | LDD 0,0 |  |  |
| LBI 3,13 |  | B TO NEW POSITION $(3,13)$ | X |  | STORE A |
| OBD | $D(0>13$ | CHECK D | OMG | $\mathrm{G}=9$ | NO CHANGE |
| CLRA |  | MAKE SURE $A=0$ | CLRA |  |  |
| XABR |  | $3>\mathrm{A} ; 0>\mathrm{Br}$ | ASC |  |  |
| CAB |  | MOVE 3 to Bd | X |  |  |
| OBD | $D(13>3)$ | CHECK XABR CAB \& D CHANGE | OMG | $G(9>10)$ | CARRY ADDS ONE TO MEMORY |
| CLRA |  | 1 | CAMQ |  | STORE A \& M IN Q; 10,9 |
| AISC 2 |  | IFORCE $A>2$ | XDS |  | $9>3,1 ; 10>A ; B d>3,0$ |
| CAB |  | $2>\mathrm{Bd}$ | X |  | STORE 9 IN 3,0 |
| OBD | $D(3>2)$ | VERIFY 2 FROM A > Bd | OMG | $\mathrm{G}(10>9)$ |  |
| STII 7 |  | $7>0.2$ \& Bd $>3$ | LD 2 |  | $9>\mathrm{A} ; \mathrm{Bd}>1,0$ |
| OBD | $D(2>3)$ | STII INCREMENTS Bd |  |  |  |
| CAB |  | SEE THAT A STILL THE SAME | INSTRUCTION | RESULT | COMMENTS |
| OMG | $\mathrm{G}(6>7)$ | OMB \& RAM CHECK |  |  |  |
| CLRA |  |  | OMG | $\mathrm{G}(9>1)$ |  |
| CAB |  | $\mathrm{B}(0,0)$ | LD 3 |  | $1>\mathrm{A} ; \mathrm{Bd}>2,0$ |
| OMG | $\mathrm{G}(7>8)$ | TIE IN RAM, A \& G OPERATION | OMG | $\mathrm{G}(1>2)$ |  |
| SMB 0 |  | SMB INST. CHECK | ADD |  | ADD WITHOUT CARRY |
| OMG | $\mathrm{G}(8>9)$ | : | X |  | STORE 3 IN 2,0 |
| SMB 1 |  | : | SC |  |  |
| OMG | $\mathrm{G}(9>11)$ | : | LDD 0,0 |  | $7>$ A |
| RMB 0 |  | : | CASC |  | CHECK CASC |
| RMB 3 |  | $:$ | SKC |  |  |
| X |  | : $0>0,0 ; 2>\mathrm{A}$ | X |  | STORE 12 |
| CAB |  | $\mathrm{A}=2>\mathrm{B}$ | OMG | $\mathrm{G}(2>12)$ |  |
| OMG | $\mathrm{G}(11>7)$ | OUTPUT M $(0,2)$ | CLRA |  | : |
| LD 1 |  | $\mathrm{M}(0,2)>A_{i} \mathrm{~B}>1,2$ | AISC 3 |  | : |
| XAD 0,0 |  | $\mathrm{A}(7)<->\mathrm{M}(0,0) 2$ | X |  | : |
| AISC 15 |  | AISC CHECK; $\mathrm{A}=1$ | SC |  | :CHECK |
| LDD 0,0 |  | CHECK SKIP OF 2 BYTE INST. | SKC |  | :SKC/SC |
| X |  | STORE 1 | X |  | : |
| OMB | $G(7>1)$ | VERIFY | OMG | $\mathrm{G}(12>3)$ |  |
| LDO |  | COPY1,2 BACK TO A | RC |  |  |
| ADT |  | ADD TEN | SKC |  | :CHECK |
| XDS |  | LEAVE 11 IN 1,2;GO 1, 1 WITH 1 | X |  | :RC |
| XDS |  | LEAVE 1 IN 1,$1 ; \mathrm{GO} 1,0 \mathrm{~W}$ ? | OMG | $\mathrm{G}(3>12)$ |  |
| OBD | $D(2>0)$ | CHECK Bd MOVEMENT | LBI 0,0 |  | :CHECK |
| STIl 5 |  | $5>1,0 ; B d$ TO 1,1 | LBI 1,15 |  | ;SEQUENTIAL LBI'S |
| CBA |  | CHECK B > A | LBI 2,7 |  | ALSO SKIPPED (LBI 2,7 NOT IN 410) |
| AISC 3 |  | AISC CHECK $4>$ A | OMG <br> CQMA | $\mathrm{G}(2>7)$ | LOAD CONSTANTS FROM Q |
| INSTRUCTION | RESULT | COMMENTS | $\begin{aligned} & \text { OMG } \\ & \mathrm{X} \end{aligned}$ | $\mathrm{G}(7>9)$ | CHECK : |
| XDS |  | $1>\mathrm{A} ; 4>1,1$ | OMG | $\mathrm{G}(9>10)$ | : |
| OMG | $\mathrm{G}(1>5)$ | FROM 1,0 | LEI 1 |  |  |
| XDS |  | $5>\mathrm{A} ; 1>1,0 ; \mathrm{Bd}<15$ SKIP | XAS |  | STORE A - > S (9) |
| LDD 0,0 |  | SKIPPED! | CLRA |  |  |
| OBD | $D(0>15)$ |  | AISC 7 |  | : |
| AISC 4 |  | $9>\mathrm{A}$ | SKGBZ 0 |  |  |
| X |  | $9>15$ | X |  | :CHECK |
| OMG | $\mathrm{G}(5>9)$ |  | OMG |  | : |
| CLRA |  |  | SKGBZ 1 |  |  |
| COMP |  | ONES TO A | X |  | ;G BIT |
| XOR |  | FLIP MEMORY | OMG | $\mathrm{G}(10>7)$ | : |
| XIS |  | $6>1,15 ; 9>\mathrm{A} ; \mathrm{Bd}>1,0$ | SKGBZ 2 |  | : |
| LDD 0,0 |  | SKIP | X |  | : |
| SKE |  |  | OMG | $G(7>10)$ | :TESTS |
| LB 1,2 |  | SKIP 2 WORD LBI (NOT IN 410) | SKGBZ 3 |  | : |
| OBD | $D(15>0)$ | VERIFY WORD | X |  | : |
| SKE |  | 11 NOT = 9 | OMG | $\mathrm{G}(10>7)$ | : |
| LBI 1,0 |  | BACK TO 1,0 |  |  |  |
| SMB 2 |  | , | INSTRUCTION | RESULT | COMMENTS |
| SKE |  |  |  |  |  |
| RMB 2 |  | : | SKGZ |  |  |
| SKE |  | :CHECK BIT | X |  | :CHECK |
| SMB 3 |  | :MANIPULATIONS | OMG | $\mathrm{G}(7>10)$ |  |
| SKE |  | - | OGIO | $\mathrm{G}(10>0)$ | :G TEST |
| LDD 0,0 |  | : | SKGZ |  | : |
| $\times 3$ |  | $\mathrm{Bd}>2,0$ | X |  | : |
| XAD 1,1 |  | $9>1,1 ; 4>A$ | OMG | $\mathrm{G}(0>10)$ | : |
| XIS 1 |  | $4>2,0 ; \mathrm{Bd}>3,1$ | SKMBZ 0 |  |  |
| ${ }_{\mathrm{X}}^{\text {ING }}$ |  | INPUT G PORT STORE | $x$ $\hat{O M G}$ |  | CHECK MEMORY BIT TESTS NO CHANGE |
| X |  | STORE | OMG SKMBZ 1 |  | NO CHANGE |


| INSTRUCTION | RESULT | TABLE I. Typical T COMMENTS | quence (Continued) instruction | RESULT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| X |  |  | STII 2 |  |  |
| OMG | $\mathrm{G}(10>7)$ | NO SKIP | STII 9 |  |  |
| SKMBZ 2 |  |  | STIIO |  |  |
| X |  | WON'T SKIP | LBI 3,0 |  |  |
| OMG | $\mathrm{G}(7>10)$ |  | STII 7 |  |  |
| INIL |  | SEE THAT L LATCHES RESET | STII 14 |  |  |
| ININ |  | ASSUME G - > 1 | STII 5 |  |  |
| SKE |  |  | STII 12 |  |  |
| X1 |  | $\mathrm{Br}>1$ | STII 3 |  |  |
| OMG |  | SHOULD BE EQUAL | STII 10 |  |  |
| INIL |  | : | STIl 1 |  |  |
| X |  | : | STII 8 |  |  |
| SKMBZ 3 |  | : | STII 15 |  |  |
| OBD | $D(15>0)$ | :INIL TEST | STII 6 |  |  |
| OGI 1 |  | : | STII 13 |  |  |
| LBI3,11 |  | : | STII 4 |  |  |
| OGIO |  | : | STII 11 |  |  |
| INIL |  | : | STII 2 |  |  |
| X |  | : | STII 9 |  |  |
| SKMBZ 0 |  | : | STII 0 |  |  |
| OBD | $D(0>11)$ | : |  |  |  |
| NOP |  |  | INSTRUCTION | RESULT | COMMENTS |
| XAS |  |  |  |  |  |
| X |  | :XAS TEST | LBIO,0 |  | CHECK FOR RAM DATA |
| OMG | $\mathrm{G}(10>9)$ | : | OMG |  | OUTPUT DATA |
|  |  |  | LD |  |  |
| INSTRUCTION | RESULT | COMMENTS | $\begin{aligned} & \text { XIS } \\ & \text { OMG } \end{aligned}$ |  | :MOVE TO NEXT DIGIT OUTPUT DATA |
| LBIO,0 |  | LOAD RAM WITH | LD |  |  |
| STII 7 |  | CONSTANTS USING | XIS |  | :MOVE TO NEXT DIGIT |
| STII 14 |  | STII | OMG |  | OUTPUT DATA |
| STII 5 |  |  | LD |  |  |
| STII 12 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 3 |  |  | OMG |  | OUTPUT DATA |
| STII 10 |  |  | LD |  |  |
| STII 1 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 8 |  |  | OMG |  | OUTPUT DATA |
| STII 15 |  |  | LD |  |  |
| STIII 6 |  | - | XIS |  | :MOVE TO NEXT DIGIT |
| STII 13 |  |  | OMG |  | OUTPUT DATA |
| STII 4 |  |  | LD |  |  |
| STII 11 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 2 |  |  | OMG |  | OUTPUT DATA |
| STII 9 |  |  | LD |  |  |
| STII 0 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| LBI 1,0 |  |  | OMG |  | OUTPUT DATA |
| STII 7 |  |  | LD |  |  |
| STII 14 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 5 |  |  | OMG |  | OUTPUT DATA |
| STII 12 |  |  | LD |  |  |
| STII 3 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 10 |  |  | OMG |  | OUTPUT DATA |
| STII 1 |  |  | LD |  |  |
| STII 8 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 15 |  |  | OMG |  | OUTPUT DATA |
| STIII 6 |  |  | LD |  |  |
| STII 13 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 4 |  |  | OMG |  | OUTPUT DATA |
| STII 11 |  |  | LD |  |  |
| STII 2 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 9 |  |  | OMG |  | OUTPUT DATA |
| STII 0 |  |  | LD |  |  |
| LBI 2,0 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 7 |  |  | OMG |  | OUTPUT DATA |
| STII 14 |  |  | LD |  |  |
| STII 5 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 12 |  |  | OMG |  | OUTPUT DATA |
| STII 3 |  |  | LD |  |  |
| STII 10 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 1 |  |  | OMG |  | OUTPUT DATA |
| STII 8 |  |  | LD |  |  |
| STII 15 |  |  | XIS |  | :MOVE TO NEXT DIGIT |
| STII 6 STII 13 |  |  | INSTRUCTION | RESULT | COMMENTS |
|  |  |  | instruction | RESULT | COMMENTS |
| INSTRUCTION | RESULT | COMMENTS | $\begin{aligned} & \text { LBI } 1,0 \\ & \text { OMG } \end{aligned}$ |  | CHECK FOR RAM DATA OUTPUT DATA |
| STII 4 |  |  | LD |  |  |
| STII 11 |  |  | XIS |  | :MOVE TO NEXT DIGIT |


| INSTRUCTION | RESULT | TABLE I. Typical Test Sequence (Continued) COMMENTS <br> INSTRUCTION |  | RESULT | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  | : | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA |  |  |  |
| LD |  |  | INSTRUCTION | RESULT | COMMENTS |
| XIS |  | :MOVE TO NEXT DIGIT |  |  |  |
| OMG |  | OUTPUT DATA | LBI 3,0 |  | CHECK FOR RAM DATA |
| LD |  |  | OMG |  | OUTPUT DATA |
| XIS |  | :MOVE TO NEXT DIGIT | LD |  |  |
| OMG |  | OUTPUT DATA | XIS |  | :MOVE TO NEXT DIGIT |
| LD |  |  | OMG |  | OUTPUT DATA |
| XIS |  | :MOVE TO NEXT DIGIT | LD |  |  |
| OMG |  | OUTPUT DATA | XIS |  | :MOVE TO NEXT DIGIT |
| LD |  |  | OMG |  | OUTPUT DATA |
| XIS |  | :MOVE TO NEXT DIGIT | LD |  |  |
| OMG |  | OUTPUT DATA | XIS |  | :MOVE TO NEXT DIGIT |
| LD |  |  | OMG |  | OUTPUT DATA |
| XIS |  | :MOVE TO NEXT DIGIT | LD |  |  |
| OMG |  | OUTPUT DATA | XIS |  | :MOVE TO NEXT DIGIT |
| LD |  | : | OMG |  | OUTPUT DATA |
| XIS |  | :MOVE TO NEXT DIGIT | LD |  |  |
| OMG |  | OUTPUT DATA | XIS |  | :MOVE TO NEXT DIGIT |
| LD |  |  | OMG |  | OUTPUT DATA |
| XIS |  | :MOVE TO NEXT DIGIT | LD |  |  |
| OMG |  | OUTPUT DATA | XIS |  | :MOVE TONEXT DIGIT |
| LD |  |  | OMG |  | OUTPUT DATA |
| XIS |  | :MOVE TO NEXT DIGIT | LD |  |  |
| OMG |  | OUTPUT DATA | XIS |  | :MOVE TO NEXT DIGIT |
| LD |  |  | OMG |  | OUTPUT DATA |
| XIS |  | :MOVE TO NEXT DIGIT | LD |  |  |
|  |  |  | XIS OMG |  | :MOVE TO NEXT DIGIT OUTPUT DATA |
| Instruction | RESULT | COMMENTS | $\begin{aligned} & \text { OMG } \\ & \text { LD } \end{aligned}$ |  | output data |
| LBI 1,0 |  | CHECK FOR RAM DATA | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  | : | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TONEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TONEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TONEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS |  | :MOVE TO NEXT DIGIT | XIS |  | :MOVE TO NEXT DIGIT |
| OMG |  | OUTPUT DATA | OMG |  | OUTPUT DATA |
| LD |  |  | LD |  |  |
| XIS OMG |  | :MOVE TO NEXT DIGIT OUTPUT DATA | XIS |  | :MOVE TO NEXT DIGIT |
| ${ }_{\text {LD }}^{\text {OMG }}$ |  | OUTPUT DATA |  |  | COMMENTS |
| LD XIS |  | :MOVE TO NEXT DIGIT | INSTRUCTION | RESULT | COMMENTS |
| OMG |  | OUTPUT DATA | JMP X | INITIALIZ | EELECT ADDRESS X |
| LD |  |  |  | FOR OGI | OMG (SELECT LBI |
| XIS |  | :MOVE TO NEXT DIGIT |  | FOR KNO | DATA) |
| OMG |  | OUTPUT DATA | RELEASE TEST MODE | OBD (SEL | B FOR KNOWN |
| LD |  |  |  | CONDITI | CHECKS JMP |
| XIS |  | :MOVE TO NEXT DIGIT |  |  |  |


| TABLE I. Typical Test Sequence (Continued) INSTRUCTION RESULT COMMENTS |  |
| :---: | :---: |
| SET TEST MODE |  |
| JPX-2 |  |
| JSR Y | CHECK JP \& JSR |
| RELEASE TEST MODE | " Y " SHOULD CHANGE THE OUTPUT CONDITIONS OF "X" |
|  | IF AT ALL POSSIBLE |
| SET TEST MODE |  |
| RET |  |
| RELEASE TEST MODE |  |
| EXECUTE "X" AGAIN | VERIFIES RET |
| SET TEST MODE |  |
| JP X-2 |  |
| JSRP Z | CHECK JSRP \& RETSK |
| RELEASE TEST MODE |  |
| EXECUTE CODE | "Z" SHOULD CHANGE " $X$ " |
|  | OUTPUT CONDITIONS |
| SET TEST MODE |  |
| RETSK | DON'T CHANGE Z CONDITIONS RETSK |
| RELEASE TEST MODE |  |
| EXECUTE " |  |
| SET TEST MODE |  |
| LOAD A \& M TO | FIND VALUE OF ADDRESS IN BLOCK (4 PAGES) |
| VALUE OF ADDRESS | AT OR JUST BEFORE AN OUTPUT |
| TO GO TO | CHANGE SET A \& M TO ADDRESS |
| OUTPUT CHANGE | OF "VALUE" |
| JID | CHECKS JID |
| RELEASE TEST MODE |  |
| EXECUTE OUTPUT |  |
| SET TEST MODE | LOAD A \& M WITH A UNIQUE ADDRESS |
| LOAD A \& M | SUCH THAT CONTENTS OF THAT ADDRESS WILL BE SEEN ONG |
| LQID |  |
| X064 | ;OR USE THIS CAUSE THE DATA COMES ;FROM YOUR TESTER ANYWAY |
| CQMA |  |
| OMG | LQUID \& CQMA CHECKED |
| X |  |
| OMG |  |
| INL |  |
| OMG | $\mathrm{G} \mathrm{-} \mathrm{>} 2$ INL. TEST (COPY OF 2nd BYTE) |
| X |  |
| OMG | $\mathrm{G}->\mathrm{E}:$ |

This test sequence is not to be taken as a recommended test routine and is only shown as an example of what might be done to test various COPS parts. It is also advisable to approach measurements in the test mode with some caution. As stated earlier, one can force a large current into the SO node to place the chip in the test mode. Not only can this current do damage if unlimited, but it can also cause local current overloading such that some I/O conditions may be adversely affected. Obviously this will be more pronounced at higher $V_{C C}$ voltages. A specific example is that the $L$ output current sink test should only be tested at a VOut of 0.4 V and 0.36 mA as the more stringent tests can exceed power limits when combined with the SO current.

## MICROWIRETM

National's super-sensible MICROWIRE serial data exchange standard allows interfacing to any number of specialized peripherals using an absolute minimum number of valuable I/O pins; this leaves more I/O lines available for system interfacing and/or may permit the COPS controller to be packaged in a smaller (and even lower cost) package. (MICROWIRE peripherals may also be used with non-COPS controllers). For further applications information, refer to COPS Briefs 8 and 9. MICROWIRE makes sense.
The example below illustrates the power and versatility of MICROWIRE via an extreme example-using one of each type of peripheral with a single controller.


## COP431 SERIES, 8-BIT A/D CONVERTERS

The COP431 series is an 8 -bit successive approximation A/D converter with a serial I/O and configurable input multiplexer with up to 8 channels. The serial I/O is configured to comply with the NSC MICROWIRE serial data exchange standard for easy interface to the COPS family of processors, and can interface with standard shift registers or other $\mu \mathrm{Ps}$.
The 2, 4 or 8 channel multiplexers are software configured for single-ended or differential inputs as well as channel assignment.
The differential analog voltage input allows increasing the common-mode rejection and offsetting the analog zero input voltage value. In addition, the voltage reference input can be adjusted to allow encoding any smaller analog voltage span to the full 8 bits of resolution.

## COP452L FREQUENCY/COUNTER PERIPHERAL

The COP452L contains 2 independent 16 -bit counter/register pairs, and is well suited to a wide variety of tasks involving the measurement and/or generation of times and/or frequencies. Included are multiple tones, precise duty cycles, event counting, waveform measurement, "white noise" generation, and A-D/D-A conversions. An on-chip zero-crossing detector can trigger a pulse with a programmed delay and duration.

## COP470 V.F. DISPLAY DRIVER

The COP470 is designed to directly drive a multiplexed Vacuum Fluorescent display. Data is loaded serially and held in internal latches. The COP470 has an on-chip oscillator to multiplex four digits of eight segment display, and may be cascaded and/or stacked to drive more digits, more segments, or both.
With the addition of external drivers, the COP470 also provides a convenient means of interfacing to a large-digit LED display.

## COP472-3 LIQUID CRYSTAL DISPLAY CONTROLLER

The COP472-3 Liquid Crystal Display (LCD) Controller drives a multiplexed liquid crystal display directly. Data is loaded serially and is held in internal latches. The COP472-3 contains an on-chip oscillator and generates all the multilevel waveforms for backplanes and segment outputs on a triplex display. One COP472-3 can drive 36 segments multiplexed as $3 \times 12$ ( $41 / 2$ digit display). Two COP472-3 devices can be used together to drive 72 segments ( $3 \times 24$ ) which could be an $81 / 2$ digit display.

## COP494 256-BIT SERIAL ELECTRICALLY ERASABLE PROGRAMMABLE MEMORY

The COP494 is a 256 -bit non-volatile memory. The device contains 256 bits of read/write memory divided into 16 registers of 16 bits each. Each register is serially read or written by the COP400 Family Controller. Written information is stored in a floating gate cell with at least 10 years of retention.

## COP498/COP499 LOW POWER CMOS RAM AND TIMER

The COP498 low power CMOS Random-Access Memory and Timer is an external memory and timer chip with the simple MICROWIRE serial interface. The device contains 256 bits of read/write memory divided into 4 registers of 64 bits each. The COP498 also contains a crystal-based timer for timekeeping purposes, and can provide a "wake-up" signal to turn on a COPS controller.
The COP498 can be used for low power standby memory and can also be used for low power operation by turning the controller off and on, on a duty cycle basis.
The COP499 Low Power CMOS Random-Access Memory is an external memory and switch chip with the simple MICROWIRE serial interface. The device contains 256 bits of read/write memory divided into 4 registers of 64 bits each. The COP499 also contains circuitry that enables the user to turn a controller on and off while maintaining the integrity of the memory.

## Current Consumption in NMOS COPSTM Microcontrollers

Current consumption in the N-channel COPS microcontrollers is a function of manufacturing process variation and three operating condition parameters: temperature, voltage, and frequency. The aforementioned process variation swamps all other variations. Of the operating condition parameters, temperature is by far the most significant. This application brief is intended to provide the user with a guide to approximate the worst-case current consumption of the NMOS COPS microcontroller at a given set of operating conditions and to approximate the current variation with respect to temperature, voltage, and frequency.
Note that this is a guide only. Some approximations in the equations have been made. Only the current values found in the various device data sheets are guaranteed. Values derived by the techniques described here are neither guaranteed nor tested.

## PROCESS VARIATION

If a user were to measure the current in two identical COPS microcontrollers under identical operating conditions (i.e., same temperature, voltage, and frequency), the results would probably be different. The reason for this difference is variation in the manufacturing process within its valid range. This variation can be quite substantial; a range of about 3 to 1 can be expected. This variation is essentially a device-todevice variation and basically not related to the operating conditions of the device. The three operating condition parameters (temperature, voltage, and frequency) affect current in the manner described below.
The values for current consumption in the various device data sheets are worst-case maximum values and assume that the processing parameters are at the end of the valid range which will produce maximum current consumption in the device.

## THE EFFECT OF FREQUENCY

The frequency effect on current consumption is primarily a device design consideration. The higher the intended operating frequency, the higher the maximum current. However, once the device is designed in this process for a given maximum frequency, there is little variation with operating frequency. To be sure, there is some variation. As might be expected, current consumption is greater at higher frequencies. The variation is, however, slight-typically less than 5\%.

National Semiconductor Corp. Application Brief 3 Len Distaso


## THE EFFECT OF VOLTAGE

The operating voltage of the microcontroller has a slightly greater effect on current consumption than the operating current. Current consumption increases with increasing operating voltage. On examining the MOS device equations, one finds that the device current is proportional to the square of a voltage term:

$$
1 \alpha\left(V_{G S}-V_{T}\right)^{2}
$$

where:

$$
1 \text { = device current }
$$

$V_{\mathrm{GS}}=$ device gate to source voltage
$V_{T}=$ device threshold voltage.
In the N-channel COPS devices, current is consumed primarily by the load devices. Most of these devices, though not all, are depletion mode devices with the gate and source tied together. Thus, $V_{G S}$ is 0 . Therefore, the primary mechanism for current consumption as related to voltage is variation in $V_{T}$. The depletion mode load devices in the COPS NMOS microcontrollers have geometries (length is much greater than width) which tend to minimize variations in threshold voltage. There are additional second order effects related to operating voltage, such as effective channel lengths shortening due to increased voltage, which affect current consumption. These effects, however, do not have a major impact on current consumption. Note also that the threshold voltage is affected by process variation. This is one of the areas where the process variation contributes to the device-to-device variation in current consumption. The user can typically expect to see a $5 \%$ to $10 \%$ variation in current due to operating voltage with the maximum current consumption occurring at maximum operating voltage.

## THE EFFECT OF TEMPERATURE

Of the three operating parameters affecting current consumption in the NMOS COPS microcontrollers, temperature has by far the greatest impact. The relationship is given by the following simplified, empirical equation:
$\mathrm{I}(\mathrm{T})=\mathrm{I}_{\mathrm{O}}\left(\mathrm{T} / \mathrm{T}_{\mathrm{O}}\right)^{-3 / 2}$
where:
$\mathrm{T}_{\mathrm{O}}=$ reference junction temperature in ${ }^{\circ} \mathrm{K}$
$\mathrm{T}=$ device junction temperature in ${ }^{\circ} \mathrm{K}$
$I_{O}=$ device current at temperature $T_{O}$
$I(T)=$ device current at temperature $T$.
Although this equation is for a single transistor, it can be applied to the entire microcontroller since all the devices are made with the same process and will exhibit the same
characteristics. It should also be noted that the temperatures involved are device junction temperatures. The junction temperature is essentially a function of two items:

$$
T_{j}=F\left(T_{A}, \theta_{j A}\right)
$$

where:

$$
T_{j}=\text { junction temperature }
$$

$\mathrm{T}_{\mathrm{A}}=$ ambient temperature

$$
\theta_{\mathrm{JA}}=\text { package thermal characteristic. }
$$

The preceding relationship indicates that the package for the device will affect current because the package affects junction temperature. This should not come as a surprise. One need only consider the differences between ceramic and plastic packages to find support for this claim.
For purposes of discussion, it will be assumed that junction temperature is given by the following:

$$
T_{j}=T_{A}+25^{\circ} K
$$

where $T_{j}$ and $T_{A}$ are as defined previously. Note that this is an approximation. It is not necessarily true for all packages, or any package. The relationship between junction temperature and ambient temperature is also not necessarily linear. However, the approximation is reasonable and provides a workable framework.
Substituting the junction temperature relationship into the current equation, the following equation results:

$$
I\left(T_{A}\right) \cong I_{0}\left(\frac{T_{A}+25}{T_{A O}+25}\right)^{-3 / 2}
$$

where:
$\mathrm{T}_{A O}=$ reference ambient temperature, ${ }^{\circ} \mathrm{K}$
$\mathrm{T}_{\mathrm{A}}=$ ambient temperature, ${ }^{\circ} \mathrm{K}$
$I_{O}=$ current at ambient temperature $T_{A O}$
$I\left(T_{A}\right)=$ current at ambient temperature $T_{A}$.

## AN EXAMPLE

The COP320L has a specified maximum current of 10 mA . In this process, maximum current occurs at minimum temperature, which is $40^{\circ} \mathrm{C}$ in this case. It is desired to find the maximum current at $25^{\circ} \mathrm{C}$. Therefore,

$$
\begin{aligned}
& T_{A O}=-40^{\circ} \mathrm{C}=233^{\circ} \mathrm{K} \\
& T_{A}=25^{\circ} \mathrm{C}=298^{\circ} \mathrm{K} \\
& I_{O}=10 \mathrm{~mA} \\
& I\left(T_{A}\right) \text { to be determined } \\
& I\left(T_{A}\right)
\end{aligned} \begin{aligned}
& \cong I_{O}\left(\frac{T_{A}+25}{T_{A O}+25}\right)^{-3 / 2} \\
& \cong 10 \mathrm{~mA}(323 / 258) \\
& \cong 7.14 \mathrm{~mA} .
\end{aligned}
$$

Thus the maximum current for the COP320L at $25^{\circ} \mathrm{C}$ is approximately 7 mA .

## CONCLUSION

A means is provided to the user to approximate the current variation of the NMOS COPS microcontroller over its valid operating range. A given device will consume its maximum current at maximum operating voltage, maximum operating frequency, and minimum operating ambient temperature. Conversely, minimum current will be consumed at minimum operating voltage, minimum operating frequency, and maximum operating ambient temperature.
The user should remember that this document is intended as a guide only. The values produced here are reasonable but they are approximations and are not guaranteed values. The user should also remember that the equations and methods discussed here do not involve process variation. The numbers calculated approximate the worst-case maximum current values at a given set of operating conditions. The user should be prepared to see a wide range of values over the course of volume production.

## Further Information on Testing of COPS ${ }^{\text {TM }}$ Microcontrollers

COP Note 7 describes the basic approach and philosophy for testing COPS microcontrollers. This application brief is intended to complement and expand COP Note 7. It is assumed that the reader is familiar with and has access to COP Note 7.

## TEST MODE

On COPS microcontrollers, test mode is entered by forcing the SO output to a logic " 1 " when it should otherwise be a logic " 0 ". The easiest way to do this is to hold the COPS device in reset, hold the RESET pin low, and pull SO up to a logic " 1 " level. WARNING: Do not force more than 3.0V on SO, as damage to the device may occur. SO should be forced to approximately 2.5 V to guarantee entry into test mode and to protect the device from damage.
Once the device is in test mode, the state of the SI input controls the type of test. SI at a logic " 1 " (high level) conditions the device to accept instructions from an external source via the L port. In test mode, when SI is high, the internal ROM is disabled. SI at a logic " 0 " (low level) forces the device to dump the internal ROM to the L port where the user can read and verify the ROM contents.

## INSTRUCTION INPUT

With the device in test mode and SI at a logic " 1 ", the microcontroller will read the data at the $L$ port as instructions. The instructions must be presented at the beginning of each cycle time and must remain valid during the whole cycle time. The chip SK output is the instruction cycle clock in test mode and can be used as the timing reference. Figure 1 indicates the timing for instruction input using the chip's SK output as the reference. A new instruction must be valid at the $L$ inputs within approximately 200 ns of the rising edge of SK. The user should make every effort to make this time ( t 2 in Figure 1) as short as possible.
It is possible to create an external SK signal which more closely duplicates the internal SK. This requires building a divider from CKI and synchronizing the resultant signal with the device under test. This is significant because it is the internal version of the SK signal which is the master timing signal for the microcontroller. The short time from the rising edge of the SK output to instruction valid is necessary because the actual objective is to provide new instructions at the rising edge, or close to it, of the internal timing signal. If the user creates the external timing signal, the 200 ns time is not applicable. A new instruction, or ROM word, would be presented at each rising edge of the external signal. A method for generating and using this external SK is described in COP Note 7.

## ROM DUMP

With SI at logic " 0 " in test mode, the microcontroller will dump the ROM to the L port. ROM will be dumped sequentially, one word at a time, starting at whatever value the

National Semiconductor Corp.
Application Brief 4
Len Distaso

program counter contains. A new ROM word appears at the $L$ lines every falling edge of the chip SK signal. The output timing ( t 1 in Figure 1) is the L output timing as found in the various device data sheets. The device will remain in ROM dump mode as long as SI is at logic " 0 " in test mode. The program counter will wrap around from the maximum address to 000 and ROM dump will continue.
To get a ROM dump, the user cannot simply enter test mode and force SI to logic "0". Some conditioning of the device is necessary. This requires that the user first go into instruction input mode and set up the device. The suggested sequence is as follows:

1. Enter test mode-pull $\overline{R E S E T}$ low, force SO to about 2.5 V .
2. Force SI to logic " 1 " and force Os on L lines-RESET still low.
3. Force RESET high and input the following sequence to the device:

| CLRA |  |  |
| :--- | :--- | :--- |
| JMP | 3FC | (modify for ROM size) |
| LQID |  |  |
| O44H |  |  |
| LEI | 4 |  |
| NOP |  |  |

4. During the NOP, change SI from high to low as shown in Figure 2. The ROM dump should start at address 000 H at the time shown in Figure 2.
Figure 3 presents a general timing diagram for the entire sequence above. The jump instruction (JMP 3FC) in the sequence is used merely to position the program counter so that the ROM dump will begin at a specified location. That jump will be modified to reflect different ROM sizes or different desired starting locations for the ROM dump.

## CHANGING BETWEEN INSTRUCTION INPUT AND ROM DUMP

The change from instruction input to ROM dump is accomplished according to the timing in Figure 2. It is necessary to do this to perform a valid ROM dump. However, it is not recommended to go the other direction, from ROM dump to instruction input, "on the fly". The instruction input mode should only be entered while the device is reset, $\overline{\text { RESET }}$ line low, to guarantee proper timing.

## CONCLUSION

With COP Note 7 and this application brief, the user should be able to create a workable functional test for his COPS microcontroller. The relative timing is presented here and general techniques and sequences are provided in COP Note 7.

$11=\mathrm{L}$ output timing (tpD1, $\mathrm{t}_{\mathrm{pDO}}$ ) as found in data sheet
t2 ~ 200 ns max

FIGURE 1. Basic Test Mode Timing


TL/DD/5146-2
FIGURE 2. Timing for Changing from Instruction Input to ROM Dump-Test Mode


TL/DD/5146-3
FIGURE 3. Relative Timing for Suggested Sequence to Generate ROM Dump

## COPS ${ }^{\text {TM }}$ Interrupts



This brief describes in detail the timing requirements pertinent to COPS interrupts. Figure 1 shows a typical enable-interrupt sequence in relation to the SK (Instruction Cycle) Clock. The SK clock is actually derived afrom the $\phi 1$ clock which is $180^{\circ}$ out of phase with the $\phi 2$ clock. It is the $\phi 1$ and $\phi 2$ clocks to which all operation is referenced but for our purposes the SK will suffice. Program instructions are read on a rising $\phi 1$ edge and executed during the $\phi 1, \phi 2$ cycle time. Here we see the EN register interrupt enable bit EN2 being set with an LEI instruction. Interrupts are actually enabled on the $\phi 2$ leading edge of the second byte of the instruction point (3). Timing for an INTERRUPT DISABLE is essentially the same.
The interrupt line is sampled on the leading edge of $\phi 1$ as shown and interrupts are recognized if the minimum setup and hold times shown are satisfied. Note that the guaranteed times are longer than the typicals. The interrupt signal conditioning circuitry contains a falling edge detection circuit (a one shot) which requires that in addition to meeting the setup and hold times, the enable interrupt bit EN1 must have been turned on sometime before the end of the WINDOW of OPPORTUNITY shown. If not, the interrupt will be missed and another high to low IN1 transition will be required. EN1 is automatically disabled upon interrupt recognition at point (5). Note that although the interrupt is recog-
nized at point (4) it will not be acted upon until all successive transfer of control instructions are executed as defined in the data sheets.
Because of gate delays it is doubtful that if an interrupt had been generated in time to meet the leading $\phi 1$ edge at point (2) that the EN1 enable bit would have been on in time to meet the WINDOW of OPPORTUNITY.
By doing a worst case analysis one can see that in order to guarantee reception of an asynchronous interrupt IN1 must remain low for at least 2 instruction cycles. The analysis is as follows. Assuming that interrupts had been enabled prior to point © , if the interrupt arrives a little after point (1) it will not satisfy the minimum setup requirements bringing us up to a point (5) our total elapsed time becomes (5) - (1) $=2$ tcyc.
In a dual COPS the interrupt sequence is the same except that now an instruction cycle time is made up of both a Processor $X$ and a Processor $Y$ instruction execution cycle. With one $\phi 1$ and $\phi 2$ clock per processor execution cycle itne instruction cycle time is made up of $2 \phi 1$ 's and $\phi 2$ 's. Therefore 1 instruction cycle time in a dual COPS is equivalent to 2 instruction cycle times in a single COPS as far as $\phi 1$ 's, $\phi 2$ 's and interrupts are concerned.


## Protecting Data in the NMC9306/COP494 and NMC9346/COP495 Serial EEPROMs

National Semiconductor Corp. Application Brief 15
Asim Bajwa

The NMC9306/COP494 and NMC9346/COP495 are nonvolatile serial access memories with the folloiving salient features:

- Low cost
- Single supply read/write/erase operation ( $5 \mathrm{~V} \pm 10 \%$ )
- TTL compatible
- MICROWIRETM compatible I/O
- $16 \times 16$ serial read/write memory (NMC9306/COP494) $64 \times 16$ serial read/write memory (NMC9346/COP495)
- Self-timed programming cycle (NMC9346/COP495 only)
- Ready/busy status signal during programming (NMC9346/COP495 only)
- Read-only mode

The read-only mode is provided to prevent accidental data disturb, especially during $V_{C C}$ power up, power down or excessive noise on the I/O or power supply pins.
Executing the EWDS instruction (Figure 1) activates this mode by disabling the programming modes and the high voltage pump. The READ instruction is not affected and can
be executed as usual. However, all programming instructions (ERASE, WRITE, ERAL and WRAL) are ignored until the EWEN instruction is executed to enable programming.
On $V_{C C}$ power up the device is designed to automatically enter the read-only mode to avoid accidental data loss due to power up transients. Putting the device in the read-only mode before powering down $\mathrm{V}_{\mathrm{CC}}$ avoids spurious programming during power down.
The following guidelines are presented and should be incorporated into the user's designs to achieve the maximum possible protection of stored data (Figure 2) :

1) The device powers up in the read-only mode. However, as a backup, the EWDS instruction should be executed as soon as possible after $V_{C C}$ to the EEPROM is powered up to ensure that it is in the read-only mode.
2) Immediately preceding a programming instruction (ERASE, WRITE, ERAL or WRAL), the EWEN instruction should be executed to enable the device for programming; the EWDS instruction should be executed immediately following the programming instruction to return


TL/D/7085-1
FIGURE 1. EWEN, EWDS Instruction Timing


TL/D/7085-2
*EWDS must be executed before $\mathrm{V}_{\mathrm{CC}}$ drops below 4.5 V to prevent accidental data loss during subsequent power down and/or power up transients.
FIGURE 2. Typical Instruction Flow for Maximum Data Protection
the device to the read-only mode and protect the stored data from accidental disturb during subsequent power transients or noise.
3) Special care must be taken in designs in which programming instructions are initiated to store data in the EEP. ROM after the main power supply has gone down. This is usually accomplished by maintaining $V_{C C}$ for the EEP. ROM and its controller on a capacitor for a sufficient amount of time (approximately 50 ms , depending on the clock rate) to complete these operations. This capacitor
must be large enough to maintain $V_{C C}$ between 4.5 and 5.5 volts for the total duration of the store operation, $\mathbb{I N}$. CLUDING the execution of the EWDS instruction immediately following the last programming instruction. FAILURE TO EXECUTE THE LAST EWDS INSTRUCTION BEFORE $V_{C C}$ DROPS BELOW 4.5 VOLTS MAY CAUSE INADVERTENT DATA DISTURB DURING SUBSEQUENT POWER DOWN AND/OR POWER UP TRANSIENTS.

## COPS ${ }^{\text {TM }}$ Peripheral Chips

## National Semiconductor Corp.

 Application Brief 28There are several 1/O peripheral chips that are compatible with the COPS microcontroller by communicating through the serial I/O port.
Two different sets of timing employed by them are shown in Figure 2. A brief description of the electrical characteristics of each chip is given below.

## COP452 FREQUENCY/COUNTER PERIPHERAL

The COP452 is fabricated using N -channel silicon-gate MOS technology. Containing 2 independent 16 -bit counter/ register pairs, it is well suited to a wide variety of tasks involving the measurement and/or generation of times and/or frequencies. Included are multiple tones, precise duty cycles, event counting, waveform measurement, "white noise" generation, and A-D/D-A conversions. An on-chip zero-crossing detector can trigger a pulse with a programmed delay and duration.

## COP470 V.F. DISPLAY DRIVER

The COP470 is designed to directly drive a multiplexed Vacuum Fluorescent display. Data is loaded serially and held in internal latches. The COP470 has an on-chip oscillator to multiplex four digits of eight segment display, and may be cascaded and/or stacked to drive more digits, more segments, or both.
With the addition of external drivers, the COP470 also provides a convenient means of interfacing to a large-digit LED display.

## COP472 LIQUID CRYSTAL DISPLAY CONTROLLER

The COP472 Liquid Crystal Display (LCD) Controller is fabricated using CMOS technology. It drives a multiplexed liquid
crystal display directly. Data is loaded serially and is held in internal latches. The COP472 contains an on-chip oscillator and generates all the multilevel waveforms for backplanes and segment outputs on a triplex display. One COP472 can drive 36 segment multiplexed as $3 \times 12$ ( $41 / 2$ digit display). Two COP472 devices can be used together to drive 72 segments $(3 \times 24)$ which could be an $81 / 2$ digit display.
COP494 256-Bit Serial Electrically erasable programmable memory. The COP494 is a 256 -bit non-volatile memory. The device contains 256 bits of Read/Write memory divided into 16 registers of 16 bits each. Each register is serially read or written by the COP400 controller. Written information is stored in a floating gate cell with at least 10 years retention.
COP498/COP499 LOW POWER CMOS RAM AND TIMER
The COP498 low power CMOS Random-Access Memory and Timer is an external memory and timer chip with the simple MICROWIRETM serial interface. The device contains 256 bits of read/write memory divided into 4 registers of 64 bits each. The COP498 also contains a crystal based timer for timekeeping purposes, and can provide a "wake-up" signal to turn on a COPS controller.
The COP498 can be used for low power standby memory and can also be used for low power operation by turning the controller off and on, on a duty cycle basis.
The COP499 Low Power CMOS Random-Access Memory is an external memory and switch chip with the simple MICROWIRE serial interface. The device contains 256 bits of read/write memory divided into 4 registers of 64 bits each. The COP499 also contains circuitry that enables the user to turn a controller on and off while maintaining the integrity of the memory.



## A Users Guide to COPSTM Oscillator Operation

The following discussion is an overview of the COPS oscillator circuits meant to give the reader a working knowledge of the circuits. Although the descriptions are very general and light on detail; a background in complex frequency analysis is necessary. For additional information the references cited should be consulted as well as the many works on oscillator theory.
There are 2 basic circuits from which all of the COPS oscillator options are provided. (See option lists in individual data sheets.) The first and simplest in description is the astable one shot of Figure 1 which gives us our RC oscillator option. A1 and A2 are inverters with A1 possessing a Schmitt trigger input. T 1 is a large N channel enhancement MOS FET. Operation with the external R-C shown is as follows. Assuming $C$ is initially discharged the CKI pin is low forcing T1 off. As $C$ charges through $R$ the trigger point of $A 1$ is eventually reached at which time T 1 is turned on discharging C and beginning a new cycle. Although almost any combination of R-C could be chosen, we would ideally like to have as short a discharge time as possible thereby eliminating the high variability in T1 drain current from device to device as a timing factor. For this reason R is chosen very large and $C$ very small. This choice also leads to minimum R-C power dissipation. For the CKI Schmitt trigger clock input option the T1 MOS FET is merely mask disabled from the oscillator circuit.


FIGURE 1. R-C Oscillator

The second oscillator circuit is the classic phase shift oscillator depicted in Figure 2. Found not only on COPS but on most other microprocessor circuits it is the simplest oscillator in terms of component complexity but the most difficult to analyze.

National Semiconductor Corp.
Application Note 326
Jim Murashige

The conditions under which the circuit will oscillate are described by the Barkhausen Criterion which states that oscillation will occur at the frequency for which the total loop phase shift from $x_{i}$ to $x_{f}$ is $0^{\circ}$ or a multiple of $360^{\circ}$ (i. e., $x_{f}$ is identical to $x_{i}$ ). In addition the total loop gain must be $>1$ to insure self propagation. The inverting amplifier shown between $x_{j}$ and $x_{0}$ provides $180^{\circ}$ of phase shift thus leaving the feedback network to supply the other $\pm 180^{\circ}$. The feedback network can be comprised of active or passive components but highly effective oscillators are possible using only passive reactive components and the general configuration of Figure 3.
If you work out the feedback loop equations for Figure 3 it can be shown that in order to achieve $\pm 180^{\circ}$ phase shift:

$$
\begin{equation*}
X 1+X 2+X 3=0 \tag{1}
\end{equation*}
$$

$X 1$ and $X 2$. must both be inductors or capacitors
therefore X 3 is inductive if X 1 is capacitive and vice versa if X 1 and X 2 are capacitors it is a Colpitts Oscillator X 1 and X 2 are inductors it is a Hartley Oscillator


TL/DD/5139-3
FIGURE 3. Typical Feedback Configuration

The Colpitts configuration is commonly shown in microprocessor oscillator circuits (Figure 5) with the inductive X3 replaced by a crystal for reasons we shall soon see. The equivalent electrical model of a crystal is shown in Figure $4 b$ and a plot of its Reactance versus Frequency shown in Figure 4c. R-L-C represent the electro-mechanical properties of the crystal and $\mathrm{C}_{0}$ the electrode capacitance. There are 2 important points on the reactance curve labeled $f_{a}$ and $f_{b}$.
At $f_{a}=\frac{1}{2 \pi} \sqrt{\frac{1}{L C}}$
the crystal is at series resonance with $L$ and $C$ canceling each other out leaving only a nonreactive R for 0 phase shift. This mode of operation is important in oscillator circuits where a non-inverting amplifier is used and $0^{\circ}$ phase shift must be preserved.
$A t f_{b}=\frac{1}{2 \pi} \sqrt{\frac{1}{L C}+\frac{1}{L C_{C}}}$
which is just a little higher than $f_{a}$ the crystal is at parallel resonance and appears very inductive or capacitive. Note that the cyrstal will only appear inductive between $f_{a}$ and $f_{b}$ and that it becomes highly inductive very quickly. In addition $f_{b}$ is only a fraction of a percent higher than $f_{a}$. Therefore the only time that the crystal will satisfy the $\mathrm{X} 3=-(\mathrm{X} 1+$ X2) condition in the Colpitts configuration of Figure 5 is when the circuit is oscillating between $f_{a}$ and $f_{b}$. The exact frequency will be the one which gives an inductive reactance large enough to cancel out:
$X_{1}+X_{2}=\frac{1}{\omega C 1}+\frac{1}{\omega \mathrm{C} 2}=\frac{1}{\omega}\left[\frac{1}{\mathrm{C}_{1}}+\frac{1}{\mathrm{C} 2}\right]=\frac{1}{2 \pi \mathrm{f}}\left[\frac{1}{\mathrm{C}_{\mathrm{L}}}\right]$
Therefore by varying C1 or C2 we can trim slightly the oscillator frequency.

b. Electrical Equivalent



FIGURE 5. Colpitts Oscillator

The Q of a circuit is often bounced around in comparing different circuits and can be viewed graphically here as the slope of the reactance curve between $f_{a}$ and $f_{b}$. Obviously the steeper the curve the smaller the variation in f necessary to restore the Barkhausen Phase Shift Criterion. In addition a lower $Q$ (more R) means that the reactance curve won't peak as high at $f_{b}$, necessitating a smaller $\mathrm{X} 1+\mathrm{X} 2$. When selecting crystals the user should be aware that the frequency stamped on the cans are for either parallel or series resonance, which, although very close, may matter significantly in the particular application.
An actual MOS circuit implementation of Figure 5 is shown in Figure 6. It consists of a MOS inverter with depletion load and the crystal $\pi$ network just presented. External to the COPS chips are the $R_{f}$ and $R_{g}$ resistors. $R_{f}$ provides bias to the MOS inverter gate $V_{g}=V_{0}$. Since the gate draws no current $R_{f}$ can be very large ( $M \Omega$ ) and should be, since we do not wish it to interact with the crystal network. $\mathrm{R}_{\mathrm{g}}$ increases the output resistance of the inverter and keeps the crystal from being over driven.

TL/DD/5139-8
FIGURE 6. MOS Oscillator


Of course the feedback network doesn't have to have the configuration of Figure 3 and can be anything so long as the Barkhausen Phase Shift Criterion is satisfied. One popular configuration is shown in Figure 7 where the phase shift will be $180^{\circ}$
at $f=\frac{1}{(2 \pi R C \sqrt{6})}$


TL/DD/5139-9 FIGURE 7. R-C Phase Shift Oscillator

REFERENCES

1. Crystal/INS8048 Oscillator, AN-296, March 1982, National Semiconductor
2. Oscillator Characteristics of COPS Microcontrollers, CN-5, Feb. 1981, National Semiconductor
3. Integrated Electronics, Chapter 14, Millman and Halkias 1972
4. Handbook of Electronics Calculations, Chapter 9, Kaufman and Seidman 1979
5. 1982 COPS Microcontroller Databook, National Semiconductor


TL/DD/5139-10

## Implementing an 8-Bit Buffer in COPS ${ }^{\text {TM }}$

Sometimes a COP microcontroller must input and/or output 8 -bit data; for instance, when handling ASCII data. In some applications, the processor must also provide temporary storage for 8 -bit data before it is output. The COP instruction set and RAM structure lend themselves very nicely to providing a 32 digit, 8 -bit buffer for a solution to these applications.
Such a large buffer is possible using a COP440 or a COP444L. The other members of the COP400 family with half as much RAM as these two would provide a 16 digit 8 bit buffer using the techniques described in this example.
Four adjacent RAM registers ( 16 digits each) are required. Referring to Figure 1, registers 4, 5, 6, and 7 are used for the buffer. Each RAM location contains 4 bits, so 2 locations will be used to store a byte of data. But these RAM locations are not adjacent to each other. You will note that the MSD of digit number OA hex is in RAM location (4, A) while the LSD of the same digit is in RAM location ( $6, A$ ).
The 2 RAM locations CHARM and CHARL are used for temporary storage of an 8-bit value.
In addition, 4 RAM locations are used for buffer pointers: those labelled IPM and IPL are the MSD and LSD of the

National Semiconductor Corp. Application Note 329
David Pointer

input pointer, and those labelled OPM and OPL are the MSD and LSD of the output pointer. Each pointer's function is to store an 8 -bit counter whose value ranges from 00 hex thru $1 F$ hex. The input pointer's value is used for storing the temporary storage buffer contents into the digit with the same number. For example, if the input pointer equals 14 hex, then the contents of CHARM would be stored in RAM location $(5,4)$ and the contents of CHARL would be stored in RAM location $(7,4)$. The output pointer's value is used for retrieving a digit from the buffer and putting it in CHARM and CHARL. For instance, if the output pointer equals 05 hex, then the contents of RAM location $(4,5)$ would be transferred to CHARM and the contents of RAM location $(6,5)$ would be transferred to CHARL.
A simple example of one possible application of the buffer is flowcharted in Figure 2. In this example, data is input to CHARM and CHARL, then stored in the buffer. An output device (a printer) is checked to see if it is ready to receive data. If it is, data is brought out of the buffer and put in CHARM and CHARL for output to the printer.
Pages 3 and 4 contain a listing of the subroutines needed to perform the data transfers in the 32-digit, 8-bit buffer.


FIGURE 1. 8-Bit Buffer RAM Map


TL/DD/5181-2
FIGURE 2. Buffer Example Flowchart

COP CROSS ASSEMBLER PAGE: 2
BUFFER

```

```

COP CROSS ASSEMBLER PAGE: 3
BUFFER

| CHARL | 002c |  | CHARM | 002D | CTOM | 008E | INCIP | 009C * |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INCOP | 009D | * | IPL | 002E | IPM | 002F | MTOC | 0080 |

OPL 003E OPM 003F
NO ERROR LINES
42 ROM WORDS USED
COP 444 ASSEMBLY
SOURCE CHECKSUM = C6A5
INPUT FILE 6:RBUFFC. SRC VN: 5

```

\section*{Designing with the NMC9306/COP494 a Versatile Simple to Use E2 PROM}

This application note outlines various methods of interfacing an NMC9306/COP494 with the COPSTM family of microcontrollers and other microprocessors. Figures 1-6 show pin connections involved in such interfaces. Figure 7 shows how parallel data canbe converted into a serial format to beinputted to the NMC9306; as well as how serial data outputted from an NMC9306 can be converted to a parallel-format. The second part of the application note summarizes the key points covering the critical electrical specifications to be kept in mind when using the NMC9306/COP494.
The third part of the application note shows a list of various applications that can use a NMC9306/COP494.

\section*{GENERIC CONSIDERATIONS}

A typical application should meet the following generic criteria:
1. Allow for no more than \(10,000 \mathrm{E} / \mathrm{W}\) cycles for optimum and reliable performance.
2. Allow for any number of read cycles.
3. Allow for an erase or write cycle that operates in the \(10-30 \mathrm{~ms}\) range, and not in the tens or hundreds of ns range as used in writing RAMs. (Read vs write speeds are distinctly different by orders of magnitude in E2PROM, not so in RAMs.)

National Semiconductor Corp. Application Note 338 Masood Alavi
4. No battery back-up required for data-retention, which is fully non-volatile for at least 10 years at room-ambient.

\section*{SYSTEM CONSIDERATIONS}

When the control processor is turned on and off, power supply transitions between ground and operating voltage may cause undesired pulses to occur on data, address and control lines. By using WEEN and WEDS instructions in conjunction with a LO-HI transition on CS, accidental erasing or writing into the memory is prevented.
The duty cycle in conjunction with the maximum frequency translates into having a minimum Hi-time on the SK clock. If the minimum SK clock high time is greater than \(1 \mu \mathrm{~s}\), the duty cycle is not a critical factor as long as the frequency does not exceed the 250 kHz max. On the low side no limit exists on the minimum frequency. This makes it superior to the COP499 CMOS-RAM. The rise and fall times on the SK clock can also be slow enough not to require termination up to reasonable cable-lengths.
Since the device operates off of a simple 5V supply, the signal levels on the inputs are non-critical and may be operated anywhere within the specified input range.


FIGURE 1. NMC9306/COP494 — COP420 Interface


TL/D/5286-2
FIGURE 2. NMC93O6 - Standard \(\mu\) P Interface Via COP Processor


TL/D/5286-3

* SK Is generated on port pins by bit-set and bit-clear operations in software. A symmetrical duty cycle is not critical.
* CS is set in software. To generate \(\mathbf{1 0 - 3 0} \mathbf{~ m s}\) write/erase the timer/counter is used. During write/erase. SK may be turned off.

FIGURE 3. NSC800TM to NMC9306 Interface (also Valid for 8085/8085A and 8156)

(3)
\(\left.\begin{array}{ll}\text { Z80-P10 } & 9306 \\ \text { A0 } & \text { SK } \\ \text { A1 } \\ \text { A2-A7 } & \text { DI/DO }\end{array}\right\} \quad\) CS1-CS6 6 Common to all 9306's (Bank 1)
* Only used if prlority Interrupt dalsy chain is desired
* Identical connection for Port B

FIGURE 4. Z80 — NMC9306 Interface Using Z80-PIO Chip


TL/D/5286-5
* SK and DI are generated by software. It should be noted that at \(2.72 \mu \mathrm{~s} /\) Instruction. The minimum SK period achlevable will be \(10.88 \mu 8\) or 92 kHz , well within the NMC9306 trequency range.
* DO may be brought out on a separate port pin if desired.

FIGURE 5. 48 Series \(\mu \mathbf{P}\) — NMC9306 Interface


Expander outputs


FIGURE 6. 8048 I/O Expansion


TL/D/5286-7
FIGURE 7. Converting Parallel Data Into Serial Input for NMC9306/COP494

\begin{tabular}{|c|c|}
\hline Min & Max \\
\hline \({ }_{\text {t CyCle }} 0\) & 250 kHz \\
\hline DUTY CYCLE 25\% & 75\% \\
\hline \(t_{\text {DIS }} 400\) & ns \\
\hline \(t_{\text {D1H }} 400\) & ns \\
\hline tcss 200 & ns \\
\hline \({ }^{\text {t }} \mathrm{CSH} \mathrm{O}\) & ns \\
\hline tppo & \(2 \mu \mathrm{~s}\) \\
\hline tpD1 & \(2 \mu \mathrm{~s}\) \\
\hline
\end{tabular}

TL/D/5286-8

FIGURE 8. NMC9306/COP494 Timing

\section*{THE NMC9306/COP494}

Extremely simple to interface with any \(\mu \mathrm{P}\) or hardware logic. The device has six pins for the following functions:
\begin{tabular}{lll} 
Pin 1 & CS* & HI enabled \\
Pin 2 & SK & \begin{tabular}{l} 
Clock input for data bit \\
maneuvering
\end{tabular}
\end{tabular}
Pin 3 DI For instruction or data
Pin 4 DO** For data read TRI-STATE@ otherwise
\begin{tabular}{lll} 
Pin 5 & GND & \\
Pin 8 & VCC & For 5V power \\
Pins 6-7 & No Connect & No termination required
\end{tabular}
* Following an E/W instruction feed, CS is also toggled low for 10 ms (typical) for an E/W operation. This internally turns the VPP generator on (HI-LO on CS) and off (LO-HI on CS).
** DI and DO can be on a common line since DO is TRISTATED when unselected DO is only on in the read mode.

\section*{USING THE NMC9306/COP494}

\section*{The following points are worth noting:}
1. SK clock frequency should be in the \(0-250 \mathrm{kHz}\) range. With most \(\mu \mathrm{Ps}\) in the \(1-11 \mathrm{MHz}\) range this is easily achieved when implemented in software by bit-set and bit-clear instructions, which take 4 instructions to execute a clock or a frequency in the 100 kHz range for standard \(\mu \mathrm{P}\) speeds. Symmetrical duty cycle is irrelevant if SK HI time is \(\geq 2 \mu \mathrm{~s}\).
2. CS low period following an E/W instruction must not exceed the 30 ms max. It should best be set at typical or minimum spec of 10 ms . This is easily done by timer or a software connect. The reason is that it minimizes the 'on time' for the high VPP internal voltage, and so maximizes endurance. SK-clock during this period may be turned off if desired.
3. All E/W instructions must be preceded by EWEN and should be followed by an EWDS. This is to secure the stored data and avoid inadvertent erase or write.
4. A continuously 'on' SK clock does not hurt the stored data. Proper sequencing of instructions and data on DI is essential to proper operation.
5. Stored data is fully non-volatile for up to ten years independent of \(\mathrm{V}_{\mathrm{CC}}\), which may be on or off. For all practical purposes any number of read cycles have no adverse effects on data retention.
6. Up to 10,000 E/W cycles/register are possible. Under typical conditions, this number may actually approach 1 million. For applications requiring a large number of cycles, redundant use of internal registers beyond 10,000 cycles is recommended.
7. Data shows a fairly constant E/W Programming behavior over temperature. In this sense E2PROMs supersede
- EPROMs which are restricted to room temperature programming.
8. As shown in the timing diagrams, the start bit on DI must be set by a ZERO - ONE transition following a CS enable (ZERO - ONE), when executing any instruction. ONE CS enable transition can only execute ONE instruction.
9. In the read mode, following an instruction and data train, the DI can be a don't care, while the data is being outputted i.e., for next 17 bits or clocks. The same is true for other instructions after the instruction and data has been fed in.
10. The data-out train starts with a dummy bit 0 and is terminated by chip deselect. Any extra SK cycle after 16 bits is not essential. If CS is held on after all 16 of the data bits have been outputted, the DO will output the state of DI till another CS LO-HI transition starts a new instruction cycle.
11. When a common line is used for DI and DO, a probable overlap occurs between the last bit on DI and start bit on DO.
12. After a read cycle, the CS must be brought low for 1 SK clock cycle before another instruction cycle can start.
INSTRUCTION SET
\begin{tabular}{llll}
\hline Commands & \multicolumn{2}{c}{ Opcode } & \multicolumn{2}{c}{ Comments } \\
\hline READ & 10000A3A2A1AO & Read Register 0-15 \\
WRITE & 11000A3A2A1AO & Write Register 0-15 \\
ERASE & 10100A3A2A1A0 & Erase Register 0-15 \\
EWEN & 111000 & 0 & 0 \\
1 & Write/Erase Enable \\
ENDS & 111000 & 0 & 1 \\
0 & & Write/Erase Disable \\
*** WRAL & 111000 & 1 & 0 \\
\hline
\end{tabular}

All commands, data in, and data out are shifted in/out on rising edge of SK clock.
Write/erase is then done by pulsing CS low for 10 ms .
All instructions are initiated by a LO-HI transition on CS followed by a LO-HI transition on DI.
READ - After read command is shifted in DI becomes don't care and data can be read out on data out, starting with dummy bit zero.
WRITE - Write command shifted in followed by data in ( 16 bits) then CS pulsed low for 10 ms minimum.
ERASE
ERASE ALL - Command shifted in followed by
WRITE ALL - Pulsing CS low for 10 ms .
WRITE
ENABLE/DISABLE - Command shifted in.
*** (This Instruction is not speced on Data sheet.)

The following is a list of various systems that could use a
NMC9306/COP494
A. Airline terminal

Alarm system
Analog switch network
Auto calibration system
Automobile odometer
Auto engine control
Avionics fire control
B. Bathroom scale

Blood analyzer
Bus interface
C. Cable T.V. tuner

CAD graphics
Calibration device
Calculator-user programmable
Camera system
Code identifier
Communications controller
Computer terminal
Control panel
Crystal oscillator
D. Data acquisition system

Data terminal
E. Electronic circuit breaker

Electronic DIP switch
Electronic potentiometer
Emissions analyzer
Encryption system
Energy management system
F. Flow computer

Frequency synthesizer
Fuel computer
G. Gas analyzer

Gasoline pump
H. Home energy management

Hotel lock
I. Industrial control

Instrumentation
J. Joulemeter
K. Keyboard -softkey
L. Laser machine tool
M. Machine control

Machine process control
Medical imaging
Memory bank selection
Message center control Mobile telephone

Modem
Motion picture projector
N. Navigation receiver

Network system
Number comparison
O. Oilfield equipment
P. PABX

Patient monitoring
Plasma display driver
Postal scale
Process control
Programmable communications
Protocol converter
Q. Quiescent current meter
R. Radio tuner

Radar dectector
Refinery controller
Repeater
Repertory dialer
S. Secure communications system

Self diagnostic test equipment
Sona-Bouy
Spectral scanner
Spectrum analyzer
T. Telecommunications switching system

Teleconferencing system
Telephone dialing system
T.V. tuner

Terminal
Test equipment
Test system
TouchTone dialers
Traffic signal controller
U. Ultrasound diagnostics Utility telemetering
V. Video games

Video tape system
Voice/data phone switch
W. Winchester disk controller
X. X-ray machine Xenon lamp system
Y. YAG-laser controlier
Z. Zone/perimeter alarm system

\section*{A Study of the Crystal Oscillator for CMOS-COPS \({ }^{\text {™ }}\)}

\section*{INTRODUCTION}

The most important characteristic of CMOS-COPS is its low power consumption. This low power feature does not exist in TTL and NMOS systems which require the selection of low power IC's and external components to reduce power consumption.
The optimization of external components helps decrease the power consumption of CMOS-COPS based systems even more.

A major contributor to power consumption is the crystal oscillator circuitry.
Table I presents experimentally observed data which compares the current drain of a crystal oscillator vs. an external squarewave clock source.
The main purpose of this application note is to provide experimentally observed phenomena and discuss the selection of suitable oscillator circuits that cover the frequency range of the CMOS-COPS.
Table I clearly shows that an unoptimized crystal oscillator draws more current than an external squarewave clock. An RC oscillator draws even more current because of the slow rising signal at the CKI input.
Although there are few components involved in the design of the oscillator, several effects must be considered. If the requirement is only for a circuit at a standard frequency which starts up reliably regardless of precise frequency stability, power dissipation and etc., then the user could directly consult the data book and select a suitable circuit with proper components. If power consumption is a major requirement, then reading this application note might be helpful.

\section*{WHICH IS THE BEST OSCILLATOR CIRCUIT?}

The Pierce Oscillator has many desirable characteristics. It provides a large output signal and drives the crystal at a low power level. The low power level leads to low power dissipation, especially at higher frequencies. The circuit has good short-term stability, good waveforms at the crystal, a frequency which is independent of power supply and temperature changes, low cost and usable at any frequency. As compared with other oscillator circuits, this circuit is not disturbed very much by connecting a scope probe at any point in the circuit, because it is a stable circuit and has low impedance. This makes it easier to monitor the circuit without any major disturbance. The Pierce oscillator has one disadvantage. The amplifier used in the circuit must have high gain to compensate for high gain losses in the circuitry surrounding the crystal.

National Semiconductor Corp.
Application Note 400
Abdul Aleaf

TABLE I
A. Crystal oscillator vs. external squarewave COP410C change in current consumption as a function of frequency and voltage, chip held in reset, CKI is \(\div 4\).
\(\mathrm{I}=\) total power supply current drain (at \(\mathrm{V}_{\mathrm{CC}}\) ).
Crystal
\begin{tabular}{|c|c|c|c|}
\hline \(\mathbf{V}_{\mathbf{C C}}\) & \(\mathbf{f}_{\mathbf{c k l}}\) & \begin{tabular}{c} 
Inst. cyc. \\
time
\end{tabular} & \(\mathbf{I} \mu \mathbf{A}\) \\
\hline 2.4 V & 32 kHz & \(125 \mu \mathrm{~s}\) & 8.5 \\
\hline 5.0 V & 32 kHz & \(125 \mu \mathrm{~s}\) & 83 \\
\hline 2.4 V & 1 MHz & \(4 \mu \mathrm{~s}\) & 199 \\
\hline 5.0 V & 1 MHz & \(4 \mu \mathrm{~s}\) & 360 \\
\hline
\end{tabular}

External Squarewave
\begin{tabular}{|c|c|c|c|}
\hline \(\mathbf{V}_{\mathbf{C C}}\) & \(\mathbf{f}_{\text {ckI }}\) & \begin{tabular}{c} 
Inst. cyc. \\
time
\end{tabular} & \(\mathbf{I}\) \\
\hline 2.4 V & 32 kHz & \(125 \mu \mathrm{~s}\) & \(4.4 \mu \mathrm{~A}\) \\
\hline 5.0 V & 32 kHz & \(125 \mu \mathrm{~s}\) & \(10 \mu \mathrm{~A}\) \\
\hline 2.4 V & 1 MHz & \(4 \mu \mathrm{~s}\) & \(127 \mu \mathrm{~A}\) \\
\hline 5.0 V & 1 MHz & \(4 \mu \mathrm{~s}\) & \(283 \mu \mathrm{~A}\) \\
\hline
\end{tabular}

\section*{WHAT IS A PIERCE OSCILLATOR?}

The Pierce is a series resonant circuit, and its basic configuration is shown below.


TL/DD/8439-1
FIGURE 1
For oscillation to occur, the Barkhausen criteria must be met: (1) The loop gain must be greater than one. (2) The phase shift around the loop must be \(360^{\circ}\).

Ideally, the inverting amplifier provides \(180^{\circ}\), the \(R_{1} C_{1}\) integration network provides a \(90^{\circ}\) phase lag, and the crystal's impedance which is a pure resistance at series resonance together with \(\mathrm{C}_{2}\) acts as a second integration network which provides another \(90^{\circ}\) phase lag. The time constants of the two RC phase shifting networks should be made as big as possible. This makes their phase shifts independent of any changes in resistance or capacitance values. However, big RC values introduce large gain losses and the selected amplifier should provide sufficient gain to satisfy gain requirement. CMOS inverters or discrete transistors can be used as amplifiers. An experimental evaluation of crystal oscillators using either type of amplifier is given within this report.

\section*{CRYSTAL OSCILLATORS USING CMOS-IC}

The use of CMOS-IC's in crystal oscillators is quite popular. However, they are not perfect and could cause problems. The input characteristics of such IC's are good, but they are limited in their output drive capability.
The other disadvantage is the longer time delay in a CMOSinverter as compared to a discrete transistor. The longer this time delay the more power will be dissipated. This time delay is also different among different manufacturers.
As a characteristic of most CMOS-IC's the frequency sensitivity to power supply voltage changes is high. As a group, IC's do not perform very well when compared with discrete transistor circuits.
But let us not be discouraged. Low component count which leads to low cost is one good feature of IC oscillators.
As a rule, IC's work best at the low end of their frequency range and poorest at the high end.
Several types of crystal oscillators using CMOS-IC's have been found to work satisfactorily in some applications.

\section*{CMOS—TWO INVERTER OSCILLATOR}

The two inverter circuit shown in Figure 2 is a popular one. The circuit is series resonant and uses two cascaded inverters for an amplifier.


FIGURE 2
Each inverter has a DC biasing resistor which biases the inverter halfway between the logic " 1 " and " 0 " states. This will help the inverters to amplify when the power is applied and the crystal will start oscillation.
The 74C family works better as compared with other CMOSIC's. Will oscillate at a higher frequency and is less sensitive to temperature changes. The CMOS-COPS data sheet states that a crystal oscillator will typically draw \(100 \mu \mathrm{~A}\) more than an external clock source. However, the crystal oscillator described above will draw approximately as much
current as an external squarewave clock. The experimental data presented below shows the comparison:

Chip held in Reset, \(\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V}\)
\(f=455 \mathrm{kHz}\), COP 444 C, CKI is \(\div 8\)
Instruction cycle time \(=17.5 \mu \mathrm{~s}\)
I = total power supply ( \(V_{C C}\) ) current drain
\begin{tabular}{|c|c|}
\hline Oscillator Type & I (current drain) \\
\hline \begin{tabular}{c} 
Crystal Osc. \\
(data sheet)
\end{tabular} & \(950 \mu \mathrm{~A}\) \\
\hline \begin{tabular}{c} 
Crystal Osc. \\
(two inverter)
\end{tabular} & \(810 \mu \mathrm{~A}\) \\
\hline Ext. Clock & \(790 \mu \mathrm{~A}\) \\
\hline
\end{tabular}

\section*{PIERCE IC OSCILLATOR}

Figure 3 shows a Pierce oscillator using CMOS inverter as an amplifier.


TL/DD/8439-3
FIGURE 3
The gain of CMOS inverter is low, so the resistor \(R_{1}\) should be made small. This reduces gain losses. The output resistance of the inverter (Ro) can be the integrating resistor for the RoC \({ }_{\text {I }}\) phase lag network.
Omitting \(\mathrm{R}_{1}\) or with a small value of \(\mathrm{R}_{1}\), the crystal will be driven at a much higher voltage level. This will increase power dissipation.
For lower frequencies (i.e., 32 kHz ), \(\mathrm{R}_{1}\) must be large enough so that the inverter won't overdrive the crystal. Also, if \(R_{1}\) is too large we won't get an adequate signal back at the inverter's input to maintain oscillation. With large values of \(R_{1}\) the inverter will remain in its linear region longer and will cause more power dissipation. Typically for \(32 \mathrm{kHz}, \mathrm{R}_{1}\) should be constrained by the relation.
\[
\frac{1}{2 \pi \mathrm{R}_{1} \mathrm{C}_{1}} \ll 32 \mathrm{kHz}
\]

At higher frequencies, selection of \(\mathrm{R}_{1}\) is again critical. In order to drive a heavy load at high frequency, the amplifier output impedance must be low. In order to isolate the oscillator output from \(\mathrm{C}_{1}\) so it can drive the following logic stages, then \(\mathrm{R}_{1}\) should be large. But again, \(\mathrm{R}_{1}\) must not be too large, otherwise it will reduce the loop gain.

The value of \(R_{1}\) is chosen to be roughly equal to the capacitive reactance of \(\mathrm{C}_{1}\) at the frequency of operation, or the value of load impedance \(\mathrm{Z}_{\mathrm{L}}\).
\[
\text { Where } \begin{aligned}
Z_{L} & =\frac{X_{C 1}^{2}}{R_{L}} \\
R_{L} & =R_{S}=\text { series resistance of crystal }
\end{aligned}
\]

The small values of \(\mathrm{C}_{1}\) and \(\mathrm{C}_{2}\) will help minimize the gain reduction they introduce.
\[
\text { typically: } \begin{aligned}
\mathrm{C}_{1} & =\mathrm{C}_{2}=220 \mathrm{pF} \text { at } 1 \mathrm{MHz} \\
\mathrm{C}_{1} & =\mathrm{C}_{2}=330 \mathrm{pF} \text { at } 2 \mathrm{MHz}
\end{aligned}
\]

\section*{DISCRETE TRANSISTOR OSCILLATOR}

As mentioned earlier, a discrete transistor circuit performs better than an IC circuit. The reason for this is that in a discrete transistor circuit it is easier to control the crystal's source and load resistances, the gain and signal amplitude. A discrete transistor circuit has shorter time delay, because it uses one or two transistors. This time delay should always be minimized, since it causes more power dissipation and shifts frequency with temperature changes. Figure 4 shows a basic Pierce oscillator using a transistor as an amplifier.


FIGURE 4
The basic phase shift network consists of \(\mathrm{C}_{\mathrm{A}_{1}}, \mathrm{C}_{\mathrm{B}_{2}}\) and the crystal which looks inductive and is series resonant with \(\mathrm{C}_{\mathrm{A}_{1}}\) and \(\mathrm{C}_{\mathrm{B}_{1}}\). The phase shift through the transistor is \(180^{\circ}\) and the total phase shift around the loop is \(360^{\circ}\). The condition of a unity loop gain must also be satisfied.
\[
\begin{aligned}
& \frac{V_{A}}{V_{B}}=-\left(\frac{C_{B}}{C_{A}}\right) \\
& \frac{V_{A}}{V_{B}}=-\left(\frac{x_{C A}}{x_{C B}}\right)
\end{aligned}
\]

For oscillation to occur, the transistor gain must satisfy the relation
\[
G\left(\frac{V_{A}}{V_{B}}\right) \geq, 1
\]
where \(G=-g_{f e} Z_{L}\)
\(\mathrm{g}_{\mathrm{fe}}\) is the transconductance of the transistor
\(Z_{L}\) is the load seen by the collector
\[
Z_{L}=\frac{X_{B}{ }^{2}}{R e}, \quad X_{B}=-\frac{1}{W C_{B}}
\]

Re is the crystal's effective series resistance.
The crystal's drive level
\[
P_{d}=\frac{V_{B} 2_{R e}}{X_{B} 2}
\]

This drive level should not exceed the manufacturer's spec. Certain biasing conditions might cause collector saturation. Collector saturation increases oscillator's dependence on the supply voltage and should be avoided.
The circuit of Figure 5 has been tested and has a very good performance.


FIGURE 5
This circuit will oscillate over a wide range of frequencies 2-20 MHz.


At Saturation \(\left(V_{C E}=0\right)\)
\(I_{C(S A T)}=\frac{5}{1.2}=4.2 \mathrm{~mA}\)


TL/DD/8439-6
FIGURE 6

Having \(15.6 \mu \mathrm{~A}\) of base current, for saturation to occur
\[
\mathrm{h}_{\mathrm{FE}}=\frac{4.2 \mathrm{~mA}}{15.6 \mu \mathrm{~A}}=269
\]

The DC beta for 3904 at 1 mA is 70 to 210 , so no problem with saturation, even at lower supply voltages.
The current consumption (power supply \(V_{C C}\) current drain) of COP444C using the above oscillation circuit is around \(267 \mu \mathrm{~A}\).
The circuit of Figure 6 is another configuration of discrete transistor oscillator.
The performance of above circuit is also good. The only drawback is that it does not provide larger output signal.

\section*{CONCLUSION}

As discussed within this report, a discrete transistor circuit gives better performance than an IC circuit. However, oscillators using discrete transistors are more expensive than those using IC's when assembly labor costs are included. So, the selection of either circuit is a trade-off between better performance and cost.
The data and circuits presented here are intended to be used only as a guide for the designer. The networks described are generally simple and inexpensive and have all been observed to be functional. They only provide greater flexibility in the oscillator selection for CMOS-COPS systems.

\section*{Selecting Input/Output Options On COPS \({ }^{\text {TM }}\) Microcontrollers}

\section*{INTRODUCTION}

There are a variety of user selectable input and output options available on COPS when the ROM is masked. These options are available to help the user tailor the I/O characteristics of the Microcontroller to the application. This application note is intended to provide the user a guide to the options: What are they? When and how to use which ones? The paper is generally written without reference to a specific device except when examples are given. It must be remembered that any given generic COPS Microcontroller has a subset of all the possible options available and that a given pin might not have all possible options. A reference to the device data sheet will determine which options are available for a specific device and a specific pin of that device.

\section*{INPUT/OUTPUT OPTIONS}

Table I summarizes the I/O capability of NMOS-COPS, in general. However, some of the options have different configuration in CMOS-COPS. Data sheets provide information on the I/O options associated with the CMOS-COPS.

\section*{I. OUTPUTS}

The following discussion provides detailed information on the capabilities of the mask-programmable output options available on COPS.

\section*{A. STANDARD OUTPUT}

This option is a simple, straightforward, logic compatible output used for simple logic interface. It is available on SO, SK and all D and G outputs, It is recommended to be used as a default option for all but SO, SK outputs.


TL/DD/8440-1
FIGURE 1. Standard Output
Figure 1 shows the standard output configuration. The enhancement mode device to ground is good at sinking current (sinks 1-2 mA ) and is compatible with the

sinking requirement of 1 TTL load ( 1.6 mA at 0.4 V ). It will meet the "low" voltage requirement of CMOS logic. All output options use this device (device \#1) for current sinking. On the other hand, the relatively high impedance depletion-mode device (device \#2) to \(V_{C C}\) provides low current sourcing capability ( \(100 \mu \mathrm{~A}\) at 2.4 V ). This pullup is sufficient to provide the source current for a TTL high level and will go to \(V_{C C}\) to meet the "high" voltage requirements of CMOS logic. An external resistor to \(V_{C C}\) may be required to interface to other external devices requiring higher sourcing capability.
An interface example to a common emitter NPN transistor is given below:


FIGURE 2
\(R_{B}\) is needed to limit transistor's base current if \(I_{\text {source }}>I_{B_{(\text {max })}}\).
\(R_{p}\) helps generate base drive if the \(I_{\text {source }}\) is not sufficient. The disadvantage of \(R_{p}\) is the introduction of more power dissipation. The temperature effects on the reverse saturation current \(I_{C B O}\) causes \(I_{C}\) to shift. \(I_{\text {CBO }}\) approximately doubles for every \(10^{\circ} \mathrm{C}\) temperature rise. The effect of changes in Icbo reduces off state margin and increases power dissipation in the off state.
However, in a typical device, the current supplied by \(R_{p}\) will swamp out any effects on ICBO. Another parameter found to be decreasing linearly with temperature is \(V_{B E}\) :
\[
\Delta V_{B E}=V_{B E_{2}}-V_{B E_{1}}=-k\left(T_{2}-T_{1}\right)
\]
where \(\mathrm{k} \approx 2 \mathrm{mV} /{ }^{\circ} \mathrm{C}, \mathrm{T}\) in \({ }^{\circ} \mathrm{C}\).
Now let's consider a practical example:
LOW SOURCE CURRENT OUTPUT:
Standard output, COP420, device \#2.
The selected transistor is 2N3904.
DESIGN CONSIDERATIONS:
a. \(Q\) is in saturation during \(O N\)-state.
b. Q's collector current \(\mathrm{l}_{\mathrm{C}}=100 \mathrm{~mA}\)

TABLE 1
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline & Default & Standard & Push-Pull & High Sink & Very High Sink & LED & Hi-Current LED & TRI-STATE® Push-Pull & Hi Current TRI-STATE Push-Pull & Open Drain \\
\hline SO & Push-Pull & Logic Compatible; Non MICROWIRETM & MICROWIRE Higher Drive, Faster X'sition & & & & & & & External Pull Up \\
\hline SK & Push-Pull & Logic Compatible; Non MICROWIRE & \begin{tabular}{l}
MICROWIRE \\
Higher Drive \\
Faster \\
Transition
\end{tabular} & & & & & & & External Pull Up \\
\hline D & Standard & Logic Compatible & & \[
\begin{aligned}
& \text { L Parts Only } \\
& 15 \mathrm{~mA}
\end{aligned}
\] & \[
\begin{aligned}
& \text { L. Parts Only } \\
& 30 \mathrm{~mA}
\end{aligned}
\] & & & & & \begin{tabular}{l}
External \\
Pull Up, \\
Standard, Hi \\
Sink or V.H.S. \\
Pull Down
\end{tabular} \\
\hline G & Standard & Logic Compatible; Inputs & & L Parts Only 15 mA & \[
\begin{aligned}
& \text { L Parts Only } \\
& 30 \mathrm{~mA}
\end{aligned}
\] & & & & & \begin{tabular}{l}
External \\
Pull-Up, \\
Standard, Hi \\
Sink or V.H.S. \\
Pull Down
\end{tabular} \\
\hline L & Standard & Logic Compatible; Inputs, TRI-LEVEL & & & & Hi Source 1.5 mA TRI-LEVEL & L Parts Only Higher Source 3 mA TRI-LEVEL & \begin{tabular}{l}
MICROBUSTM \\
Meets TRI-STATE Spec. \\
TRI-LEVEL
\end{tabular} & \begin{tabular}{l}
L Parts Only Meets TRI-STATE Spec. \\
TRI-LEVEL
\end{tabular} & \begin{tabular}{l}
External \\
Pull Up \\
TRI-LEVEL
\end{tabular} \\
\hline H & Standard & Logic Compatible Inputs & & & & & & & & External Pull Up \\
\hline R & Standard & Logic Compatible; Inputs, TRI-LEVEL & Higher Drive Faster Transition TRI-LEVEL & & & & & Meets TRI-STATE Spec TRI-LEVEL & & \begin{tabular}{l}
External \\
Pull Up \\
TRI-LEVEL
\end{tabular} \\
\hline
\end{tabular}
c. Assuming a "forced" of 10 for \(Q\). This is a standard value for \(\beta\) to insure saturation.
For an \(\mathrm{I}_{\mathrm{C}}=100 \mathrm{~mA}, \beta=10\), we have \(\mathrm{I}_{\mathrm{B}} \geq 10 \mathrm{~mA}\). The low current standard output certainly cannot provide \(I_{B} \geq 10 \mathrm{~mA}\). Therefore, a pullup resistor \(\left(R_{p}\right)\) is required.
d. Now we need to select the minimum allowed value for \(R_{p}\). The sinking ability of COPS output will determine \(R_{p}\). We must sink the pullup current to a \(\mathrm{V}_{\text {OUT }}<\mathrm{V}_{\mathrm{BE}}\) in order to hold Q off. Also, note that
\[
\frac{\Delta V_{\mathrm{BE}}}{\Delta \mathrm{~T}}=-2 \mathrm{mV} /{ }^{\circ} \mathrm{C}
\]
e. Assuming the worst case is at \(\mathrm{V}_{\mathrm{CC}}\) (max) and Hightemperature (let \(\Delta T=20^{\circ} \mathrm{C} \Rightarrow \Delta V_{B E}=-40 \mathrm{mV}\) ). From \(\mathrm{V}_{\mathrm{BE}(\mathrm{ON})}\) Vs. IC curve, Figure 3 :


TL/DD/8440-3
FIGURE 3. 2N3904 I/V
at \(100 \mathrm{~mA}, 25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{BE}} \cong 0.85 \mathrm{~V}\).
So, our \(V_{B E}\left(45^{\circ} \mathrm{C}\right)=0.85-0.04 \cong 0.81 \mathrm{~V}\).
There is not margin here for process \(V_{B E}\) variations so we can allow 200 mV of slope,
\[
\mathrm{V}_{\mathrm{BE}}=0.61 \mathrm{~V} \text { (worst case) }
\]
f. Having \(V_{B E}=0.61 \mathrm{~V}\), we go to COPS sink graph and draw a vertical line at \(\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\mathrm{BE}}=0.61 \mathrm{~V}\). Figure 4 below:

Output Sink Current


FIGURE 4

This will tell us, at \(V_{\text {out }}=V_{B E}\), how much current can be sinked to keep Q "OFF". The intersection of \(V_{C C}=6.3(\mathrm{MIN})\) and \(V_{B E}=0.61 \mathrm{~V}\) gives us \(I_{\text {sink }}=4 \mathrm{~mA}\).
g. Now calculate \(\mathrm{R}_{\mathrm{p}}\).
\(R_{p} \geq \frac{6.3-0.61}{4} k \geq 1.42 \mathrm{k}\)
the actual standard \(R_{p}( \pm 10 \%)=\frac{1.42}{0.9}\)
\[
=1.6 \mathrm{k} \pm 10 \%
\]
\(h\). Using the value of \(R_{p}\), let's calculate the current through \(R_{p}\) at \(V_{C C}=4.5 \mathrm{~V}(\mathrm{MIN})\).
\(\mathrm{I}_{\mathrm{R}_{\mathrm{P}}}=\frac{4.5-0.61}{1.42} \mathrm{~mA}=2.74 \mathrm{~mA}\)
Which is less than sink ability of device ( 3 mA from Figure 4) at \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {out }}=0.61 \mathrm{~V}\).
i. Now calculate the available source current. Here we use \(V_{B E(\max )}\) which is the worst case, and low temperature.
Let \(T\) (ambient) \(=10^{\circ} \mathrm{C}\).
From \(\mathrm{V}_{\mathrm{BE}}\) vs. \(\mathrm{I}_{\mathrm{C}}\) curve, Figure 3:
\(V_{B E} \cong 0.83 \mathrm{~V}\) at \(25^{\circ} \mathrm{C}\)
\(V_{B E} \cong 0.83+2 \mathrm{mv} /^{\circ} \mathrm{C} \times 15=0.86 \mathrm{~V}\) at \(10^{\circ} \mathrm{C}\).
Using this value of \(V_{B E}\), we go to COP420 Standard Output source current curve (Figure 5), and draw a vertical line at \(\mathrm{V}_{\mathrm{BE}}=0.86 \mathrm{~V}\). The intersection of this line and \(V_{C C}=4.5(\mathrm{MIN})\) gives an \(I_{\text {source }}=325 \mu \mathrm{~A}\).


TL/DD/8440-5
FIGURE 5
This is low but typical of N-channel low current standard output.
Contribution of \(R_{p}\)
\(I_{R_{P}}=\frac{4.5-0.86}{\underbrace{(1.6)(1.1)}_{R_{p(\max )}}}=2.07 \mathrm{~mA}\)
\(I_{B}(\mathrm{~min}) \cong 2.07+0.325=2.3 \mathrm{~mA}\)

This is our worst case base drive, but we needed 10 mA .
What can we do to get the base drive we need?
1. We can use above design and allow \(Q\) to come out of saturation. The disadvantage is that Q's power dissipation increases.
2. Or use a Darlington configuration (Process 05). In such a configuration only first stage of Darlington can be saturated (not output stage). This will introduce a slightly higher power dissipation. Note that for a process 05 transistor, the forced \(\beta\) is 1000 .
3. Use a high source type output such as TRISTATE output. If we draw a vertical line at \(V_{B E}=0.86\), we get a source current of \(\simeq 6 \mathrm{~mA}\) at \(V_{C C}=4.5(\mathrm{MIN})\) Figure 6, which gives us a worst case
\[
\mathrm{I}_{\mathrm{B}(\mathrm{~min})}=8.07 \mathrm{~mA} .
\]

\section*{TRI-STATE Output} Source Current


TL/DD/8440-6
FIGURE 6
CAUTIONI On TRI-STATE graph the intersection of \(V_{\text {out }}=B_{B E}=0.86 \mathrm{~V}\) and \(\mathrm{V}_{\mathrm{CC}}=6.3 \mathrm{~V}(\mathrm{MAX})\) curve (Figure 6) would result in an \(\mathrm{I}_{\mathrm{B}(\operatorname{Max})}=50-60 \mathrm{~mA}\), which is way too much to handle. In this case there is a need for a series current limiting \(R_{B}\) to kill some of the worst case \(\mathrm{I}_{\mathrm{B}(\max )}\).
4. There is a high current Standard-L option on some COPS (i.e., COP4XL, L-port) which provides sufficient source current.
5. N -channel output can generally sink better than source. PNP transistor can be used instead of NPN. The same analysis applies and in general will show better overdirve capabilities.
As shown in Figure 7, the \(D_{0}\) output which has a standard output option, is driving the base of the PNP transistor. Assuming \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}\) (for COP402), \(\mathrm{V}_{\mathrm{BE}}=1.0 \mathrm{~V}\), and a worst case base drive requirement of 3.0 mA . We see that we must supply \(200 \mu \mathrm{~A}\) to the base-emitter resistor to turn the transistor on:
\[
1.0 \mathrm{~V} / 5.1 \mathrm{k}=200 \mu \mathrm{~A}
\]


FIGURE 7. PNP Drive
From the output sink current curve on the COP402 data sheet, we find that, at 1.0 V the D-line can sink 3.2 mA . To calculate the value of the current limiting resistor,
\[
R=\left(V_{C C}-V_{B E}-V_{D O}\right) / I
\]

When \(V_{C C}=6.3 \mathrm{~V}\), the D0 output can sink more than enough current at 0.3 V , and if the \(\mathrm{V}_{\mathrm{BE}}=0.7 \mathrm{~V}\), we can calculate the maximum \(D_{0}\) output current:
\[
\begin{aligned}
I & =\left(V_{C C}-V_{B E}-V_{D}\right) / R \\
& =(6.3-0.7-0.3) / 780=6.3 \mathrm{~mA} .
\end{aligned}
\]

\section*{Using the Standard Output Option for}

\section*{Bidirectional I/O (G-port)}

The standard output is good at sinking current, but rather weak at sourcing it. Therefore, by using the Standard Drive configuration and outputting 1's to the port, an external source may easily overdrive the port drivers with the added bonus of a built-in pullup. While the depletion-mode device provides sufficient current for a TTL high level, yet can be pulled low by an external source, thus allowing the same pin to be used as an input and output. Data written to the ports is statically latched and remains unchanged until rewritten. As inputs the lines are non-latching (Figure 8).


TL/DD/8440-8
FIGURE 8. G Port Characteristics


TL/DD/8440-9
FIGURE 9
When writing a " 0 " to the port, the enhancement-mode device to ground overcomes the high pullup and provides TTL current sinking capability. While writing a " 1 " the depletionmode device behaves as internal pullup maintaining the " 1 " level indefinitely. In this situation, an input device capable of overriding the small amount of current supplied by the pullup device can be read. This feature provides maximum user flexibility in selecting input/output lines with minimum external components.
In CMOS-COPS the low current push-pull output has even much weaker source current capability and this make it easier to be overriden.

\section*{Referring to Figure 9.}

Note that \(\mathrm{l}_{\mathrm{OL}}>\mathrm{I}_{\mathrm{OH}}\), otherwise transistors or buffers must be used.
For COP424C/444C, standard push-pull
\[
\begin{aligned}
& @ V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{\text {out }}=0 \mathrm{~V}, \mathrm{IOH}_{(\mathrm{min})}=30 \mu \mathrm{~A} \\
& \mathrm{l}_{\mathrm{OH}(\text { max })}=330 \mu \mathrm{~A} \\
& @ V_{C C}=2.4 \mathrm{~V}, \mathrm{~V}_{\text {out }}=0 \mathrm{~V}, \mathrm{IOH}_{\mathrm{Omin})}=6 \mu \mathrm{~A} \\
& \mathrm{l}_{\mathrm{OH}(\text { max })}=80 \mu \mathrm{~A}
\end{aligned}
\]

While in NMOS (COP420L), Standard output:
\[
\begin{array}{r}
@ V_{C C}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}(\text { min })}=30 \mu \mathrm{~A} \\
\mathrm{I}_{\mathrm{OH}(\text { max })}=250 \mu \mathrm{~A} \\
@ \mathrm{~V}_{\mathrm{CC}}=6.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}(\text { min })}=75 \mu \mathrm{~A} \\
\mathrm{I}_{\mathrm{OH}(\text { max })}=480 \mu \mathrm{~A}
\end{array}
\]

As we see, both in CMOS and NMOS it is easier to override \(\mathrm{l}_{\mathrm{OH}}\). Note that the standard output option is available with standard, high, or very high sink current capability ("L"' parts only). The pulldown device is bigger for the high/very high current standard output. The sourcing current is the same. These three choices provide some control over current capability.

\section*{B. OPEN-DRAIN OUTPUT}

This option uses the same enhancement-mode device to ground as the standard output with the same current sinking capability. It does not contain a load device to \(\mathrm{V}_{\mathrm{CC}}\), allowing external pullup as required by the user's application. The sinking ability of device \# 1 determines the minimum allowed external pullup. The analysis discussed earlier for Standard Output options equally applies here. Available on SO, SK, and all D, G, and L outputs.


FIGURE 10. Open-Drain Output
The open-drain option makes the ports \(G\) and \(L\) very easy to drive when they are used as inputs. This option is commonly used for high noise margin inputs, unusual logic level inputs as from a diode isolated keyboard, analog channel expansion, and direct capacitive touchpanel interface. Available with standard, high or very high sink capability ("L" parts only).

\section*{C. PUSH-PULL OUTPUT}

The push-pull output differs from the standard output configuration in having an enhancement-mode device in parallel with the depletion-load device to \(\mathrm{V}_{\mathrm{CC}}\), providing greater current sourcing capability (better drive) and faster rise and fall times when driving capacitive loads.


FIGURE 11. Push-Pull Output
If a push-pull output is interfaced to an external transistor, a current-limiting resistor must be placed in series with the base of the transistor to avoid excessive source current flow out of the push-pull output. This option is generally for MICROWIRE Serial Data exchange.

It is available on SO, SK only and is recommended to be used as a default option for these outputs. A few points must be kept in mind when using SO, SK for MICROWIRE interface.
The data sheet specifies the propagation delay for a certain test condition (i.e., \(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=0.4 \mathrm{~V}\), Loading \(=50 \mathrm{pF}\), etc.).
In practice, actual delay varies according to actual input capacitive loading (typical \(7-10 \mathrm{pF}\) per IC input), total wire capacitance and PCB stray capacitance connected to the SI input. Thus, if actual total capacitive loading is too large to satisfy the delay time relationships \(\left(t_{d}=t_{S K}-t_{r} ; t_{d}=\right.\) actual delay time, \(t_{S k}=\) the instruction cycle time, \(\mathrm{t}_{\mathrm{r}}=\) the finite SK rise time), either slow down SK cycle time or add a pullup resistor to speed up SK " 0 " to " 1 " transition or use an external buffer to drive the large load. Besides the timing requirement, system supply and fan-out/fan-in requirements have to be considered, too.
If devices of different types are connected to the same serial interface, the output driver of the controller must satisfy all the input requirements of each device. Brief\(l y\), for devices that have incompatible input levels or source/sink requirements to exchange data, external pullups or buffers are necessary to provide level shifting or driving. Unreliable operation might occur during data transfer, otherwise. For a 100 pF load, a standard COPS Microcontroller may use a 4.7 k external resistor, with the output "low" level increased by less than 0.2V. For the same load the low power COPS may use a 22 k resistor; with the SO, SK output "low" level increased by less than 0.1 V .
D. STANDARD L OUTPUT

Same as Standard Output, but may be disabled. Available on L-outputs only.


TL/DD/8440-12
FIGURE 12. Standard L Output
When this option is implemented on the L-port and the L-drivers are disabled to use the \(L\) lines as inputs, the disabled depletion-mode device cannot be relied on to source sufficient current to pull an input to a logic high. There are two ways to use \(L\) lines as inputs (having standard L option):
The first method requires that the drivers be disabled. In this case the lines are floating in an undefined state. The external circuitry must provide good logic levels both high and low to the input pins. The inputs are then read by the INL instruction. The second method is similar to the technique used for the G-port. The drivers are enabled and \(a\) " 1 " must be written to the \(Q\) register.
The external circuitry will then be required only to pull the lines low to a logic " 0 ". The line will pull up to a " 1 " itself. The INL instruction is used as before to read the lines.

\section*{E. LED DIRECT DRIVE OUTPUT}

In this configuration, the depletion-load device to \(\mathrm{V}_{\mathrm{CC}}\) is paralleled by an enhancement-mode device to \(V_{C C}\) to allow for the greater current sourcing capacity required by the segments of an LED display. Source current is clamped to prevent excessive source current flow.

(AIS DEPLETION DEVICE)
TL/DD/8440-13
FIGURE 13. LED (L output) NMOS-COPS
This configuration can be disabled under program control by resetting bit 2 (EN2) of the enable register to provide simplified display segment blanking.
However, while both enhancement-mode devices are turned off in the disabled mode, the depletion-load device to \(V_{C C}\) will still source up to 0.125 mA . As in the case of Standard L output, again this current is not sufficient to pull an input to a logic " 1 ".
The drivers must be disabled and the lines must be pulled high and low externally, whenever they are used as inputs.
Example \#1:
When COPS outputs are used to drive loads directly, the power consumed in the outputs must be considered in the maximum power dissipation of the package.
Figure 14 shows an LED segment obtaining its source current from \(L_{0}\) output and \(D_{0}\) sinking the current. In this configuration all the power required to drive the LED with the exception of the portion consumed by the LED itself, is consumed within the chip. Assuming COP404L is the driving device:


TL/DD/8440-14

FIGURE 14. LED Drive

If we assume the \(V_{\text {source }}\) is not inserted, the device has a \(V_{C C}\) of 9.5 V , and that the voltage drop across the LED is 2.0 V .
We can calculate the power dissipation in these outputs. The minimum current that \(D_{0}\) can sink at 1.0 V is 35 mA (COP404L data sheet). \(\mathrm{L}_{0}\) can source up to 35 mA at 3.0 V . Therefore, the power dissipation for the \(\mathrm{L}_{0}\) output could be: \((9.5-3.0)(0.035)=227 \mathrm{~mW}\). The power in the \(D_{0}\) output is \((1)(0.035)=35 \mathrm{~mW}\).
Now let us calculate the current limiting resistor. Referring to COP404L \(L_{0}-L_{7}\) output source current curves, at \(\mathrm{V}_{\mathrm{CC}}=9.5 \mathrm{~V}\) the minimum current curve peaks at \(\mathrm{I}=6.0 \mathrm{~mA}\) and \(\mathrm{V}_{\text {source }}=4.8 \mathrm{~V}\). The current curve is actually very flat between 4.0 and 5.0 volts. For maximum current, we need to set the voltage on the \(L\) pin equal to 4.8 V at 6.0 mA . The D line will sink this current at 0.4 V . Therefore, the resistor and LED must make up the difference:
\[
\begin{aligned}
V_{1} & =V_{D}+I R+V_{L E D} \\
4.8 & =0.4+0.006 R+2.0 \\
R & =400 \Omega
\end{aligned}
\]

At the other end of the curve, when the \(L\) line sources the maximum current, assume the LED and the D line will have the same voltage drop.
\[
\begin{aligned}
& V_{1}=0.4+I R+2.0 \\
& V_{1}=2.4+I R
\end{aligned}
\]

From the current curve, we see that at 6.4 V the L line will source 10 mA . Therefore: \(\mathrm{V}_{1}=2.4+(0.01)(400)\) \(=6.4 \mathrm{~V}\).

\section*{Example \#2:}

Let's consider a different configuration.


FIGURE 15. LED DRIVE

Now we calculate the series current limiting resistor \(R\). The circuit has two non-linear devices to be considered; the output device and the LED.
The LED in this example is NSC5050. Looking at I/V curve, the device has a threshold 1.6 V . Also, note that for \(\mathrm{V}_{\text {LED }}>1.6 \mathrm{~V}\) the I/V curve is very linear (Figure 17). Because of this, the LED characteristic can be modeled as a sharp threshold device with a non-zero source resistance (normally I/V curve is LOG looking). From ON part of curve,
\[
\mathrm{R}_{\mathrm{S}}=\frac{1.9-1.7}{0.05}=4 \Omega
\]

We can neglect \(R_{S}\) as well (only \(R_{S} \ll R\) ). Our model is simply a voltage source for the LED when
\[
\begin{aligned}
& I=0 \text { for } V_{\mathrm{LED}}<V_{T H} \\
& I=\infty \text { for } V_{\mathrm{LED}}>V_{T H}
\end{aligned}
\]

Design Procedure:
1. \(l_{\mathrm{LED}(\text { min })}=\frac{\mathrm{V}_{\mathrm{S}(\text { min })}-\left(\mathrm{V}_{\mathrm{LED}(\max )}+\mathrm{V}_{\mathrm{OUT}(\text { max })}\right)}{R(\max )}\)

We need endpoints of the load line.
a. \(@ V_{\text {out }}=0 \Rightarrow l_{\operatorname{LED}(\min )}=\frac{V_{S(\text { min })}-V_{L E D(\max )}}{R(\max )}\)
b. \(@ V_{\text {out }}+V_{\text {LED(max) }}=V_{S} \Rightarrow I=0\)
\(\left(V_{\text {LED (max })}=2 \mathrm{~V}\right)\)
2. Plot \(a\) and \(b\)

Assuming an \(I_{\min }=7 \mathrm{~mA}, \mathrm{~V}_{\mathrm{S}(\text { min })}=4.5 \mathrm{~V}\)
from \(1 \mathrm{R}_{(\max )}=357 \Omega\)
Draw the load line with slope \(-1 / 357\) crossing
\(\mathrm{V}_{\text {out }}=\mathrm{V}_{\mathrm{S}}-\mathrm{V}_{\mathrm{LED}(\max )}=4.5-2=2.5 \mathrm{~V}\).
(Figure 16).


TL/DD/8440-16
FIGURE 16. COP420


TL/DD/8440-17
FIGURE 17. LED I/V Characteristic
The intersection of this load line and \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\mathrm{~min})\) curve, we find an actual value of \(I_{(m i n)}=4.25 \mathrm{~mA}\). To determine \(I_{\text {max }}\) (at \(R=357 \Omega\) ) we draw a parallel load line intersecting \(V_{\text {out }}=6.3-2.0=4.3 \mathrm{~V}\) and find that @ \(V_{C C}=6.3 \mathrm{~V}, \mathrm{I}_{(\text {max })}=13 \mathrm{~mA}\).
3. From above calculations we observe that our \(I_{(\text {min })}\) (actual) is way off. Let's try to rotate our first load line around \(V_{\text {out }}=2.5 \mathrm{~V}\) to increase \(I_{\min }\) and then check \(I_{\text {max }}\) and R. (Figure 18).
Let's go for an \(I_{\min }\) (actual) \(=6 \mathrm{~mA}\). This will give us \(R=89 \Omega\) and the max. plot goes off the graph to \(=36 \mathrm{~mA}\).

\section*{Output Sink Current}


TL/DD/8440-18
FIGURE 18. COP420

\section*{Comments:}
1. The design must be a compromise between the two extremes (battery life should also be considered).
2. The lower the LED threshold the better. (The load line moves further up the device curve.)

\section*{F. TRI-STATE PUSH-PULL OUTPUT}

This option is specifically available to meet the specifications of National's MICROBUS, outputting data over the data bus to a host CPU. It has two enhancementmode devices to ground and \(V_{\mathrm{CC}}\).


TL/DD/8440-19
FIGURE 19. TRI-STATE Push Pull (L output)
The TRI-STATE logic can disable both enhancementmode devices to free the MICROBUS data lines for input operation.
CAUTIONI Never try to pull against the TRI-STATE Output (too much source current) with the drivers enabled and \(Q\) register previously loaded with " 1 ". The choices we have are mentioned earlier. Either TRISTATE L-port or use Standard L output option.
II. INPUTS

COPS inputs may be programmed either with a depletion load device to \(\mathrm{V}_{\mathrm{CC}}\) or floating (Hi-Z input). All inputs are TTL/CMOS compatible. Hi-Z inputs should not be left floating; they should be connected to the output of a "high" and "low" driving device if active or to \(\mathrm{V}_{\mathrm{CC}}\) and ground if unused. Especially when using CMOS COPS (very high impedance inputs), the open inputs can float to any voltage. This will cause incorrect logic function and more power dissipation. Also, the CMOS inputs are more susceptible to static charge which causes gate oxide rupture and destroys the device. Unlike inputs, the outputs should be left open to allow the output switch without drawing any DC current. Another precaution is powering up the device. Never apply power to inputs or TRI-STATE outputs before both \(\mathrm{V}_{\mathrm{CC}}\) and ground are connected. This will forward bias input protection diodes, causing excessive diode currents. It will also power the device.
Special care must be practiced when interfacing a CMOS-COPS input to an analog IC, powered by different supply voltages. Avoid overvoltage conditions resulting


TL/DD/8440-20
FIGURE 20


FIGURE 21
from such situations. As an example, consider the interface of a CMOS-COPS with the LF111 voltage comparator:
When the low level " -5 V " appears on the comparator's output, the COPS input is pulled low below "logic low" of " OV ". This will cause damage if the comparator sinks enough current. The use of a current-limiting resistor in series with the input is helpful. A better solution is to use a voltage divider as shown in Figure 20. Any time a low level appears on the comparator's output, a total voltage drop of 10 V will appear across both resistors each dropping 5 V , causing the input to sit at OV . Whenever the output goes high, the resistors will not drop any voltage (no current through the resistors) and a logic high of 5 V will appear on the input. To reduce power dissipation introduced by resistors, the resistor value must be high (>100k), because the CMOS inputs have very high input impedance.

\section*{RESET INPUT}

All COPS Microcontroller have internal reset circuitry. Internally there is an AND gate with one input coming from the RESET input, and the second input connected to a charge pump circuitry. In the Charge pump circuit, a tiny capacitor is being charged upon execution of each internal instruction cycle. When the voltage across this inter-
nal capacitor reaches a high logic level, the second input of the AND gate is released.
The Reset logic will initialize (clear) the device upon pow-er-up if the power supply rise time is less than 1 ms and greater than \(1 \mu \mathrm{~s}\). With a slowly rising power supply, the part may start running before \(\mathrm{V}_{\mathrm{CC}}\) is within the guaranteed range. In this case, the user must provide an external RC network and diode shown in Figure 21 above. The external RC network is there to hold the RESET pin below \(V_{\text {IL }}\) until \(V_{C C}\) reaches at least \(V_{C C(m i n)}\). The desired response is shown in Figure 22.


TL/DD/8440-22
FIGURE 22
\(\mathrm{t}=500-600\) instruction cycles ( 8 msec ) for COPxxxL
\(\mathrm{t}=900-1000\) instruction cycles ( 4 msec ) for COPxxxC
The diode is included in the reset circuitry to cause a "forced Reset" when the power supply goes away and recovers quickly. In such a situation the diode helps discharge the capacitor quickly. Otherwise, if the power failure occurs for a short time, the capacitor will not be fully discharged and the chip will continue operation with incorrect data.

Note that on the CMOS COPS, the internal charge pump circuitry can be disabled when using a very slow clock ( \(<32 \mathrm{kHz}\) ) [option \(23=1\) ]. This is necessary, because one can run from DC to \(4 \mu \mathrm{~s}\) instruction cycle time (fully static). In such a situation external RC network discussed earlier must be used.

\section*{INPUT PROTECTION DEVICES}

All inputs and \(/ / O\) pins have input protection circuitry. This circuitry is there regardless of any option selected. It is the first circuitry encountered at the pin.


TL/DD/8440-23
FIGURE 23
For NMOS and XMOS devices, the circuits are of the form:


TL/DD/8440-24
FIGURE 24
This is a standard circuit defined for the process. \(R_{1}\) is on the order of \(200 \Omega . \mathrm{R}_{2}\) is around \(300 \Omega\) (note that the R values are not precise).
This circuit is functionally equivalent to:


TL/DD/8440-25
FIGURE 25
The zener breakdown is around \(10-15 \mathrm{~V}\); the gate breakdown is 50 V .

\section*{CONCLUSION}

All COPS Microcontrollers have a number of I/O options necessary to implement dedicated control functions in a wide variety of applications. The flexibility to select different options allows the user to tailor within limits, the I/O characteristics of the Microcontroller to the system. Thus, the user can optimize COPS for the system, thereby achieving maximum capability and minimum cost. This application note deals with the basic functionality of COPS I/O characteristics and does not address electrical differences among the various COPS devices.

\section*{MICROWIRE \({ }^{\text {™ }}\) Serial Interface}

\section*{INTRODUCTION}

MICROWIRE is a simple three-wire serial communications interface. Built into COPSTM, this standardized protocol handles serial communications between controller and peripheral devices. In this application note are some clarifications of MICROWIRE logical operation and of hardware and software considerations.

\section*{LOGICAL OPERATION}

The MICROWIRE interface is essentially the serial I/O port on COPS microcontrollers, the SIO register in the shift register mode. S is the shift register input, the serial input line to the microcontroller. SO is the shift register output, the serial output line to the peripherals. SK is the serial clock; data is clocked into or out of peripheral devices with this clock.
It is important to examine the logical diagram of the SIO and SK circuitry to fully understand the operation of this I/O port (Figure 1).

National Semiconductor Corp. Application Note 452 Abdul Aleaf


The output at SK is a function of SYNC, ENO, CARRY, and the XAS instruction. If CARRY had been set and propagated to the SKL latch by the execution of an XAS instruction, SYNC is enabled to SK and can only be overridden by ENO (Figure 2). Trouble could arise if the user changes the state of ENO without paying close attention to the state of the latch in the SK circuit.
If the latch is set to a logical high and the SIO register enabled as a binary counter, SK is driven high. From this state, if the SIO register is enabled as a serial shift register, SK will output the SYNC pulse immediately, without any intervening XAS instruction.

The SK clock (SYNC pulse) can be terminated by issuing an XAS instruction with CARRY \(=0\) (Figure 3).


FIGURE 1. Logical Diagram of SK Circuit


TL/DD/8796-2
FIGURE 2. SK Clock Starts


The SIO register can be compared to four master-slave flipflops shown in Figure 4. The masters are clocked by the rising edges of the internal clock. The slaves are clocked by the falling edges of the internal clock. Upon execution of an XAS, the outputs of the masters are exchanged with the contents of the accumulator (read and overdrive) in such a way that the new data are present at the inputs of the four slaves when the falling edge of the internal clock occurs. The content of the accumulator is, therefore, latched respectively in the four slave flip-flops and bit 3 appears directly on SO.
This means that:
a) SO will be shifted out upon the falling edges of SK and will be stable during rising edges of SK.
b) SI will be shifted in upon the rising edge of SK, and will be stable when executing, i.e., an XAS instruction.
The shifting function is automatically performed on each of the four instruction cycles that follow an XAS instruction (Figure 5).
When the SIO register is in the shift register mode (ENO = 0 ), it left shifts its contents once each instruction cycle. The data present on the SI input is shifted into the least significant bit (bit 0 ) of the serial shift register. SO will output the most significant bit of the SIO register (bit 3) if EN3 \(=1\). Otherwise, SO is held low. The SK is a logic controlled clock which issues a pulse each instruction cycle. To ensure that the serial data stream is continuous, an XAS instruction must be executed every fourth time. Serial I/O timing is related to instruction cycle timing in the following way:


FIGURE 4


FIGURE 5. XAS Sequence

FIGURE 6．Serial I／O Timing

FIGURE 7．MICROWIRE Serial Data Exchange Timing
To write to device： \(\mathrm{t}_{\mathrm{ns}}>\mathrm{t}_{\text {setup }}\)
To read from device： \(\mathbf{t}_{\mathbf{d}} \leqslant \mathrm{t}_{\mathrm{SK}}-\mathrm{t}_{\mathrm{r}} ; \mathrm{t}_{\mathrm{RS}}>\mathrm{t}_{\mathrm{SK}} / 4\)
Where：\(t_{\text {ws }}\) is MICROWIRE write data－in（DI）setup time
tsetup \(^{\text {is device data sheet min data setup time to latch in valid data，}}\)
\(\mathbf{t}_{\mathrm{SK}}\) is system clock（ SK ）cycle time（Recommended \(50 \%\) duty cycle），
\(t_{r}\) is rise time（ \(10 \%\) to \(70 \%\) bout）of system clock（SK），
\(\mathbf{t}_{d}\) is device actual delay time before data－out（DO）valid and
\(t_{\text {RS }}\) is minimum data setup time for controller to shift－in valid data

The first clock rising edge of the instruction cycle triggers the low-to-high transition of SYNC output via SK. At this time, the processor reads the state of SI into SIO bit 0 , shifting the current bits \(0-2\) left. Halfway through the cycle (shown in Figure 6 as the eight clock rising edge), SK is reset low and the new SIO bit 3 is outputted via SO.

\section*{INTERFACING CONSIDERATIONS}

To ensure data exchange, two aspects of interfacing have to be considered: 1) serial data exchange timing; 2) fan-out/ fan-in requirements. Theoretically, infinite devices can access the same interface and be uniquely enabled sequentially in time. In practice, however, the actual number of devices that can access the same serial interface depends on the following: system data transfer rate, system supply requirement capacitive loading on SK and SO outputs, the fan-in requirements of the logic families or discrete devices to be interfaced.

\section*{HARDWARE INTERFACE}

Provided an output can switch between a HIGH level and a LOW level, it must do so in a predetermined amount of time for the data transfer to occur. Since the transfer is strictly synchronous, the timing is related to the system clock (SK) (Figure 7). For example, if a COPS controller outputs a value at the falling edge of the clock and is latched in by the peripheral device at the rising edge, then the following relationship has to be satisfied:
\[
t_{\text {DELAY }}+t_{\text {SETUP }} \leq t_{\text {CK }}
\]
where \(\mathrm{t}_{\mathrm{CK}}\) is the time from data output starts to switch to data being latched into the peripheral chip, tSETUP is the setup time for the peripheral device where the data has to be at a valid level, and tDELAY is the time for the output to read the valid level. \(\mathrm{t}_{\mathrm{CK}}\) is related to the system clock provided by the SK pin of the COPS controller and can be increased by increasing the COPS instruction cycle time.
The maximum tsETUP is specified in the peripheral chip data sheets. The maximum tDELAY allowed may then be derived from the above relationship.
Most of the delay time before the output becomes valid comes from charging the capacitive load connected to the output. Each integrated circuit pin has a maximum load of 7 pF . Other sources come from connecting wires and connection from PC boards. The total capacitive load may then be estimated. The propagation delay values given in data sheets assume particular capacitive loads (e.g. \(V_{C C}=5 \mathrm{~V}\), \(\mathrm{V}_{\mathrm{OH}}=0.4 \mathrm{~V}\), loading \(=50 \mathrm{pF}\), etc.).
If the calculated load is less than the given load, those values should be used. Otherwise, a conservative estimate is to assume that the delay time is proportional to the capacitive load.
If the capacitive load is too large to satisfy the delay time criterion, then three choices are available. An external buffer may be used to drive the large load. The COPS instruction cycle may be slowed down. An external pullup resistor may be added to speed up the LOW level to HIGH level transition. The resistor will also increase the output LOW level and increase the HIGH level to LOW level transition time, but the increased time is negligible as long as the output LOW level changes by less than 0.3 V . For a 100 pF load, the standard COPS controller may use a 4.7 k external resistor, with the output LOW level increased by less than
0.2 V . For the same load, the low power COPS controller may use a 22 k resistor, with the SO and SK LOW levels increased by less than 0.1 V .
Besides the timing requirements, system supply and fan-out/fan-in requirements also have to be considered when interfacing with MICROWIRE. For the following discussion, we assume single supply push-pull outputs for system clock (SK) and serial output (SO), high-impedance input for serial input (SI).
To drive multi-devices on the same MICROWIRE, the output drivers of the controller need to source and sink the total maximum leakage current of all the inputs connected to it and keep the signal level within the valid logic " 1 " or logic " 0 '. However, in general, different logic families have different valid " 1 " and " 0 " input voltage levels. Thus, if devices of different types are connected to the same serial interface, the output driver of the controller must satisfy all the input requirements of each device. Similarly, devices with TRI-STATE \({ }^{\circledR}\) outputs, when connected to the SI input, must satisfy the minimum valid input level of the controller and the maximum TRI-STATE leakage current of all outputs.
So, for devices that have incompatible input levels or source/sink requirements, external pull-up resistors or buffers are necessary to provide level-shifting or driving.

\section*{SOFTWARE INTERFACE}

The existing MICROWIRE protocol is very flexible, basically divided into two groups:
1) 1 AAA.....ADDD.....D
where leading 1 is the start bit and leading zeroes are ignored.
AAA.....A is device variable instruction/address word.
DDD.....D is variable data stream between controller and device.
2) No start bit, just bit stream, i.e., bbb.....b
where \(\mathbf{b}\) is a variable bit stream. Thus, device has to decode various fields within the bit stream by counting exact bit position.

\section*{SERIAL I/O ROUTINES}

Routines for handling serial I/O are provided below. The routines are written for 16-bit transmissions, but are trivially expandable up to 64 -bit transmissions by merely changing the initial LBI instruction. The routines arbitrarily select register 0 as the I/O register. It is assumed that the external device requires a logic low chip select. It is further assumed that chip select is high and SK and SO are low on entry to the routines. The routines exit with chip select high, SK and SO low. GO is arbitrarily chosen as the chip select for the external device.

\section*{SERIAL DATA OUTPUT}

This routine outputs the data under the conditions specified above. The transmitted data is preserved in the microcontroller.
\begin{tabular}{rll} 
OUT2: LBI 0,12 & ; point to start of \\
data word
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{10}{|c|}{TABLE I. MICROWIRE Standard Family} \\
\hline \multicolumn{2}{|c|}{\multirow[b]{2}{*}{Features}} & \multicolumn{8}{|c|}{Part Number} \\
\hline & & DS3906 & MM545X & COP470 & COP472 & \[
\begin{gathered}
\text { COP430 } \\
\text { (ADC83X) }
\end{gathered}
\] & COP498/499 & COP452L & \[
\begin{gathered}
\text { COP494 } \\
\text { (NMC9306) } \\
\hline
\end{gathered}
\] \\
\hline \multicolumn{10}{|l|}{GENERAL} \\
\hline \multicolumn{2}{|l|}{Chip Function} & AM/PM PLL & LED Display Driver & VF Display Driver & LCD Display Driver & A/D & RAM \& Timer & Frequency Generator & E2PROM \\
\hline \multicolumn{2}{|c|}{Process} & ECL & NMOS & PMOS & CMOS & CMOS & CMOS & NMOS & NMOS \\
\hline \multicolumn{2}{|c|}{\(\mathrm{V}_{\text {CC }}\) Range} & \(4.75 \mathrm{~V}-5.25 \mathrm{~V}\) & \(4.5 \mathrm{~V}-11 \mathrm{~V}\) & -9.5 V to -4.5 V & \(3.0 \mathrm{~V}-5.5 \mathrm{~V}\) & \(4.5 \mathrm{~V}-0.3 \mathrm{~V}\) & \(2.4 \mathrm{~V}-5.5 \mathrm{~V}\) & \(4.5 \mathrm{~V}-6.3 \mathrm{~V}\) & \(4.5 \mathrm{~V}-5.5 \mathrm{~V}\) \\
\hline \multicolumn{2}{|c|}{Pinout} & 20 & 40 & 20 & 20 & 8/14/20 & 14/8 & 14 & 14 \\
\hline \multicolumn{10}{|l|}{HARDWARE INTERFACE} \\
\hline \multicolumn{2}{|l|}{Min \(\mathrm{V}_{\mathrm{IH}} /\) Max \(\mathrm{V}_{\text {IL }}\)} & 2.1V/0.7V & \(2.2 \mathrm{~V} / 0.8 \mathrm{~V}\) & \(-1.5 \mathrm{~V} /-4.0 \mathrm{~V}\) & \(0.7 \mathrm{~V}_{\mathrm{CC}} / 0.8 \mathrm{~V}\) & \(2.0 \mathrm{~V} / 0.8 \mathrm{~V}\) & \(0.8 \mathrm{~V}_{\mathrm{CC}} / 0.4 \mathrm{~V}_{\mathrm{CC}}\) & \(2.0 \mathrm{~V} / 0.8 \mathrm{~V}\) & \(2.0 \mathrm{~V} / 0.8 \mathrm{~V}\) \\
\hline \multicolumn{2}{|l|}{SK Clock Range} & \(0-625 \mathrm{kHz}\) & \(0-500 \mathrm{kHz}\) & \(0-250 \mathrm{kHz}\) & \(4-250 \mathrm{kHz}\) & \(10-200 \mathrm{kHz}\) & \(4-250 \mathrm{kHz}\) & \(25-250 \mathrm{kHz}\) & \(0-250 \mathrm{kHz}\) \\
\hline \multirow[t]{2}{*}{Write Data DI} & Setup Min & \(0.3 \mu \mathrm{~s}\) & \(0.3 \mu \mathrm{~s}\) & \(1.0 \mu \mathrm{~s}\) & \(1 \mu \mathrm{~s}\) & \(0.2 \mu \mathrm{~s}\) & \(0.4 \mu \mathrm{~s}\) & 800 ns & \(0.4 \mu \mathrm{~s}\) \\
\hline & Hold Min & \(0.8 \mu \mathrm{~s}\) & (3) & 50 ns & 100 ns (Note 1) & \(0.2 \mu \mathrm{~s}\) & \(0.4 \mu \mathrm{~s}\) & \(1.0 \mu \mathrm{~s}\) & \(0.4 \mu \mathrm{~s}\) \\
\hline \multicolumn{2}{|l|}{Read Data Prop
Delay} & (Note 4) & (Note 3) & (Note 3) & (Note 3) & (Note 3) & \(2 \mu \mathrm{~S}\) (Note 2) & \(1 \mu \mathrm{~s}\) (Note 2) & \(2.0 \mu \mathrm{~s}\) \\
\hline \multirow[t]{2}{*}{Chip Enable} & Setup & \(0.3 \mu \mathrm{~s}\) & \(0.4 \mu \mathrm{~s}\) & \[
\begin{gathered}
1.0 \mu \mathrm{~s} \\
\mathrm{Min} \\
\hline
\end{gathered}
\] & \(1 \mu \mathrm{~s}\) (Note 1) & \(0.2 \mu \mathrm{~s}\) & \(0.2 \mu \mathrm{~s}\) (Note 1) & (Note 3) & \(0.2 \mu \mathrm{~s}\) \\
\hline & HOLD & \(0.8 \mu \mathrm{~s}\) & (Note 3) & \[
\begin{gathered}
1.0 \mu \mathrm{~s} \\
\mathrm{Min} \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
1 \mu \mathrm{~s} \\
\text { (Note 2) }
\end{gathered}
\] & \(0.2 \mu \mathrm{~s}\) & (Note 2) & (Note 3) & 0 \\
\hline \multirow[t]{2}{*}{Max Frequency Range} & AM & 8 MHz & (Note 3) & (Note 3) & (Note 3) & (Note 3) & (Note 3) & (Note 3) & (Note 3) \\
\hline & FM & 120 MHz & (Note 3) & (Note 3) & (Note 3) & (Note 3) & (Note 3) & (Note 3) & (Note 3) \\
\hline \multicolumn{2}{|l|}{Max Osc Freq.} & (Note 3) & (Note 3) & 250 kHz & (Note 3) & (Note 3) & \[
\begin{gathered}
2.1 \mathrm{MHz}(-21) \\
32 \mathrm{kHz}(-15) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
256-2100 \mathrm{kHz}(-4) \\
64-525 \mathrm{kHz}(-2) \\
\hline
\end{gathered}
\] & (Note 3) \\
\hline \multicolumn{10}{|l|}{SOFT} \\
\hline \multicolumn{2}{|c|}{\begin{tabular}{l}
Serial I/O \\
Protocol
\end{tabular}} & 11D1...D20 & 1D1...D35 & \[
\begin{gathered}
8 \text { Bits } \\
\text { At a Time } \\
\hline
\end{gathered}
\] & b1...b40 & 1xXX & 1yyxxD6...D0 Start Bit & 1yxxxx & 1AA...DD \\
\hline \multicolumn{2}{|l|}{Instruction/ Address Word} & None & None & None & None & (Note 4) & (Note 4) & (Note 4) & (Note 4) \\
\hline \multicolumn{10}{|l|}{\begin{tabular}{l}
Note 1: Reference to SK rising edge. \\
Note 2: Reference to SK falling edge. \\
Note 3: Not defined. \\
Note 4: See data sheet for different modes of operation.
\end{tabular}} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|}
\hline & LEI & 8 & ; enable shift register mode \\
\hline & JP & SEND2 & \\
\hline SEND1: & XAS & & \\
\hline SEND2: & LD & & ; data output loop \\
\hline & XIS & & \\
\hline & JP & SENDI & \\
\hline & XAS & & ; send last data \\
\hline & RC & & \\
\hline & CLRA & & \\
\hline & NOP & & \\
\hline & XAS & & ; turn SK clock off \\
\hline & OGI & 15 & ; deselect the device \\
\hline & LEI & 0 & ; turn SO low \\
\hline & RET & & \\
\hline
\end{tabular}

The code for reading serial data is almost the same as the serial output code. This should be expected because of the nature of the SIO register and the XAS instruction.

\section*{MICROWIRE STANDARD FAMILY}

A whole family of off-the-shelf devices exists that is directly compatible with MICROWIRE serial data exchange standard. This allows direct interface with the COPS family of microcontrollers.
Table I provides a summary of the existing devices and their functions and specifications.

\section*{TYPICAL APPLICATION}

Figure 8 shows pin connection involved in interfacing an NMC9306/COP494 E2PROM with the COP420 microcontroller.


FIGURE 8. NMC9306/COP494-COP420 Interface
The following points have to be considered:
1. For COP494 the SK clock frequency should be in the \(0 \mathrm{kHz}-250 \mathrm{kHz}\) range. This is easily achieved with COP420 running at \(4 \mu \mathrm{~s}-10 \mu \mathrm{~s}\) instruction cycle time (SK period is the COP420 instruction cycle time). Since the minimum SK clock high time is greater than \(1 \mu \mathrm{~s}\), the duty cycle is not a critical factor as long as the frequency does not exceed the 250 kHz max.
2. CS low period following an E/W instruction must not exceed 30 ms maximum. It should be set at typical or minimum spec of 10 ms . This is easily done in software using the SKT timer on COP420.


TL/DD/8796-9
FIGURE 9. NMC9306/COP494 TIming
3. As shown in WRITE timing diagram, the start bit on DI must be set by a " 0 " to " 1 " transition following a CS enable (" 0 " to " 1 ") when executing any instruction. One CS enable transition can only execute one instruction.
4. In the read mode, following an instruction and data train, the DI can be a "don't care," while the data is being outputted, i.e., for the next 17 bits or clocks. The same is true for other instructions after the instruction and data has been fed in.
5. The data-out train starts with a dummy bit 0 and is terminated by chip deselect. Any extra SK cycle after 16 bits is not essential. If CS is held on after all 16 of the data bits have been outputted, the DO will output the state of DI until another CS LO to HI transition starts a new instruction cycle.
6. After a read cycle, the CS must be brought low for one SK clock cycle before another instruction cycle starts.

\section*{INSTRUCTION SET}
\begin{tabular}{llll}
\hline Commands & \multicolumn{2}{c}{ Opcode } & \multicolumn{1}{c}{ Comments } \\
\hline READ & 10000A3A2A1AO & Read Register 0-15 \\
WRITE & 11000A3A2A1AO & Write Register 0-15 \\
ERASE & 10100A3A2A1A0 & Erase Register 0-15 \\
EWEN & 111000 & 0 & 0 \\
1 & Write/Erase Enable \\
ENDS & 111000 & 0 & 1
\end{tabular} 0

All commands, data in, and data out are shifted in/out on rising edge of SK clock.
Write/erase is then done by pulsing CS low for 10 ms .
All instructions are initiated by a LO-HI transition on CS followed by a LO-HI transition on DI.
READ- After read command is shifted in DI becomes don't care and data can be read out on data out, starting with dummy bit zero.
WRITE- Write command shifted in followed by data in (16 bits) then CS pulsed low for 10 ms minimum.
ERASE
ERASE ALL-Command shifted in followed by CS low.
WRITE ALL—Pulsing CS low for 10 ms .
WRITE
ENABLE/DISABLE-Command shifted in.
***(This instruction is not speced on Data sheet.)


*E/W measured to rising edge of SK or CS, whichever occurs last.

I/O ROUTINE TO EVALUATE COP494


I/O ROUTINE TO EVALUATE COP494 (Continued)


\section*{SOFTWARE DEBUG OF SERIAL REGISTER FUNCTIONS}

In order to understand the method of software debug when dealing with the SIO register, one must first become familiar with the method in which the COPS MOLETM (Development System) BREAKPOINT and TRACE operations are carried out. Once these operations are explained, the difficulties which could arise when interrogating the status of the SIO register should become apparent.

\section*{SERIAL OUT DURING BREAKPOINT}

When the MOLE BREAKPOINTs, the COPS user program execution is stopped and execution of a monitor-type program, within the COP device, is started. At no time does the COP part "idle." The monitor program loads the development system with the information contained in the COP registers.
Note also that single-step is simply a BREAKPOINT on every instruction.
If the COP chip is BREAKPOINTed while a serial function is in progress, the contents of the SIO register will be destroyed.
By the time the monitor program dumps the SIO register to the MOLE, the contents of the SIO register will have been written over by clocking in SI. To inspect the SIO register using BREAKPOINT, an XAS must be executed prior to BREAKPOINT; therefore, the SIO register will be saved in the accumulator.

An even more severe consequence is that the monitor program executes an XAS instruction to get the contents of the SIO register to the MOLE. Therefore, the SK latch is dependent on the state of the CARRY prior to the BREAKPOINT. In order to guarantee the integrity of the SIO register, one must carefully choose the position of the BREAKPOINT address.
As can be seen, it is impossible to single-step or BREAKPOINT through a serial operation in the SIO register.

\section*{SERIAL OUT DURING TRACE}

In the TRACE mode, the user's program execution is never stopped. This mode is a real-time description of the program counter and the external event lines; therefore, the four external event lines can be used as logic analyzers to monitor the state of any input or output on the COPS device. The external event lines must be tied to the I/O which is to be monitored.

The state of these I/O (external event lines) is displayed along with the TRACE information. The safest way to monitor the real-time state of SO is to use the TRACE function in conjunction with the external event lines.

\section*{CONCLUSIONS}

National's super-sensible MICROWIRE serial data exchange standard allows interfacing to any number of specialized peripherals using an absolute minimum number of valuable I/O pins; this leaves more I/O lines available for system interfacing and may permit the COPS controller to be packaged in a smaller package.

\title{
COPS \({ }^{\text {TM }}\) Based Automobile Instrument Cluster
}

\begin{abstract}
Dedicated microprocessor systems find increasing applications in automobile instrumentation. Fuel injection systems, digital radio tuners and similar applications employing the microcontroller have become common place. This paper describes a cost effective microcontroller implementation of an automobile instrument cluster by the COPS group of National Semiconductor, Santa Clara. The instrument cluster provides a vacuum fluorescent display of the vehicle speed, engine RPM, odometers, battery voltage, engine oil pressure and the fuel level. A modular design involving a single microcontroller in conjunction with peripherals to aid in data acquisition from the transducers allows the quantities to be computed with high accuracies and displayed on a real time basis. The single microcontroller environment places severe restrictions on the availability of RAM and ROM. Coupled with the requirement of real time operation the application poses a non trivial challenge. A nonvolatile RAM accumulates the mileage covered. Hamming code techniques ensure the integrity of the data contained in the nonvolatile memory. Inclusion of diagnostics allows a rapid and thorough check against improper operation of the microcontroller, peripherals and the nonvolatile memory. This paper describes the implementation with a COP444L containing 128 nybbles of RAM and 2 K bytes of ROM. A display updation rate of 16 Hz can be comfortably realized.
Over the microcomputer usage has diversified dramatically in its scope and breadth. Dedicated microprocessor systems find increasing application in automobile instrumentation and control. From its inception the automobile has acquired considerable sophistication. Increasing demands have been made of the car. Fuel efficiency, higher acceleration rates, simplicity of control and improved ride quality rank high in the demands made of the car. In response the automobile engine has evolved into a complex machine. Crude methods to control or monitor its performance no longer suffice. Microprocessor based fuel injection techniques and ignition control are becoming quite ubiquitous.
The automobile instrument cluster monitors the engine and regularly updates a status display for the operator's benefit. Pertinent information includes the vehicle speed, the engine crankshaft rotational speed, oil pressure in the engine cylinders, condition of the battery and the mileage accumulated. The instrument cluster provides a visual feedback link to the operator allowing corrective action to be initiated as the need arises.

\section*{THE AUTOMOBILE INSTRUMENT CLUSTER}

The heart of the Automobile Instrument Cluster (AIC) lies in obtaining raw data from various transducers and manipulating it to a form suitable for feedback to the human operator. The feedback, normally visual, conveys the vehicle speed, the engine rpm, the engine temperature, oil pressure, the battery voltage and the odometer values. The AIC can be viewed as a collection of either inherently independent or weakly linked subtasks. Each subtask can be further partitioned into three blocks viz. of raw data collection, processing and displaying it. The component subtasks, in spite of their high degree of independence, can be grouped on the basis of signal available from the transducers. Grouping the
subtasks modularizes the design. Partitioning the design in this manner highlights two groups, the first requires a frequency to be measured and the second a voltage level. The two major groupings are briefly examined.
Transducers for the vehicle speed monitor the driveshaft rotation. Computing the engine rpm involves measuring the crankshaft revolution rate. The two independent problems can be seen to basically consist of measuring revolution rates. Transducers based on Hall effect phenomena have been used with commendable success. Alternately the fact that mounting magnets around the driveshaft circumference generates a known number of pulses per shaft rotation can be used effectively. A normally open cam operated reed switch with closure to ground creates a simple revolution transducer. In all the cases the transducer generates a frequency proportional to the quantity under consideration. Obviously some signal conditioning is required before using the frequency with digital components. The describing function can be simply stated as
\[
\begin{equation*}
V=k \times f \tag{1}
\end{equation*}
\]
where
\(V\) is the quantity under measurement, the vehicle speed or the engine rotational speed
\(k\) is a proportionality constant
\(f\) is the transducer freqeuncy output
The proportionality constant, \(k\), can be suitably modified to include changes back and forth between British and metric units.
The problem of measuring the transducer output frequency can be restated to be one of measuring the time period. In case of digital frequencies the equation (1) can be rewritten as
\[
\begin{equation*}
V=k /(\text { Ton }+ \text { Toff }) \tag{2}
\end{equation*}
\]
where
Ton is the ON time and
Toff is the OFF time
while the remaining symbols retain their definition from the earlier equation.
The remaining quantities such as the engine temperature, oil pressure, battery voltage and available fuel prove to be slow changing ones. The lower dynamics allow them to be transduced as voltage level signals. Equation (3) states the underlying relation and closely resembles the equations stated above.
\[
\begin{equation*}
P=k \times v \tag{3}
\end{equation*}
\]
where
\(v\) is the voltage output of the transducer
\(P\) is the quantity under measurement
\(k\) is the proportionality constant
Evaluating the accumulating mileage depends indirectly upon the vehicle speed subtask. Integrating the signal from the vehicle speed transducer over time allows the mileage to be accumulated. The associated problems of storing the odometer information and ensuring its integrity require error correcting techniques. They are covered in a later section of the paper.
\end{abstract}

\section*{SYSTEM DESCRIPTION}

The COPS Group of National Semiconductor, Santa Clara, offers a wide array of microcontrollers and peripherals to suit this application. Judicious selection of peripherals to aid the microcontroller can reinforce the partitioning suggested earlier to considerably simplify the implementation. Figure 1 presents a functional block diagram of the AIC.
A COP444L four bit microcontroller provides the necessary computing and decision making capability. Equipped with 128 nybbles of RAM space organized in a matrix fashion and 2K ROM space for storage of the control program, the COP444L operating at an instruction cycle rate of 16 microseconds sequentially obtains information from the peripherals and formats the manipulated results to be manageable by the display drivers. Transducers for the vehicle speed and the engine speed provide proportional frequency signals. Two COP452 peripherals, placed in a Waveform Measure Mode, track the ON time and OFF time of the conditioned transducer outputs. Voltage level signals available from the transducers for the engine temperature, oil pressure, battery condition and the fuel tank can be monitored by a COP438, an eight channel A/D converter. An electronically erasable non volatile RAM, the COP494, allows the odometer information to be stored safely under power down conditions.
A combination of LEDs, vacuum fluorescent displays and high intensity lamps comprise the optical elements of the AIC Standard eight segment alphanumeric and bargraph format displays have been used. A 32 segment LED bargraph, controlled by a MM5450 static display driver, displays the engine rpm. Eight segment alphanumeric vacuum fluorescent displays are used for the vehicle speed and the odometer values. Sixteen segment vacuum fluorescent bargraph displays are used for the engine temperature and available fuel quantity. The battery voltage and oil pressure utilize eight segment vacuum fluorescent bargraph displays. Any potentially dangerous situations detected by the COP444L are underlined by high intensity lamps. Five COP470 display drivers multiplex the various displays under the microcontroller's orchestration.
Single pole single throw switches allow the user to select between the British or the metric units, the trip or the accumulated odometer and reset the trip odometer.

\section*{SYSTEM DIAGNOSTICS}

Diagnostics aid in isolating faulty components within a system. The algorithmic nature of the diagnostic procedure allows it to be implemented via a microprocessor. A great deal of attention has been focused on diagnostics as considerable cost savings can accrue from a microprocessor based scheme minimizing human involvement. Programming the AIC, in addition to its normal functions, with self test capabilities increases its potential for high volume applications. Normally diagnostics imply using independent means to evaluate the system's performance. Attempting to incorporate self test capabilities necessitates adopting an "inside out" strategy. A basic kernel is first evaluated as functioning correctly. Over iterations the kernel expands by establishing correct operation of other modules.
The AIC implementation described in this paper has an extensive repertoire of diagnostics to check the microcontroller and ensure correct operation of the peripherals. The
probability of the microcontroller ROM failing proves to be negligibly small compared to a fault developing in the hardware interconnections. Also the idea of encoding in ROM the algorithm to check ROM data proves suspect. Control program stored in the ROM forms the kernel assumed to be functioning correctly. Writing and reading back an alternating pattern of ones and zeros in the microcontroller RAM checks for leakage of data into adjacent locations. Applying a known voltage, derived locally, to one of the four unused channels on the A/D converter allows it to be tested. The architecture of the COP452 peripherals consists of two independent register-counter pairs. The counters count down from the initial value. To test the COP452 both the register counter pairs have to be checked. By placing the two in a Duty Cycle Mode, the counters can be loaded with initial values from the registers and set to count down. The contents of the counters after a predetermined delay can detect incorrect operation of the device. A fault at the level of a register-counter pair can thus be isolated.
The COP494 stores the odometer information. It becomes vital to maintain the integrity of the information stored in the nonvolatile memory. Continuous use of particular locations in the COP494 can result in failures, typically bit dropouts. It is imperative to be capable of recovering from such errors. Requiring a single COP494 unit to last at least the expected lifetime of the vehicle influences the design of the storage scheme. The AIC implementation described in this paper depends upon Hamming encoding techniques to provide single bit error recovery. Subsequent to recovering from a single bit error all data transactions are carried out from a new location. A flashing display sequence alerts the operator of the occurrence of a non-recoverable error. Suspending all normal functions during such conditions can be used to force the vehicle to be taken to an authorized dealer. Breaking up the odometer data into sections allows updating of particular sections as opposed to restoring the whole every time. Such a strategy maximizes the lifetime of the nonvolatile memory.

\section*{SOFTWARE DESCRIPTION}

The functional objectives of the AIC and the hardware required to realize them have been detailed in earlier sections of the paper. A summary of the software features completes the description and aids in developing a global understanding of the AIC. The AIC software, written in COP microcontroller assembly language, reflects the modular nature of the problem. The finite amount of memory of ROM space available on the COP444L coupled with real time operation requirements makes programming the AIC a non-trivial problem. Each subtask grouping has been organized as a distinct block of code. The microcontroller sequentially processes each subtask. A brief examination of the salient features follows.
It must be borne in mind that the COP452 peripheral captures an instantaneous picture of the frequency. The strength of the magnets, mounted circumferentially on the driveshaft to transduce revolution rate, cannot be precisely controlled. As a result the transducer, although generating a fixed number of pulses per revolution of the driveshaft, produces a pulse train showing both pulse period and duty cycle variations. Directly using the pulse period from the

COP452 leads to erroneous values of the vehicle speed. The computed vehicle speed, under steady vehicle speed conditions, shows excursions on either side of the nominal value. The first AIC implementation studied the application of an essentially single pole filter with different damping constants to exclude the oscillations. Although a sufficiently damped filter can effectively reduce the oscillations the scheme was discarded in lieu of the resulting degradation in response time. The solution lies in basing the vehicle speed computation on pulse period measurements averaged over consecutive pulses. Since the number of pulses per revolution is known, eight in this case, averaging the pulse period over this number minimizes the steady state error and responds fast. The nature of the solution affects the software organization. It falls upon the microcontroller to sample the conditioned output of the transducer and obtain pulse periods for eight consecutive pulses. To achieve this the software adopts a foreground-background organization. Monitoring the transducer output to catch the consecutive pulses forms the background job. The normal functions of the AIC form the foreground job. Additionally a minimal sampling rate has to be maintained to ensure that even at highest attainable vehicle speeds the microcontroller measures consecutive pulses.
The AIC electronically stores the odometer information in the non-volatile memory. Loss of odometer integrity can be disastrous. Consequently the ability to recover from errors in the non-volatile memory becomes very important. The AIC depends on single bit error correcting Hamming coding methods to avoid loss of information. The algorithm processes the odometer nybble fashion and simplifies the relat-
ed problems of encoding the data prior to storing it and decoding the composite for data retrieval to trivial table lookups. LQID, a powerfui member of the microcontroller instruction set, allows an eight bit value to be looked up based on the key value in the addresed RAM location. To minimize ROM space both the encoding and the decoding sections of the algorithm share the same error table and code for table lookups.
The remaining sections of the AIC software, also exhibit a block structure, do not prove to be as subtle. The straight forward code includes routines such as multiplications and divisions to help in the computations and routines allowing the microcontroller to communicate serially over the MICROWIRETM with the peripherals.

\section*{RESULTS AND CONCLUSIONS}

The AIC implemented via the COP444L approximately uses 2 K of ROM space. The COP444L, running at an instruction cycle time of 16 microseconds, sequences through all the functions in 228 milliseconds. The resulting display updation rate of approximately 4 Hz can be trivially increased to 16 Hz by replacing the COP444L with the equivalently packaged COP440. Table I presents in tabular form the accuracies and speeds at which the different measurements are done. It also shows the proportional speed increases obtainable.
The minimal number of peripherals used combined with the inclusion of diagnostics and error correction emphasize its low cost capabilities. The results serve to validate the feasibility of a cost effective microcontroller based Automobile Instrument Cluster.

TABLE I. Comparison of Speed and Resolution of Measurements Taken with the COP444L and the COP440
\begin{tabular}{l|c|c|c|c}
\hline \multirow{4}{*}{} & \multicolumn{2}{|c|}{\begin{tabular}{c} 
Measurements with \\
a COP444L
\end{tabular}} & \multicolumn{2}{c}{\begin{tabular}{c} 
Measurements with \\
a COP440
\end{tabular}} \\
\cline { 2 - 5 } & \begin{tabular}{c} 
Time Taken \\
\(\mu\) secs
\end{tabular} & \begin{tabular}{c} 
Resolution \\
Blts
\end{tabular} & \begin{tabular}{c} 
Time Taken \\
\(\mu\) secs
\end{tabular} & \begin{tabular}{c} 
Resolution \\
Bits
\end{tabular} \\
\hline 1. Engine rpm & 768 & 17 & 192 & 17 \\
2. Vehicle Speed & 768 & 17 & 192 & 17 \\
3. Engine Temperature & 256 & 8 & 64 & 8 \\
4. Oil Pressure & 256 & 8 & 64 & 8 \\
5. Battery Voltage & 256 & 8 & 64 & 8 \\
6. Fuel Quantity & 256 & 8 & 64 & 8 \\
\hline
\end{tabular}


TL/DD/8798-1


FIGURE 2

\title{
Automotive Multiplex Wiring
}

\section*{INTRODUCTION}

The evolutionary development of vehicle electronic systems has rapidly increased the number of individual wires in the vehicle. The conventional wiring harness will not provide solutions to the problems such as reducing size and weight in addition to meeting cost and reliability objectives. Several approaches have been taken to provide long term solutions. None has succeeded. Miniaturization of cables and wires is one example of a temporary solution.
Multiplexing on the other hand has been regarded as a technique which allows considerable savings to be made in the size and cost of the harness. It can also enhance reliability by reducing the number of electrical connections.
In a multiplex system the control functions will be distributed around the vehicle and complex interconnections between diagnostic terminals, sensors, instruments and switches will not add to the harness complexity. With all its advantages it has not been implemented on a production car yet. The reason has been economical feasibility and lack of suitable semiconductor components for power switching. But, with the rapid technology advances in power FETs and introduction of low cost microcomputers, multiplex wiring can be regarded as a logical successor to conventional wiring systems. Extended development efforts are necessary to introduce a reliable system at reasonable cost.
The Microcontroller Applications Group at National Semiconductor has taken a step towards this goal. A low end multiplex wiring system focusing on asynchronous serial communication in a multi node network has been developed. This paper describes the development of this system on an abstract model which forms the basis for analysis of communication protocol and various node functions.

\section*{SYSTEM CONFIGURATION}

Figure 1 presents a general view of the system. The system is a centralized single master multiple slave-node scheme. All units are connected together by a balanced twisted pair. The expandable interconnection of different subsystems is achieved with 9600 Baud communication over a standard UART bus. The bus handles the interface between a master controller and the intelligent nodes.
The approach to have a centralized control system offers several advantages as compared against a non-centralized system. It prevents the problem of bus monopolization by a faulty node and is potentially cheaper due to the need for only one complex node (master). The master-slave architecture also prevents bus contention problems.
The master is COP1430. The COP1430 is a 4-bit microcontroller with on chip UART that handles asynchronous communication with other processors at speeds up to 9600 Baud.
The use of 4 -bit \(49 \phi\) microcontrollers (COP413L) at the nodes not only provides intelligence which reduces the required bus bandwidth, it also reduces the incremental cost associated with automotive multiplexing. All standard nodes
are identical. One standard program is used. This uniformity contributes to the system flexibility and expandability. External standard nodes may be added to the system to control additional functions. Node types and addresses are selected via external wire jumpers or switches. The slave nodes consist of four remote units to handle functions such as headlamps, tail lamps, etc. These nodes are the front right, front left, rear right and rear left nodes. Incorporated into the system are also a keyboard node, a EIC node and a display node.
The keyboard node may call for a control action at any time. This node is being continuously monitored by the master controller which receives status and processes the command or information.
Overall system intelligence and flexibility is increased by dedicating a node to NS455 the Terminal Management Processor. This node takes the responsibility to display information on a \(4^{\prime \prime}\) flat CRT display.
An Electronic Instrument Cluster (EIC) system is a completely independent system. It typically performs all functions associated with the automobile dashboard such as vehicle speed, odometers to accumulate mileage, gauges to display engine temperature, fuel level and so on. It also indicates error conditions such as high engine temperatures, low fuel level etc. The multiplex wiring system uses a standard slave node as a bridge between the two independent systems. The slave node monitors error conditions from the EIC system and passes them to the master node upon request. It becomes relatively simple to allow the master to access all activity in the EIC system via additional commands to the slave node serving the EIC system:

\section*{THE COMMUNICATION PROTOCOL}

The master unit addresses the remote units sequentially and receives a status reply from each individual node. Data communication is via the standard UART format. It has a start bit, eight data bits, an even parity bit and one stop bit. Information to be transmitted from the master to a slave node is organized as a frame. Each frame contains the address of destination and command or data. The information in a frame is transmitted as byte format. Address/data differentiation is done by means of a flag. The byte is an address byte if the MSB is set (" 1 "), otherwise it is a data byte. Two different types of addressing schemes have been incorporated into the communication protocol; node addressing and class addressing. A class of nodes is formed by grouping together slave nodes with common functions. Commands may be executed either by specific individual nodes or by slave classes. All nodes of the same class execute the command simultaneously. The system implementation at National involved four classes with seven slave nodes per class. So, the total number of nodes possible in this system is 28.

tSt-NV

The partitioning between the class address and node address reduces the density of bus traffic significantly by eliminating repetative command transmission to individual node class. Lower bus traffic implies that lower transmission bit rate can be used, allowing additional noise immunity. Another advantage of the class addressing is the provision of synchronization for control signals such as HAZARD, LEFT/ RIGHT turns.
Error correction is incorporated into the communication protocol. The UART error flags such as PARITY and FRAMING ERRORS protect the system at the physical layer. At the system level, the nodes simply avoid sending an acknowledgement to the master when an error is detected. The master times out and sends the command again.

\section*{THE MASTER NODE}

The master controller is the heart of the system. Its responsibility is to generate the controlling commands and synchronize the system. It transmits to the remote units and listens to them to get the vehicle status and acts accordingly. Circuit complexity is reduced by implementing extensive software programming in the master controller. This means that the burden is essentially on the master and must be engineered to very high standards of reliability. The device used in the implementation as the master is the COP1430. It is a cost effective 4-bit single chip microcontroller. It features on chip UART which handles asynchronous communications at speeds up to 9600 Baud.

\section*{THE SLAVE NODES}

The standard slave nodes are based upon the COP413L. The COP413L is a low cost 4 -bit microcontroller which may be customized in production. A system such as multiplex wiring requires power consumption to be absolutely minimal. Another basic requirement is that the system should be cost effective. These two facts directed us to use the COP413L at the standard slave node. The COP413L is a low cost ( \(49 ¢!\) ) low power microcontroller from NSC drawing less
than 7 mA at 4.5 V to 5.5 V . The device contains an 8 -bit bidirectional I/O port and a serial expansion port. The CMOS version of COP413L will also be available.

\section*{THE DISPLAY NODE}

This node can serve as a condition monitoring unit for the vehicle. A considerable quantity of diagnostic information collected from transducers, switches, sensors and various loads are fed to this unit to be displayed on a CRT display. The node is based on a Terminal Management Processor the NS455. The NS455 is a CRT controller on chip. The messages are updated over the serial I/O line by the master controller. The communication format is:
a) The node receives the address.
b) If address matches the local node address, send the copy command
c) Receive new address and execute.

\section*{OUTPUT STAGES}

The power FETs used for local switching throughout the system are IRF541 (4). These N-channel FETs provide much better drive circuit specification as compared to bipolar output stages. They also feature all of the well established advantages of MOSFET such as voltage control, very fast switching, and very low on state resistance. Another advantage is the lower cost as compared to comparibly rated p-channel devices.

\section*{TRANSMISSION MEDIUM}

A balanced twisted pair is used for bus medium which provides high noise immunity. The transceiver selected for the bus is DS3695 (Figure 2). This device is a high speed differential TRI-STATE \({ }^{\circledR}\) Bus/line transceiver designed to meet EIA standard for multipoint bus transmission. Bus contention or fault situations that cause excessive power dissipation within the device are handled by a standard thermal shutdown circuit, which forces the driver outputs into the high impedance state.


FIGURE 2. Bus Interface

\section*{CONCLUSIONS}

Multiplex wiring system potentially seems to be a good replacement for conventional wiring system. Reduced complexity, increased flexibility and diagnostic capability could be achieved by incorporating microcontroller devices at nodes within the wiring system. The 4-bit microcontrollers selected are available in a price range, as low as \(49 \phi\), that will allow multiplex wiring to compare favorably on a costperformance basis with the conventional harness.

\section*{REFERENCES}
1. Michael W. Lowndes and Paul E. V. Phillips, "The Motorcar Multiplex Systems", IEE Conference on Automotive Electronics, 229, England, Nov. 1983.
2. R. F. Robins/W. J. Brittain/M. R. Lunt, "A Car Multiplex Wiring System with Self Coding Control Modules', IEE Conference on Automotive Electronics, 229, Ford Motor Company, UK, Nov. 1983.
3. Booth, J. A., 1983 "Vehicle Interconnection Systems for the Future', IEE Conference on Automotive Electronics, London, Nov. 1983.
4. International Rectifier, HEXFET Databook, 1985.

Table of Contents
1.0 INTRODUCTION TO COPS MICROCONTROLLERS
1.1 Scope and Purpose of this Manual
1.2 The COPS Microcontroller Family
1.2.1 General Description
1.2.2 COPS ROMIess Microcontrollers
1.2.3 COPS Single-Chip Microcontrollers
1.2.4 Conclusion
2.0 ARCHITECTURE OF COPS MICROCONTROLLERS
2.1 Introduction
2.2 COPS Memory Structure
2.2.1 Program Memory-ROM
2.2.2 Data Memory—RAM
2.2.3 Subroutine Stack
2.3 The Arithmetic Logic Unit
2.4 Input/Output
2.4.1 Inputs
2.4.2 Bidirectional TRI-STATE I/O
2.4.3 Bidirectional I/O
2.4.4 Outputs
2.4.5 The SIO Register
2.4.6 Microbus \({ }^{\text {TM }}\)
2.5 The Enable Register
2.5.1 E No through E \(\mathrm{N}_{3}\)
2.5.2 \(\mathrm{E} \mathrm{N}_{4}\) through \(E \mathrm{~N}_{7}\)
2.6 Internal Timer
2.6.1 Access to the Timer
2.6.2 External Event Counter
2.7 Oscillator and Basic Timing
2.7.1 Clock Generator and Divider
2.7.2 The Instruction Cycle
2.8 Initialization
3.0 THE COPS INSTRUCTION SET
3.1 Basic Characteristics
3.2 Detailed Instruction Description
3.2.1 Arithmetic/Logic Instructions
3.2.2 Transfer of Control Instructions
3.2.3 Memory Reference Instructions
3.2.4 Register Reference Instructions
3.2.5 Test Instructions
3.2.6 Input/Output Instructions
3.3 Notes on Addressing Modes

\subsection*{4.0 PROGRAMMING COPS MICROCONTROLLERS}
4.1 Introduction
4.2 Boundary Conditions
4.2.1 Page Boundaries
4.2.2 Block Boundaries
4.2.3 Chapter Boundaries
4.3 Skip Conditions
4.3.1 Effect of Skips on Timing Loops
4.3.2 Instructions That Generate a Skip
4.4 Carry
4.5 Input/Output
4.5.1 Unidirectional Ports
4.5.2 Bidirectional Ports
4.5.3 The Serial I/O Port - MICROWIRE
4.6 Interrupt
4.6.1 Conditions for Interrupt Recognition
4.6.2 Effects of Interrupt Acknowledge
4.6.3 Interrupt Handling
4.6.4 Interrupt Disable
4.6.5 Interrupt in the COP440 Series
4.7 Program Efficiency
4.8 Rules and Techniques
4.8.1 Absolute Requirements
4.8.2 General Guidelines
4.9 Structured Programming Techniques
5.0 STANDARD PROGRAMS
5.1 Introduction
5.2 Math Pack
5.2.1 Basic Increment Routines
5.2.2 Basic Decrement Routines
5.2.3 Integer Addition
5.2.4 A Doubling Routine
5.2.5 Integer Subtract
5.2.6 Up-Down Counters
5.2.7 Binary Multiply
5.2.8 Basic Arithmetic Package
5.2.9 Square Root
5.2.10 Binary to BCD Conversion
5.2.11 BCD to Binary Conversion
5.3 Timekeeping Routines
5.3.1 Basic Clock Routines - External Input
5.3.2 Clock Routines Based on Internal Timer
5.4 Data Manipulation and String Operations
5.4.1 Register Transfers
5.4.2 Shift Routines
5.4.3 Data/String Compare
5.4.4 String Search
5.4.5 RAM Clear Routines
5.5 Input/Output
5.5.1 Table Look Up
5.5.2 Microbus I/O
5.5.3 Serial I/O - MICROWIRE
5.5.4 SI as a General Purpose Input
5.6 Display Control
5.6.1 A Four-Digit Multiplexed Display
5.6.2 Peripheral Display Drivers
5.7 Keyboard Scan

Appendix A Data RAM in COP420L/411L/413L and COP410C/411C Devices
A. 1 Data Ram Description

Appendix B Devices with Subroutine Stack in RAM
B. 1 Subroutine Stack in RAM Description and Location

\subsection*{1.0 Introduction to COPSTM Microcontrollers}

\subsection*{1.1 SCOPE AND PURPOSE OF THIS MANUAL}

How is an efficient COPS program written? The answer to this question begins with dividing the broad category of microcomputers into two areas: microcontrollers and microprocessors. This distinction is made because these are really two different types or classes of devices. Microcontrollers generally have a dual-bus architecture rather than the mem-ory-mapped von Neumann architecture common in most microprocessors. For control applications, microcontrollers are generally more memory efficient than microprocessors. The microcontroller instruction set is quite different in nature than the microprocessor instruction set. Microcontrollers are invariably single-chip devices and microprocessors are, generally, multi-chip devices. Microcontrollers dominate the microcomputer marketplace in terms of volume. To be sure, the division between microcontroller and microprocessor is sometimes blurred but the distinction is real nonetheless.
COPS devices are microcontrollers. It is the intent of this manual to provide the user/programmer of COPS microcontrollers the requisite information to write an efficient COPS program-to take full advantage of the characteristics of the devices. To achieve that end, this manu'al is written from the programmer's perspective. The various characteristics of COPS microcontrollers are described in the context of the effect of those characteristics on the programming of the devices. The COPS architecture is discussed; the instruction set is described in detail; general techniques of COPS programming are explained; and standard programs are provided. The standard programs are commonly used as vehicles to illustrate various programming techniques. The user or reader would be well advised to carefully read the explanations associated with routines showing multiple implementations. The intent of providing multiple implementations is not to show how many different ways a routine can be written but rather to show techniques, "tricks", tradeoffs, considerations, etc. Therefore, a great deal of useful information is included in those explanations.
This manual does not attempt to explain the detailed physical or electrical characteristics of COPS microcontrollers. To the extent any such information is provided here, it is to explain some software effect or characteristic. Therefore, the physical details may be simplified to clarify the software explanation.

\subsection*{1.2 THE COPS MICROCONTROLLER FAMILY}

\subsection*{1.2.1 General Decscription}

COPS devices are general purpose, single-chip microcontroller. These microcontrollers are complete microcomputers containing all system timing, internal logic, ROM, RAM, and I/O necessary to implement dedicated control functions in a wide variety of applications. The COP400 family presently consists of a large number of devices enabling the user to select the device best suited to his application.

The software is upward compatible-programs written on one device may be transferred to the next larger device (in terms of memory capacity) with little or no change. The package pin configurations have also been selected so that movement up or down (using memory size as the variable parameter) within the family can be accomplished easily. All COPS microcontrollers, regardless of memory size or number of pins, have the same basic architectural structure. In addition to the large number and wide range of devices, all COPS microcontrollers have a number of I/O options, specified at the same time as the program, which allow the user to tailor, within limits, the I/O characteristics of the microcontroller to the system. Thus, the user can optimize the microcontroller for the system, thereby achieving maximum capability and minimum cost.
This manual deals with the basic functionality of COPS microcontrollers. It does not address electrical differences among the various devices. Thus, this manual does not distinguish between the COP400 and the COP300 series. These two series differ only in electrical characteristics and not in function. This manual further does not distinguish the high-speed devices from the low-power devices or from the CMOS devices except to the extent that some of the devices may have features that affect programming.

\subsection*{1.2.2 COPS ROMless Microcontroilers}

Several COPS microcontrollers are designed to use external program memory. Basically, these devices have been created by removing the ROM from their single-chip counterparts. These devices are primarily intended to be used in program development and debug, device emulation, and low-volume production. Table I provides a list of COP400 ROMless devices currently available or in design. The devices are designed so that each COPS microcontroller has at least one ROMless device that can be used for accurate emulation. Since these devices are functionally equivalent to the single-chip microcontrollers, this manual does not generally distinguish the ROMless device from its singlechip counterpart.

\subsection*{1.2.3 COPS Single-Chip Microcontrollers}

Table II provides a list of COPS single-chip microcontrollers currently available or in design. It is readily apparent that the list is quite extensive. Many of the variations are simply different packagings of the same device, e.g., the COP441 is the COP440 in a 28 -lead package; the COP442 is the COP440 in a 24 -lead package; the COP440 is a 40 -pin device. Another important characteristic is the commonality of the pinouts of the single-chip devices; all 40-pin devices have the same pinout; all 24 -pin devices have the same pinout; the COP411L and COP411C have the same pinout; the COP422 and COP422L have the same pinout. See Connection Diagrams Figure 1 through Figure 4.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{8}{|c|}{TABLE I. COPS ROMless Microcontrollers-General Software Overview} \\
\hline COP & 401L & 402 & 402M & 404C & 404L & & 404 \\
\hline External ROM \(\times 8\) & Up to 512 & \multicolumn{2}{|r|}{Up to 1024} & \multicolumn{4}{|c|}{Up to 2048} \\
\hline RAM \(\times 4\) & 32 & \multicolumn{2}{|c|}{64} & \multicolumn{2}{|c|}{128} & & 160 \\
\hline Inputs & 0 & \multicolumn{2}{|c|}{4} & \multicolumn{2}{|c|}{4} & & 4 \\
\hline Bidirectional TRI-STATE \({ }^{\text {® }}\) I/O & 8 & \multicolumn{2}{|c|}{8} & \multicolumn{2}{|c|}{8} & & 16 \\
\hline Bidirectional I/O & 4 & \multicolumn{2}{|c|}{4} & \multicolumn{2}{|c|}{4} & & 8 \\
\hline Outputs & 4 & \multicolumn{2}{|c|}{4} & \multicolumn{2}{|c|}{4} & & 4 \\
\hline Serial I/O and External Event Counter & Yes & \multicolumn{2}{|c|}{Yes} & \multicolumn{2}{|c|}{Yes} & & Yes \\
\hline Internal Time Base Counter & No & \multicolumn{2}{|c|}{Yes} & \multicolumn{2}{|c|}{Yes} & & Yes \\
\hline Time Base Counter Programmable & No & \multicolumn{2}{|c|}{No} & Yes & No & & Yes \\
\hline Interrupt & No & Yes & No & \multicolumn{2}{|c|}{Yes} & \multicolumn{2}{|r|}{Yes-4 Sources} \\
\hline Stack Levels & 2 & \multicolumn{2}{|c|}{3} & \multicolumn{2}{|c|}{3} & 4 & 4 per CPU \\
\hline Microbus \({ }^{\text {TM }}\) Option & No & No & Yes & Yes & No & & Yes \\
\hline Instruction Cycle ( \(\mu \mathrm{s}\) ) min-max & 15-40 & \multicolumn{2}{|c|}{4-10} & 4-DC & 15-40 & & 4-10 \\
\hline Package Size (Pins) & 40 & \multicolumn{2}{|c|}{40} & 48 & 40 & & 48 \\
\hline Availability & Now & \multicolumn{2}{|c|}{Now} & Now & Now & & Now \\
\hline
\end{tabular}
*These devices are NOT available as of this writing. The information on these devices is preliminary and subject to change. Advance information has been provided for completeness and as an aid to the user. Announcements will be made by National Semiconductor at the appropriate times regarding the availability and ultimate charcteristics of these devices.

TABLE II. COPS Microcontrollers-General Software Overview
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline COP & 410L & 410C & 411L & 411C & 413L & 413C & 420 & 420L & 424C & 421 & 421L & 425C & 422 & 422L & 426C & 444L & 444C & 445L & 445C & 440 & 441 & 442 \\
\hline ROM \(\times 8\) & \multicolumn{6}{|c|}{512} & \multicolumn{9}{|c|}{1024} & \multicolumn{7}{|c|}{2048} \\
\hline RAM \(\times 4\) & \multicolumn{6}{|c|}{32} & \multicolumn{9}{|c|}{64} & \multicolumn{4}{|c|}{128} & \multicolumn{3}{|c|}{160} \\
\hline Inputs & \multicolumn{6}{|c|}{0} & \multicolumn{9}{|c|}{} & \multicolumn{4}{|c|}{0} & \multicolumn{2}{|l|}{4} & 0 \\
\hline Bidirectional TRI-STATE I/O & \multicolumn{6}{|c|}{8} & \multicolumn{9}{|c|}{8} & \multicolumn{4}{|c|}{8} & 16 & & 8 \\
\hline Bidirectional I/O & \multicolumn{2}{|l|}{4} & \multicolumn{2}{|l|}{3} & \multicolumn{2}{|l|}{4} & \multicolumn{3}{|c|}{4} & \multicolumn{3}{|c|}{4} & \multicolumn{3}{|c|}{2} & \multicolumn{4}{|c|}{4} & \multicolumn{3}{|l|}{8 - 4} \\
\hline Outputs & \multicolumn{2}{|l|}{4} & \multicolumn{2}{|l|}{2} & \multicolumn{2}{|l|}{No} & \multicolumn{3}{|c|}{4} & \multicolumn{3}{|c|}{4} & \multicolumn{3}{|c|}{2} & \multicolumn{4}{|c|}{4} & \multicolumn{3}{|c|}{4} \\
\hline Serial I/O and External Event Counter & \multicolumn{6}{|c|}{Yes} & \multicolumn{9}{|c|}{Yes} & \multicolumn{4}{|c|}{Yes} & \multicolumn{3}{|c|}{Yes} \\
\hline Internal Time Base Counter & \multicolumn{6}{|c|}{No} & \multicolumn{9}{|c|}{Yes} & \multicolumn{4}{|c|}{Yes} & \multicolumn{3}{|c|}{Yes} \\
\hline \begin{tabular}{l}
Time Base \\
Counter Programmable
\end{tabular} & \multicolumn{6}{|c|}{No} & \multicolumn{2}{|r|}{No} & Yes & \multicolumn{2}{|r|}{No} & Yes & \multicolumn{2}{|r|}{No} & Yes & No & Yes & No & Yes & \multicolumn{3}{|c|}{Yes} \\
\hline Interrupt & \multicolumn{6}{|c|}{No} & \multicolumn{3}{|c|}{Yes} & \multicolumn{6}{|c|}{No} & \multicolumn{2}{|c|}{Yes} & \multicolumn{2}{|l|}{No} & \multicolumn{2}{|l|}{Yes 4 Sources} & \begin{tabular}{l}
Yes \\
2 \\
Sources
\end{tabular} \\
\hline Stack Levels & \multicolumn{6}{|c|}{2} & \multicolumn{9}{|c|}{3} & \multicolumn{4}{|c|}{3} & \multicolumn{3}{|c|}{4} \\
\hline MICROBUS Option & \multicolumn{6}{|c|}{No} & Yes & No & Yes & \multicolumn{6}{|c|}{No} & No & Yes & \multicolumn{2}{|l|}{No} & \multicolumn{3}{|r|}{Yes No} \\
\hline \begin{tabular}{l}
Instruction \\
Cycle ( \(\mu \mathrm{s}\) ) \\
min-max
\end{tabular} & 16-40 & 4-DC & \multicolumn{2}{|l|}{16-40 4 -DC} & 16-40 & 4-DC & 4-10 & 16-40 & 4-DC & 4-10 & 16-40 & 4-DC & 4-10 & 16-40 & 4-DC & 16-40 & 4-DC & 16-40 & 4-DC & \multicolumn{3}{|c|}{4-10} \\
\hline Package SRE (Pins) & \multicolumn{2}{|l|}{24} & \multicolumn{4}{|c|}{20} & \multicolumn{3}{|c|}{28} & \multicolumn{3}{|c|}{24} & \multicolumn{3}{|c|}{20} & \multicolumn{2}{|c|}{28} & \multicolumn{2}{|l|}{24} & 40 & 28 & 24 \\
\hline Availability & \multicolumn{6}{|c|}{Now} & \multicolumn{3}{|c|}{Now} & \multicolumn{3}{|c|}{Now} & \multicolumn{3}{|c|}{Now} & \multicolumn{2}{|c|}{Now} & \multicolumn{2}{|l|}{Now} & \multicolumn{3}{|c|}{Now} \\
\hline
\end{tabular}
*These devices are not available as of this writing, the information on these devices is preliminary and subject to change. Advance information has been provided for completeness and as an aid to the user. Announcements will be made by National Semiconductor at the appropriate time regarding the availability and ultimate characteristics of these devices.

\section*{Connection Diagrams}


TL/DD/8B00-5
FIGURE 3

\section*{COP440}


TL/DD/8800-6
FIGURE 4

FIGURE 2

\subsection*{1.2.4 Conclusion}

COPS microcontrollers comprise a broad, general purpose, powerful, and flexible family of devices. The hardware and software compatibility of the devices allow the user to move easily within the family as the need arises or the application dictates. Many ROMless devices are available to aid in emulation and development. The applications of COPS devices are unlimited. COPS microcontrollers have been used in automotive (trip computer, seat position controller, electronic instrument cluster, ignition systems, diagnostic systems), appliance (ovens, microwave ovens, vacuum cleaners, sewing machines, washers, dryers, food processors), home electronic (electronically tuned radios, cassette recorders, video cassette recorders, stereo systems), security system, timekeeping, energy management, industrial/commercial (utility meters, keyboard encoders, cash registers, dictation equipment, coin changers, vending machines, jukeboxes), telephone (repertory dialers, simple phone dialers, call timers), exercise equipment (exercise bicycle, jogging machine), miscellaneous home (garage door openers, lawn sprinklers, Christmas ornaments, cable television), toy, game, and many other applications.

\subsection*{2.0 Architecture of COPS Microcontrollers}

\subsection*{2.1 INTRODUCTION}

This section deals with the architecture of COPS microcontrollers. Figure 2-1 is the generic block diagram for COPS microcontrollers. The diagram is accurate as is for the COP420/421/422, COP420L/421L/422L, COP424C/ 425C/426C, COP444L/445L, COP444C/445C, and COP484/485 devices. The addition or deletion of certain elements creates the other microcontrollers in the COPS family. Figure 2-2, the block diagram of the COP410L/ \(411 \mathrm{~L} / 413 \mathrm{~L} / 413 \mathrm{C}\) and COP410C/411C, Figure 2-3, the block diagram of the COP440/441/442 illustrate this fact. It is clear, even from a cursory examination, that all COPS microcontrollers possess the fundamental architecture that
is indicated in Figure 2-1. Therefore, Figure 2-1 is the focal point for the discussion of the COPS architecture. The additions or deletions that lead to the other block diagrams are discussed where appropriate.

\subsection*{2.2 COPS MEMORY STRUCTURE}

\subsection*{2.2.1 Program Memory-ROM}

The program memory in COPS microcontrollers is a readonly (ROM) organized as a number of eight-bit words. COPS microcontrollers with ROM capacities of 512, 1024, and 2048 words are presently available. Devices with ROM capacity of 3072 and 4096 words are currently in design. The ROM words are addressed sequentially by a binary program counter (in ROMless devices, the program counter is brought out to pins to address external memory). The program counter starts at zero and, if there are no jumps or subroutines or table lookups, will increment to the maximum value possible for the device and rolls over to zero and begins again.
Internally, COPS microcontrollers have a semi-transparent page, block, and chapter structure to the ROM. A page is composed of 64 contiguous ROM words. The lower six bits of the program counter are zeroes at the first address of a page and ones at the last address of a page. A block, which is significant only in the table lookup and indirect jump operations, is composed of four contiguous pages ( 256 contiguous ROM words). The lower eight bits of the program counter are zeroes at the first address of a block and ones at the last address of a block. The first address of a block is also the first address of a page and the last address of a block is also the last address of a page. The chapter division is relevant only in COPS devices with more than 2048 ROM words or ROMless devices capable of addressing more than 2048 ROM words. The lower 11 bits of the program are zeroes at the first address of a chapter and ones at the last address of a chapter. The first address of a chapter is also the first address of a block and the last address of a chapter is also the last address of a block. Table III lists the hexadecimal address and the corresponding page/chapter/block divisions.


FIGURE 2－1．Basic Block Diagram for COPS Microcontrollers


TL/DD/8800-8
*These pins not available on COP410L and 411C.
+ These pins not available on the COP413L/COP413C.
++ Only CMOS COPS except 411C.
FIGURE 2-2. COP410L/411L/413L and COP410C/411C Block Diagram


FIGURE 2-3. COP440/411/442 Microcontrollers Block Diagram

TABLE III. Address-Page-Block-Chapter Mapping


This internal structure is semi-transparent. Only some jumps, some subroutine calls, and table lookups are affected by this structure. As indicated earlier, the block divisions come into play only in the table lookups and indirect jumps. The page and chapter divisions affect some direct jumps and subroutine calls. Section 4 explains the effects of these divisions on the pertinent instructions. Complete operational programs can be written without consideration of this internal structure. Such a program, however, will use more code, and therefore require larger ROM capacity, than a program written with this structure in mind. Section 4 will address this in greater detail. This page/block/chapter structure has no effect on the program counter. The binary program counter will freely increment through page, block, or chapter boundaries.

\subsection*{2.2.2 Data Memory—RAM}

The data memory (RAM) in COPS microcontrollers is organized as a matrix. Each row in the matrix is called a register; each column in the matrix is called a digit. A digit is 4 bits wide. As shall be seen, this particular structure contributes to the general efficiency of COPS microcontroller. All RAM addressing is based on this register-digit (or row-column) organization. The RAM address register identifies a specific digit in the RAM matrix. COPS devices with RAM sizes of 32 digits ( 4 registers by 8 digits, 128 bits), 64 digits ( 4 registers by 16 digits, 256 bits), 128 digits ( 8 registers by 16 digits), and 160 digits ( 10 registers by 16 digits) are presently available. A device with RAM sizes 256 digits ( 16 registers by 16 digits) is in design. A ROMless device with 512 digits ( 32 registers by 16 digits) of RAM is also in design.
The RAM in COPS microcontrollers is not in the program memory space. The RAM is not addressed by the program counter but has its own address register, the B register. The \(B\) register can be loaded directly or through the accumulator. Since the RAM has its own address register, most COPS instructions which access RAM do not contain an address field. This tends to promote ROM code efficiency. The B register is divided into two distinct parts: Br -the row or register address and Bd-the column or digit address. Bd is 4 bits wide in all COPS microcontrollers. Br is between 2 and 5 bits wide depending on the particular device. Bd, in addition to being the digit address, is the source for the D output register. On software command, the contents of Bd can be transferred to the \(D\) port where the information is latched.
The data memory digit addressed by the B register is normally accessed through the accumulator. The contents of the RAM digit may be directed, under software command, to one of several output ports as well as used in the normal program flow. Two instructions, LDD and XAD, carry a RAM address with them. These instructions operate (load or exchange) on the specified RAM digit without modifying the \(B\) register.

\subsection*{2.2.3 Subroutine Stack}

COPS microcontrollers have a subroutine stack of two, three, or four save registers. On all COPS microcontrollers with two or three save registers in the subroutine stack, a physical transfer of register contents within the stack occurs on all operations affecting the stack, primarily calls and returns. On these devices, the stack is physically and logically separate from data RAM. The user does not have access to the stack and, therefore, may not read or write the stack in these devices.

On COPS devices with four or more stack levels, the stack is located in data RAM. Four stack levels use up one data register. The user has access to the stack since the data RAM contains the stack. However, in no case does the stack expand beyond its assigned area into the rest of the data memory. These devices contain a stack pointer which is incremented or decremented on operations affecting the stack. Overflowing the stack merely causes the stack pointer to wrap around from its maximum value back to zero. On the COP440 series, only the user also has access to the stack pointer and may read or write the pointer. In all of these devices which permit stack access, the programmer has increased versatility. However, caution is recommended. Increased power brings with it increased risk, and the programmer should exercise care that the stack is not accidentally accessed in these devices.

\subsection*{2.3 THE ARITHMETIC LOGIC UNIT}

The arithmetic logic unit (ALU) in COPS microcontrollers is a 4 -bit parallel binary adder. It performs all the arithmetic and logic functions in the microcontrollers. The destination for all such operations is the 4-bit accumulator, and one input to the ALU is always the accumulator. The other input is either an immediate operand as specified by an instruction or, more commonly, the data RAM digit addressed by the B register. The one-bit \(C\) register sometimes is a third input to the ALU. The ALU outputs a carry bit which, depending on the instruction being executed, can be loaded into the \(C\) register. See the instruction set description and Section 4.4 for more details on carry and the C register.

\subsection*{2.4 INPUT/OUTPUT}

\subsection*{2.4.1 Inputs}

Only one input port, the IN port, is available on COPS microcontrollers. This port is available only on devices with 28 or more leads. On software command, the four \(\mathbb{N}\) lines are read, as a group, into the accumulator. In addition to the direct inputs, INO and IN3 have latches associated with them. These latches capture a high to low transition on the particular line. The status of the latches is read into the accumulator on software command. Thus, the programmer can read the present status of the IN lines directly or can read the status of the latches associated with INO and IN3.
The IN1 input can, under software control, serve as an interrupt input. The enabling or disabling of interrupts is a software decision. As such, in a given program, interrupts may be always enabled, never enabled, or sometimes enabled. On the COP440/441 devices only, IN1 may be mask programmed to be a zero crossing input. As such, interrupts may be generated at each zero crossing. Note that the zero crossing option is a mask, i.e., hardware option and not a software option.
On the new COP424C and the COP444C, IN2 may be mask programmed to be an input to the time base counter. Again, this is a hardware option and is not software alterable. On the COP440/441 devices, IN2 may also be selected as an input to the time base counter. On these devices, however, the choice is controlled in software by the programmer.

\subsection*{2.4.2 Bidirectional TRI-STATE I/O}

All COPS microcontrollers have at least one eight-bit bidirectional I/O port. This is the L port. In output operations,
the \(L\) lines output the contents of the eight-bit \(Q\) register. The input path is from the pins to the accumulator and RAM. Note that the \(L\) lines are drives only: they do not retain any data. Output data for the \(L\) port is stored in the \(Q\) register. The \(L\) drivers can be placed in the high impedance, or TRI-STATE mode for ease in interface to a system bus.
The COP440 has an additional eight-bit bidirectional I/O port, the R port. The R port contains latches and drivers. Data to be output is latched into the R register. The input path is from the pins to the accumulator and RAM. Input data at the \(R\) pins is not, and cannot be, latched into the \(R\) register by any external signal. This must be done indirectly by the program. The \(R\) drivers, like the \(L\) drivers, can be put into a high impedance, or TRI-STATE, condition for simple bus interface.
Both the L port and the R port can be inputs. There is no input state per se. If used as inputs, either port may be put into a high impedance, or TRI-STATE, condition. In this case, the external signal must drive the line both high and low and guarantee the valid " O " and " 1 " logic levels. Alternatively, for both ports, the \(Q\) register or the \(R\) register can serve as a pullup for the \(L\) and \(R\) lines respectively. The programmer may write " 1 's" to the input positions and enable the drivers. In this case, the external signal need only pull the line down to a valid low level.

\subsection*{2.4.3 Bidirectional I/O}

The G port is a four-bit bidirectional I/O port. The G outputs are latches and drivers. Therefore, data can be saved in the G port. The input path is from the pins to the accumulator. in addition to reading the port, the G lines can be directly tested, either individually or as a four-bit group, in software. Note, the latches on \(G\) are for output only; input signals are not latched into the G port.
The COP440 has an additional bidirectional four-bit port, the H port. The H port is essentially a duplicate of the G port except that H cannot be directly tested.
There is no restriction on H or G as to which lines may be inputs or outputs. All G lines may be inputs; all G lines may be outputs; any \(G\) line, or group of \(G\) lines, may be outputs with the remaining G lines inputs. The same is true of the H lines.

\subsection*{2.4.4 Outputs}

The D port is an output-only port. The outputs are latched. On software command, the contents of Bd, the digit address portion of the RAM address register, are copied to the D port. These outputs will remain in that state until the next write to \(D\). The \(D\) port is loaded only from Bd.

\subsection*{2.4.5 The SIO Register}

The SIO register is a dual-purpose four-bit register. Depending on the status of the EN register, whose contents are user alterable, this register may be a four-bit binary down coutner or a four-bit serial shift register. When SIO is a down counter, SI is the counter input, the counter decrements on the high to low transition, provided that the input remains low for two instruction cycles of the signal at the SI output. SO and SK are logic level outputs which can be directly controlled by the program. When SIO is a shift register, SI is the input to the 4-bit shift register and SO is the shift register output. SK is a serial clock running at the instruction cycle
rate. By means of the EN register, and while SIO remains enabled as a shift register, SO can be disabled, i.e., forced to zero. Similarly SK can also be forced to zero in this mode. Note that when SIO is enabled as a shift register and SO enabled as a shift register output, whatever is at SI will appear at SO four instruction cycles later unless the program alters the contents of SIO. When enabled as a shift register, SIO is always shifting at the instruction cycle rate regardless of the status of SO or SK.

\section*{MICROWIRETM I/O}

The MICROWIRE concept provides a simple, easy to use serial interface between COPS microcontrollers and various peripheral devices. The MICROWIRE interface is, essentially, the serial I/O port on COPS microcontrollers, the SIO register in the shift register mode. SI is the shift register input, the serial input line to the microcontroller. SO is the shift register output, the serial output line to the peripherals. SK is the serial clock, data is clocked into or out of peripheral devices with this clock. MICROWIRE is available on all COPS microcontrollers.

\section*{MICROWIRE PERIPHERALS}

For MICROWIRE interface, a peripheral device requires some or all of the following:
DI Data Input. This is the serial input to the peripheral. This is connected to SO on the microcontroller. All MICROWIRE peripherals must have this pin.
SK Serial Clock. This is the serial clock connected to SK of the microcontroller. All MICROWIRE peripherals must have this pin.
CS Chip Select. This merely selects a particular device. It may be connected to any convenient microcontroller output. Chip Select is required in any multiple peripheral systems. In a single peripheral system, whether or not Chip Select must be connected to a microcontroller output depends on the peripheral itself and its design.
DO Data Output. This is the serial output from the peripheral. It is connected to SI of the microcontroller. DO is required only on peripherals that communicate back to the microcontroller.

\subsection*{2.4.6 Microbus}

Microbus is a universal eight-bit parallel system bus. Certain COPS microcontrollers have a mask option permitting them to be used as Microbus-compatible peripheral devices. As far as the COPS device is concerned, the Microbus is composed of the following elements:
- An eight-bit bidirectional data bus
- Data Strobes - a read strobe and write strobe
- Chip Select - to identify the device
- Interrupt/Acknowledge - return line to main CPU

In COPS microcontrollers, the data bus is the \(Q\) register-L drivers combination. If the device is selected and a write strobe occurs, data is transferred from the bus-L directly into the \(Q\) register. Similarly, if the device is selected and a read strobe occurs, data is copied from the \(Q\) register onto the bus-L. Input \(\mathbb{N}_{1}\) becomes \(\overline{R D}\), the read strobe. Input \(\mathbb{N}_{2}\) becomes \(\overline{\mathrm{CS}}\), the chip select. Input \(\mathrm{N}_{3}\) becomes \(\overline{\mathrm{WR}}\), the write strobe. Note that these three inputs are all active low. A logical " 0 " on \(\overline{\mathrm{CS}}\left(\mathrm{I} \mathrm{N}_{2}\right)\) selects the COPS device and enables operation of \(\overline{R D}\) and \(\overline{W R}\). A logical " 0 " on \(\overline{R D}\left(I N_{1}\right)\) or \(\overline{W R}\left(\mathrm{~N}_{3}\right)\) when \(\overline{\mathrm{CS}}\) is also a logical " 0 " will cause the data read or write as described above. I/O pin GO serves
as an interrupt/acknowledge or ready pin back to the main CPU. G0 is normally high-ready. It is set high by the user program. The occurrence of a write strobe while the device is selected automatically sets GO to the low or busy state. The user program sets GO high again.
The Microbus option on COPS microcontrollers is completely compatible with the Microbus standard. The timing and timing relationships are those defined by that standard.
The Microbus option is a mask option, i.e., a hardware option. The functions of \(\mathbb{N}_{1}, \mathbb{I N}_{2}, \mathbb{I N}_{3}, G 0\), and \(L\) drivers and the \(Q\) register are physically altered by this option. The Microbus option is available on the following COPS microcontrollers only: COP420, COP424C, COP444C, COP440 and COP441.

\subsection*{2.5 THE ENABLE REGISTER}

The ENABLE (EN) register is an internal four- or eight-bit loaded under program control. The state of the individual bits of this register selects or deselects certain features in the microcontroller.

\subsection*{2.5.1 \(\mathrm{EN}_{0}\) through \(\mathrm{EN}_{3}\)}

These four bits of the EN register are present on all COPS microcontrollers. Their function is as follows:
\(E N_{0}\), the least significant bit of the enable register, controls the status of the SIO register. With EN 0 set, a logical " 1 ", the SIO register is a four-bit asynchronous binary down counter decrementing its value by one upon each low going pulse at the Sl input. The pulse must be low at least two instruction cycles. With EN \(\mathrm{EN}_{0}\) equal to " 1 ", SO and SK are logic signals. SK outputs the value of SKL. SO outputs the value of \(E N_{3}\). With \(E N_{0}\) reset (low), the SIO register is a four-bit serial shift register that shifts left, from SI toward SO, one bit each instruction cycle time. Data is shifted into the least significant bit of SIO from SI. SO can be enabled to output the most significant bit of SIO. When EN 0 reset, SK becomes a logic controlled clock whose period is the instruction cycle time.
\(E N_{1}\) controls the interrupt. With \(E N_{1}\) set, the interrupt is enabled. If a signal meeting the timing requirements appears at the interrupt input when \(E N_{1}\) is set, the interrupt will be recognized. With \(E N_{1}\) reset, the interrupt is disabled, the signal at the interrupt input is ignored. Obviously, the status of \(E N_{1}\) is significant only in those COPS microcontrollers having interrupt capability.
\(E N_{2}\) controls the \(L\) drivers. With \(E N_{2}\) set, the \(L\) drivers output the data in the \(Q\) register to the \(L\) I/O port. With \(E N_{2}\) reset, the L drivers are disabled thereby placing the LI/O port into a high impedance, or TRI-STATE, condition. \(\mathrm{EN}_{2}\) has no effect on the L drivers in devices that have the Microbus option implemented.
On the COP440 and COP441, devices which have the Microbus option selected, \(E N_{2}\) serves a different function. In this case, \(\mathrm{EN}_{2}\) set will disable any writing, by the program, into GO which is the ready signal back to the main CPU.
\(\mathrm{EN}_{3}\), in conjunction with \(\mathrm{EN}_{0}\), controls the SO output. As stated above, if \(E N_{0}\) is set, SO outputs the value of \(E N_{3}\). If \(E N_{0}\) is reset and \(E N_{3}\) is set, SO is the output of the SIO serial shift register. If \(E N_{0}\) is reset and \(E N_{3}\) is reset \(S O\) is set to logical " 0 ". SIO remains a shift register shifting data in from SI; SO is merely held low by internal logic. Table IV provides a summary of the SIO modes associated with \(E N_{0}\) and \(\mathrm{EN}_{3}\).

TABLE IV. Effects of \(\mathrm{EN}_{3}, \mathrm{EN}_{0}\), on SIO, SI, SO, and SK
\begin{tabular}{c|c|c|l|l|c|c}
\hline \(\mathbf{E N}_{\mathbf{3}}\) & EN \(_{\mathbf{0}}\) & SKL & \multicolumn{1}{|c|}{ SIO } & \multicolumn{1}{|c}{ SI } & SO & SK \\
\hline 0 & 0 & 0 & Shift Register & Input to Shift Register & 0 & 0 \\
\hline 0 & 0 & 1 & Shift Register & Input to Shift Register & 0 & Clock \\
\hline 1 & 0 & 0 & Shift Register & Input to Shift Register & Serial Out & 0 \\
\hline 1 & 0 & 1 & Shift Register & Input to Shift Register & Serial Out & Clock \\
\hline 0 & 1 & 0 & Binary Down Counter & Input to Binary Counter & 0 & 0 \\
\hline 0 & 1 & 1 & Binary Down Counter & Input to Binary Counter & 0 & 1 \\
\hline 1 & 1 & 0 & Binary Down Counter & Input to Binary Counter & 1 & 0 \\
\hline 1 & 1 & 1 & Binary Down Counter & Input to Binary Counter & 1 & 1 \\
\hline
\end{tabular}

Note: SKL not affected by \(\mathrm{EN}_{3}\) or \(\mathrm{EN} \mathrm{N}_{0}\), but SKL does affect SK status.

\subsection*{2.5.2 \(\mathrm{EN}_{4}\) through EN \(\mathbf{7}_{7}\)}

These "extra" four bits of the enable register are present only in the following devices: COP440, COP441 and COP442. Obviously, therefore, the information in this section applies to those devices only.
\(E N_{4}\)-In conjunction with \(E N_{5}, E N_{4}\) selects the interrupt source. See Table V.
\(E N_{5}\)-In conjunction with \(E N_{4}, \mathrm{EN}_{5}\) selects the interrupt source. See Table V.
\(E N_{6}\)-With \(E N_{6}\) set (high), \(\mathrm{IN}_{2}\) becomes the input to the internal eight-bit \(T\) counter. With \(E N_{6}\) reset (low), the input to the eight-bit \(T\) counter is the output of a divide by 4 prescaler from the instruction cycle frequency, thus providing a ten-bit time base counter.
On the COP442 \(\mathrm{IN}_{2}\) is not available as an input. Therefore, on these devices, \(E N_{6}\) functions as a \(T\) counter disable: \(E N_{6}\) set disables further counting, and \(E N_{6}\) reset produces the ten-bit time base counter.
\(E N_{7}\) controls the R I/O port. With \(E N_{7}\) set, the contents of the R register are output to the R I/O port. With \(\mathrm{EN}_{7}\) reset, the R I/O port is placed into a TRI-STATE, or high impedance, condition. The contents of the \(R\) register are not affected.

TABLE V. Interrupt Source Selection
\begin{tabular}{|c|c|c|}
\hline\(E_{5}\) & EN \(_{4}\) & \multicolumn{1}{|c|}{ Interrupt Source } \\
\hline 0 & 0 & \(\mathbf{I N}_{1}\) - Low Going Pulse \\
\hline 0 & 1 & \begin{tabular}{c} 
CKO Input (if CKO Input Option \\
Mask Programmed)
\end{tabular} \\
\hline 1 & 0 & \begin{tabular}{l} 
Zero Crossing on \(\mathrm{IN}_{1}\) \\
(or \(\mathrm{IN}_{1}\) Level Transition)
\end{tabular} \\
\hline 1 & 1 & TCounter Overflows \\
\hline
\end{tabular}

\subsection*{2.6 INTERNAL TIMER}

All COPS microcontrollers except the COP410L, COP411L, COP413L, COP413C, COP410C, and COP411C have an internal time base counter. This counter is in the form of a ten-bit counter with the input being the instruction cycle frequency. Thus, this counter divides the instruction cycle frequency by 1024 or overflows once every 1024 instruction cycle times. A timer latch is set every time the counter overflows. This latch may be tested and reset (a single instruction) by the user's program.

\subsection*{2.6.1 Access to the Timer}

All COPS microcontrollers that have the time base counter have the ability to test and reset the timer latch. Some de-
vices, however, also have the ability to read and write the upper eight bits (the \(T\) counter) of the timer. The devices with this capability are as follows: The COP424C, COP425C, COP426C, COP444C/445C, COP440/441/442, and their associated ROMless devices. The timer overflow latch is still present and is still set when the counter overflows. These devices allow the user to modify, under program control, the overflow rate of the time base counter.

\subsection*{2.6.2 External Event Counter}

On some devices, the COP424C, COP444C, COP440/441, the upper eight bits or the \(T\) counter of the time base counter may be disconnected from the instruction cycle clock and connected to input \(\mathrm{IN}_{2}\). In this mode, the T counter counts external pulses. The timer overflow latch is set whenever the \(T\) counter overflows. The latch is tested in the normal manner. This characteristic is a mask option on the COP424C and COP444C devices. Thus, on these devices, the \(T\) counter may be connected to form the ten-bit time base counter or the \(T\) counter may be connected to \(\mathrm{IN}_{2}\) to count external events. On the COP440/441 devices, this characteristic is a software option. The user's program controls the connection of the \(T\) counter via \(E N_{6}\). There is no restriction, in these devices, on changing the \(T\) counter connection during program execution. The user is free to alternate between a time base counter and an external event counter if doing so is useful in his or her application.

\subsection*{2.7 OSCILLATOR AND BASIC TIMING}

\subsection*{2.7.1 Clock Generator and Divider}

The clock generator on COPS microcontrollers is extremely versatile and, by means of mask options, will work with a variety of oscillators: crystal, external, simple RC, or more involved RC, RLC, or LC networks. Furthermore, the clock generator will usually operate over a fairly large range in order to give the user maximum flexibility in selecting the oscillator frequency. Several divider (prescaler) options are available, as mask options, to insure that the COPS microcontroller is operating within its valid range with the oscillator frequency being used. See the various device data sheets for precise details regarding the oscillator frequency, clock generator, and divider.

\subsection*{2.7.2 The Instruction Cycle}

The instruction cycle frequency is the frequency after the divider or prescaler. The period of this frequency, or the instruction cycle time, is the basic timing reference in COPS
microcontrollers. Minimum pulse widths, for counter inputs, interrupt, etc., are expressed in terms of instruction cycle times. The highest degree of resolution with which a COPS microcontroller can read input pulses or generate output pulses is the instruction cycle time.
The instruction cycle time or frequency can be measured by the user. The period of the SK output when the microcontroller is reset (RESET low) or when SK is enabled as a clock output is the instruction cycle time.

\subsection*{2.8 INITIALIZATION}

On power up, providing the timing parameters in the data sheets are met, the following registers are cleared on all COPS microcontrollers: A, B, C, D, EN, G, and the program counter PC. The SK latch, SKL, is set on all devices. In addition the \(T\) counter is cleared on the COP440 series, the COP424C series, and the COP444C series devices. In the COP440 the IL register and the Q register are also cleared. (Note that these two registers are not cleared on other devices.) The \(R, H\), and \(N\) registers are also cleared on reset in the COP440.

Reset, or initialization, occurs on power up and whenever a logical " 0 " at least three instruction cycles wide appears at the RESET input. On the COP440 and the COP424C/ COP444C series devices, the T counter is cleared within these three instruction cycle times. On other COPS microcontrollers, the logical " 0 " at the RESET input must be ten cycles wide to clear the time base counter. In this situation, the timer overflow latch is set.
The reset condition of COPS microcontrollers is as follows:
- The program counter, PC, is set to 0 .
- The accumulator, \(A\), is 0 .
- The RAM address register, \(B\), is set to 0,0 .
- The carry, C, is set to 0 .
- The D register and D output port are set to 0 .
- The enable register is set to 0 and SKL set to 1 .
1. SIO is a shift register.
2. SI is shift register input.
3. SO is 0 .
4. SK is clock output.
5. Interrupts are disabled.
6. The \(L\) port is put into a high impedance, or TRI-STATE condition.
- The G output port is set to 0 .
- On the COP440/COP2440 series, the following is also true:
1. The \(Q\) register is set to 0 .
2. The H register and \(\mathrm{I} / \mathrm{O}\) port are set to 0 .
3. The R register is set to 0 .
4. The R I/O port is put into a high impedance, or TRISTATE condition.
5. The interrupt source is \(\mathrm{IN}_{\mathrm{l}}\), low-going pulse.
6. The T counter is cleared and connected to form the time base counter.
7. The IL register is set to 0 .

\subsection*{3.0 The COPS Instruction Set}

\subsection*{3.1 BASIC CHARACTERISTICS}

The instruction set of COPS microcontrollers is designed to take maximum advantage of the COPS dual-bus architecture. The COPS instruction set, merged with the COPS architecture, provides the user with the power, versatility, and efficiency to achieve the maximum function and capability in minimum memory.
Since COPS microcontrollers are not memory-mapped devices, most instructions do not have the burden of carrying some form of address field. Therefore, most instructions are one byte in length. This, in turn, increases program efficiency. ROM space is devoted to performing a function rather than pointing to the locations of various items.
It is quite common for a COPS instruction to contain a multiplicity of function. This obviously creates program efficiency by performing in a single instruction a number of functions that would otherwise require several instructions.
The test instructions, like most COPS instructions, do not contain an address. Therefore, a successful test causes the text instruction to be skipped. It is quite common for one or both of the instructions following the test to be jumps. More importantly, however, this skipping characteristic allows the programmer to do a number of "unusual" things. Tests without following jumps are common. B or A or other parameters can be altered in line without jumping by judicious use of the test instructions. Examples of this, and further details, are provided in Section 4. Furthermore, the skip feature has been "built into" a number of arithmetic functions thereby eliminating the need to make separate tests.

\subsection*{3.2 DETAILED INSTRUCTION DESCRIPTION}

For purposes of discussion and explanation, the COPS instructions are loosely grouped into the following six categories:
1. Arithmetic/Logic Instructions
2. Transfer of Control Instructions
3. Memory Reference Instructions
4. Register Reference Instructions
5. Test Instructions
6. Input/Output Instructions

This section provides a detailed description of all COPS instructions. This description includes the following information:
- The instruction mnemonic.
- A written description of the instruction.
- The data or program flow associated with the instruction.
- The instruction opcode in hex and binary.
- The instruction execution time-expressed in instruction cycles.
- Skip conditions associated with the instruction.
- Any restrictions on the instruction or its use; any "special effects" of the instruction.
- The COPS microcontrollers which have or do not have the instruction.

For ease and simplicity of description, the COPS microcontrollers are divided into the following four groups:
Group 1 devices: COP401L, COP410L, COP411L, COP413L, COP413C, COP410C, COP411C
Group 2 devices: COP402, COP402M, COP404L, COP404C, COP420, COP421, COP422, COP420L, COP421L, COP422L, COP424C, COP425C, COP444L, COP445L, COP444C, COP445C
Group 3 devices: COP404, COP440, COP441, COP442
The following list defines the symbols used in the descriptions of the instructions.
\begin{tabular}{|c|c|}
\hline A & 4-bit accumulator \\
\hline B & RAM address register \\
\hline Br & Upper bits of B, register address \\
\hline Bd & Lower 4 bits of B, digit address \\
\hline C & 1-bit carry register \\
\hline D & 4-bit data output port \\
\hline EN & Enable register \\
\hline G & 4-bit register to latch data for G I/O port \\
\hline H & 4-bit register to latch data for H 1/O port \\
\hline IL & Two 1-bit latches associated with IN3 and INO inputs \\
\hline IN & 4-bit input port \\
\hline \(\mathrm{N}_{1} \mathrm{Z}\) & Zero crossing input \\
\hline L & 8 -bit TRI-STATE I/O port \\
\hline M & 4-bit contents of RAM addressed by B \\
\hline \(N\) & Subroutine stack pointer \\
\hline PC & ROM address register, program counter \\
\hline Q & 8-bit register to latch data for L I/O port \\
\hline R & 8-bit register to latch data for R I/O port \\
\hline SIO & 4-bit shift register and counter \\
\hline SK & Logic controlled clock output \\
\hline T & 8 -bit binary counter register \\
\hline RAM (B) & 4-bit contents of RAM addressed by B \\
\hline \(\mathrm{RAM}_{\mathrm{N}}\) & Contents of RAM location addressed by stack pointer N \\
\hline ROM(t) & Contents of ROM location addressed by t \\
\hline \(\mathrm{PC}_{a} \mathrm{~b}\) & Bits a through b of program counter PC \\
\hline
\end{tabular}

\subsection*{3.2.1 Arithmetic/Logic Instructions}

\section*{ASC}

Binary add, with carry, the accumulator with the memory location specified by the B register. The result is placed in the accumulator. If result \(>15_{10}\), generate a skip.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \(A \leftarrow A+\) & & & \multicolumn{6}{|l|}{C: Set or reset according to carry from bit three} \\
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 30 & 0 & 0 & 1 & 1 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: If \(1 \rightarrow C\), skip
Restrictions: None
Availability: All COPS microcontrollers

\section*{ADD}

Binary add the accumulator with the memory location specified by the B register. Result is placed in the accumulator.
\(A \leftarrow A+R A M(B) \quad C:\) Not used or affected
Hex Code
31 \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\cline { 2 - 8 } & 0 & 0 & 1 & 1 & 0 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
ADT
Binary add 10 to the accumulator. Instruction used for decimal adjust.
\(A \leftarrow A+10_{10} \quad\) C: Not used or affected


Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: Not available on: Group 1 devices
AISC y
Binary add the immediate value \(y\) to the accumulator and place the result in the accumulator. Generate a skip if there is a carry out of bit 3 .
\[
A \leftarrow A+y \quad C: \text { Not used or affected }
\]
Hex Code
\(5 y\) \begin{tabular}{|cccc|cccc|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 1 & 0 & 1 & \(y_{3}\) & \(y_{2}\) & \(y_{1}\) & \(y_{0}\) \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: If carry from bit 3, skip
Restrictions: \(\quad y \neq 0,0<y \leq F H\)
Availability: All COPS microcontrollers

\section*{CASC}

Binary add, with carry, of the one's complement of the accumulator with the data in the memory location specified by the B register. Generate a skip if result \(>15_{10}\). This is the basic subtract instruction.
\(A \leftarrow \bar{A}+R A M(B)+C \quad\) C: Set or reset according to carry from bit three
Hex Code
10 \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\cline { 2 - 8 } & 0 & 0 & 0 & 1 & 0 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: If \(1 \rightarrow \mathrm{C}\), skip
Restrictions: None
Availability: \(\quad\) Not available on: Group 1 devices

CLRA
Clear the accumulator.
\(A \leftarrow 0\)
C: Not affected
Hex Code
00 \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers

\section*{COMP}

Replace the value in A with its one's complement.
\(A \leftarrow \bar{A} \quad C:\) Not affected
\begin{tabular}{l|llll|llll|} 
Hex Code \\
40 & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\cline { 2 - 8 } & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
NOP
No operation. C: Not affected
Hex Code
44 \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 1 & 0 & 0 & 0 & 1 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers

\section*{OR}

Logical OR of accumulator with contents of memory location specified by the \(B\) register. Result in accumulator.
\(A \leftarrow A \vee \operatorname{RAM}(B)\)
C: Not affected
Hex Code
33
\(1 A\) \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline 0 & 0 & 0 & 1 & 1 & 0 & 1 & 0 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
\(\begin{array}{ll}\text { Restrictions: } & \text { None } \\ \text { Availability: } & \text { Group } 3 \text { devices }\end{array}\)
RC
Reset/clear the one-bit carry register.
\(C \leftarrow 0 \quad\) A: Not affected
Hex Code
32 \begin{tabular}{|rrrr|rrrr|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\cline { 2 - 8 } & 0 & 0 & 1 & 1 & 0 & 0 & 1 \\
\hline
\end{tabular}
\begin{tabular}{ll} 
Execution Time: & 1 Instruction Cycle \\
Skip Conditions: & None \\
Restrictions: & None \\
Availability: & All COPS microcontrollers
\end{tabular}

\section*{SC}

Set the one-bit carry register.
\(C \leftarrow 1\) A: Not affected
Hex Code
22 \begin{tabular}{|llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\cline { 2 - 8 } & 0 & 0 & 1 & 0 & 0 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers

\section*{XOR}

Exclusive OR, bit by bit, of accumulator with contents of memory location specified by the B register. Result placed in accumulator.
\(A \leftarrow A \oplus \operatorname{RAM}(B) \quad C:\) Not affected


Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers

\subsection*{3.2.2 Transfer of Control Instructions}

JID
Jump Indirect. This involves a two-step modification of the program counter. First, load the lower eight bits of the program counter with the contents of the accumulator (upper four bits) and the memory location specified by the B register. The data addressed by this modified program counter is then loaded into the lower eight bits of the program counter. Execution continues at this second address.
(1) PC \(\leftarrow \mathrm{PC}+1 \quad \mathrm{C}\) : Not affected
(2) \(\mathrm{PC}_{7: 0} \leftarrow \mathrm{~A}, \mathrm{RAM}(B) \quad \mathrm{A}\) : Not affected
(3) \(\mathrm{PC} \quad \leftarrow \mathrm{PC}+1\)
(4) \(\mathrm{PC}_{7: 0} \leftarrow \operatorname{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \operatorname{RAM}(\mathrm{~B})\right)\)
Hex Code
FF \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: JID at last word of block looks to next block for vector addresses (step one above). Vector address at last word of block points into next block (Step 3, 4 above).
Availability: All COPS microcontrollers
JMP a
Jump Direct. Load the program counter (lower 11 bits) with the address specified in the instruction. Continue program execution at this address.
\(\mathrm{PC}_{10: 0} \leftarrow\) a \(\quad \mathrm{C}:\) Not affected
A: Not affected
Hex Code
\(6-\)
- \begin{tabular}{ccccccccc|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{cccc|ccc}
0 & 1 & 1 & 0 & 0 & \(a_{10}\) & \(a_{9}\) \\
\(a_{8}\) \\
\(a_{7}\) & \(a_{6}\) & \(a_{5}\) & \(a_{4}\) & \(a_{3}\) & \(a_{2}\) & \(a_{1}\) \\
\(a_{0}\) \\
\hline
\end{tabular}
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: \(\quad a_{10}=0, a_{9}=0\) Group 1 devices
\(\mathrm{a}_{10}=0\) in 1 k devices
JMP in last two words of chapter jumps
to next chapter
Availability: All COPS microcontrollers
JP a
Jump within Page.
(1) \(\mathrm{PC} \quad \leftarrow \mathrm{PC}+1 \quad \mathrm{C}\) : Not affected
(2) \(\mathrm{PC}_{6: 0} \leftarrow\) a-pages 2,3 only A : Not affected
or
(2) \(\mathrm{PC}_{5: 0} \leftarrow \mathrm{a}\)-all other pages

(above for pages 2, 3 only)
\begin{tabular}{|llll|llll|}
\hline 1 & 1 & \(a_{5}\) & \(a_{4}\) & \(a_{3}\) & \(a_{2}\) & \(a_{1}\) & \(a_{0}\) \\
\hline
\end{tabular}
(all other pages)
Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: May not JP to last word of a page. JP in last word of a page jumps to next page (Step 1 above).
Availability: All COPS microcontrollers
JSRP a
Jump to subroutine within Page 2.
(1) \(\mathrm{PC} \leftarrow \mathrm{PC}+1\)
(2) \(\mathrm{SB} \leftarrow \mathrm{SA} \leftarrow \mathrm{PC} \quad\) Group 1 devices
or
(2) \(\mathrm{SC} \leftarrow \mathrm{SB} \leftarrow \mathrm{SA} \leftarrow \mathrm{PC} \quad\) Group 2 devices
or
(2) RAM \(_{N} \leftarrow P C \quad\) Group 3 and Group 4 devices
\(N \leftarrow N+1\)
(3) \(\mathrm{PC}_{5: 0} \leftarrow \mathrm{a}\) address within Page 2
\(\mathrm{PC}_{8: 6} \leftarrow 010\) load Page 2
\(\mathrm{PC}_{\text {all other }} \leftarrow 0\)


Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: \(\quad\) May not be used within Pages 2 and 3 May not JSRP to last word of Page 2
Availability: All COPS microcontrollers
JSR a
Jump to subroutine direct. Load lower 11 bits of the program counter with the address a. Push the subroutine stack. Continue execution at the address specified by the instruction.
(1) \(\mathrm{PC} \leftarrow \mathrm{PC}+2\)
(2) \(\mathrm{SB} \leftarrow \mathrm{SA} \leftarrow \mathrm{PC} \quad\) Group 1 devices
or
(2) \(\mathrm{SC} \leftarrow \mathrm{SB} \leftarrow \mathrm{SA} \leftarrow \mathrm{PC} \quad\) Group 2 devices or
(2) RAM \(_{N} \leftarrow \mathrm{PC} ; \mathrm{N} \leftarrow \mathrm{N}+1 \quad\) Group 3 and Group 4 devices
(3) \(\mathrm{PC}_{10: 0} \leftarrow \mathrm{a}\)
Hex Code
\(6-\)
- \(\quad\)\begin{tabular}{cccc|cccc}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 1 & 1 & 0 & 1 & \(a_{10}\) & \(a_{9}\) & \(a_{8}\) \\
\(a_{7}\) & \(a_{6}\) & \(a_{5}\) & \(a_{4}\) & \(a_{3}\) & \(a_{2}\) & \(a_{1}\) & \(a_{0}\) \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: \(\quad a_{10}=0, a_{9}=0\) in Group 1 devices \(\mathrm{a}_{10}=0\) in 1 k devices JSR in last two words of chapter calls subroutine in next chapter.
Availability: All COPS microcontrollers

\section*{RET}

Return from subroutine and return control to the main program at the instruction following the JSR, or JSRP, or JSRL.
\(\mathrm{PC} \leftarrow \mathrm{SA} \leftarrow \mathrm{SB} \quad\) Group 1 devices
or
\(\mathrm{PC} \leftarrow \mathrm{SA} \leftarrow \mathrm{SB} \leftarrow \mathrm{SC} \quad\) Group 2 devices
or
\(N \leftarrow N-1 \quad\) Group 3 and Group 4 devices
\(\mathrm{PC} \leftarrow \mathrm{RAM}_{\mathrm{N}}\)
Hex Code
48 \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\cline { 2 - 9 } & 0 & 1 & 0 & 0 & 1 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers

\section*{RETSK}

Return from subroutine. Return control to the main program and always skip the instruction following the JSR, JSRP, or JSRL.
\(\mathrm{PC} \leftarrow \mathrm{SA} \leftarrow \mathrm{SB} \quad\) Group 1 devices
or
\(\mathrm{PC} \leftarrow \mathrm{SA} \leftarrow \mathrm{SB} \leftarrow \mathrm{SC}\) Group 2 devices
or
\(N \leftarrow N-1, P C \leftarrow\) RAM \(_{N}\) Group 3 and Group 4 devices


Execution Time: 1 Instruction Cycle
Skip Conditions: Always skip on return
Restrictions:
None
Availability: All COPS microcontrollers

\section*{HALT}

Stop all internal operation of the device. Retain all internal status. Resume operation as result of external stimulus.
A, B, C, PC, G, L, Q, EN, RAM, T:
\begin{tabular}{l} 
Hex Code \\
3
\end{tabular} \begin{tabular}{lllll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
38 & 0 & 0 & 1 & 1 & 1 & 0 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None

Restrictions: Requires Hardware external restart Availability: COP410C, COP411C, COP413C,

COP424C, COP425C, COP426C, COP444C, COP445C, and COP404C
Note: This instruction places the eight microcontrollers mentioned above in their minimum power dissipation state.

\section*{IT}

Stop all internal operation, except the timer, of the device. Resume operation at the instruction following IT when the timer overflows.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \(\mathrm{PC} \leftarrow \mathrm{PC}\) & \multicolumn{8}{|l|}{A, B, C, G, L, Q, EN, PC, RAM: Not affected} \\
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline 39 & 0 & 0 & 1 & 1 & 1 & 0 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: COP424C, COP425C, COP426C, COP444C, COP445C, COP404C

\subsection*{3.2.3 Memory Reference Instructions \\ CAME}

Copy the eight-bit contents of \(A\) and the memory location addressed by the B register to the eight-bit enable register (Note: the enable register is eight bits long in COP440 and COP2440 series only). This is the inverse of the CEMA instruction in function and with respect to the four bits of the enable register with which A and RAM(B) communicate.
\(\mathrm{EN}_{7: 4} \leftarrow \mathrm{~A}_{3: 0} \quad \mathrm{~A}:\) Not affected
\(\mathrm{EN}_{3: 0} \leftarrow \operatorname{RAM}(\mathrm{~B})_{3: 0} \quad \mathrm{C}:\) Not affected
Hex Code
33
\(1 F\) \begin{tabular}{|cccc|cccc|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 0 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: Group 3 devices

\section*{CAMQ}

Copy the eight-bit contents of the accumulator and the memory location addressed by the B register to the eight-bit Q register. This is the inverse of the CQMA instruction in function and with respect to the four bits of \(Q\) with which \(A\) and RAM(B) communicate.
\(Q_{7: 4} \leftarrow A_{3: 0} \quad A:\) Not affected
\(Q_{3: 0} \leftarrow \operatorname{RAM}(B)_{3: 0} \quad\) C: Not affected
\begin{tabular}{l|llll|llll|} 
Hex Code \\
33 \\
\(3 C\)
\end{tabular}\(\quad\)\begin{tabular}{|llll|l}
7 & 6 & 5 & 4 & 3 \\
0 & 0 & 1 & 1 & 0 \\
0 & 0 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 1 \\
1 & 1 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers

\section*{CAMT}

Copy the eight-bit contents of the accumulator and the memory location addressed by the \(B\) register to the eight-bit timer register ( T ). This is the inverse of the CTMA instruction in function and with respect to the four bits of \(T\) with which \(A\) and M communicated.
\(\mathrm{T}_{7: 4} \leftarrow \mathrm{~A}_{3: 0} \quad\) A: Not affected
\(\mathrm{T}_{3: 0} \leftarrow \operatorname{RAM}(\mathrm{~B})_{3: 0} \quad \mathrm{~B}:\) Not affected
Hex Code
33
\(3 F\) \begin{tabular}{|llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: Group 3 devices, COP424C, COP425C, COP426C, COP444C, COP445C, COP404C

\section*{CEMA}

Copy the contents of the eight-bit enable register (COP440 series only) to the memory location addressed by the B register and to the accumulator. This is the inverse of the CAME instruction in function and with respect to the four bits of the enable register with which \(A\) and RAM(B) communicate.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \(\mathrm{A}_{3: 0} \leftarrow E N\) & & Not & fec & & & & & \\
\hline RAM \((\mathrm{B})_{3: 0}\) & & & & & & & & \\
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline OF & 0 & 0 & 0 & 0 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: Group 3 devices

\section*{CQMA}

Copy the cont ints of the eight-bit Q register to the memory location addressed by the B register and to the accumulator. This is the inverse of the CAMQ instruction in function and with respect to the four bits of the Q register with which \(A\) and RAM(B) communicate.
\(A_{3: 0} \leftarrow Q_{3: 0} \quad C:\) Not affected
\(\operatorname{RAM}(B)_{3: 0} \leftarrow Q_{7: 4}\)
Hex Code
33
2C \begin{tabular}{|llll|llll|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 0 & 1 & 1 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: Not available on COP410L, COP411L, COP401L, COP410C, COP411C

\section*{CTMA}

Copy the eight-bit contents of the time register to the memory location addressed by the B register and to the accumulator. This is the inverse of the CAMT instruction in function and with respect to the four bits of \(T\) with which \(A\) and RAM \((B)\) communicate.
\(A_{3: 0} \leftarrow T_{3: 0} \quad\) C: Not affected
\(\operatorname{RAM}(B)_{3: 0} \leftarrow \mathrm{~T}_{7: 4}\)
\begin{tabular}{lllllllll|} 
Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
33 \\
\(2 F\) & \begin{tabular}{llll|l}
0 & 0 & 1 & 1 & 0 \\
0 & 0 & 1 & 1 \\
0 & 0 & 1 & 0 & 1 \\
1 & 1 & 1 \\
\hline
\end{tabular}
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: Group 3 devices, COP424C, COP425C, COP426C, COP444C, COP445C, COP404C
LD \(n\)
Load the accumulator with the contents of the memory location addressed by the B register. Also, exclusive-OR the upper part of the \(B\) register \((\mathrm{Br})\) with the \(n\) value.
\(A \leftarrow \operatorname{RAM}(B) \quad C:\) Not affected
\(\mathrm{Br} \leftarrow \mathrm{Br} \oplus n\)
Hex Code
n5 \begin{tabular}{|cccc|ccc|}
7 & 6 & 5 & 4 & 3 & 2 & 1 \\
0 & 0 \\
\cline { 2 - 7 } \multicolumn{1}{c|}{\(n=0,1,2\), or 3}
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: \(\quad n=0,1,2,3\) only
Availability: All COPS microcontrollers
LDD r,d
Load the accumulator with the contents of the memory addressed by the operand field, \(r\) r,d. The B register is not used or altered.
\(\begin{array}{ll}\mathrm{A} \leftarrow \operatorname{RAM}(r, d) & \text { B: Not affected } \\ & \text { C: Not affected }\end{array}\)
Hex Code
23
rd \(\quad\)\begin{tabular}{|cccc|cccc|}
\hline 0 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 0 & 0 & 0 & 1 & 1 \\
0 & \(r_{2}\) & \(r_{1}\) & \(r_{0}\) & \(d_{3}\) & \(d_{2}\) & \(d_{1}\) & \(d_{0}\) \\
\hline
\end{tabular}
\[
r=0: 7 ; d=0: 15
\]

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: \(\quad r=0,1,2,3,4,5,6\), or 7 only
Availability: \(\quad\) Not available in Group 1 devices

\section*{LID}

Load the accumulator and the memory location addressed by the R register ith the eight-bit ROM word addressed by the upper bits of the program counter, \(A\) and RAM(B).
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{9}{|l|}{\(\mathrm{PC} \leftarrow \mathrm{PC}+2 \quad \mathrm{C}\) : Not affected} \\
\hline \multicolumn{9}{|l|}{\(\mathrm{RAM}(\mathrm{B}) \leftarrow \operatorname{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{RAM}(\mathrm{B})\right)_{7} \mathbf{4}\)} \\
\hline \multicolumn{9}{|l|}{\(A \leftarrow \operatorname{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{RAM}(\mathrm{B})\right)_{3: 0}\)} \\
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline 19 & 0 & 0 & 0 & 1 & 1 & 0 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 3 Instruction Cycles
Skip Conditions: None

Restrictions:

Availability:

\section*{LQID}

Load the \(Q\) register with the eight-bit ROM word addressed by the upper bits of the program counter, the accumulator and the memory location addressed by the B register.
\(P C \leftarrow P C+1 \quad A:\) Not affected
\(\mathrm{Q}_{7: 4} \leftarrow \operatorname{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{RAM}(\mathrm{B})\right)_{7: 4} \quad\) C: Not affected
\(\mathrm{Q}_{3: 30} \leftarrow \operatorname{ROM}\left(\mathrm{PC}_{10: 8}, \mathrm{~A}, \mathrm{RA},(\mathrm{B})\right)_{3: 0}\)


Execution Time: 2 Instruction Cycles

\section*{Skip Conditions: None}

Restrictions: LQID in last word of a block accesses next block (\#1 above). One level of subroutine stack is used by this instruction in Group 1 and Group 2 devices.
Availability: All COPS microcontrollers

\section*{RMB 0, RMB 1, RMB3}

Reset the bit specified in the instruction in the memory location addressed by the B register.
RAM \((B) n \leftarrow 0 \quad\) C: Not affected
\(n=n, 1,2,3 \quad A:\) Not affected
\begin{tabular}{lll} 
& Hex Code \\
RMB & 0 & 4 C \\
RMB & 1 & 45 \\
RMB & 2 & 42 \\
RMB & 3 & 43
\end{tabular}\(\quad\)\begin{tabular}{|llllllll|}
\hline 0 & 1 & 0 & 5 & 4 & 0 & 1 & 1 \\
0 & 0 & 0 \\
\hline 0 & 1 & 0 & 0 & 0 & 1 & 0 & 1 \\
\hline 0 & 1 & 0 & 0 & 0 & 0 & 1 & 0 \\
\hline 0 & 1 & 0 & 0 & 0 & 0 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
SMB 0, SMB 1, SMB2, SMB 3
Set the bit specified in the instruction in the memory location addressed by the \(B\) register.

RAM \((B) n \leftarrow 1 \quad C\) : Not affected
\(n=0,1,2,3 \quad\) A: Not affected
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline & & Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline SMB & 0 & 4D & 0 & 1 & 0 & 0 & 1 & 1 & 0 & 1 \\
\hline SMB & 1 & 47 & 0 & 1 & 0 & 0 & 0 & 1 & 1 & 1 \\
\hline SMB & 2 & 46 & 0 & 1 & 0 & 0 & 0 & 1 & 1 & 0 \\
\hline SMB & 3 & 4B & 0 & 1 & 0 & 0 & 1 & 0 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
STII \(y\)
Store the immediate value y into the memory location addressed by the B register. Then increment the lower four
bits of the \(B\) register (Bd). The upper portion of the \(B\) register \((\mathrm{Br})\) is not affected.

RAM \((B) \leftarrow y \quad A:\) Not affected
\(\mathrm{Bd} \leftarrow \mathrm{Bd}+1 \quad \mathrm{C}:\) Not affected
Hex Code
\(7 y\) \begin{tabular}{|cccc|cccc}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\cline { 2 - 8 } & 0 & 1 & 1 & 1 & \(y_{3}\) & \(y_{2}\) & \(y_{1}\) \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
X \(n\)
Exchange the contents of the accumulator with the contents of the memory location addressed by the B register. Then replace Br with the exclusive OR of Br and n . Bd is not affected.


Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: \(\quad n=0,1,2\), or 3 only
Availability: All COPS microcontrollers
XAD r,d
Exchange the contents of the accumulator with the contents of the memory location addressed by \(\mathrm{r}, \mathrm{d}\). The B register is not affected.
\(A \longleftrightarrow R A M(r, d)\)
B: Not affected
C: Not affected

Group 1 devices 2
\(\begin{array}{lllllllll}\text { Hex Code } & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}\)
\begin{tabular}{|llll|llll|}
\hline 0 & 0 & 1 & 0 & 0 & 0 & 1 & 1 \\
\hline 1 & 0 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

All Others 23
r,d
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0 & 0 & 1 & 0 & 0 & 0 & 1 & 1 \\
\hline 1 & \({ }_{2}\) & 1 & 0 & \(\mathrm{d}_{3}\) & \(\mathrm{d}_{2}\) & & \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: On Group 1 devices; \(r=3, d=15\) only All other COPS microcontrollers:
\(r=0,1,2,3,4,5,6\), or 7 only
Availability: All COPS microcontrollers
XDS \(n\)
Exchange the contents of the accumulator with the contents of the memory location addressed by the B register. Replace Br with the exclusive OR of Br and n . Decrement Bd by 1. Generate a skip if Bd decrements from 0 to 15.
\(\mathrm{A} \longleftrightarrow \mathrm{RAM}(\mathrm{B}) \quad \mathrm{C}:\) Not affected
\(\mathrm{Br} \longleftarrow \mathrm{Br} \oplus \mathrm{n}\)
\(\mathrm{Bd} \longleftarrow \mathrm{Bd}-1\)


Execution Time: 1 Instruction Cycle
Skip Conditions: Generate a skip if \(\mathrm{Bd}-1=15\)
Restrictions: \(\quad n=0,1,2\), or 3 only
Availability: All COPS microcontrollers
XIS \(n\)
Exchange the contents of the accumulator with the contents of the memory location addressed by the B register. Replace Br with the exclusive OR of Br and n . Increment Bd by one. Generate a skip if Bd increments from 15 to 0 .
\(A \longleftrightarrow\) RAM (B) \(\quad\) C: Not affected
\(\mathrm{Br} \leftarrow \mathrm{Br} \oplus n\)
\(\mathrm{Bd} \leftarrow \mathrm{Bd}+1\)

\[
n=0,1,2,3
\]

Execution Time: 1 Instruction Cycle
Skip Conditions: Generate a skip if \(\mathrm{Bd}+1=0\)
Restrictions: \(\quad n=0,1,2\), or 3 only
Availability: All COPS microcontrollers

\subsection*{3.2.4 Register Reference Instructions}

CAB
Copy the contents of the accumulator to the lower four bits of the B register.
\(\mathrm{Bd} \leftarrow \mathrm{A} \quad \mathrm{A}:\) Not affected
C: Not affected
Br: Not affected
Hex Code
50 \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 1 & 0 & 1 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
\begin{tabular}{ll} 
Execution Time: & 1 Instruction Cycle \\
Skip Conditions: & None \\
Restrictions: & None \\
Availability: & All COPS microcontrollers \\
CBA &
\end{tabular}

Copy the lower four bits of the B register to the accumulator.
\(\mathrm{A} \leftarrow \mathrm{Bd} \quad \mathrm{C}:\) Not affected
B: Not affected


Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
LBI r,d
Load the B register immediate with the values r (to the upper portion of the \(B\) register). Skip all subsequent LBI instructions until an instruction that is not an LBI is encountered.
\(\begin{array}{ll}\mathrm{Br} \leftarrow \mathrm{r} & \mathrm{A}: \text { Not affected } \\ \mathrm{Bd} \leftarrow \mathrm{d} & \mathrm{C}: \text { Not affected }\end{array}\)
\begin{tabular}{l|cccc|ccc|} 
Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 \\
\(r(d-1)\) & 0 & 0 & \(R_{1}\) & \(R_{0}\) & \((d-1)\) \\
\hline
\end{tabular}
\[
r=0: 3 ; d=0,9: 15
\]
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline rd & 1 & r2 & 11 & r0 & d3 & d2 & d1 & d0 \\
\hline
\end{tabular}
\begin{tabular}{l|cccc|cccc|}
\multicolumn{8}{c|}{\(r=0: 7 ; d=0: 15\)} \\
33 \\
\(7-\) \\
rd & \begin{tabular}{cccc|ccc}
0 & 0 & 1 & 1 & 0 & 0 & 1 \\
0 & 1 \\
0 & 1 & 1 & 1 & 0 & 0 & 0 \\
\(r 3\) & \(r 2\) & \(r 1\) & \(r 0\) & \(d 3\) & \(d 2\) & \(d 1\) \\
r2 & \(d 0\) \\
\hline
\end{tabular}
\end{tabular}
\[
r=0: 31 ; d=0: 15
\]

Execution Time: 1 Instruction Cycle (One-byte form)
2 Instruction Cycles (Two-byte form)
3 Instruction Cycles (Three-byte form)
Skip Conditions: Skip until not an LBI
Restrictions: One-byte form:
\[
\begin{aligned}
& r=0,1,2,3 \text { only } \\
& d=0,9,10,11,12,13,14,15 \text { only }
\end{aligned}
\]

Two-byte form: \(r=0,1,2,3,4,5,6,7\) only Three-byte form: None
Availability: One-byte form: All COPS microcontrollers
Two-byte form: Not available on Group 1 devices
Three-byte form: Available on Group 4 devices only
LEI y
Load the enable regiter (lower four bits on COP440 and COP2440 series) with the immediate value \(y\).
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \(\mathrm{EN}_{3}: 0 \leftarrow \mathrm{y}\) & \multicolumn{4}{|l|}{\begin{tabular}{l}
A: Not affected \\
C: Not affected
\end{tabular}} & & & & \\
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline 6 y & 0 & 1 & 1 & 0 & \(\mathrm{y}_{3}\) & \(\mathrm{y}_{2}\) & \(y_{1}\) & \(y_{0}\) \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
XABR
Exchange the contents of the accumulator with the contents of the upper part of the B register ( Br ). If Br is less than four bits wide, zeroes are placed in the corresponding bits of the accumulator.
\(\mathrm{Br} \longleftrightarrow \mathrm{A}, \mathrm{A}_{3} \leftarrow 0, \mathrm{~A}_{2} \leftarrow 0 \quad\) Devices with 64 or 32 RAM digits
\(\mathrm{Br} \longleftrightarrow \mathrm{A}, \mathrm{A}_{\mathrm{S}} \leftarrow 0 \quad\) COP404L, COP404C, COP444L, COP445L, COP444C, COP445C
\(\mathrm{Br} \longleftrightarrow \mathrm{A} \quad\) Group 3 and Group 4 devices
Hex Code
12 \begin{tabular}{|llllllll}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 0 & 1 & 0 & 0 & 1 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: \(\quad\) Not available on Group 1 devices

\section*{XAN}

Exchange the contents of the accumulator with the contents of the two-bit subroutine stack pointer. The lower two bits of A go into the stack pointer and the same two bits of \(A\) are loaded with the pointer value. The upper two bits of \(A\) are cleared.
\(A_{1}: 0 \longleftrightarrow N \quad C:\) Not affected
\(A_{2} \leftarrow 0, A_{3} \leftarrow 0\)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline OB & 0 & 0 & 0 & 0 & 1 & 0 & 1 & 1 \\
\hline
\end{tabular}
\begin{tabular}{ll} 
Execution Time: & 2 Instruction Cycles \\
Skip Conditions: & None \\
Restrictions: & None \\
Availability: & Group 3 devices
\end{tabular}

\subsection*{3.2.5 Test Instructions}

\section*{SKC}

If the one-bit carry register ( C ) is equal to " 1 ", skip the next program instruction.

A: Not affected
C: Not affected
Hex Code
20 \begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: Skip if \(\mathrm{C}=1\)
Restrictions: None
Availability: All COPS microcontrollers

\section*{SKE}

If the contents of the accumulator are equal to the contents of the memory location addressed by the B register, skip the next program instruction.

A: Not affected
C: Not affected
Hex Code
21 \begin{tabular}{|llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 0 & 0 & 0 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: \(\quad\) Skip if \(A=\operatorname{RAM}(B)\)
Restrictions:
None
Availability: All COPS microcontrollers

\section*{SKGZ}

If all four \(G\) lines are low (" 0 "), skip the next program instruction.

\section*{A: Not affected}

C: Not affected
G: Not affected
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline 21 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: \(\quad\) Skip if \(\mathrm{G}_{3: 0}=0\)
Restrictions: None
Availability: All COPS microcontrollers
SKGBZ \(n, \quad n=0,1,2,3\)
If \(\mathrm{G}(\mathrm{n})\) is zero, skip the next program instruction.
A,C,G: Not affected
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline & & Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{SKGBZ} & \multirow[t]{2}{*}{0} & 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline & & 01 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 \\
\hline \multirow[t]{2}{*}{SKGBZ} & \multirow[t]{2}{*}{1} & 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline & & 11 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 1 \\
\hline \multirow[t]{2}{*}{SKGBZ} & \multirow[t]{2}{*}{2} & 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline & & 03 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 1 \\
\hline \multirow[t]{2}{*}{SKGBZ} & \multirow[t]{2}{*}{2} & 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline & & 13 & 0 & 0 & 0 & 1 & 0 & 0 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: Skip if specified \(G\) bit is zero
Restrictions:
Availability: All COPS microcontrollers
SKMBZ \(\boldsymbol{n} \quad \mathbf{n}=0,1,2,3\)
If the specified bit in the memory location addressed by the \(B\) register is " 0 ", skip the next program instruction.

A,C,RAM(B): Not affected
\begin{tabular}{lll} 
& & Hex Code \\
SKMBZ & 0 & 01
\end{tabular}\(\quad\)\begin{tabular}{|llllllll|}
\hline 0 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 \\
\hline SKMBZ & 1 & 11 & \begin{tabular}{|llll|llll|}
\hline 0 & 0 & 0 & 1 & 0 & 0 & 0 & 1 \\
\hline
\end{tabular} \\
SKMBZ & 2 & 03 & \begin{tabular}{|llll|llll}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 1 & 1 \\
\hline
\end{tabular} &
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: \(\quad\) Skip if \(\operatorname{RAM}(B) \mathrm{n}=0\)
Restrictions:
None
Availability: All COPS microcontrollers

\section*{SKSZ}

If the four-bit serial input/output register is " 0 ", skip the next program instruction.

\section*{A,C: Not affected}
Hex Code \begin{tabular}{llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
33 \\
\(1 C\)
\end{tabular}\(\quad\)\begin{tabular}{|llllll}
0 & 0 & 1 & 1 & 0 & 0 \\
1 & 1 \\
0 & 0 & 0 & 1 & 1 & 1 \\
0 & 0 & 0 \\
\hline
\end{tabular}\(~\)

Execution Time: 2 Instruction Cycles
Skip Conditions: \(\quad\) Skip if SIO \(=0\)
Restrictions: None
Availability: Group 3 devices

\section*{SKT}

If T counter carry (overflow) has occurred since the last test (last SKT), skip the next program instruction. Reset the SKT latch. (Timer carry/overflow sets SKT latch. SKT instruction tests and resets this latch).

SKTL \(\leftarrow 0 \quad\) A,C,T: Not affected
Hex Code
41 \begin{tabular}{|cccc|cccc|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 1 & 0 & 0 & 0 & 0 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: \(\quad\) Skip if SKTL \(=1\)
Restrictions: None
Availability: \(\quad\) Not available on Group 1 devices

\subsection*{3.2.6 Input/Output Instructions}

\section*{CAMR}

Copy the contents of the accumulator and the memory location addressed by the \(B\) register to the eight-bit R port. This is the inverse of the INR instruction in function and with respect to the four bits of R which are accessed by A and RAM(B).
\(\mathrm{R}_{7: 4} \leftarrow \mathrm{~A} \quad \mathrm{~A}:\) Not affected
\(\mathrm{R}_{3: 0} \leftarrow \operatorname{RAM}(\mathrm{~B}) \quad\) C: Not affected
Hex Code
33
\(3 D\)\(\quad\)\begin{tabular}{|llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 1 & 1 & 1 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: ' Group 3 devices
Note: On COP441 and COP442,R as I/O port is not present, but R as eightbit internal register is available.

\section*{ING}

Copy the status of the G I/O port into the accumulator.
\(A \leftarrow G\)
C: Not affected
G: Not affected
Hex Code
33
2 A \begin{tabular}{|llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 0 & 1 & 0 & 1 & 0 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions:
None
Availability: All COPS microcontrollers

\section*{INH}

Copy the status of the H I/O port to the accumulator.
\[
\begin{aligned}
A \leftarrow H & \text { C: Not affected } \\
& H: \text { Not affected }
\end{aligned}
\]
Hex Code
33
\(2 B\) \begin{tabular}{|llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 0 & 1 & 0 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: Group 3 devices
Note: On COP441 and COP442, H as I/O port is not present, but H as fourbit internal register is available.

\section*{ININ}

Copy the status of the four \(\operatorname{IN}\) lines to the accumulator.
\(A \leftarrow \mathbb{I N} \quad\) C: Not affected
Hex Code
33
28 \(\quad\)\begin{tabular}{|llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 0 & 1 & 0 & 0 & 0 \\
\hline
\end{tabular}
\begin{tabular}{ll} 
Execution Time: & 2 Instruction Cycles \\
Skip Conditions: & None \\
Restrictions: & None \\
Availability: & COP420, COP420L, COP444L, COP440, \\
& COP441, COP424C, COP444C
\end{tabular}

INIL
Copy the status of the IL latches and CKO input and zero cross input (COP440, 441) to the accumulator. Reset the IL latches.

1a) A 3:0 \(0 \leftarrow\) IL 3, CKO, IN 1Z, IL \(0 \quad\) COP440, COP441
or
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline 1b) A \(3: 0 \leftarrow\) & 3, & KO, & & & \multicolumn{4}{|l|}{\[
\begin{aligned}
& \text { COP420, COP420L, } \\
& \text { COP444L, COP424C, } \\
& \text { COP444C }
\end{aligned}
\]} \\
\hline \multicolumn{9}{|l|}{or} \\
\hline \multicolumn{5}{|l|}{1c) A 3:0 ¢ "0', CKO, "0", "0"} & \multicolumn{4}{|l|}{\[
\begin{aligned}
& \text { COP442, COP2442, } \\
& \text { COP421, COP422, } \\
& \text { COP421L, COP422L, } \\
& \text { COP445C, COP425C, } \\
& \text { COP426C }
\end{aligned}
\]} \\
\hline \multicolumn{9}{|l|}{2) \(\mathrm{IL}_{3} \leftarrow 0, \mathrm{IL}_{0} \leftarrow 0\)} \\
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & & 0 & 1 & 1 & 0 & 0 & & 1 \\
\hline 29 & 0 & 0 & 1 & 0 & 1 & 0 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: If CKO is not selected as general input, " 1 " is loaded into \(A_{2}\). IL latches are reset at power on in Group 3 and Group 4 devices only. On other devices, the latches are undefined until first INIL.
Availability:
Not available on Group 1 devices

\section*{INL}

Copy the status of the eight-bit \(L\) port to the memory location addressed by the B register and the accumulator.
\(\operatorname{RAM}(B) \leftarrow L_{7: 4} \quad\) C: Not affected
\(A \leftarrow L_{3: 0}\)
Hex Code
33
2 E \(\quad\)\begin{tabular}{|llll|llll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 0 & 1 & 1 & 1 & 0 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
INR
Copy the status of the eight-bit R port to the memory location addressed by the B register and the accumulator. This is the inverse of the CAMR instruction and with respect to the four bits of \(R\) which are accessed by \(A\) and RAM(B).
\(\operatorname{RAM}(B) \leftarrow R_{7: 4} \quad C:\) Not affected
\(A \leftarrow R_{3: 0}\)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 33 & 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline 2D & 0 & 0 & 1 & 0 & 1 & 1 & 0 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: Group 3 devices
Note: On COP441 and COP442, R as an I/O port is not present but R as eight-bit internal register is available.

\section*{OBD}

Copy the contents of the lower four bits of the B register (Bd) to the D output port.
\(D \leftarrow\) Bd A: Not affected
B: Not affected
C: Not affected
\begin{tabular}{l|llllllll|} 
Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
33 \\
\(3 E\)
\end{tabular}\(\quad\)\begin{tabular}{|llll|llll}
0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 1 & 1 & 1 & 1 & 0 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers
OGI y
Output the immediate value \(y\) to the four-bit \(G\) port.
\(G \leftarrow y\)
A: Not affected
C: Not affected
Hex Code
33
\(5 y\)\(\quad\)\begin{tabular}{cccc|cccc|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & \(y_{3}\) & \(y_{2}\) & \(y_{1}\) & \(y_{0}\) \\
\hline
\end{tabular}

Execution Time:
Skip Conditions: None
Restrictions: None
Availability: \(\quad\) Not available on Group 1 devices
OMG
Copy the contents of the memory location addressed by the \(B\) register to the four-bit G port.
\(G \leftarrow \operatorname{RAM}(B) \quad A:\) Not affected
C: Not affected
\begin{tabular}{l|llll|llll|} 
Hex Code & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
33 \\
\(3 A\)
\end{tabular}\(\quad\)\begin{tabular}{|llll|llll}
0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
0 & 0 & 1 & 1 & 1 & 0 & 1 & 0 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers

\section*{OMH}

Copy the contents of the memory location addressed by the B register to the four bit H port.
\[
\begin{array}{ll}
H \leftarrow \operatorname{RAM}(B) & \text { A: Not affected } \\
& \text { C: Not affected }
\end{array}
\]
Hex Code
33
\(3 B\) \begin{tabular}{|cccc|cccc|}
\hline & 6 & 6 & 5 & 4 & 3 & 2 & 1 \\
0 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
\hline 0 & 0 & 1 & 1 & 1 & 0 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 2 Instruction Cycles
Skip Conditions: None
Restrictions: None
Availability: Group 3 devices

\section*{XAS}

Exchange the contents of the accumulator with the contents of the SIO register. Copy the contents of the one-bit C register to the SK latch. This is the basic MICROWIRE interface instruction and is the primary control over the serial port.

A \(\longleftrightarrow\) SiO \(\quad\) C: Not affected
SKL \(\leftarrow C\)
Hex Code
4 F \begin{tabular}{|llllllll|}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 1 & 0 & 0 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

Execution Time: 1 Instruction Cycle
Skip Conditions: None
Restrictions: None
Availability: All COPS microcontrollers

\subsection*{3.3 NOTES ON ADDRESSING MODES}

COPS microcontrollers do not have addressing modes in the sense of most popular microprocessors. To be sure, every instruction can be said to have some form of addressing mode associated with it. For example, a jump can be direct (JMP), indirect (JID), or "modified relative" (JP); and adds can be immediate (AISC) or inherent/implied (ASC,ADD). A classification of this kind can be made, but it is awkward and forced; it is an attempt to impose the structure of one type of microcomputer on another type of microcomputer. Because of the difference in kind between these microcomputers, a comparison on the basis of number of addressing modes between COPS and some other microcomputer is not valid. One may be able to find six or seven kinds of addressing modes in the COPS instruction set, but such an effort is more an exercise of the imagination than a meaningful evaluation of the instruction set. Comparisons should be made on what the instruction set really requires, in terms of the relevant parameters, memory usage, and speed, to perform a given function.

\subsection*{4.0 Programming COPS Microcontrollers}

\subsection*{4.1 INTRODUCTION}

This section deals with all aspects of programming COPS devices. The concepts, structures, rules, suggestions, and tricks for COPS programming are discussed. The detailed effects of various instructions are also discussed.

\subsection*{4.2 BOUNDARY CONDITIONS}

Although the program counter in COPS microcontrollers will increment linearly throughout the address space, three types of boundaries exist in the program space that the user should remember.
- Page boundaries
- Block boundaries
- Chapter boundaries

Even though these boundaries exist, their impact on the actual programming is minimal. This is true because these boundaries are important in only a few instructions and even there the primary effect, in most cases, is to allow the user to use a more code efficient instruction.

\subsection*{4.2.1 Page Boundaries}

A page is composed of 64 contiguous ROM words. Page 0 is the group of ROM words located at hex addresses 000 through 03F; Page 1 is the group of ROM words located at hex addresses 040 through 07F; etc. (See Table III.) The page boundary saves code by allowing the use of the sin-gle-byte jump (JP) and the single-byte subroutine call (JSRP).
Furthermore, Pages 2 and 3 are the special subroutine pages. Page 2 is the destination page for subroutines called by JSRP instruction.

\section*{THE JP INSTRUCTION}

The JP instruction is the single-byte jump. It loads the lower six bits of the program counter only; therefore, it causes a jump within a page only. There is an exception to this, however. A JP instruction located at the last word of a page (hex addresses 03F, 07F, OBF, OFF, etc.) will cause a jump into the next page. In all COPS microcontrollers, the program counter is incremented before the execution of the instruction. Thus, the program counter will increment from hex address 13F, the last word of a page, to hex address 140, the first word of the next page; then the JP will load the lower six bits of the PC. The effect is to cause a jump from one page to the next page with the single-byte JP.
The JP instruction cannot be used to jump to the last word of a page. The reason for this is evident from an examination of the instruction OP codes. The two most significant bits of the JP instruction are 11. The lower bits of the address of the last word of a page are all ones. Thus, the OP code of a JP to the last word of a page would be hex FF. This, however, is the opcode for the JID instruction. Therefore, JP cannot be used to jump to the last word of a page because the opcode that would otherwise implement that jump has been used to create the JID instruction.
The JP instruction has an expanded range within the subroutine pages-Pages 2 and 3. In these two pages only, the JP instruction loads the lower 7 bits of the program counter. Thus, a JP within Pages 2 and 3 may jump anywhere, except the last word of Page 2 or last word of Page 3, within Pages 2 and 3.

\section*{The JSRP Instruction}

The JSRP instruction is the single-byte subroutine call. Page 2 is the destination page for the subroutine jump. The instruction indicates the address within Page 2 where the subroutine begins. The two restrictions on the use of JSRP are as follows:
1. JSRP to the last word of Page 2 is not allowed
2. JSRP may not be used within Page 2 or 3

The reason for both restrictions is evident from the ODcodes. The most significant two bits of JSRP are 10. The lower six bits are the address within Page 2. Thus, JSRP to the last word of Page 2 would have the opcode hex BF. This opcode, however, has been used to implement the LQID
instruction. Thus, a JSRP to hex address OBF, the last word of Page 2, is not allowed. JSRP may not be used within Pages 2 and 3 simply because the opcodes have been used to expand the range of the JP instruction as explained in Section 4.2. The sacrifice of the JSRP to expand JP in the subroutine pages helps to create more entry points in Page 2 which tends to increase program efficiency.

\subsection*{4.2.2 Block Boundaries}

A block is composed of four contiguous pages or 256 contiguous ROM words. Block 0 consists of Pages 0 through 3; Block 1 consists of Pages 4 through 7; etc. (See Table III.) The block boundary is significant only with respect to the indirect instructions: JID, LQID, and LID. These instructions operate within a block and do not normally cross block boundaries.

\section*{LQID and LID}

These are the table look-up instructions. LQID looks up data identified by \(A\) and \(\operatorname{RAM}(B)\) and puts the value in \(Q\). LID does the same but returns the value to \(A\) and \(\operatorname{RAM}(B)\). Hence, the look up is based on an eight-bit value. The lower eight bits of the program counter are temporarily replaced by the contents of A and RAM(B). The remaining bits of the PC are not affected by the instruction. Thus, these instructions work within a block.
Just as with the JP instruction, a special situation exists if the LQID is at the last word of a block of LID is at the last two words of a block. In this situation, the look up is performed in the next block. The reason is, as explained before, the program counter is incremented before the instruction is executed. Thus, the program counter will be in the next block before the look-up operation is performed.

\section*{The JID Instruction}

The JID instruction looks up an address on the basis of \(A\) and \(\operatorname{RAM}(B)\), then loads the lower eight bits of the program counter with that address. Again, since eight-bit values are being used, block boundaries are respected.
Since the program counter is incremented prior to instruction execution, a JID at the last word of a block will look up its address in the next block and execute the jump in that block. An additional related special case exists with the JID instruction. If the look-up address for the JID is at the last word of a block (i.e., \(A=15_{10}\) and \(\operatorname{RAM}(B)=15_{10}\) ), then the jump will be in the next block. A final combination case exists: If JID is at the last word of a block and \(A=15_{10}\) and \(B=15_{10}\), then the jump will be in the second block from the present block (see Table VI).

\subsection*{4.2.3 Chapter Boundaries}

The Chapter is the largest memory division in COPS microcontrollers. A Chapter is composed of eight contiguous blocks ( 32 contiguous pages, 2048 contiguous ROM words). Obviously, the Chapter boundary has no relevance, in fact does not exist, if the microcontroller has fewer than 2048 words of program memory. Only the two-byte JMP and two-byte JSR are affected by the Chapter boundary. These instructions will jump anywhere within a Chapter or call a subroutine anywhere within a Chapter and will not normally cross a Chapter boundary. The exception is basically the same as seen before: a JMP at the last two words of a Chapter will jump to the next Chapter; a JSR at the last two words of a Chapter will call a subroutine in the next Chapter. The reason is the same: the program counter is incremented before the instruction is executed.

TABLE VI. Effects of Block Boundaries on JID Destinations
\begin{tabular}{|c|c|c|l|}
\hline \multicolumn{1}{|c|}{ JID Location } & A & RAM(B) & Destination \\
\hline \begin{tabular}{c} 
Block N, anywhere \\
except last word
\end{tabular} & \(\neq 15\) & \(\neq 15\) & Block \(N\) \\
\hline \begin{tabular}{c} 
Block N, anywhere \\
except last word
\end{tabular} & 15 & \(\neq 15\) & Block \(N\) \\
\hline \begin{tabular}{c} 
Block \(N\), anywhere \\
except last word
\end{tabular} & \(\neq 15\) & 15 & Block \(N\) \\
\hline \begin{tabular}{c} 
Block \(N\), anywhere \\
except last word
\end{tabular} & 15 & 15 & Block \(N+1\) \\
\hline Block \(N\), last word & \(\neq 15\) & \(\neq 15\) & Block \(N+1\) \\
\hline Block \(N\), last word & 15 & \(\neq 15\) & Block \(N+1\) \\
\hline Block \(N\), last word & \(\neq 15\) & 15 & Block \(N+1\) \\
\hline Block \(N\), last word & 15 & 15 & Block \(N+2\) \\
\hline
\end{tabular}

\subsection*{4.3 SKIP CONDITIONS}

In COPS microcontrollers, program address information is contained only in the jump and subroutine call instructions. Thus, decision instructions, or tests, do not contain a bíanch address. There is no single instruction equivalent of "If condition \(X\) is true (false) branch to address A." Instead, in COPS devices, if the test condition is met a skip is generated. This skip prohibits the execution of the following instruction, i.e., "skipping" that instruction. The number of program bytes in the instruction has no bearing on the skip operation. Thus, following a test instruction with jumps or subroutine calls produces the desired branching. However, the skip feature allows much greater flexibility than merely branching. In many cases, the skip feature eliminates the need for branching since almost any register or variable parameters in COPS microcontrollers can be modified, in line, on the basis of a skip (see Section 4.7).

\subsection*{4.3.1 Effect of Skips on Timing Loops}

Software timing loops are commonly part of a microcontroller program. In such a case, it is usually necessary that various paths through the loop take the same amount of time. The skip feature actually helps to achieve this goal rather than, as might be expected, conflicting with it. The reason is in the operation of the skip. If an instruction is to be skipped, the internal logic forces a NOP equal in length to the number of program bytes in the skipped instruction in place of that instruction. Then the NOP is executed. Thus, whether or not an instruction is skipped has no effect on the time to execute a given sequence of instructions. Note: this "hardware NOP" is temporary; it exists for the duration of the skipped instructions only and in no way alters the ROM contents. It therefore becomes a simple matter to compute execution time through a given sequence. Merely count the number of bytes, not instructions, in the path without regard to tests or skips and multiply by the instruction cycle time.

\section*{The Indirect Instructions-An Exception}

The indirect instructions JID, LQID, and LID constitute an exception to this general rule. These are the only COPS instructions that require more instruction cycle times than the number of bytes in the instruction to execute. They require one more instruction cycle time than the number of bytes to execute: JID and LQID are one-byte instructions and require two instruction cycles to execute; LID is a twobyte instruction that requires three instruction cycles to exe-
cute. The result is that these instructions use one more instruction cycle when executed than when skipped because the hardware forced NOP is related to the number of bytes in the instruction rather than the execution time of the instruction. This distinction is significant nnly for these three instructions.

\subsection*{4.3.2 Instructlons That Generate a SkIp}

As would be expected, all test instructions can generate a skip. If the test condition is met, a skip is generated. However, certain other instructions can also generate skips. The following arithmetic instructions generate a skip if the result of a four-bit binary addition is greater than \(15_{10}\) : ASC, CASC, and AISC. The advantage here is that the common test after such instructions (testing carry or overflow) is built directly into the instruction thereby eliminating the need for a separate test instruction.
The LBI (load B register immediate) can also generate a skip. This instruction forces a skip until an instruction is reached that is not an LBI. This permits multiple entry points to a common routine without affecting the code. The code savings of this feature are more subtle, but this allows the user a degree of flexibility not found in other devices. Section 4.7 will explain this feature in more detail.
The XIS and XDS instructions can also generate skips. These generate a skip when one increments or decrements "off the end" of a register (Bd incrementing from 15 to 0 or decrementing from 0 to 15). This becomes very useful in loop operations as the need for testing for completion of the loop is often eliminated-another test is eliminated. Section 4.7 will illustrate the use of these instructions.

The final instruction that generates a skip is RETSK. When executed, this instruction always forces a skip of the instruction located at the return address. This instruction becomes very valuable in implementing complex tests in a subroutine, or in reversing the direction of a frequently used test by means of a special subroutine. It is, of course, useful whenever the user wishes to force a skip of a subroutine return address.

\subsection*{4.4 CARRY}

The ALU in COPS microcontrollers is a four-bit parallel binary adder. The user does not have access to the bit-to-bit carry within the ALU, but does have varying degrees of access to the carry as a result of a four bit operation. Within this category the user should be aware of several distinctions: the carry register, the carry out of the ALU, and simple arithmetic overflow. These are not always the same thing and the difference can be important. The carry register, C, may be set or reset directly by the program. Those instructions that do an "add with carry", ASC and CASC, use the C register in the addition. These same two instructions are the only instructions that load the carry out of the ALU, the carry as a result of the four-bit addition, into the C register. The SKC instruction test the status of the C register, not the carry from the ALU.
The carry from the ALU is the controlling factor in those arithmetic instructions that can generate a skip: ASC, CASC, AISC. If the carry from the ALU is a one as a result of any of these instructions, a skip is generated. The C register is not used for this form of skip generation. In fact, the AISC instruction neither uses nor affects the \(C\) register.
The ADD and ADT instructions cause an add to be performed. This add may well cause an arithmetic overflow. This overflow, however, is not quite the same as the carry from the ALU since no skip condition occurs. Furthermore, the C register is neither used nor affected.

This can be viewed as a hierarchy of overflows:
1. Simple arithmetic overflow; no skip; \(C\) neither used nor affected. ADD, ADT
2. Carry from the ALU (= arithmetic overflow which generates a skip); C neither used nor affected. AISC
3. Carry from the ALU that loads C (= arithmetic overflow which generates skip, C loaded with status of carry from ALU); C both used and affected. ASC, CASC

\subsection*{4.5 INPUT/OUTPUT}

All input/output operations are handled by unique instructions. The instructions may be executed at any point in the program.

\subsection*{4.5.1 Unidirectlonal Ports}

Two unidirectional ports are found in COPS microcontrollers: the IN input port and the D output port. The IN port is read by the ININ instruction. The IL latches, associated with the IN port, are read by the INIL instruction. Pin CKO may be configured as an input, via a mask option, on some devices. The INIL instruction also reads the state of the CKO input in those devices that have that option. See the descriptions of the \(\mathbb{N} I N\) and \(\operatorname{INIL}\) instructions for further details.
The D output is loaded from the lower four bits of the \(B\) register (Bd) by means of the OBD instruction. There is no path from the accumulator or RAM to the \(D\) port.

\subsection*{4.5.2 Bidirectional Ports \\ Non TRI-STATE Ports}

There are two bidirectional, non TRI-STATE ports available: The G port, available, at least partially, on all COPS microcontrollers; and the H port, available on the COP440. The output function is simple; merely write the data to the port with the appropriate instruction: OGI, OMG, or OMH. Data is read via the ING or INH instruction. In addition, the \(G\) lines may be directly tested individually or as a four bit group. When using any of the G or H lines as inputs the user must write a " 1 " to the lines used as inputs. This is a requirement imposed by hardware rather than software considerations. The external circuitry will pull the line to logic " 0 ".
On 20-pin COPS devices, only two of the four G lines are brought out. The other two lines, however, are available for internal use as flags or storage. The same is true of the H port on the COP441/COP442.
Any G or H line, or any combination, may be used as inputs while the others are used as outputs. There is no conflict and the user has complete flexibility.

\section*{TRI-STATE Ports}

Two eight-bit bidirectional TRI-STATE ports are available: The Q register-L drivers available on all COPS microcontrollers and the R port available on the COP440. The L port is written by loading \(Q\) with CAMQ or LQID and enabling \(L\), via LEI or CAME. The application will determine if \(L\) should be enabled before or after loading \(Q\) or enabled all the time. The decision is not significant in terms of software. Remember, the L outputs are dirvers only. They are not latched. When enabled, L outputs the contents of \(Q\). L must be enabled in order to output data. The R port is a latched output port. The user writes to the R register by means of the CAMR instruction. The \(R\) drivers are enabled by means of the CAME instruction. In terms of software alone, it is not significant when the R drivers are enabled, but the drivers must be enabled to output the contents of the R register.

There are two ways to use these lines as inputs. The first method requires that the drivers be disabled. In this case, the lines are truly floating and in an undefined state. The external circuitry must provide good logic levels, both high and low, to the input pins. The inputs are then read by the INL or INR instructions. The second method is very similar to the technique used for G and H . The drivers are enabled. A "1" must be written to the Q or R register in the positions of the input lines. The external circuitry will then be required only to pull the line down to a logic " 0 ". The line will pull itself up to a logic " 1 ". The INL and INR instructions are used as before to read the lines.
Any L or R line, or any combination, may be used as inputs while the others are used as outputs. However, the \(L\) drivers are enabled or disabled as a group. The same is true of the \(R\) drivers. The \(L\) drivers are enabled or disabled by means of the LEI or CAME instructions. The R drivers are controlled by means of the CAME instruction only. On most devices, the \(Q\) register can be read without affecting \(L\). The \(R\) register can be read only through the \(R\) lines. The data on the \(L\) lines does not affect the contents of the \(Q\) register except on devices with the MICROBUS option selected. The data on the \(R\) lines does not affect the contents of the \(R\) register. The R lines are available only on the COP440. The R register, however, is available and can be used in the COP441/ COP442.

\subsection*{4.5.3 The Serial I/O Port—MICROWIRE}

As explained in Section 2.4.5, the serial I/O port may be configured as a serial shift register or a four-bit binary down counter. In the shift register mode, the serial port is the MICROWIRE interface (see Section 2.4.5). The operating mode of the serial port is controlled by the Enable register (see Section 2.5 and Table IV).
In the binary counter mode, SO and SK are logic controlled outputs. The state of SO is directly controlled by the LEI instruction. SK outputs the status of SKL, the SK latch. In the shift register mode, SO is either " 0 " or serial out, and SK is either " 0 " or a clock output as indicated in Table IV. Regardless of mode, SKL is loaded with the status of the C register whenever an XAS instruction is executed. Thus, SK is controlled by setting or resetting \(C\) and then executing an XAS. The XAS instruction, however, is also the means of reading the SIO register. Therefore, every time the user reads SIO, C is copied to SKL. Therefore, the user should insure the status of \(C\) before executing an XAS instruction if the status of SK is important. Also note that if SIO is in counter mode and SKL is " 1 " ( \(S K=1\) ), and SIO changed to shift register mode, SK will become a clock immediately. The converse is also true: If SIO is shift register and SKL = 1 , and SIO is changed to a counter, SK will go to a high state immediately.
Regardless of mode, SI can be used as a general purpose input. In the shift register mode, data will shift in at the SI pin. The user can read the status of SI with the XAS instruction. In the counter mode, SIO will, in effect, capture a lowgoing pulse. The user can preload the counter by setting the accumulator to some value, typically 0 or 15, and loading that value into SIO with an XAS instruction. The user would then periodically read SIO to see if the value had been decremented. If it had, the pulse had occurred.
With the SIO register in the shift register mode, continuous data streams can be sent or received. In this mode, data is normally in multiples of four bits. To preserve proper timing, an XAS must appear every fourth instruction cycle. As will be seen, this is simple to implement. The reason for this
requirement should be obvious. SIO is a four-bit shift register which shifts at the instruction cycle rate. Thus data must be read, or new data loaded, every fourth instruction cycle.

\subsection*{4.6 INTERRUPT}

The interrupt input on COPS microcontrollers is \(\mathbb{N}_{1}\). In the COP440 series and COP2440 series, the CKO input may also be an interrupt input. Thus, except for the COP442, interrupt is not available on any device that does not have the \(\mathbb{N}_{1}\) input.

\subsection*{4.6.1 Conditions for Interrupt Recognition}

An interrupt will be recognized or acknowledged if and only if the following conditions are met:
1. Interrupt has been enabled by setting bit \(E N_{1}\) of the enable register.
2. A low-going pulse ("1" to " 0 ") at least two instruction cycles wide occurs at the \(\mathrm{N}_{1}\) (or CKO in COP440 series) input. The high to low transition must occur while \(\mathrm{EN}_{1}\) is set.
3. A currently executing instruction is completed.
4. All successive transfers of control instructions and successive LBI instructions are completed (e.g., if the main program is executing a jump or subroutine call which transfers control to another jump or subroutine call, the interrupt will not be acknowledged until the second jump or subroutine call has been executed).

\subsection*{4.6.2 Effects of Interrupt Acknowledge}

When an interrupt has been acknowledged as explained in Section 4.6.1, the following occurs:
1. The next sequential program counter address ( \(\mathrm{PC}+1\) ) is pushed onto the program stack.
2. On COP440 series device, an interrupt status bit is stored with the address in the subroutine stack.
3. On all other COPS microcontrollers, the interrupt status bit, which remembers the status of the skip logic, is saved separately. This bit is not carried with the address in these devices.
4. The program counter is set to address OFF hex. On all devices except the COP440 series, the next executable address is hex 100. In the COP440 series, hex 100 is the next executable address if \(\mathrm{EN}_{4}\) is reset. If \(\mathrm{EN}_{4}\) is set in these devices, the program counter branches from hex address OFF to hex address 300.
5. \(\mathrm{EN}_{1}\) is reset thereby disabling further interrupts.

\subsection*{4.6.3 Interrupt Handling}

Due to hardware considerations, the instruction at hex address OFF must be a NOP.
The interrupt status bit remembers if a skip was generated as a result of the completed instruction. In the COP420/ COP424C/420L/444L devices, this bit is stored separate from the return address. If set, this bit forces a skip on the first "stack pop" following the interrupt. This means that the use of subroutines or nested interrupts is limited in these devices. An unexpected skip may occur and the original skip status is lost. The user may, of course, defeat this skip by means of an artificial subroutine call, e.g., a JSRP to a RET instruction, followed by a NOP. This will clear the status bit, and subroutines, etc. may be used without restriction. Remember, however, that this procedure destroys the original skip status. No such situation exists in the COP440 series devices. The status bit is saved with the address.

Subroutines may be freely used in the interrupt service routines and nested interrupts are permitted.
Subject to the restraints mentioned above, interrupts may be re-enabled at any time by means of the LEI or CAME instructions. Typically, this re-enabling would occur immediately before the return instruction at the end of the interrupt service routines.

\subsection*{4.6.4 Interrupt Disable}

Interrupts are disabled by resetting \(\mathrm{EN}_{1}\) by any valid instruction (LEI or CAME) and by interrupt acknowledge. While \(E N_{1}\) is low, no interrupt processing of any kind goes on. Thus, a high to low transition at \(I N_{1}\) which is otherwise valid is not recognized when \(E N_{1}\) is reset. Furthermore, when \(E N_{1}\) is set, there is no memory of the event that occurred while \(E N_{1}\) was reset. The software interrupt disable will prohibit recognition of all interrupt signals which occur subsequent to the disable. Obviously, the interrupt disable instruction cannot disable interrupts which occur before the instruction is executed. More significantly, the interrupt disable instruction also does not disable interrupts which occur during the execution of the instruction. Thus, a valid interrupt signal may occur, and interrupt acknowledge is pending completion of the current instruction. That current instruction may well be an interrupt disable; nonetheless, the interrupt will be acknowledged and the interrupt service routine entered.
Note that in branching to the interrupt routine, the microcontroller saves only the program counter and the skip status. If it is necessary to save other items, the user must do so himself in software. Similarly, the user must restore those values at the end of the interrupt service routine.

\subsection*{4.6.5 Interrupt in the COP440}

The COP440 series devices are the only COPS microcontrollers with more than one possible interrupt source. The choice of interrupt is governed by bits \(E N_{4}\) and \(E N_{5}\) of the enable register as indicated in Table \(V\). The four possible interrupt sources are as follows:
1. \(I N_{1}\) negative edge-This is the standard COPS interrupt \(\left(E N_{5}, E N_{4}=00\right)\).
2. CKO input-if the CKO input mask option is selected, that input can be selected as an interrupt input. Operation is the same as the \(I N_{1}\) interrupt \(\left(E N_{5}, E N_{4}=0\right)\). If CKO is not selected as an input, selection of CKO as interrupt source has no effect. No interrupt will occur.
3. Zero Crossing on \(I N_{1}-N_{1}\) may be mask programmed to be a zero crossing detect input. Interrupt can be selected to occur at each zero crossing. If the zero cross detect option is not selected, this interrupt source selection will result in an interrupt at every transition of \(\mathrm{IN}_{1}\left(\mathrm{EN}_{5}, \mathrm{EN}_{4}\right.\) \(=10\) ).
4. T counter overflows-This is an interrupt which can be selected. Interrupt will occur whenever the T counter overflows. All the conditions required for interrupt to be acknowledged, with the obvious exception of input pulse width, are still valid and must be met \(\left(\mathrm{EN}_{5}, \mathrm{EN}_{4}=11\right)\).
The interrupt source should not be changed while the interrupt is enabled ( \(\mathrm{EN}_{1}=1\) ). A false interrupt may occur if the interrupt source is changed while \(\mathrm{EN}_{1}\) is a 1 . To avoid this problem, the interrupt must be disabled prior to, or at the same time as, the change of the interrupt source. Do not enable the interrupt at the same time as changing the interrupt source. A proper sequence for altering the interrupt source, then, is as follows:
1. Disable interrupt.
2. Change interrupt source (Steps 1 and 2 may be combined).
3. Enable interrupt.

\subsection*{4.7 PROGRAM EFFICIENCY}

Three factors are normally involved in determining program efficiency:
1. Program memory (ROM) efficiency, using the least amount of ROM.
2. Data memory (RAM) efficiency, using the least amount of RAM.
3. Execution time efficiency, executing the function in the shortest amount of time.
These three factors, unfortunately, conflict with one another. The most memory efficient implementation of a function is not usually the most execution time efficient implementation. The most RAM efficient implementation is frequently not the most ROM efficient implementation.
Like all single-chip microcontrollers, COPS microcontrollers are memory limited. A premium is therefore placed on general memory efficiency-getting the maximum function in the smallest memory. The reason is simple economics: devices with greater memory capacity are generally more expensive than devices with lesser capacity. Despite the premium on memory efficiency, the application can easily require compromises-sacrifice a little ROM or RAM or both in order to achieve faster execution speed.
Since these conflicting requirements exist, several versions of the standard programs in Chapter 5 are provided. These should help the user to understand the conflict and to make intelligent, informed decisions on any compromises.

\subsection*{4.8 RULES AND TECHNIQUES}

\subsection*{4.8.1 Absolute Requirements}

There are very few absolute requirements for COPS programming. The restrictions on the instructions are described in Chapter 3. The remaining absolute rules are as follows:
1. The instruction at address 000 must be a CLRA.
2. If interrupts are used, the instruction at hex address OFF must be a NOP.
3. At least the first instruction of subroutines called with the single byte JSRP must be in Page 2. Note there is no requirement that any other instructions of such subroutines be located in Page 2.

\subsection*{4.8.2. General Guidelines}

This section will provide general guidelines to help the programmer write an efficient COPS program. Examples are provided here and in Section 5. Most of these guidelines will reduce memory usage at the expense of execution speed. The programmer may have to make the compromises described in Section 4.7.

\section*{Maximize the Use of Subroutines}

If a single operation is frequently performed, make that operation a subroutine. If possible, make it a subroutine that can be called with the single-byte JSRP. Try to combine similar operations into a common subroutine, even if it means that an unnecessary operation is performed in some cases. This is "wrong" only if this unnecessary operation interferes in some significant way with achieving the end result. The programmer may use pieces of existing subroutines as new subroutines: multiple entry points are a good thing if code is saved. Consider the following short routine:
\begin{tabular}{ll} 
ENTRY1: & LBI 0,15 \\
ENTRY2: & LD \\
ENTRY3: & CAB \\
ENTRY4: & OBD \\
ENTRY5: & RET
\end{tabular}

It is entirely conceivable that every instruction in this routine is a subroutine entry point. We shall assume that this routine is in Page 2 for maximum savings. A JSRP to ENTRY1 will output the value in RAM \((0,15)\) to \(D\). A JSRP to ENTRY2 will output the RAM digit addressed by \(B\) to the D port. A JSRP to ENTRY3 will output the accumulator to the D port. A JSRP to ENTRY4 simply does an OBD. A JSRP to ENTRY5 is, effectively, a NOP but finds usefulness in creating software delays. This is an example of maximizing subroutine usage and sharing commonality or finding commonality where it is not obvious. Page 2 should be filled with subroutine entry points. This will increase the memory efficiency of the program.
Any multibyte instruction can be converted into a single-byte instruction by means of a subroutine. Entry point ENTRY4 in the preceding example illustrates this. If a given multibyte instruction is frequently used in a program, it will probably be beneficial to make a subroutine out of it. Remember, this includes any multibyte instruction. It is common that various branches of a program will jump back to some central location in the program. These jumps can be implemented with a JSRP; the subroutine will consist totally of JMP CENTER, a jump to the central location. This is completely acceptable and will save code. A subroutine does not have to have a return instruction associated with it.
Use the skip feature of successive LBI instructions. This is a very powerful feature that permits code sharing and promotes commonality. It easily lends itself to multiple entry point routines. Consider the following digit right shift routine:
\begin{tabular}{lll} 
RSHO: & LBI & 0,15 \\
RSH1: & LBI & 1,15 \\
RSH2: & LBI & 2,15 \\
RSH3: & LBI & 3,15 \\
& CLRA & \\
LOOP: & XDS & \\
& JP & LOOP \\
& RET &
\end{tabular}

Depending on the entry point, this routine will right shift register \(0,1,2\), or 3 one digit. The successive LBI feature finds use in this kind of routine, so the same routine can be used regardless of data location in tests and in "non-obvious" ways. Consider the following:
\begin{tabular}{lll} 
G10: & LBI & 0,10 \\
G9: & LBI & 0,9 \\
G1: & LBI & 0,1 \\
GO: \(:\) & LBI & 0,0 \\
& CBA & \\
& X & \\
& OMG & \\
& X & \\
& RET &
\end{tabular}

Here, the LBI instruction is being used to establish the \(G\) output value. The LBI instruction can be used in many similar ways. The interesting thing about this usage is that the LBI is, in itself, being used to create a value and not to point to a given RAM digit, even though the B register is modified by the instruction.
Careful RAM allocation is essential. Careful placement of data in RAM can have significant impact on the amount of program memory required. The use of a RAM map, a visualization of the data placement in RAM, is an invaluable aid. It is nearly impossible to write an efficient program without the use of a RAM map. Figure 4-1 is a sample RAM map for a COP420. The basic guidelines for data placement in RAM are as follows:
1. Flags should be placed in memory locations addressable by a single-byte LBI.
2. A commonality of bit position within a digit for flags is desirable. This permits the creation of flag testing subroutines like the following:
\begin{tabular}{lll} 
FLAGI: & LBI & 3,15 \\
FLAGZ: & LBI & 3,14 \\
& SKMBZ & 1 \\
& RET & \\
& RETSK &
\end{tabular}
3. Data should be placed at the "ends" of register to take advantage of the skip features of the XIS and XDS instructions. It takes far less code to exit by "falling of the end" of a register than to test Bd, or some other loop counter, for completion.
The LD, X, XIS, and XDS are associated with the exclusive OR feature whereby Br can be modified. If RAM data and flags are intelligently placed, data manipulation and \(B\) register modification can be accomplished in a single instruction thereby saving code. Obviously, the effective use of these instructions goes hand in hand with an effective RAM layout. The basic integer BCD addition below illustrates this feature. The routine is a four-digit BCD addition, adding register 0 to register 3; result to register 0 .

DIGIT ADDRESS (BD)

\begin{tabular}{|c|c|c|c|}
\hline BCDADD : & LBI & 3,12 & \\
\hline \multirow[t]{6}{*}{LOOP :} & LD & 3 & ;fetch data and point to \\
\hline & & & R0 \\
\hline & AISC & 6 & ;decimal adjust to force \\
\hline & & & carry if \(A=9\) \\
\hline & ASC & & ;add \\
\hline & ADT & & ;decimal correct \\
\hline \multirow[t]{4}{*}{:} & XIS & 3 & ;place digit in RO, \\
\hline & & & increment Bd , point to R3 \\
\hline & JP & L00P & ;XIS skip indicates finish \\
\hline & RET & & \\
\hline
\end{tabular}

In the above routine, the \(B\) register is being continuously modified but there is no LBI instruction other than the one required at the start of the routine.
The table look-up instructions, LQID and LID, can save both code and execution time. Tables can be used in many ways: code conversions, arithmetic, data processing, key decoding, etc. If some set of values is to be derived from another set of values, a table will frequently be more efficient than a computation. The look up will also be invariably faster than a computation. Tables greatly facilitate the handling of inputs from non-linear sources e.g., temperature sensors; they make creation of display a trivial task. The use of a table is not a panacea but is frequently a possible solution worth considering.
The indirect jump instruction, JID, should be used with some care. Because of its "two-tier" organization, this instruction does not always save code. JID permits a jump on the basis of data. As such, it is very useful in decode situations. It is not necessarily the most code efficient decoding scheme, but it is always the most time efficient and time uniform decoding scheme.
For execution speed efficiency, do not put unnecessary instructions in loops. Look for ways to move instructions out
of loops. It is frequently possible to move seemingly necessary instructions out of program loops. This is a speed improvement that usually costs little or no code.

\subsection*{4.9 STRUCTURED PROGRAMMING TECHNIQUES}

The techniques of structured programming or top-down programming are excellent organizational tools and work well on large systems. However, these techniques have a basic implementation problem at the level of single-chip microcontroller in general and COPS microcontrollers in particular. Systems based on COPS devices are generally seeking maximum function with minimum memory.
Efficient COPS programming requires the elimination or minimization of redundant or duplicated code. Maximum sharing of common or related code is necessary. Partial sharing of routines is also common. Most subroutines in an efficient COPS program will have multiple entry points. There are branches into and out of routines that exist solely to reduce memory usage. All of this is in direct conflict with the top-down modular approaches. An efficient COPS program is not written by assembling independent blocks. That technique will use excessive code and could require a user to use a larger device than necessary. It is difficult, in an efficient COPS program, to extract independent modules other than the most basic functions.
The concepts of structured programming are still useful in defining the functions that must be performed and their in-ter-relationships. When the time comes to write the code within the memory limits of the microcontroller, the concepts fail. At this point, the user should use the approaches and techniques in this manual. Remember, the objective is to write an efficient COPS program thereby obtaining maximum function in minimum memory. Rarely, if ever, is the objective to write an easily readable program with modular, transportable functional blocks that exceed the memory capacity of the device.

\subsection*{5.0 Standard Programs}

\subsection*{5.1 INTRODUCTION}

This section contains a number of standard programs illustrating various techniques and the implementation of various functions. If the user wishes to use any of these programs, he or she should remember that maximum efficiency will be obtained by tailoring the program to the application. Copying the programs "as is" generally is not efficient.

\subsection*{5.2 MATH PACK}

This section includes a variety of arithmetic routines, including the following:
- Increment routines
- Decrement routines
- Integer Addition
- Integer Subtraction
- Binary Multiply
- Basic Arithmetic Package: Add, Subtract, Multiply, Divide
- Square Root
- Binary to BCD Conversion
- BCD to Binary Conversion

Typically, more than one implementation of a function is given.

\subsection*{5.2.1 Basic Increment Routines}

\section*{Binary Routines}

The following three routines have the same function: They perform a binary addition of 1 to a 12 -bit binary number. The number is located in register 0, digits 15 through 13.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{Bd} & & & & & & \multirow[t]{5}{*}{} \\
\hline \multirow{4}{*}{Br 0} & 15 & 14 & 13 & & & & & & \\
\hline & M & & L & & & & & & \\
\hline & S & & S & & & & & & \\
\hline & B & & B & & & & & & \\
\hline \multicolumn{4}{|c|}{I} & \multicolumn{3}{|c|}{II} & \multicolumn{3}{|c|}{II} \\
\hline \multirow[t]{2}{*}{INCR:} & \multicolumn{2}{|l|}{LBI} & \multirow[t]{2}{*}{0,13} & \multirow[t]{2}{*}{\begin{tabular}{l}
INCR: \\
INCRI:
\end{tabular}} & LBI & 0,13 & \multirow[t]{2}{*}{INCR:} & LBI & 0,13 \\
\hline & SC & & & & LD & & & LD & \\
\hline \multirow[t]{12}{*}{INCRI:} & \multicolumn{3}{|l|}{CLRA} & & AISC & 1 & & AISC & 1 \\
\hline & \multicolumn{3}{|l|}{ASC} & & JP & INCR2 & & AISC & \multirow[t]{3}{*}{15} \\
\hline & \multicolumn{3}{|l|}{NOP} & & \multicolumn{2}{|l|}{XIS} & & XIS & \\
\hline & \multicolumn{3}{|l|}{XIS} & & JP & INCRI & & LD & \\
\hline & \multicolumn{2}{|l|}{JP} & \multirow[t]{8}{*}{INCRI} & & \multicolumn{2}{|l|}{RET} & & AISC & 1 \\
\hline & \multicolumn{2}{|l|}{\multirow[t]{7}{*}{RET}} & & \multirow[t]{7}{*}{INCR2:} & \multicolumn{2}{|l|}{X} & & AISC & \multirow[t]{3}{*}{15} \\
\hline & & & & & \multirow[t]{6}{*}{RET} & & & XIS & \\
\hline & & & & & & & & LD & \\
\hline & & & & & & & & AISC & 1 \\
\hline & & & & & & & & NOP & \\
\hline & & & & & & & & X & \\
\hline & & & & & & & & RET & \\
\hline ROM Wo & Use & & & & 9 & & & 14 & \\
\hline Execut (inst & Time & \[
18
\]
\[
18
\] & & Data De & dent & & & 14 & \\
\hline
\end{tabular}

The preceding three examples illustrate an important point: The most code efficient method of implementing this function takes more time to execute than either of the other two implementations. This is a fairly common characteristic. Implementation II is, on the average, the fastest executing routine. Its main drawback is that its execution time is data dependent. This may not be significant. Implementation I uses and modifies the C register; the other implementations do not. All three routines use the accumulator.

\section*{BCD Routines}

The following routines have the same function: They increment a three-digit BCD number by one.
instruction cycles)
\begin{tabular}{|c|c|c|c|c|c|}
\hline INCR: & LBI & 0,13 & INCR: & LBI & 0,13 \\
\hline \multirow[t]{6}{*}{INCR1:} & LD & & & LD & \\
\hline & AISC & 7 & & AISC & 7 \\
\hline & JP & INCR2 & & AISC & 9 \\
\hline & XIS & & & XIS & \\
\hline & JP & INCRI & & LD & \\
\hline & RET & & & AISC & 7 \\
\hline \multirow[t]{7}{*}{INCR2:} & ADT & & & AISC & 9 \\
\hline & X & & & XIS & \\
\hline & \multirow[t]{5}{*}{RET} & & & LD & \\
\hline & & & & AISC & 7 \\
\hline & & & & ADT & \\
\hline & & & & X & \\
\hline & & & & RET & \\
\hline \multicolumn{3}{|l|}{10} & & 14 & \\
\hline Data De & dent 7 & & & 14 & \\
\hline
\end{tabular}

The same comments made for the binary routines are valid for the BCD routines.

\subsection*{5.2.2 Basic Decrement Routines}

\section*{Binary Routines}

The following routines take a 12-bit binary number and decrements it by one.

\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{3}{|c|}{I} & \multicolumn{3}{|c|}{II} & \multicolumn{3}{|c|}{II} \\
\hline DECR: & LBI & 0,13 & DECR: & LBI & 0,13 & DECR: & LBI & 0,13 \\
\hline & RC & \multirow{11}{*}{DECR1} & DECR1: & LD & & & LD & \\
\hline \multirow[t]{10}{*}{DECR1:} & CLRA & & \multirow{10}{*}{DECR2:} & AISC & 15 & & AISC & 15 \\
\hline & CASC & & & JP & DECR2 & & XIS & \\
\hline & NOP & & & X & \multirow{8}{*}{DECR1} & & LD & \\
\hline & XIS & & & RET & & & AISC & 15 \\
\hline & JP & & & XIS & & & XIS & \multirow{6}{*}{15} \\
\hline & RET & & & JP & & & LD & \\
\hline & & & & \multirow[t]{4}{*}{RET} & & & AISC & \\
\hline & & & & & & & NOP & \\
\hline & & & & & & & X & \\
\hline & & & & & & & RET & \\
\hline \multicolumn{3}{|l|}{\multirow[t]{3}{*}{\begin{tabular}{l}
ROM Words Used: 8 \\
Execution Time: 18 \\
(instruction cycles)
\end{tabular}}} & \multicolumn{3}{|c|}{9} & & \multicolumn{2}{|l|}{12} \\
\hline & & & \multicolumn{3}{|l|}{\multirow[t]{2}{*}{Data Dependent 6-17}} & & \multirow[t]{2}{*}{12} & \\
\hline & & & & & & & & \\
\hline
\end{tabular}

As with the increment routines, the routine requiring the least code takes the most time.

\section*{BCD Routines}

The following routines take a three-digit decimal number and decrement it by one.
(instruction cycles)
\begin{tabular}{|c|c|c|c|c|c|}
\hline DECR: & LBI & 0,13 & DECR: & LBI & 0,13 \\
\hline DECRI: & LD & & & LD & \\
\hline \multirow[t]{4}{*}{'} & AISC & 15 & & AISC & 15 \\
\hline & JP & DECR2 & & STII & 9 \\
\hline & X & & & LD & \\
\hline & RET & & & AISC & 15 \\
\hline \multirow[t]{6}{*}{DECR2:} & ADT & & & STII & 9 \\
\hline & XIS & & & LD & \\
\hline & JP & DECRI & & AISC & 15 \\
\hline & \multirow[t]{3}{*}{RET} & & & ADT & \\
\hline & & & & X & \\
\hline & & & & RET & \\
\hline \multicolumn{3}{|c|}{10} & & 12 & \\
\hline \multicolumn{3}{|l|}{Data Dependent 6-20} & & 12 & \\
\hline
\end{tabular}

The same pattern is observed here as in the other similar routines.

\subsection*{5.2.3 Integer Addition}

\section*{Binary Addition}

The routine below is the basic addition routine. It illustrates the power of the exclusive OR argument of the LD, XIS, XDS, and X instructions. It also illustrates the conciseness that can come from intelligent data placement in RAM. As written, the routine is a 16 -bit binary add, R1 + R0 \(\rightarrow\) R0.

Bd

```

BINADD: LBI 1,12 ;set-up B register

```
    RC ;initialize Carry to 0
LOOP: LD 1 ;fetch data from RI and point to RO
    ASC \(\quad\);add \(\operatorname{RAM}(B)+A+C \rightarrow A\)
    NOP ;defeat skip
    XIS \(\quad 1\);store result to \(R 0\), increment \(B d\), point to \(R 1\)
    JP LOOP ;Loop control
    RET ;all done, exit

ROM Words Used: 8
Execution Time: 23 instruction cycle times

BCD Addition
This routine is essentially the same as the binary add routine. A four-digit BCD add is illustrated. Again, R1 + R0 \(\rightarrow\) R0.


ROM Words Used: 9
Execution Time: 23 instruction cycle times
Both of these addition routines can be expanded up to 64 bits or 16 digits merely by changing the starting address, the Bd value in particular. Also note that the data could be placed at the other end of the register and XDS used in place of XIS.
Since the routine is essentially independent of data length and the exclusive OR feature of the LD, XIS, XDS, and X instructions permits easy transportation across data registers, a very versatile and compact routine can be created. Consider the following variation on the BCD addition routine:
\begin{tabular}{llrl} 
ADD1: & LBI & 3,0 & \(; R 3+R 0 \rightarrow R 0,16\)-digit add \\
ADD2: & LBI & 0,0 & \(; R 3+R 0 \rightarrow R 3,16-d i g i t ~ a d d ~\) \\
ADD3: & LBI & 1,10 & \(; R 1+R 2 \rightarrow R 2,6-d i g i t\) add \\
ADD4: & LBI & 2,10 & \(; R 1+R 2 \rightarrow R 1,6-d i g i t\) add \\
& RC & & \\
LOOP: & LD & 3 & \\
& AISC & 6 & \\
& ASC & & \\
& ADI & & \\
& XIS & 3 & \\
& JP & LOOP & \\
& RET & &
\end{tabular}

Here we have the same routine able to work on two different sets of registers with different data lengths. Furthermore, either register in a given set can be the destination for the result. The controlling factor in all of this is simply the value in the B register at the start of the routine. The repeated LBI skip feature proves very useful in creating a multiple entry subroutine such as this one.
Variations on these basic two register additions similar to the techniques shown in the basic increment and decrement routines can be created. This is left as an exercise for the programmer. The most code efficient techniques have been illustrated here.

\subsection*{5.2.4 A Doubling Routine}

A routine to double the value in a register is a simple outgrowth from the basic addition routine. This routine is illustrated before for a binary double. Data placement is the same as shown earlier.


The routine for a decimal double is derived from the BCD add routine in the same manner: the exclusive OR argument on the LD and XIS instructions is changed to 0 so that Br is not altered by those instructions.

\section*{An Example of the Effect of Data Placement in RAM}

If assumed, in either of the addition routines presented earlier, that the data is not optimally placed at the end of registers, the following routine could be the result:
\begin{tabular}{|c|c|c|c|}
\hline & \multicolumn{3}{|c|}{Bd} \\
\hline & 15 & 1413 & 12 \\
\hline & M & & \\
\hline Br 0 & S & Operand 1;sum & S \\
\hline 1 & & Operand 2; & \\
\hline
\end{tabular}
\(R 1+R 0 \rightarrow R 0,16\)-bit binary
```

BINADD: LBI 1,10 ;initialize B
RC ;initialize Carry
LOOP: LD I
ASC
NOP
XIS I
CBA ;test for Bd > 13-if yes, done
AISC 2
JP LOOP
RET

```

ROM Words Used: 10
Execution Time: 31 instruction cycle times
In this example, inefficient data placement resulted in a 25 per cent code increase and a nearly 50 per cent increase in execution time. The message should be clear from this: Placement of data in RAM can have dramatic effects on the program.

\subsection*{5.2.5 Integer Subtract}

These routines are the counterparts of the integer addition routines in Section 5.2.3. The RAM maps are the same as in that section.

\section*{Binary Subtraction}

The routine as written below is a 16 -bit binary subtraction ( \(\mathrm{R} 1-\mathrm{RO} \rightarrow \mathrm{R} 1\) ).
```

BINSUB: LBI 0,12 ;initialize B register
SC ;set Carry for subtract
LOOP: LD I ;fetch R value and point to Rl
CASC ;subtract
NOP
XIS l;save result in Rl, increment Bd, point to Rl
JP LOOP
RET

```

\section*{BCD Subtraction}

The BCD counterpart of the preceding is the following four-digit subtract routine ( \(\mathrm{R} 1-\mathrm{R} 0 \rightarrow \mathrm{R} 1\) ).
```

BCDSUB: LBI 0,12 ;initialize B
SC ;set C for subtract
LOOP: LD I ;fetch RO value, point to Rl
CASC ;subtract
ADT ;decimal correct (15 }->9
XIS l ;save in Rl, increment Bd, point to RO
JP LOOP
RET

```

These routines are direct counterparts to the addition routines. The comments in Section 5.2 .3 are equally valid for these subtract routines.

\subsection*{5.2.6 Up-Down Counters}

The up-down counter routine is an extension or combination of the basic increment or decrement routines. Both an increment and a decrement have, effectively, been combined. The C register is used to distinguish between counting up or counting down. The basic flow for the routine and the RAM map is shown below in Figure 5-1.


The flow chart and RAM map are valid for both the binary and BCD versions of the routine. Two implementations of each are given: The first is a simple combination of the increment decrement routines. The second is a somewhat more sophisticated implementation which saves a little code but uses more RAM (one extra digit which is in TEMP STORE in the RAM map).


TL/DD/8800-11
FIGURE 5-1. Basic Flow for Up-Down Counter Routine

\section*{Binary Up-Down Counter}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{3}{|c|}{I} & \multicolumn{3}{|c|}{II} \\
\hline UPDOWN: & LBI & 2,12 & UPDOWN: & LBI & 3,12 \\
\hline & SKC & & & CLRA & \\
\hline & JP & DOWN & & SKC & \\
\hline \multirow[t]{6}{*}{UP:} & CLRA & & & COMP & \\
\hline & ASC & & COUNT : & X & 1;point to 2,12 \\
\hline & NOP & & & & \\
\hline & XIS & & COUNT1: & LDD & 3,12 \\
\hline & JP & UP & & ASC & \\
\hline & RET & & & NOP & \\
\hline \multirow[t]{6}{*}{Down:} & CLRA & & & XIS & \\
\hline & CASC & & & JP & COUNT1 \\
\hline & NOP & & & RET & \\
\hline & XIS & & & & \\
\hline & JP & Down & & & \\
\hline & RET & & & & \\
\hline
\end{tabular}

Version II of this routine loads 0 or 15 into a RAM location. Then the state of the carry controls addition or subtraction. Note that the location of the temporary data storage digit was chosen to use the exclusive OR capability of the X instruction to eliminate an instruction.

\section*{BCD Up-Down Counter}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{3}{|c|}{I} & \multicolumn{3}{|c|}{II} \\
\hline \multirow[t]{3}{*}{UPDOWN:} & LBI & 2,12 & UPDOWN: & LBI & 3,12 \\
\hline & SKC & & & CLRA & \\
\hline & JP & DOWN & & SKC & \\
\hline \multirow[t]{7}{*}{UP:} & CLRA & & & AISC & 9 \\
\hline & AISC & 6 & COUNT : & X & 1 \\
\hline & ASC & & & & \\
\hline & ADT & & COUNT1: & LDD & 3,12 \\
\hline & XIS & & & AISC & 6 \\
\hline & JP & UP & & ASC & \\
\hline & RET & & & ADT & \\
\hline \multirow[t]{6}{*}{DOWN :} & CLRA & & & XIS & \\
\hline & CASC & & & JP & COUNT1 \\
\hline & ADT & & & RET & \\
\hline & XIS & & & & \\
\hline & JP & DOWN & & & \\
\hline & RET & & & & \\
\hline
\end{tabular}

The comparison is the same as the binary routines. Version II here also illustrates another point. As written, Version II will execute (increment or decrement the four-digit counter) in 34 instruction cycle times. By merely moving the AISC 6 instruction from its present location to after the CLRA, the execution time is improved without any penalty.
\begin{tabular}{|c|c|c|c|}
\hline & IIa & & \\
\hline \multirow{4}{*}{UPDOWN:} & CIRA & & \\
\hline & AISC & & ;build decimal correct into the stored constant \\
\hline & SKC & & \\
\hline & AISC & 9 & \\
\hline COUNT : & X & 1 & \\
\hline \multirow[t]{6}{*}{COUNT1:} & LDD & 3,12 & \\
\hline & ASC & & \\
\hline & ADT & & \\
\hline & XIS & & \\
\hline & JP & COUNTI & \\
\hline & RET & & \\
\hline
\end{tabular}

This routine is completely equivalent in function, approach, and amount of code as Version II. It executes faster, however, 31 instruction cycles rather than 34. The reason for the speed improvement is that an instruction, the AISC 6, was moved out of the loop and into the "main body" of the routine.

\subsection*{5.2.7 Binary Multiply}

A routine for a 16 by 16 bit binary multiply is given below. A 32 -bit product is generated. A RAM map for this routine is given below. A flow chart is in Figure 5-2.

Bd
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline & 15 & \(14 \quad 13\) & 12 & 11 & 10 & 9 & 8 & 7 \\
\hline Br 0 & & X (multiplicand) & & & & & & BIT COUNTER \\
\hline 1 & & '0" & & & Y (mu & & & NOT USED \\
\hline
\end{tabular}

The routine does the following:
\(X x Y \rightarrow X Z\), previous \(X\) lost; \(Y\) unchanged


FIGURE 5-2. Binary Multiply
```

BINMULT: LBI 0,7
STII 0 ;clear bit counter and Z
STII 0
STII 0
STII 0
STII 0
LBI 1,12
STII 0
STII 0
STII 0
STII 0
LBI 0,8
RC
LSH: LD ;left shift XZ l bit, putting XMSB into C
ASC
NOP
EX: XIS
JP LSH
SKC
JP BITCTR
BINADD: RC
LBI 1,8 ;Y + XZ }->\textrm{XZ
ADD: LD
ASC
NOP
XIS 1
JP ADD
BITCTR: LBI 0,7 ;increment bit counter and test if done
ID
AISC 1
JP EX
RET

```

\subsection*{5.2.8 Basic Arithmetic Package}

This section includes the basic arithmetic functions, add, subtract, multiply, and divide. The routines are written as a cohesive unit. They are for eight-digit floating-point fully algebraic arithmetic. Figures 5-4 through 5-7 are the RAM map and flow chart for these routines.
Both decimal and binary (hexadecimal) versions of these routines are provided. The flow charts and RAM map are valid for both these versions.
The routines listed in Figures 5-3 and 5-8 have an arbitrary error handling routine; the error is merely flagged by setting the decimal point and sign position to 15 . The user can modify this to a perhaps more useful arrangement.
\begin{tabular}{|c|c|c|c|c|}
\hline \multicolumn{3}{|l|}{\multirow[t]{2}{*}{COP CROSS ASSEMBLER MAINPR}} & PAGE: & 1 \\
\hline & & & & \\
\hline 1 & & ;BASIC & BCD FLOAI & InN P \\
\hline \multicolumn{2}{|l|}{2} & ; & & \\
\hline \multicolumn{2}{|l|}{3} & ;REGIS & ER \(0=X\) & ,REGIS \\
\hline \multicolumn{2}{|l|}{4} & ; & & \\
\hline \multicolumn{2}{|l|}{5} & ;THE R & UTINES & RE FOR \\
\hline \multicolumn{2}{|l|}{6} & ;MULTI & LY AND D & DIVIDE. \\
\hline \multicolumn{2}{|l|}{7} & ;THE R & UTINES A & SSUME \\
\hline \multicolumn{2}{|l|}{8} & ;DECIM & L POINT & DIGIT. \\
\hline \multicolumn{2}{|l|}{9} & ;POSIT & ON INDIC & ATOR, I \\
\hline \multicolumn{2}{|l|}{10} & ;THAT & HE DECIM & AL POI \\
\hline \multicolumn{2}{|l|}{11} & ;DEC.P & . POSITI & ON OF \\
\hline \multicolumn{2}{|l|}{12} & ;PLACE & AFTER & HE MSD \\
\hline \multicolumn{2}{|l|}{13} & ; IN TH & SAME MA & NNER T \\
\hline \multicolumn{2}{|l|}{14} & ; & & \\
\hline \multicolumn{2}{|l|}{15} & ;THE R & UTINES & SO AS \\
\hline \multicolumn{2}{|l|}{16} & ;DIGIT & FOR THE & NUMBER \\
\hline \multicolumn{2}{|l|}{17} & ;DIGIT & FOR A TO & TAL OF \\
\hline \multicolumn{2}{|l|}{18} & ;USE 0 & LY AND & NOT \\
\hline \multicolumn{2}{|l|}{19} & ; & & \\
\hline \multicolumn{2}{|l|}{20} & ;THE R & UTINES CA & AN BE \\
\hline \multicolumn{2}{|l|}{21} & ;AS TH & ALGORI & MMS AR \\
\hline \multicolumn{2}{|l|}{22} & ;OBVIO & S THINGS & LIKE \\
\hline \multicolumn{2}{|l|}{23} & ;BE MO & IFIED TO & ACCOM \\
\hline \multicolumn{2}{|l|}{24} & ; & & \\
\hline \multicolumn{2}{|l|}{25} & ;THE C & DE AS WR & ITTEN \\
\hline \multicolumn{2}{|l|}{26} & ;THE R & UTINES A & RE WRI \\
\hline \multicolumn{2}{|l|}{27} & ;PROGR & M. ONE I & EVEL \\
\hline \multicolumn{2}{|l|}{28} & ;ROUTI & ES. COMP & ARABLE \\
\hline \multicolumn{2}{|l|}{29} & ;BUT S & ME CHANG & ES ARE \\
\hline \multicolumn{2}{|l|}{30} & ;ALTHO & GH THE I & MPLEME \\
\hline \multicolumn{2}{|l|}{31} & ; & & \\
\hline 32 & 0022 & SAVE1 & \(=\) & 2,2 \\
\hline 33 & 000F & XGUARD & = & 0,15 \\
\hline 34 & 000E & XMSD & = & 0,14 \\
\hline 35 & 0007 & XLSD & = & 0,7 \\
\hline 36 & 0006 & ROUND & = & 0,6 \\
\hline 37 & 0001 & XSIGN & = & 0,1 \\
\hline 38 & 0000 & XDP & = & 0,0 \\
\hline 39 & 001F & YGUARD & = & 1,15 \\
\hline 40 & 001E & YMSD & = & 1,14 \\
\hline 41 & 0017 & YLSD & = & 1,7 \\
\hline \multirow[t]{2}{*}{42} & 0011 & YSIGN & = & 1,1 \\
\hline & 0010 & YDP & = & 1,0 \\
\hline 4 & 002F & ZGUARD & = & 2,15 \\
\hline 45 & 002E & ZMSD & = & 2,14 \\
\hline 46 & 0027 & 2LSD & = & 2,7 \\
\hline \multirow[t]{2}{*}{47} & 0021 & ZSIGN & = & 2,1 \\
\hline & 0020 & ZDP & = & 2,0 \\
\hline 48 & 003F & FLAGS & = & 3,15 \\
\hline 50 & 0030 & OFLOW & = & 3,0 \\
\hline 51 & & ; & = & 3,0 \\
\hline
\end{tabular}

FIGURE 5-3. BCD Arithmetic Package (Sheet 1 of 9)

COP CROSS ASSEMBLER PAGE: 2
MAINPR
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline 52 & & 0000 & & . PAGE & 0 & \\
\hline 53 & 000 & 00 & & CLRA & & \\
\hline 54 & 001 & OF & & LBI & 0,0 & ;CLEAR ALL THE RAM \\
\hline 55 & 002 & 53 & & AISC & 3 & \\
\hline 56 & 003 & 12 & RAMCLR: & XABR & & \\
\hline 57 & 004 & 81 & & JSRP & CLEAR & \\
\hline 58 & 005 & 12 & & XABR & & \\
\hline 59 & 006 & 5F & & AISC & 15 & \\
\hline 60 & 007 & C9 & & JP & TESTG & \\
\hline 61 & 008 & C3 & & JP & RAMCLR & \\
\hline 62 & & & ; & & & \\
\hline
\end{tabular}
;********************************************************
;FOLLOWING CODE-TO NEXT LINE OF **-IS FOR CONTROL ONLY
    ;

009 335F TESTG: OGI 15 ;PUT G LINES HIGH FOR READING G
;USING G Lines for primitive control to select add, sub ;MULTIPLY OR DIVIDE-WILL ENTER NUMBERS IN BREAKPOINT ;MODE USING MODIFY COMMAND
1 2 00B 3301

SKGBZ 0 OOD D3 OOE 3E 00F 70 0106840 7012 C9 0133311 015 D9 016 3E 01774 018 D0 0193303 4 01B DF 5 OIC 3E
6 O1D 70
7 OIE E 8 01F 3313
```

021 C9

```
00223 E
102378
0246940
026 C9

JSMD: \(\begin{aligned} & \text { STII } \\ & \text { JSR } \\ & \text { JP MULDIV }\end{aligned}\)
;
;PRECEDING CODE FOR CONTROL ONLY,hAS NOTHING TO DO WITH the ;ARITHMETIC ALGORITHMS
;***********************************************************
0040 . PAGE 1
; this is the align routine for add/Subtract. it makes the ; DECIMAL POSITIONS OF the two numbers Equal before add or ; subtract takes place. the routine assumes that the numbers

COP CROSS ASSEMBLER PAGE: 3
MAINPR


FIGURE 5-3 BCD Arithmetic Package (Sheet 3 of 9 )
```

COP CROSS ASSEMBLER PAGE: 4
MAINPR
155 08F 00 RSFTRX: CLRA
156090 07 RSFT: XDS
157 091 23A2 XAD
158 093 4E CBA
159 094 59
160 095 99
161 }096232
16209890
163 099 2322
164 09B 48
165 09C 32
166 09D 15
167 09E 56
168 09F 30
169 OAO 4A
170 OAl 14
171 OA2 9D
172 OA3 48
173 OA4 22
174 OA5 15
175 OA6 10
176 OA7 4A
177 OA8 14
178 OA9 A5
179 OAA 48
180 OAB 2F
181 OAC 3F
182 OAD 05
183 OAE 5F
184 OAF 44
185 OBO O6
186 OB1 48
187 OB2 OF
188 OB3 3F
189 OB4 2F
190 OB5 O5
191 OB6 51
192 OB7 BO
193 OB8 O6
194 OB9 49
195 OBA 25
196 OBB 24
197 OBC BA
198 OBD 48
1 9 9
200 0100 .PAGE 4
201
202
203
204 100 3E
205 101 03
206 102 DO
THIS IS THE ADD/SUBTRACT ROUTINE. ROUTINE IS FOR 8 DIGITS.
;FLOATING POINT, FULLY ALGEBRAIC.
;
ADDSUB: LBI FLAGS
SKMBZ 2 ;TEST IF SHOULD SUBTRACT
JP CHNGMO ;CHANGE SIGN RO(X) IF SUBTRACT
FIGURE 5-3. BCD Arithmetic Package (Sheet 4 of 9)

```
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|l|}{COP CROSS ASSEMBLER} & PAGE: & 5 & \\
\hline \multicolumn{7}{|l|}{MAINPR} \\
\hline 207 & 103 & 3381 & ADSB1: & LBI & XSIGN & ;NOW TEST FOR SIGNS EQUAL \\
\hline 208 & 105 & 15 & & LD & 1 & \\
\hline 209 & 106 & 21 & & SKE & & \\
\hline 210 & 107 & D7 & & JP & SUB & ;NOT EQUAL, HENCE SUBTRACT \\
\hline 211 & 108 & 3387 & ADD : & LBI & XLSD & \\
\hline 212 & 10A & 9 C & & JRP & BCDADD & ; Rl+RO \(\rightarrow\) Rl, \((\mathrm{Y}+\mathrm{X} \rightarrow \mathrm{Y})\) \\
\hline 213 & 10B & 1E & ERRCHK: & LBI & YGUARD & ;TEST FOR OVERFLOW \\
\hline 214 & 10C & 00 & & CLRA & & ;IF 1,15(YGUARD) NOT 0,UNDERFLOW \\
\hline 215 & 10D & 21 & & SKE & & \\
\hline 216 & 10E & ED & & JP & UNDRFL & \\
\hline 217 & 10F & 48 & & RET & & \\
\hline 218 & 110 & 3381 & CHNGMO: & LBI & XSIGN & ; CHANGE SIGN OF RO(X) \\
\hline 219 & 112 & 05 & & LD & & \\
\hline 220 & 113 & 58 & & AISC & 8 & \\
\hline 221 & 114 & 44 & & NOP & & \\
\hline 222 & 115 & 06 & & X & & \\
\hline 223 & 116 & C3 & & JP & ADSB1 & \\
\hline 224 & 117 & 3387 & SUB : & IBI & XLSD & \\
\hline 225 & 119 & A4 & & JSRP & BCDSUB & ;R1-R0 \(\rightarrow\) R1, (Y-X \(\rightarrow\) ) \\
\hline 226 & 11A & 20 & & SKC & & ;SEE IF MUST COMPLEMENT \\
\hline 227 & 11B & DD & & JP & COMPL & \\
\hline 228 & 11C & CB & & JP & ERRCHK & \\
\hline 229 & 11D & 3397 & COMPL : & LBI & YLSD & ;NEGATIVE RESULT, COMPLEMENT \\
\hline 230 & 11F & 22 & & SC & & \\
\hline 231 & 120 & 00 & COMPLI: & CLRA & & \\
\hline 232 & 121 & 06 & & X & & \\
\hline 233 & 122 & 10 & & CASC & & \\
\hline 234 & 123 & 4A & & ADT & & \\
\hline 235 & 124 & 04 & & XIS & & \\
\hline 236 & 125 & E0 & & JP & COMPLI & \\
\hline 237 & 126 & 3391 & & LBI & YSIGN & ;NOW CHANGE SIGN OF Rl(Y) \\
\hline 238 & 128 & 05 & & LD & & \\
\hline 239 & 129 & 58 & & AISC & 8 & \\
\hline 240 & 12A & 44 & & NOP & & \\
\hline 241 & 12B & 06 & & X & & \\
\hline 242 & 12 C & CB & & JP & ERRCHK & \\
\hline 243 & 12D & 8 E & UNDRFL: & JSRP & RSFTR1 & ;DO AN UNDERFLOW \\
\hline 244 & 12 E & 1 F & & LBI & YDP & ;ERROR IF YDP IS O WHEN UNDERFLOW \\
\hline 245 & 12F & AD & & JSRP & MINUS1 & \\
\hline 246 & 130 & 5 F & & AISC & 15 & \\
\hline 247 & 131 & F3 & & JP & ERROR & \\
\hline 248 & 132 & 48 & & RET & & \\
\hline 249 & 133 & 1 F & ERROR: & LBI & YDP & \\
\hline 250 & 134 & 7 F & & STII & 15 & ;15 \(\rightarrow\) YDP \& YSIGN FOR ERROR \\
\hline 251 & 135 & 7 F & & STII & 15 & \\
\hline 252 & 136 & 48 & & RET & & \\
\hline 253 & & 0140 & & . PAGE & 5 & \\
\hline 254 & & & ;MULTIPL & L, DIVID & E Routin & S. FLOATING POINT, 8 DIGIt \\
\hline 255 & & & ; & & & \\
\hline 256 & 140 & 3387 & MULDIV: & LBI & XLSD & \\
\hline 257 & 142 & BA & & JSRP & XFER2 & ; MO \(\rightarrow\) M2, \(\mathrm{X} \rightarrow \mathrm{Z}\), THEN CLEAR X \\
\hline 258 & 143 & 25 & & LD & 2 & ;TRANSFER DP AND SIGN ALSO \\
\hline
\end{tabular}

FIGURE 5-3. BCD Arithmetic Package (Sheet 5 of 9)

COP CROSS ASSEMBLER PAGE: 6 MAINPR
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline 259 & 144 & 24 & & XIS & 2 & \\
\hline 260 & 145 & 25 & & LD & 2 & \\
\hline 261 & 146 & 26 & & X & 2 & \\
\hline 262 & 147 & 80 & & JSRP & Clearo & ;CLEAR MO \\
\hline 263 & 148 & 3E & & LBI & FLAGS & ;NOW TEST IF MULTIPLY OR DIVIDE \\
\hline 264 & 149 & 13 & & SKMBZ & 3 & \\
\hline 265 & 14A & 61C0 & & JMP & MULPLY & \\
\hline 266 & & & ; & & & \\
\hline 267 & 14C & 22 & DIVIDE: & SC & & ; \(\mathrm{MO} / \mathrm{Ml} \rightarrow \mathrm{MO},(\mathrm{X} / \mathrm{Y} \rightarrow \mathrm{X})\) \\
\hline 268 & 14D & 1 F & & LBI & YDP & ;DP2-DPO \(\rightarrow\) DP2, (DPZ-DPX \(\rightarrow\) DPZ \\
\hline 269 & 14 E & 35 & & LD & 3 & \\
\hline 270 & 14 F & 10 & & CASC & & \\
\hline 271 & 150 & 44 & & NOP & & \\
\hline 272 & 151 & 06 & & X & & \\
\hline 273 & 152 & 3F & & LBI & OFLOW & ;15 TO OFLOW DIGIT IF BORROW, ELSE 0 \\
\hline 274 & 153 & 00 & & CLRA & & \\
\hline 275 & 154 & 20 & & SKC & & \\
\hline 276 & 155 & 40 & & COMP & & \\
\hline 277 & 156 & 06 & & X & & \\
\hline 278 & 157 & 3397 & DIVIA: & LBI & YLSD & \\
\hline 279 & 159 & A4 & & JSRP & BCDSUB & ;MO - M1 TO MO,M1 SAVED \\
\hline 280 & 15A & 20 & & SKC & & ;PART OF THE REPEATED SUBTRACT FEATURE \\
\hline 281 & 15B & E2 & & JP & DIV3A & \\
\hline 282 & 15C & 33A7 & DIV3: & LBI & ZLSD & ;DIVIDE BY O CHECK \\
\hline 283 & 15E & B5 & & JSRP & PLUS1 & \\
\hline 284 & 15F & D7 & & JP & DIV1A & ;ALL OK, CONTINUE \\
\hline 285 & 160 & 6189 & & JMP & DIVBYO & \\
\hline 286 & 162 & 3397 & DIV3A: & LBI & YLSD & \\
\hline 287 & 164 & 9C & & JSRP & BCDADD & ;RESTORE VALUE \\
\hline 288 & 165 & OF & & LBI & XDP & \\
\hline 289 & 166 & 05 & & LD & & \\
\hline 290 & 167 & 57 & & AISC & 7 & \\
\hline 291 & 168 & 617F & & JMP & DIV1B & ;TESTING DP FOR FINISHED \\
\hline 292 & 16A & 2 E & DIV4: & LBI & ZGUARD & \\
\hline 293 & 16B & 00 & & CLRA & & \\
\hline 294 & 16C & 21 & & SKE & & \\
\hline 295 & 16D & 61E5 & & JMP & MDENDI & \\
\hline 296 & 16F & 3F & & LBI & OFLOW & \\
\hline 297 & 170 & 21 & & SKE & & ;TEST OVERFLOW DIGIT \\
\hline 298 & 171 & F8 & & JP & DIV4A & \\
\hline 299 & 172 & 2 F & & LBI & ZDP & ;TEST DP2(ZDP) >= 9 \\
\hline 300 & 173 & 05 & & LD & & \\
\hline 301 & 174 & 57 & & AISC & 7 & \\
\hline 302 & 175 & F8 & & JP & DIV4A & \\
\hline 303 & 176 & 61E5 & & JMP & MDENDI & \\
\hline 304 & 178 & B4 & DIV4A: & JSRP & ZDPPLI & ;DP2+1 \(\rightarrow\) DP2, (ZDP+1 \(\rightarrow\) 2DP) \\
\hline 305 & 179 & 6181 & & JMP & DIV1B2 & \\
\hline 306 & 17B & B3 & & JSRP & OFLPLI & ;INCREMENT OVERFLOW DIGIT \\
\hline 307 & 17C & 44 & & NOP & & ;DEFEAT SKIP \\
\hline 308 & 17D & 6181 & & JMP & DIV1B2 & \\
\hline 309 & 17F & B2 & DIV1B: & JSRP & XDPPLI & ;DPO + \(1 \rightarrow\) DPO \\
\hline 310 & 180 & 44 & & NOP & & \\
\hline
\end{tabular}

FIGURE 5-3. BCD Arithmetic Package (Sheet 6 of 9 )
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|l|}{COP CROSS ASSEMBLER} & PAGE: & 7 & \\
\hline \multicolumn{7}{|l|}{MAINPR} \\
\hline 311 & 181 & 33A7 & DIV1B2: & LBI & 2LSD & \\
\hline 312 & 183 & 89 & & JSRP & LSFTX & \\
\hline & 184 & 3387 & & LBI & XLSD & \\
\hline 314 & 186 & & & JSRP & LSFT & \\
\hline 315 & 187 & 6157 & & JMP & DIVIA & \\
\hline 316 & 189 & 621B & DIVBYO: & JMP & MDERR & \\
\hline 317 & & O1C0 & & . PAGE & 7 & \\
\hline 318 & 1C0 & 32 & MULPLY: & RC & & ;DP1+DP2 \(\rightarrow\) DP2, (DPY + DPZ \(\rightarrow\) DPZ \\
\hline 319 & 1 Cl & 1 F & & LBI & YDP & \\
\hline 320 & 1C2 & 35 & & LD & 3 & \\
\hline 321 & 1 C 3 & 30 & & ASC & & \\
\hline 322 & 1 C 4 & 44 & & NOP & & \\
\hline 323 & \(1 \mathrm{C5}\) & 06 & & X & & \\
\hline 324 & 1C6 & 00 & & CLRA & & ;1 TO OFLOW IF CARRY, ELSE 0 \\
\hline 325 & \(1 \mathrm{C7}\) & 20 & & SKC & & \\
\hline 326 & \(1 \mathrm{C8}\) & CA & & JP & MULIA & \\
\hline 327 & 1C9 & 51 & & AISC & 1 & \\
\hline 328 & 1CA & 3 F & MULIA : & LBI & OFLOW & \\
\hline 329 & 1CB & 06 & & X & & \\
\hline 330 & 1CC & 33A7 & MULI : & LBI & ZLSD & \\
\hline 331 & 1CE & 05 & & LD & & \\
\hline 332 & 1CF & 5 F & & AISC & 15 & ;LSD CONTROLLING REPEATED ADDS \\
\hline 333 & 1DO & D6 & & JP & MUL2 & \\
\hline 334 & 1D1 & 06 & & X & & \\
\hline 335 & 1D2 & 3397 & & LBI & YLSD & ; \(\mathrm{MO}+\mathrm{Ml} \rightarrow \mathrm{MO},(\mathrm{X}+\mathrm{Y} \rightarrow \mathrm{X})\) \\
\hline 336 & 1D4 & 9C & & JSRP & BCDADD & \\
\hline 337 & 1D5 & CC & & JP & MULI & \\
\hline 338 & 1D6 & 8D & MUL2 : & JSRP & RSFTRO & \\
\hline 339 & 1D7 & 2 E & & LBI & ZGUARD & \\
\hline 340 & 1D8 & 90 & & JSRP & RSFT & \\
\hline 341 & lD9 & B2 & & JSRP & XDPPLI & \\
\hline 342 & 1DA & 58 & & AISC & 8 & \\
\hline 343 & 1DB & CC & & JP & MUL1 & ;PRECEDING IS DP ADJUST \\
\hline 344 & 1DC & 78 & MUL3: & STII & 8 & \\
\hline 345 & 1DD & 3387 & & LBI & XLSD & \\
\hline 346 & 1DF & 00 & MUL3X : & CLRA & & ;TEST MO \(=0(\mathrm{X}=0)\) \\
\hline 347 & 1E0 & 21 & & SKE & & \\
\hline 348 & 1E1 & 6212 & & JMP & MUL5 & \\
\hline 349 & 1E3 & 04 & & XIS & & \\
\hline 350 & 1E4 & DF & & JP & MUL3X & \\
\hline 351 & 1E5 & 2 E & MDEND1: & LBI & ZGUARD & \\
\hline 352 & IE6 & 00 & & CLRA & & \\
\hline 353 & 1E7 & 21 & & SKE & & \\
\hline 354 & 1E8 & ED & & JP & MDX & \\
\hline 355 & 1E9 & 2 F & & LBI & ZDP & \\
\hline 356 & IEA & 05 & & LD & & \\
\hline 357 & LEB & 57 & & AISC & 7 & ;TEST > \(=9\) \\
\hline 358 & 1EC & F7 & & JP & MDEND2 & \\
\hline 359 & 1ED & 2 E & MDX : & LBI & ZGUARD & \\
\hline 360 & IEE & 8F & & JSRP & RSFTRX & \\
\hline 361 & lEF & 3386 & & LBI & ROUND & ;SAVE VALUE FOR ROUNDING \\
\hline 362 & 1 Fl & & & X & & \\
\hline
\end{tabular}

FIGURE 5-3. BCD Arithmetic Package (Sheet 7 of 9)

COP CROSS ASSEMBLER PAGE: 8
MAINPR
\begin{tabular}{|c|c|c|c|c|c|}
\hline 363 & 1F2 AB & & JSRP & ZDPMN1 & \\
\hline 364 & \(1 F 305\) & & LD & & ;TEST DP2(ZDP) \(=15\) \\
\hline 365 & \(1 F 451\) & & AISC & 1 & \\
\hline 366 & 1 F 5 F 7 & & JP & MDEND2 & \\
\hline 367 & 1 F 6 AC & & JSRP & OFLMN1 & ;SUBTRACT 1 FROM OVERFLOW DIGIT \\
\hline 368 & \(1 F 7\) 2F & MDEND2 : & LBI & 2,0 & ;TRANSFER R2 TO RO \\
\hline 369 & 1F8 BA & & JSRP & XFER2 & \\
\hline 370 & 1F9 3391 & & LBI & YSIGN & ;ADD SIGNS AND PUT TO MO(X) \\
\hline 371 & 1FB 15 & & LD & 1 & \\
\hline 372 & 1FC 31 & & ADD & & \\
\hline 373 & 1FD 06 & & X & & \\
\hline 374 & 1FE 3F & & LBI & OFLOW & ;TEST OVERFLOW DIGIT \\
\hline 375 & 1FF 05 & & LD & & \\
\hline 376 & 20051 & & AISC & 1 & \\
\hline 377 & 201 C 3 & & JP & MDEND4 & ;NOT 15 \\
\hline 378 & 202 DB & & JP & MDERR & ;IS 15,NUMBER TOO BIG \\
\hline 379 & 20300 & MDEND4: & CLRA & & ;NOW TEST DIGIT > 0 \\
\hline 380 & 20421 & & SKE & & \\
\hline 381 & 20580 & & JSRP & CLEARO & ;IS NON ZERO,CLEAR MO \\
\hline 382 & 2063387 & MDRJ : & LBI & XLSD & ;RIGHT JUSTIFY the Result \\
\hline 383 & 20800 & & CLRA & & \\
\hline 384 & 20921 & & SKE & & \\
\hline 385 & 20A 48 & & RET & & ;IF LSD NON ZERO,STOP \\
\hline 386 & 20B OF & & LBI & XDP & ;IF DP PSN \(=0, S T O P\) \\
\hline 387 & 20C 05 & & LD & & \\
\hline 388 & 20D 5F & & AISC & 15 & \\
\hline 389 & 20E 48 & & RET & & \\
\hline 390 & 20F 06 & & X & & ;ELSE,DECREMENT BY 1 AND CONTINUE \\
\hline 391 & 2108 D & & JSRP & RSFTRO & \\
\hline 392 & 211 C6 & & JP & MDRJ & \\
\hline 393 & 212 2F & MUL5 : & LBI & ZDP & ;TEST DP2(ZDP) \(=0\) \\
\hline 394 & 21300 & & CLRA & & \\
\hline 395 & 21421 & & SKE & & \\
\hline 396 & 215 D8 & & JP & MUL3A & \\
\hline 397 & 21640 & & COMP & & ;15 TO DP2(ZDP) \\
\hline 398 & 21706 & & X & & \\
\hline 399 & 218 AD & MUL3A : & JSRP & MINUS1 & ; DP2 (ZDP) - \(1 \rightarrow\) DP2(ZDP) \\
\hline 400 & 219 61D6 & & JMP & MUL2 & \\
\hline 401 & 21B OE & MDERR : & LBI & 0,15 & \\
\hline 402 & 21C 7F & & STII & 15 & \\
\hline 403 & 21D 7F & & STII & 15 & \\
\hline 404 & 21E 48 & & RET & & \\
\hline 405 & & & . END & & \\
\hline
\end{tabular}

FIGURE 5-3. BCD Arithmetic Package (Sheet 8 of 9)

COP CROSS ASSEMBLER PAGE: 9
MAINPR
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline ADD & 0108 * & ADDSUB & 0100 & ADSB1 & 0103 & ALIGN & 0040 \\
\hline ALIGN2 & 0046 & BCD1 & 009D & BCDADD & 009C & BCDS 1 & 00A5 \\
\hline BCDSUB & 00A4 & CHNGMO & 0110 & CLEAR & 0081 & CLEARO & 0080 \\
\hline COMPL & 011D & COMPLI & 0120 & DIV1A & 0157 & DIVIB & 017F \\
\hline DIV1B2 & 0181 & DIV3 & 015C * & DIV3A & 1062 & DIV4 & 016A \\
\hline DIV4A & 0178 & DIVBYO & 0189 & DIVIDE & 014C & DONE & 0099 \\
\hline DPOGTI & 0056 & DPOLTI & 0048 * & DPMIN1 & 0053 & DPPLI & 004E \\
\hline ERRCHK & O10B & ERROR & 0133 & FLAGS & 003F & JSMD & 0024 \\
\hline JSRALN & 0010 & LSFT & 008A & LSFTRO & 0087 & LSFTRI & 0085 \\
\hline LSFTX & 0089 & MDEND1 & O1E5 & MDEND2 & 01F7 & MDEND4 & 0203 \\
\hline MDERR & 021B & MDRJ & 0206 & MDC & O1ED & MINUSI & 00AD \\
\hline MULI & O1CC & MULIA & 01CA & MUL2 & 01D6 & MUL3 & O1DC \\
\hline MUL3A & 0218 & MUL3X & 01DF & MUL5 & 0212 & MULDIV & 0140 \\
\hline MULPLY & 01c0 & OFLMN1 & 00AC & OFLOW & 0030 & OFLPLI & 00B3 \\
\hline PLUS 1 & 00B5 & Plusia & OOBO & ROLSFT & 004C & RORSFT & 005C \\
\hline RILSFT & 005A * & RIRSFT & 0051 & RAMCLR & 0003 & ROUND & 0006 \\
\hline RSFT & 0090 & RSFTRO & 008D & RSFTRI & 008E & RSFTRX & 008F \\
\hline SAVE1 & 0022 & SUB & 0117 & testa & 0009 & TESTGI & 0013 \\
\hline TESTG2 & 0019 & TESTG3 & \(001 F\) & UNDRFL & 012D & XDP & 0000 \\
\hline XDPPL1 & 00B2 & XFER2 & 00BA & XGUARD & 000F & XISD & 0007 \\
\hline XMSD & OOOE & XSIGN & 0001 & YDP & 0010 & YgUARD & 001F \\
\hline YLSD & 0017 & YMSD & 001E & YSIGN & 0011 & ZDP & 0020 \\
\hline ZDPMN1 & 00AB & ZDPPLI & 00B4 & ZGUARD & 002F & ZLSD & 0027 \\
\hline
\end{tabular}

NO ERROR LINES
356 ROM WORDS USED
COP 420 ASSEMBLY
SOURCE CHECKSUM = FBE9
INPUT FILE ABDUL10:ARITH.SRC VN: 20
FIGURE 5-3. BCD Arithmetic Package (Sheet 9 of 9)


TL/DD/8800-13
FIGURE 5-4. RAM Map-Basic Arithmetic Routines


FIGURE 5-5. Align Routine for Add/Subtract



FIGURE 5-7. Multiply/Divide (Sheet 1 of 3)



FIGURE 5-7. Multiply/Dlvide (Sheet 3 of 3)

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|l|}{COP CROSS ASSEMBLER} & \multicolumn{3}{|l|}{PAGE: 2} \\
\hline \multicolumn{4}{|l|}{HXMATH HEXADECIMAL} & \multicolumn{3}{|l|}{ARITHMETIC} \\
\hline 53 & & 0010 & YDP & \(=\) & 1,0 & \\
\hline 54 & & 002F & ZGUARD & \(=\) & 2,15 & \\
\hline 55 & & 002E & ZMSD & \(=\) & 2,14 & \\
\hline 56 & & 0027 & 2LSD & = & 2,7 & \\
\hline 57 & & 0021 & ZSIGN & \(=\) & 2,1 & \\
\hline 58 & & 0020 & ZDP & = & 2,0 & \\
\hline 59 & & 003F & FLAGS & = & 3,15 & \\
\hline 60 & & 0030 & OFLOW & \(=\) & 3,0 & \\
\hline 61 & & & ; & & & \\
\hline 62 & & 0000 & & . PAGE & 0 & \\
\hline 63 & 000 & 00 & & CLRA & & \\
\hline 64 & 001 & OF & & LBI & 0.0 & ; CLEAR ALL THE RAM \\
\hline 65 & 002 & 53 & & AISC & 3 & \\
\hline 66 & 003 & 12 & RAMCLR: & XABR & & \\
\hline 67 & 004 & 81 & & JSRP & CLEAR & \\
\hline 68 & & 12 & & XABR & & \\
\hline 69 & 006 & 5 F & & AISC & 15 & \\
\hline 70 & 007 & C9 & & JP & TESTG & \\
\hline 71 & 008 & C3 & & JP & RAMCLR & \\
\hline 72 & & & ; & & & \\
\hline 73 & & & ;******* & ******* & ******* & *************************************** \\
\hline 74 & & & ;FOLLOWI & ING COD & -TO NEX & LINE OF **-IS FOR CONTROL ONLY \\
\hline 75 & & & ; & & & \\
\hline 76 & 009 & 335 F & TESTG: & OGl & & ;PUT G LINES HIGH FOR READING G \\
\hline 77 & & & ; & & & \\
\hline 78 & & & & ;USING & LINES & R PRIMITIVE CONTROL TO SELECT ADD, SUB \\
\hline 79 & & & & ;MULTIP & OR DIV & IDE--WILL ENTER NUMBERS IN BREAKPOINT \\
\hline 80 & & & & ;MODE US & ING MOD & Y COMMAND \\
\hline 81 & & & & ; & & \\
\hline 82 & OOB & 3301 & & SKGBZ & 0 & \\
\hline 83 & OOD & D3 & & JP & TESTGI & \\
\hline 84 & 00E & 3E & & LBI & FLAGS & \\
\hline 85 & 00F & 70 & & STII & 0 & ;RESET BIT 2 FOR ADD \\
\hline 86 & 010 & 6840 & JSRALN: & JSR & ALIGN & \\
\hline 87 & 012 & C9 & & JP & TESTG & \\
\hline 88 & 013 & 3311 & TESTG1: & SKGBZ & 1 & \\
\hline 89 & 015 & D9 & & JP & TESTG2 & \\
\hline 90 & 016 & 3E & & LBI & FLAGS & ;SET SUBTRACT BIT \\
\hline 91 & 017 & 74 & & STII & 4 & ;SET BIT 2 FOR SUBTRACT \\
\hline 92 & 018 & D0 & & JP & JSRALN & \\
\hline 93 & 019 & 3303 & TESTG2: & SKGBZ & 2 & \\
\hline 94 & 01B & DF & & JP & TESTG3 & \\
\hline 95 & 01C & 3E & & LBI & FLAGS & \\
\hline 96 & 01D & 70 & & STII & 0 & ;RESET BIT 3 FOR DIVIDE \\
\hline 97 & O1E & E4 & & JP & JSMD & \\
\hline 98 & 01F & 3313 & TESTG3: & SKGBZ & 3 & \\
\hline 99 & 021 & C9 & & JP & TESTG & \\
\hline 100 & 022 & 3E & & LBI & FLAGS & \\
\hline 101 & 023 & 78 & & STII & 8 & ;SET BIT 3 FOR MULTIPLY \\
\hline 102 & 024 & 6940 & JSMD: & JSR & MULDIV & \\
\hline 103 & 026 & C9 & & JP & TESTG & \\
\hline 104 & & & ; & & & \\
\hline
\end{tabular}

FIGURE 5-8. Binary (Hexadecimal) Arithmetic Package (Sheet 2 of 9)


FIGURE 5-8. Binary (Hexadecimal) Arithmetic Package (Sheet 3 of 9)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|l|}{COP CROSS ASSEMBLER} & PAGE: & 4 & \\
\hline HXM & ATH & \multicolumn{4}{|c|}{HEXADECIMAL ARITHMETIC} & \\
\hline 155 & 083 & 81 & & JP & CLEAR & \\
\hline 156 & 084 & 48 & & RET & & \\
\hline 157 & 085 & 3397 & LSFTRI: & LBI & YLSD & \\
\hline 158 & 087 & 3387 & LSFTRO: & LBI & XLSD & \\
\hline 159 & 089 & 00 & LSFTX: & CLRA & & \\
\hline 160 & 08A & 04 & ISFT: & XIS & & \\
\hline 161 & 08B & 8A & & JP & LSFT & \\
\hline 162 & 08C & 48 & & RET & & \\
\hline 163 & 08D & OE & RSFTRO: & LBI & 0,15 & \\
\hline 164 & 08E & 1E & RSFTRI: & LBI & 1,15 & \\
\hline 165 & 08F & 00 & RSFTRX: & CLRA & & \\
\hline 166 & 090 & 07 & RSFT : & XDS & & \\
\hline 167 & 091 & 23A2 & & XAD & SAVEl & ;SAVE VALUE TEMPORARILY \\
\hline 168 & 093 & 4E & & CBA & & ;ONLY WANT 8 DIGIT SHIFT \\
\hline 169 & 094 & 59 & & AISC & 9 & \\
\hline 170 & 095 & 99 & & JP & DONE & \\
\hline 171 & 096 & 2322 & & LDD & SAVEl & ;FETCH SAVED VALUE \\
\hline 172 & 098 & 90 & & JP & RSFT & \\
\hline 173 & 099 & 2322 & DONE: & LDD & SAVEl & \\
\hline 174 & 09B & 48 & & RET & & \\
\hline 175 & 09C & 32 & BINADD : & RC & & \\
\hline 176 & 09D & 15 & BIN1: & LD & 1 & ;TWO REGISTER BINARY ADDITION \\
\hline 177 & 09E & 30 & & ASC & & \\
\hline 178 & 09F & 44 & & NOP & & \\
\hline 179 & OAO & 14 & & XIS & 1 & \\
\hline 180 & OAl & 9D & & JP & BIN1 & \\
\hline 181 & OA2 & 48 & & RET & & \\
\hline 182 & OA3 & 22 & BINSUB: & SC & & ;TWO REGISTER BINARY SUBTRACTION \\
\hline 183 & OA4 & 15 & BINSI: & LD & 1 & \\
\hline 184 & OA5 & 10 & & CASC & & \\
\hline 185 & OA6 & 44 & & NOP & & \\
\hline 186 & 0A7 & 14 & & XIS & & \\
\hline 187 & OA8 & A4 & & JP & BINSI & \\
\hline 188 & OA9 & 48 & & RET & & \\
\hline 189 & OAA & 2 F & ZDPMN1: & LBI & ZDP & \\
\hline 190 & OAB & 3 F & OFLMN1: & LBI & OFLOW & \\
\hline 191 & OAC & 05 & MINUS1: & LD & & ;SUBTRACT 1 FROM MEMORY \\
\hline 192 & OAD & 5 F & & AISC & 15 & \\
\hline 193 & OAE & 44 & & NOP & & \\
\hline 194 & OAF & 06 & PLUSIA : & X & & \\
\hline 195 & OBO & 48 & & RET & & \\
\hline 196 & OB1 & OF & XDPPLI: & LBI & XDP & \\
\hline 197 & OB2 & 3 F & OFLPLI: & LBI & OFLOW & \\
\hline 198 & OB3 & 2 F & ZDPPL1: & IBI: & ZDP & \\
\hline 199 & OB4 & 05 & PLUS1: & LD & & ;ADD 1 TO MEMORY \\
\hline 200 & OB5 & 51 & & AISC & 1 & \\
\hline 201 & OB6 & AF & & JP & PLUS1A & ;WILL SKIP IF GREATER THAN 15 \\
\hline 202 & OB7 & 06 & & X & & \\
\hline 203 & OB8 & 49 & & RETSK & & \\
\hline 204 & OB9 & 25 & XFER2: & LD & 2 & \\
\hline 205 & OBA & 24 & & XIS & 2 & \\
\hline 206 & OBB & B9 & & JP & XFER2 & \\
\hline 207 & OBC & & & RET & & \\
\hline 208 & & & ; & & & \\
\hline
\end{tabular}

FIGURE 5-8. Binary (Hexadecimal) Arithmetic Package (Sheet 4 of 9)
```

lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll
lllllll

```
    FIGURE 5-8. Binary (hexadecimal) Arithmetic Package (Sheet 5 of 9)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|l|}{COP CROSS ASSEMBLER} & \multicolumn{3}{|l|}{PAGE: 6} \\
\hline HXMA & ATH & \multicolumn{5}{|c|}{HEXADECIMAL ARITHMETIC} \\
\hline 261 & 136 & 48 & & RET & & \\
\hline 262 & & 0140 & & . PAGE & 5 & \\
\hline 263 & & & ;MULTIPL & LY,DIVI & E ROUTIN & ES. FLOATING POINT,8 DIGIT \\
\hline 264 & & & ; & & & \\
\hline 285 & 140 & 3387 & MULDIV : & LBI & XLSD & \\
\hline 266 & 142 & B9 & & JSRP & XFER2 & ; MO \(\rightarrow\) M2, \(\mathrm{X} \rightarrow \mathrm{Z}\), THEN CLEAR X \\
\hline 267 & 143 & 25 & & LD & & ;TRANSFER DP AND SIGN ALSO \\
\hline 268 & 144 & 24 & & XIS & 2 & \\
\hline 269 & 145 & 25 & & ID & 2 & \\
\hline 270 & 146 & 26 & & X & 2 & \\
\hline 271 & 147 & 80 & & JSRP & CLEARO & ;CLEAR MO \\
\hline 272 & 148 & 3E & & LBI & FLAGS & ;NOW TEST IF MULTIPLY OR DIVIDE \\
\hline 273 & 149 & 13 & & SKMBZ & 3 & \\
\hline 274 & 14A & 6100 & & JMP & MULPLY & \\
\hline 275 & & & ; & & & \\
\hline 276 & 14C & 22 & DIVIDE & SC & & ;MO/M1 \(\rightarrow\) MO, \(\mathrm{X} / \mathrm{Y} \rightarrow \mathrm{X})\) \\
\hline 277 & 14D & \(1 F\) & & LBI & YDP & ;DP2-DPO \(\rightarrow\) DP2, (DPZ-DPX \(\rightarrow\) DPZ \\
\hline 278 & 14E & 35 & & LD & 3 & \\
\hline 279 & 14F & 10 & & CASC & & \\
\hline 280 & 150 & 44 & & NOP & & \\
\hline 281 & 151 & 06 & & X & & \\
\hline 282 & 152 & 3 F & & LBI & OFLOW & ;15 TO OFLOW DIGIT IF BORROW,ELSE 0 \\
\hline 283 & 153 & 00 & & CLRA & & \\
\hline 284 & 154 & 20 & & SKC & & \\
\hline 285 & 155 & 40 & & COMP & & \\
\hline 286 & 156 & 06 & & X & & \\
\hline 287 & 157 & 3397 & DIVIA: & LBI & YLSD & \\
\hline 288 & 159 & A3 & & JSRP & BINSUB & ;MO - M1 TO MO,M1 SAVED \\
\hline 289 & 15A & 20 & & SKC & & ;PART OF THE REPEATED SUBTRACT FEATURE \\
\hline 290 & 15B & E3 & & JP & DIV3A & \\
\hline 291 & 15C & \(33 A 7\) & DIV3: & LBI & ZLSD & ;DIVIDE BY 0 CHECK \\
\hline 292 & 15E & B4 & & JSRP & PLUS1 & \\
\hline 293 & 15F & D7 & & JP & DIV1A & ;ALL OK,CONTINUE \\
\hline 294 & 160 & 6189 & & JMP & DIVBYO & \\
\hline 295 & 162 & 3397 & DIV3A: & LBI & YLSD & \\
\hline 296 & 164 & 9C & & JSRP & BINADD & ;RESTORE VALUE \\
\hline 297 & 165 & OF & & LBI & XDP & \\
\hline 298 & 166 & 05 & & LD & & \\
\hline 299 & 167 & 57 & & AISC & 7 & \\
\hline 300 & 168 & 617F & & JMP & DIVIB & ;TESTING DP FOR FINISHED \\
\hline 301 & 16A & 2E & DIV4: & LBI & ZGUARD & \\
\hline 302 & 16B & 00 & & CLRA & & \\
\hline 303 & 16C & 21 & & SKE & & \\
\hline 304 & 16 D & 61E5 & & JMP & MDENDI & \\
\hline 305 & 16 F & 3F & & LBI & OFLOW & \\
\hline 306 & 170 & 21 & & SKE & & ;TEST OVERFLOW DIGIT \\
\hline 307 & 171 & F8 & & JP & & DIV4A \\
\hline 308 & 172 & 2 F & & LBI & ZDP & ;TEST DP2(2DP) >= 9 \\
\hline 309 & 173 & 05 & & LD & & \\
\hline 310 & 174 & 57 & & AISC & 7 & \\
\hline 311 & 175 & F8 & & JP & DIV4A & \\
\hline 312 & 176 & 6155 & & JMP & MDEND1 & \\
\hline
\end{tabular}

FIGURE 5-8. Binary (Hexadecimal) Arithmetic Package (Sheet 6 of 9)
```

COP CROSS ASSEMBLER PAGE: 7
HXMATH HEXADECIMAL ARITHMETIC

| 313 | 78 | B3 | DIV4A : | JSRP | 2DPPLI | ;DP2+1 $\rightarrow$ DP2, (2DP+1 $\rightarrow$ ZDP) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 314 | 179 | 6181 |  | JMP | DIV1B2 |  |
| 315 | 17B | B2 |  | JSRP | OFLPLI | ;INCREMENT OVERFLOW DIGI |

316 17C $44 \quad$ NOP
317 17D 6181
JMP DIVIB2
318 17F BI DIVIB: JSRP XDPPLI
31918044 NOP
320181 33A7 DIV1B2: LBI ZLSD
32118389 JSRP LSFTX
3221843387 LBI XLSD
323186 8A JSRP LSFT
3241876157 JMP DIVIA
325189 621B DIVBYO: JMP MDERR
326 OlCO .PAGE 7

| 327 | $1 C 0$ | 32 |  |
| :--- | :--- | :--- | :--- | :--- |
| 328 | $1 C 1$ | $1 F$ | MULPLY: RC |
| LBI |  |  |  |

329 1C2 35 LD 3
330 1C3 30
331 1C4 44
33210506
333 1C6 00
33410720
3351 CB CA
336 1C9 51
337 1CA 3F
338 1CB 06
339 1CC $33 A 7$ MULI.
340 1CE 05
341 1CF 5F
342 1DO D6
343 1D1 06
344 1D2 3397
345 1D4 9C
346 1D5 CC
347 1D6 8D
348 1D7 2E
349 1D8 90
350 1D9 Bl
351 1DA 58
352 1DB CC
353 1DC 78
354 1DD 3387
355 1DF 00
356 1EO 21
357 1E1 6212
358 1E3 04
359 1E4 DF
360 1E5 2E
361 1E6 00
362 1E7 21
;DP2+1 -> DP2,(ZDP+1 -> ZDP)
;DEFEAT SKIP
;DPO + 1 -> DPO
;DP1+DP2 }->\mathrm{ DP2,(DPY+DPZ }->\textrm{DPZ}
ASC
NOP
X
CLRA ;1 TO OFLOW IF CARRY,ELSE 0
SKC
JP MULIA
AISC 1
MULIA: LBI OFLOW
MUL1: LBI ZLSD
LD
AISC 15
JP MUL2
X
LBI YLSD ;MO + MI }->\mathrm{ MO,(X+Y }->\textrm{X}
JSRP BINADD
JP MULl
MUL2: JSRP RSFTRO
LBI ZGUARD
JSRP RSFT
JSRP XDPPLI
AISC 8
JP MULI ;PRECEDING IS DP ADJUST
MUL3: STII 8
LBI XLSD
MUL3X CLRA
SKE
JMP MUL5
XIS
JP MUL3X
MDENDI: LBI ZGUARD
CLRA
SKE

```

FIGURE 5-8. BInary (Hexadecimal) Arlthmetic Package (Sheet 7 of 9)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|l|}{COP CROSS ASSEMBLER} & PAGE & 8 & \\
\hline HXM & ATH & \multicolumn{4}{|l|}{HEXADECIMAL ARITHMETIC} & \\
\hline 363 & 1E8 & ED & & JP & MDX & \\
\hline 364 & 1E9 & 2 F & & LBI & ZDP & \\
\hline 365 & 1EA & 05 & & LD & & \\
\hline 366 & 1EB & 57 & & AISC & 7 & ;TEST > \(=9\) \\
\hline 367 & 1EC & F7 & & JP & MDEND2 & \\
\hline 368 & 1ED & 2 E & MDX : & LBI & ZGUARD & \\
\hline 369 & 1EE & 8 F & & JSRP & RSFTRX & \\
\hline 370 & 1EF & 3386 & & LBI & ROUND & ;SAVE VALUE FOR ROUNDING \\
\hline 371 & 1 Fl & 06 & & X & & \\
\hline 372 & 1F2 & AA & & JSRP & ZDPMN1 & \\
\hline 373 & 1F3 & 05 & & LD & & ;TEST DP2(ZDP) \(=15\) \\
\hline 374 & 1F4 & 51 & & AISC & 1 & \\
\hline 375 & 1F5 & F7 & & JP & MDEND2 & \\
\hline 376 & 1F6 & AB & & JSRP & OFLMN1 & ;SUBTRACT 1 FROM OVERFLOW DIGIT \\
\hline 377 & 1 F 7 & 2 F & MDEND2 : & LBI & 2,0 & ;TRANSFER R2 TO RO \\
\hline 378 & 1F8 & B9 & & JSRP & XFER2 & \\
\hline 379 & 1F9 & 3391 & & LBI & YSIGN & ;ADD SIGNS AND PUT TO MO(X) \\
\hline 380 & 1FB & 15 & & LD & 1 & \\
\hline 381 & 1FC & 31 & & ADD & & \\
\hline 382 & 1FD & 06 & & X & & \\
\hline 383 & 1 FE & 3 F & & LBI & OFLOW & ;TEST OVERFLOW DIGIT \\
\hline 384 & 1FF & 05 & & LD & & \\
\hline 385 & 200 & 51 & & AISC & 1 & \\
\hline 386 & 201 & C3 & & JP & MDEND4 & ;NOT 15 \\
\hline 387 & 202 & DB & & JP & MDERR & ;IS 15,NUMBER TOO BIG \\
\hline 388 & 203 & 00 & MDEND4 : & CLRA & & ;NOW TEST DIGIT > 0 \\
\hline 389 & 204 & 21 & & SKE & & \\
\hline 390 & 205 & 80 & & JSRP & Clearo & ;IS NON ZERO, CLEAR MO \\
\hline 391 & 206 & 3387 & MDRJ : & LBI & XLSD & ;RIGHT JUSTIFY THE RESULT \\
\hline 392 & 208 & 00 & & CLRA & & \\
\hline 393 & 209 & 21 & & SKE & & \\
\hline 394 & 20A & 48 & & RET & & ;IF LSD NON ZERO,STOP \\
\hline 395 & 20B & OF & & LBI & XDP & ;IF DP PSN \(=0, \mathrm{STOP}\) \\
\hline 396 & 20C & 05 & & LD & & \\
\hline 397 & 20D & 5 F & & AISC & 15 & \\
\hline 398 & 20E & 48 & & RET & & \\
\hline 399 & 20F & 06 & & X & & ;ELSE, DECREMENT BY 1 AND CONTINUE \\
\hline 400 & 210 & 8D & & JSRP & RSFTRO & \\
\hline 401 & 211 & C6 & & JP & MDRJ & \\
\hline 402 & 212 & 2 F & MUL5 : & LBI & ZDP & ;TEST DP2(ZDP) \(=0\) \\
\hline 403 & 213 & 00 & & CLRA & & \\
\hline 404 & 214 & 21 & & SKE & & \\
\hline 405 & 215 & D8 & & JP & MUL3A & \\
\hline 406 & 216 & 40 & & COMP & & ;15 TO DP2(2DP) \\
\hline 407 & 217 & 06 & & X & & \\
\hline 408 & 218 & AC & MUL3A : & JSRP & MINUS1 & ;DP2(2DP) - \(1 \rightarrow\) DP2(ZDP) \\
\hline 409 & 219 & 61D6 & & JMP & MUL2 & \\
\hline 410 & 21B & OE & MDERR : & LBI & 0,15 & \\
\hline 411 & 21C & 7 F & & STII & 15 & \\
\hline & 21D & 7 F & & STII & 15 & \\
\hline & 21E & 48 & & RET & & \\
\hline 414 & & & & . END & & \\
\hline
\end{tabular}

COP CROSS ASSEMBLER PAGE: 9
HXMATH HEXADECIMAL ARITHMETIC
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline ADD & 0108 & * & ADDSUB & 0100 & & ADSB1 & 0103 & & ALIGN & 0040 \\
\hline ALIGN2 & 0046 & & BIN1 & 009D & & BINADD & 009C & & BINS1 & 00A4 \\
\hline BINSUB & 00A3 & & CHNGMO & 0110 & & CLEAR & 0081 & & CLEARO & 0080 \\
\hline COMPL & 011D & & COMPII & 0120 & & DIV1A & 0157 & & DIV1B & 017F \\
\hline DIV1B2 & 0181 & & DIV3 & 015C & * & DIV3A & 1062 & & DIV4 & 016A \\
\hline DIV4A & 0178 & & DIVBYO & 0189 & & DIVIDE & 014C & * & DONE & 0099 \\
\hline DPOGT1 & 0056 & & DPOLTI & 0048 & * & DPMIN1 & 0053 & & DPPLI & 004E \\
\hline ERRCHK & 010B & & ERROR & 0133 & & FLAGS & 003F & & JSMD & 0024 \\
\hline JSRALN & 0010 & & LSFT & 008A & & LSFTRO & 0087 & & LSFTR1 & 0085 \\
\hline LSFTX & 0089 & & MDEND1 & OlE5 & & MDEND2 & 01F7 & & MDEND4 & 0203 \\
\hline MDERR & 021B & & MDRJ & 0206 & & MDX & O1ED & & MINUSI & 00AC \\
\hline MULI & 010 C & & MULIA & 01CA & & MUL2 & 01D6 & & MUL3 & 01DC \\
\hline MUL3A & 0218 & & MUL3X & 01DF & & MUL5 & 0212 & & MULDIV & 0140 \\
\hline MULPLY & 0100 & & OFLMN1 & 00AB & & OFLOW & 0030 & & OFLPLI & 00B2 \\
\hline PLUSI & 00B4 & & PLUSIA & 00AF & & ROLSFT & 004C & * & RORSFT & 005C \\
\hline RILSFT & 005A & * & RIRSFT & 0051 & & RAMCLR & 0003 & & ROUND & 0006 \\
\hline RSFT & 0090 & & RSFTRO & 008D & & RSFTR1 & 008E & & RSFTRX & 008F \\
\hline SAVE1 & 0022 & & SUB & 0117 & & TESTG & 0009 & & TESTGI & 0013 \\
\hline TESTG2 & 0019 & & testg3 & 001F & & UNDRFL & 012D & & XDP & 0000 \\
\hline XDPPLI & 00B1 & & XFER2 & 00B9 & & XGUARD & 000F & * & XLSD & 0007 \\
\hline XMSD & O00E & & XSIGN & 0001 & & YDP & 0010 & & YGUARD & 001F \\
\hline YLSD & 0017 & & YMSD & 001E & & YSIGN & 0011 & & ZDP & 0020 \\
\hline 2DPMN1 & 00AA & & ZDPPL1 & 00B3 & & ZGUARD & 002F & & ZLSD & 0027 \\
\hline ZMSD & 002E & * & ZSIGN & 0021 & & & & & & \\
\hline \multicolumn{11}{|l|}{NO ERROR LINES} \\
\hline \multicolumn{11}{|c|}{355 ROM WORDS USED} \\
\hline COP & 420 & & SEMBLY & & & & & & & \\
\hline \multicolumn{11}{|l|}{SOURCE CHECKSUM \(=7921\)} \\
\hline \multicolumn{2}{|l|}{INPUT FILE} & \multicolumn{5}{|l|}{ABDUL10:HEXARITH.SRC VI} & 5 & & & \\
\hline
\end{tabular}

FIGURE 5-8. Binary (Hexadecimal) Arithmetic Package (Sheet 9 of 9)

\subsection*{5.2.9 Square Root}

Two square root routines are provided: an integer square root and full floating-point square root. Both routines are based on the mathematical relationship:
\[
\sum_{i=1}^{n}(2 i-1)=n^{2}
\]

Therefore, if sequential odd numbers were subtracted from a value, the square root of that value is given by the number of odd numbers that must be subtracted from the original value to reduce that original value to " 0 " (or at least to reduce the integer part to 0 ).

\section*{Integer Square Root-BCD}

A simple routine is provided that computes the integer portion of the square root of an integer. The technique is the simple subtraction of odd numbers as described above. The flow chart for this routine is given in Figure 5-9. The code and RAM map for a four-digit routine is given below.


The subroutines are assumed to be located in Page 2.


TL/DD/8800-22
FIGURE 5-9. Integer Square Root
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{6}{*}{SQROOT :} & LBI & 1,12 & ; \(\rightarrow\) \\
\hline & STII & 1 & \(; 1 \rightarrow \mathrm{Y}, \mathrm{Bd}+1 \rightarrow \mathrm{Bd}\) \\
\hline & JSRP & CLEAR & \\
\hline & LBI & 2,12 & ; \(0 \rightarrow\) Z \\
\hline & JSRP & CLEAR & \\
\hline & LBI & 0,12 & ;test \(\mathrm{X}=0\),if so exit \\
\hline \multirow[t]{6}{*}{TSTZR0:} & CLRA & & \\
\hline & SKE & & \\
\hline & JP & XMINUSY & ; \(\mathrm{X}=0\) \\
\hline & XIS & & \\
\hline & JP & TSTZR0 & \\
\hline & RET & & \\
\hline \multirow[t]{7}{*}{XMINUSY:} & JSRP & SUB & ; \(\mathrm{X}-\mathrm{Y} \rightarrow \mathrm{X}\) \\
\hline & SKC & & ;test borrow, \(\mathrm{C}=0\) if borrow \\
\hline & RET & & ;if borrow,exit-finished \\
\hline & JSRP & ZPLUS1 & ; \(\mathrm{Z}+1 \rightarrow\) Z \\
\hline & JSRP & YPLUS1 & ; \(\mathrm{Y}+2 \rightarrow \mathrm{Y}\) \\
\hline & JSRP & YPLUSI & ; \\
\hline & JP & Xminusy & \\
\hline
\end{tabular}

The following subroutines, assumed to be in Page 2, are used by the square root routine above:
```

CLEAR: CLRA ; simple register clear
XIS
JP CLEAR
RET
SUB: LBI 1,12
ID l ; this is the basic BCD subtract routine as given
; earlier
SUB1: CASC
ADT
XIS 1
JP SUBI
RET
ZPLUS: LBI 2,12 ; this is the basic BCD increment routine as
; given earlier, with the repeated LBI skip
; feature
YPLUS: LBI 1,12
SC
PLUSI: CLRA
AISC }
ASC
ADT
XIS
JP PIUSl
RET

```

\section*{Floating-Point Square Root-BCD}

A full floating-point BCD square root routine is provided. As written, the routine works on a 12 -digit number with a two-digit signed exponent. Although substantially more complex than the integer square root routine seen earlier, this routine has the same conceptual basis-the subtraction of odd numbers.
The first part of the routine creates the exponent of the result of dividing the original exponent by two. Note that this is accomplished by first multiplying the exponent by 5 , via repeated additions, and then dividing it by 10 by means of a right-digit shift.
Two flow charts are provided, a generalized flow chart (Figure 5-10) and a detailed flow chart (Figure 5-10a), to help clarify the routine. The RAM map for the routine is indicated below.


The routine performs \(\sqrt{x} \rightarrow \mathrm{x}\).


TL/DD/8800-23
FIGURE 5-10. Square Root-General Flow Chart


TL/DD/8800-25
FIGURE 5-10a. Square Root-Detailed Flow Chart (Sheet 1 of 2)


TL/DD/8800-27
FIGURE 5-10a. Square Root-Detailed Flow Chart (Sheet 2 of 2)


FIGURE 5-11. Square Root Routine (Sheet 1 of 6)

```

COP CROSS ASSEMBLER PAGE: 3
SQROOT SQUARE ROOT ROUTINE

| 10309994 | JP | XRET |
| :--- | :--- | :--- |
| $10409 A 94$ | JP | XRET |

105
;
106 09B 22 SUBXY: SC
107 09C LF IBI YLSD
108 09D 15 SUBLOOP:ID I
109 09E 10 CASC
110 09F 4A ADT
111 OAO 14 XIS 1
112 OAl 4
113 0A2 53
114 OA3 9D
115 OA4 48
1 1 6
117 OA5 OB
118 OA6 OO
119 0A7 07
120 0A8 A7
121 OA9 48
122
124 OAB O
125 OAC O
126 OAD AC
127 OAE 48
128
129 OAF 15
130 OBO 14
131 OBI AF
132 OB2 48
133
134 0100
135
136
137
138
139
140
141
142 100 2D
14310180
144
145 102 OA
146 103 05
147 104 5F
148 10548
149 106 0
150 107 l
151 10849
152 109 OF
153 10A AF JSRP XFERI ;X }->\mathrm{ Y FOR SUBSEQUENT ADDS
154

```

FIGURE 5-11. Square Root Routine (Sheet 3 of 6 )
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{3}{|l|}{COP CROSS} & EMBLER & PAGE: & 4 & \\
\hline & OOT & \multicolumn{4}{|c|}{SQUARE ROOT ROUTINE} & \\
\hline 155 & 10B & 84 & SQ3: & JSRP & ADDXY & ;THIS LOOP MULTIPLIES X MANTISSA BY \\
\hline 156 & 10C & 1D & & LBI & YEXPLO & ;5 AND THE X EXPONENT BY 5 \\
\hline 157 & 10D & 85 & & JSRP & ADDXYE & \\
\hline 158 & 10E & 86 & & JSRP & ADLOOP & \\
\hline 159 & 10F & 20 & & SKC & & \\
\hline 160 & 110 D & D3 & & JP & TSTCTR & \\
\hline 161 & 111 & 2 E & & LBI & EXPOVF & ;EXTRA DIGIT FOR THE EXPONENT MULTIPLY \\
\hline 162 & 112 & 91 & & JSRP & PLUS1 & \\
\hline 163 & 113 & 96 & TSTCTR: & JSRP & CTRMN1 & ;CNTR IS USED AS LOOP COUNTER HERE \\
\hline 164 & 114 & 05 & & LD & & \\
\hline 165 & 115 & 53 & & AISC & & ;IF CNTR IS < 13,MULTIPLY IS COMPLETE \\
\hline 166 & 116 & D8 & & JP & SQ5CNT & \\
\hline 167 & 117 & CB & & JP & SQ3 & \\
\hline 168 & & & ; & & & \\
\hline 169 & 118 & OD & SQ5CNT & LBI & XEXPLO & ;TEST X EXPONENT EVEN(IF ORIGINAL X \\
\hline 170 & 119 & 05 & & LD & & ;EXPONENT EVEN,5 TIMES IT WILL RESULT \\
\hline 171 & 11A & 5 F & & AISC & 15 & ;IN XEXPLO BEING 0) \\
\hline 172 & 11 B & A5 & & JSRP & RSHX & ;FOR SQRT 25,SQRT 2.5 TYPE CASE \\
\hline 173 & & & ; & & & \\
\hline 174 & 11 C & 2 E & & LBI & EXPOVF & ;RIGHT SHIFT X EXP WITH O'FLOW DIGIT \\
\hline 175 & 11D & 25 & & LD & 2 & ;RESULTS IN NET EXPONENT DIVIDE BY 2 \\
\hline 176 & 11E 0 & 07 & & XDS & & ; WHICH IS DESIRED RESULT FOR SQUARE \\
\hline 177 & \(11 F\) & 07 & & XDS & & ;ROOT \\
\hline 178 & 120 & 01 & & SKMBZ & 0 & ;SEE IF X < 1 \\
\hline 179 & 121 & E9 & & JP & SQ4A & ;YES \\
\hline 180 & 122 & 1 F & SQ4: & LBI & YLSD & ;CLEAR Y,WILL CREATE ANSWER IN Y \\
\hline 181 & 123 & 80 & & JSRP & CLEAR & \\
\hline 182 & 124 & OC & & LBI & XSIGN & ;MOVE SIGN,EXPONENT TO Y \\
\hline 183 & 125 & AF & & JSRP & XFERI & \\
\hline 184 & 126 & 2 D & & LBI & CNTR & ;LOAD DIGIT COUNTER WITH NUMBER \\
\hline 185 & 127 & 7 C & & STII & 12 & ;OF DIGITS \\
\hline 186 & 128 & FC & & JP & SQ6 & \\
\hline 187 & 129 & OD & SQ4A: & LBI & XEXPLO & ;TEST ORIGINAL EXPONENT ODD, 5 TIMES IT \\
\hline 188 & 12A & 5B & & AISC & 11 & ;RESULTS IN A, AT THIS POINT, \(=5\) IF \\
\hline 189 & 12B & E2 & & JP & SQ4 & ;ORIGINAL X EXPONENT ODD \\
\hline 190 & 12C 9 & 91 & & JSRP & PLUSl & ;ORIGINAL EXPONENT WAS ODD * X<1, \\
\hline 191 & 12D 5 & 57 & & AISC & 7 & ;CORRECT EXPONENT BY ADDING 1 \\
\hline 192 & 12E & E2 & & JP & SQ4 & ;IF LSD EXPONENT WAS < 9,STOP \\
\hline 193 & 12F 7 & 70 & & STII & 0 & ; WAS \(=9,50\) SET TO 0 AND INCREMENT \\
\hline 194 & 130 & 91 & & JSRP & PLUSI & ;MSD OF EXPONENT \\
\hline 195 & 131 & E2 & & JP & SQ4 & \\
\hline 196 & & & ; & & & \\
\hline 197 & & & ;EXPONEN & T COMP & TATION C & MPLETE AT THIS POINT.the Rest of the \\
\hline 198 & & & ;CODE CO & MPUTES & THE MANT & SSA OF the Result by the technique \\
\hline 199 & & & ;OF SUBT & Ractio & OF ODD & NUMBERS. SINCE THE MANTISSA HAS BEEN \\
\hline 200 & & & ;MULTIPL & IED BY & 5, 5 TIM & S THE VARIOUS ODD NUMBERS WILI BE SUB- \\
\hline 201 & & & ;TRACTED & . THUS & TO SUBTR & CT 1,2,5,7,... FROM THE ORIGINAL WE \\
\hline 202 & & & ;SUBTRAC & T 5,15 & 25,35,.. & FROM 5 TIMES THE ORIGINAL VALUE. \\
\hline 203 & & & ; & & & \\
\hline 204 & 132 & 2 D & SQ7: & LBI & CNTR & \\
\hline 205 & 133 & 35 & & LD & & ; INCREMENT Y(CNTR) \\
\hline 206 & 1345 & 50 & & CAB & & \\
\hline 207 & 135 & 91 & & JSRP & PLUSl & \\
\hline 208 & 136 & 9 B & SQ8: & JSRP & SUBXY & ;THIS IS THE REPEATED SUBTRACT \\
\hline
\end{tabular}

FIGURE 5-11. Square Root Routine (Sheet 4 of 6)

COP CROSS ASSEMBLER PAGE: 5
SQROOT SQUARE ROOT ROUTINE
\begin{tabular}{|c|c|c|c|c|}
\hline 20913720 & & SKC & & ;IF WE BORROW,NEED TO SHIFT \\
\hline 210138 FA & & JP & SQ8A & \\
\hline 211139 F 2 & & JP & SQ7 & \\
\hline 212 13A 84 & SQ8A : & JSRP & ADDXY & ;RESTORE VALUE \\
\hline 213 13B AA & & JSRP & LSHX & \\
\hline 214 13C 96 & SQ6: & JSRP & CTRMN1 & ;DECREMENT DIGIT COUNTER \\
\hline 21513 D 05 & & LD & & \\
\hline 21613 El & & AISC & 1 & ;SEE IF IT WAS 0 FOR EXIT \\
\hline 217 13F C3 & & JP & SQ6A & \\
\hline \(2181401 F\) & DONE: & LBI & YLSD & ;DONE, TRANSFER RESULT IN Y TO X \\
\hline 219141 AF & & JSRP & XFER1 & \\
\hline 22014248 & & RET & & \\
\hline 22114335 & SQ6A: & LD & 3 & ; \(0 \rightarrow Y(C N T R)\) \\
\hline 22214450 & & CAB & & \\
\hline 22314500 & & CLRA & & \\
\hline 22414607 & & XDS & & \\
\hline 22514775 & & STII & 5 & ;5 \(\rightarrow \mathrm{Y}(\) CNTR - 1 ) \\
\hline 2261486136 & & JMP & SQ8 & \\
\hline 227 & ; & & & \\
\hline 228 & & .END & & \\
\hline
\end{tabular}

FIGURE 5-11. Square Root Routine (Sheet 5 of 6)
COP CROSS ASSEMBLER PAGE: 6
SQROOT SQUARE ROOT ROUTINE
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline ADDXY & 0084 & & ADDXYE & 0085 & & ADLOOP & 0086 & ADLP2 & 008D \\
\hline CLEAR & 0080 & & CNTR & 002E & & CTRMN1 & 0096 & DONE & 0140 \\
\hline ERROR & 0108 & * & EXPOVF & 002F & & LSHX & 00AA & LSHXI & 00AC \\
\hline MINUS & 0097 & * & PLUSI & 0091 & & RSHX & 00A5 & RSHXI & 00A7 \\
\hline SQ1 & 0102 & & SQ2 & 0106 & * & SQ3 & 010B & SQ4 & 0122 \\
\hline SQ4A & 0129 & & SQ5CNT & 0118 & & SQ6 & 013C & SQ6A & 0143 \\
\hline SQ7 & 0132 & & SQ8 & 0136 & & SQ8A & 013A & SQROOT & 0100 \\
\hline START & 0000 & * & STRTI & 0001 & & STRT2 & 0002 & SUBLOO & 009D \\
\hline SUBXY & 009B & & TESTSQ & 0008 & & TSTCTR & 0113 & XEXPHI & 000F \\
\hline XEXPLO & 000E & & XFERI & 00AF & & XGUARD & 000C & XLSD & 0000 \\
\hline XMSD & 000B & & XRET & 0094 & & XSIGN & 000D & YEXPHI & 001F \\
\hline YEXPLO & 001E & & YGUARD & 001C & * & YLSD & 0010 & & \\
\hline \multicolumn{10}{|l|}{NO ERROR LINES} \\
\hline \multicolumn{10}{|c|}{144 ROM WORDS USED} \\
\hline \multicolumn{10}{|l|}{COP 420 ASSEMBLY} \\
\hline \multicolumn{10}{|l|}{SOURCE CHECKSUM \(=46 E D\)} \\
\hline INPUT FI & & & UL10:SQ & ROOT & .SR & VN: & 9 & & \\
\hline
\end{tabular}

FIGURE 5-11. Square Root Routine (Sheet 6 of 6 )

\subsection*{5.2.10 Binary to BCD Conversion}

Several methods of performing a binary to BCD conversion are illustrated. These different approaches illustrate algorithms and different programming techniques.

\section*{A Simple 8-blt Binary to BCD Routine}

This is a simple routine for converting an eight-bit binary number to its three-digit BCD equivalent. The conversion is the straightforward scheme of adding the respective powers of two. However, this is reduced if the eight-bit number is treated as a two-digit hex number: then we merely expand the number by the powers of 16 . Thus we have:
\(11100111_{2}=E 7_{16}=14_{10} * 16_{10}^{1}+7_{10} * 16_{10}^{0}=231_{10}\)
\(01011111_{2}=5 F_{16}=510 * 16_{10}^{0}+15_{10} * 16_{10}^{0}=95_{10}\)
The flow chart for this routine is given in Figure 5-12. The RAM map is given below.


The routine converts the binary number in R0 to the BCD number in R1. R2 is used as work space. The binary value is destroyed. Four implementations of this routine are presented.


TL/DD/8800-28
FIGURE 5-12. Elght-Bit Binary to BCD Conversion

Version I

```

    XIS
        STII 0
        STII 0
        LBI 2,13 ;016 -> Z
        STII 6
        STII 1
        STII 0
        LBI 1,13 ;test BCD LSD > 9, if so, decimal adjust
        LD
        AISC 6
        JP TEST
        XIS
        STII 1
    TEST: LBI 0,15 ;test BINMSD = 0, if yes exit
ID ;conversion complete
AISC 15
RET ;decrement BINMSD by l
X
LBI 2,13
RC
LOOP: LDD 3 ;add BCD+16 (BCD+Z) }->\mathrm{ AISC BCD
AISC 6
ASC
ADT
XIS 3
JP LOOP
JP TEST

```
Version II
RIBCD: LBI 0,14
    XDS 1 ; \(\mathrm{BIN}_{\text {LSD }} \rightarrow \mathrm{BCD}_{\text {LSD }}\), 0 to other digits in \(B C D\)
        XIS
        STII 0
        STII 0
        LBI 2,13 ; equivalent of \(016 \rightarrow Z\)
        STII 12 ; have incorporated AISC 6 into constant for subsequent BCD addition
        STII 7
        STII 6
        LBI 0,13 ; test \(B C D_{\text {LSD }} \rightarrow 9\), if so decimal adjust
        LD
        AISC 6
        JP TEST
        XIS
        STII 1
TEST: LBI 0,15 ; test \(B N_{M S D}=0\), if yes exit - conversion complete
    ID
    AISC 15
    RET
    X ; decrement \(\mathrm{BIN}_{\text {MSD }}\) by 1
        LBI 2,13
        RC
LOOP: LD \(3 \quad ; B C D+16 \rightarrow B C D\)
    ASC
    ADT
    XIS 3
    JP LOOP
    JP TEST
```

Version III
BINBCD: LBI 0,14 ; BIN LSD }->\mp@subsup{BCD}{LSD}{\prime},0\mathrm{ to other digits in BCD
XDS l
XIS
STII 0
STII 0
LBI 0,13 ; test BCD LSD > 9, if so decimal adjust the number
LD
AISC 6
JP TEST
XIS
STII 1
TEST: LBI 0,15 ; test BINMSD = 0, 1f yes exit
LD ; conversion complete
AISC 15 ; else decrement BINMSD by l
RET
X
LBI 2,13 ; straight line BCD+16 }->\mathrm{ BCD using no additional RAM
RC
CLRA
AISC 12
ASC
ADT
XIS
CLRA
AISC 7
ASC
ADT
XIS
CLRA
AISC 6
ASC
ADT
X
JP TEST ; loop back to TEST
Version IV
BINBCD: LBI 0,14
XDS l ; BIN LSD }->\mp@subsup{B}{LCD}{LSD},0\mathrm{ to other digits in BCD
XIS
STII 0
STII 0
LBI 2,13
STII 0 ; clear Z
STII 0
STII 0
LOOP: JSRP BCDADD; decimal adjust f1rst time, add l6 in all subsequent times
LBI 2,13
STII 6
STII 1
LBI 0,15
LD
AISC 15
RET
X
JR LOOP

```

The routine uses the following subroutine, assummed to be located in Page 2.
\begin{tabular}{lll} 
BCDADD: & LBI & 2,13 \\
& RC & \\
ADLOOP: & LD & 3 \\
& AISC & 6 \\
& ASC & \\
& ADT & \\
& XIS & 3 \\
& JP & ADL00P \\
& RET &
\end{tabular}

Note: By using the same kind of "trick" as was illustrated in Version il, the total ROM count can be reduced by one word and the execution speed improved.
Let us now consider these four programs. They all do precisely the same thing: convert an eight-bit binary number to a three-digit BCD number using the same algorithm. The differences are in implementation only. Version 1 takes 29 ROM words, uses 8 RAM digits (two for input binary number, three for BCD result, and three for scratch pad), has a worst case execution time of 409 instruction cycles, and uses no subroutines. Version II takes 28 ROM words, also uses 8 RAM digits, has a worst case execution time of 364 instruction cycles, and also uses no subroutines. Version III takes 34 ROM words, uses only 5 RAM digits, has a worst case execution time of 360 instruction cycles, and uses no subroutines. Version IV uses 28 ROM words, including 9 words in a subroutine; uses 8 RAM digits; and has a worst case execution time of 474 instruction cycles. Other variations on these routines are possible which will affect ROM, RAM, and execution time.
Version I is the straightforward implementation of the flow chart with few tricks. It is fairly representative of the amount of code required for the task; uses the maximum RAM for the function and is about midrange in execution speed. Version II makes a very slight change to Version I. It sets up a constant with a decimal adjust factor built in. The result is that Version II uses one less ROM word and the same amount of RAM as Version 1; however, Version II executes considerably faster, about a 10 percent speed improvement. Version III uses the minimum RAM for the function, uses the most ROM, and has the fastest execution time. This has been achieved by straight line coding the BCD add 16. This both maximizes speed and reduces RAM usage but the penalty is ROM code. RAM usage is reduced by storing the constant " 16 " in ROM rather than RAM. Version IV is preferable in cases where a \(B C D\) addition subroutine already exists in the program. Not counting the subroutine Version IV uses only 19 ROM words. However, Version IV has the slowest execution time. By the addition of two ROM words, as shown in Version IVA, the speed of Version IV can be significantly improved. Version IVA is the same as Version IV but achieves faster speed, by moving some code out of the main loop, with a small ROM penalty.
```

Version IVA
BINBCD LBI 0,14 ; BIN LSD }->\mp@subsup{BCD}{LSD}{},0\mathrm{ to other
XDS 1 ; digits in BCD
XIS
STII 0
STII 0
LBI 2,13 ; clear 2
STII 0
STII 0
STII 0
JSRP BCDADD ; decimal adjust BCD
LBI 2,13 ; 16 }->\textrm{Z
STII 6
STII 1
JP TEST
LOOP: JSRP BCDADD ; basic loop
TEST: LBI 0,15
LD
AISC 15
RET
X
JP LOOP

```

Version IVA uses 21 ROM words (not counting the subroutine), uses 8 RAM digits, and executes in 454 instruction cycle times.

\section*{Binary to BCD Conversion-Doubling Methods}

If we have a binary number expressed as \(b_{n} b_{n-1} \ldots b_{2} b_{1} b_{0}\) where \(b x\) is either 1 or 0 , the standard expansion to produce the decimal (BCD) number is as follows:
\(b_{n}{ }^{*} 2^{n}+b_{n}-1^{*} 2^{n-1}+\ldots+b_{2}{ }^{*} 2^{2}+b_{1}{ }^{*} 2+b_{0}=\sum_{i=0}^{n} b_{i}{ }^{*} 2^{i}\)
For simplicity, a six-bit binary number is used.
\(b_{5} b_{4} b_{3} b_{2} b_{1} b_{0}\)
The expansion for this number for its decimal equivalent, is then
\(b_{5}{ }^{*} 2^{5}+b_{4} 2^{4}+b_{3} * 2^{3}+b_{2} * 2^{2}+b_{1} * 2+b_{0}\)
This can be rewritten as
\(2\left\{2\left[2<2\left(2\left(b_{5}\left(+b_{4}\right)+b_{3}>+b_{2}\right]+b_{1}\right\}+b_{0}\right.\right.\)
This expression, although apparently more complex, points out one means of conversion that is easy to implement because it is iterative. The first step is to set the BCD number equal to the most significant bit, here it is \(b_{5}\). Then the value is doubled and one is added if the next bit is one. The value is then doubled again and one is added if the next bit is one. The cycle continues until the LSB is added to the result. Figure \(5-13\) is the flow chart for this general approach.

\section*{The Stralghtforward Implementation}

This implementation is the straightfonward implementation of the flow chart of Figure 5-13. As written, it converts a 16-bit binary number to its five-digit BCD counterpart. The routine expands by merely changing the pertinent LBI instructions. Figure 5-14 is the RAM map for this routine. The routine uses one subroutine level.
The routine uses the following subroutines assumed to be located in Page 2.


FIGURE 5-13. Binary to BCD Conversion-Basic Doubling Algorithm
\begin{tabular}{|c|c|c|c|}
\hline DOUBLE : & LBI & 2,11 & ; decimal double of \(B C D\) number \\
\hline \multirow[t]{6}{*}{DBLA :} & LD & & ; modify the LBI for larger numbers \\
\hline & AISC & 6 & \\
\hline & ASC & & \\
\hline & ADT & & \\
\hline & XIS & & ; sips on Bd increment past 15 \\
\hline & JP & DBLA & \\
\hline \multirow[t]{5}{*}{SETUP:} & RC & & ; Palls into SETUP routine-which \\
\hline & LBI & 2,10 & ; is also called independently \\
\hline & LD & 3 & ; fetch digit position of binary number \\
\hline & CAB & & ; and load Bd with it. Br adjusted by \\
\hline & RET & & ; LD 3 instruction \\
\hline
\end{tabular}
The basic routine is as follows:
BINBCD: LBI 2,10 ; load pointer with position of binary MSB
BINBCD: LBI 2,10 ; load pointer with position of binary MSB
    STII 15
    STII 15
CLEAR: CLRA ; 0 B BCD
CLEAR: CLRA ; 0 B BCD
    XIS
    XIS
    JP CLEAR
    JP CLEAR
BINDEC: JSRP SETUP ; point to proper digit in binary number
BINDEC: JSRP SETUP ; point to proper digit in binary number
        SKMBZ 3 ;
        SKMBZ 3 ;
        SC ; march down the digit;set C
        SC ; march down the digit;set C
        JSRP DOUBLE ; if addressed bit is l. Then do
        JSRP DOUBLE ; if addressed bit is l. Then do
        SKMBZ 2 ; double to get 2* BCD + bx }->\mathrm{ BCD
        SKMBZ 2 ; double to get 2* BCD + bx }->\mathrm{ BCD
        SC ; (C is reset on exit from SETUP and DOUBLE)
        SC ; (C is reset on exit from SETUP and DOUBLE)
        JSRP DOUBLE
        JSRP DOUBLE
        SKMBZ 1
        SKMBZ 1
        SC
        SC
        JSRP DOUBLE
        JSRP DOUBLE
        SKMBZ O
        SKMBZ O
        SC
        SC
        JSRP DOUBLE
        JSRP DOUBLE
        LBI 2,10 ; test for done, here finished
        LBI 2,10 ; test for done, here finished
        LD
        LD
        AISC 3 ; if Bd \leq 12
        AISC 3 ; if Bd \leq 12
        RET
        RET
        AISC 12 ; else, decrement Bd by l and
        AISC 12 ; else, decrement Bd by l and
        X
        X
    JP BINDEC ; continue
    JP BINDEC ; continue

This routine used 25 words plus 12 words in the subroutine page for a total of 37 words. The routine executes in 690 instruction cycles. The execution time is data independent. The routine preserves the binary number. The routine uses 10 RAM digits; 4 for the original number, 5 for the BCD result, and 1 scratch pad.

Variation I-The Doubling Algorithm—"Shift 1"
The straightforward implementation can be modified in a simple way by using some left bit shifting on the binary number. The basic flow chart is the same but a detailed modified flow chart is shown in Figure 5-15. Figure \(5-16\) is the RAM map for this variation.


FIGURE 5-15. Flow Chart for Variation 1


FIGURE 5-16. RAM Map for Variation 1 on the Doubling Algorithm

The code for this implementation is as follows:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{4}{*}{BINBCD: CLEAR:} & LBI & 2,10 & \\
\hline & CLRA & & ; \(0 \rightarrow\) bit counter, BCD number \\
\hline & XIS & & \\
\hline & JP & CLEAR & \\
\hline \multirow[t]{2}{*}{BINDEC:} & LBI & 1,12 & ; left-shift binary number one \\
\hline & RC & & ; bit with MSB going into C \\
\hline \multirow[t]{5}{*}{L00P1:} & LD & & \\
\hline & ASC & & ; left-shift by means of binary double \\
\hline & NOP & & \\
\hline & XIS & & \\
\hline & JP & L00P1 & \\
\hline DCDBL & LBI & 2,11 & ; double BCD number \\
\hline \multirow[t]{6}{*}{LOOP2:} & LD & & \\
\hline & AISC & 6 & \\
\hline & ASC & & \\
\hline & ADT & & \\
\hline & XIS & & \\
\hline & JP & L00P2 & \\
\hline \multirow[t]{5}{*}{TEST} & LBI & 2,10 & ; test if finished \\
\hline & LD & & \\
\hline & AISC & 1 & ; done if bit counter \(=15\) \\
\hline & JP & X1 & \\
\hline & RET & & \\
\hline X1: & X & & \\
\hline & JP & BINDEC & \\
\hline
\end{tabular}

This routine uses no subroutines, takes 25 ROM words, and uses 10 digits of RAM-just as the first method. The existence of a CLEAR subroutine and/or a decimal double and/or a binary double routine in the program would further reduce the code required for this routine. As written, the routine does not preserve the binary number. The routine executes in 954 instruction cycles. Thus, it uses code, overall, than the previous routine but executes substantialiy slower.

\section*{Variation 2-The Shifting Algorithm}

The left bit shift shown in Section 5.2 .9 is simply a binary double. The primary algorithm still requires the add one to the doubled BCD number when the binary bit is a one. This routine does the doubling a little differently: A binary double is performed on the BCD number with a subsequent decimal correct. The RAM map for this scheme is given in Figure 5-17. The flow chart is in Figure 5-18. The flow chart is general for the algorithm. Judicious placement of data in RAM eliminates the need for the digit counter, DC, shown in the flow chart.


FIGURE 5-17. RAM Map for Binary to BCD Conversion


FIGURE 5-18. Binary to BCD Conversion-Shifting Algorithm

The routine as written uses no subroutines. However, the presence of a binary double routine in the program would reduce the code required in this routine.
The code is as follows:
```

BINBCD: LBI 0,11 ; 0 B BCD
CLEAR: CLRA
XIS
JP CLEAR
LBI 1,15 ; 0 }->\mathrm{ bit counter
STII 0
SHIFT: RC ; left bit shift binary number
LBI 0,7
LOOPl: LD ; and BCD number
ASC
NOP
XIS
JP LOOPl
FINISH: LBI 1,15 ; test if done
LD
AISC 1
JP RDCADJ ; no done, BCD adjust
RET
BCDADJ: X
LBI 0,1l
DECADJ: LD ; decimal adjust before left shift
AISC 11 ; number > 9 after shift is > 4 before shift
JP LESS5
AISC 8 ; number > 4; do net + 3(=+6 after shift)
NOP
X
LESS5: LD
XIS ; go through the whole number
JP DECADJ
JP SHIFT

```

The routine takes 31 ROM words, uses 10 RAM digits, and has a worst case execution time of 1525 instruction cycle times. Unlike the other routines, this routine is data dependent.

\subsection*{5.2.11 BCD to Binary Conversion}

Several methods of performing a BCD to binary conversion are presented. The methods, like the binary to BCD routines in Section 5.2.9, illustrate different algorithms and different programming techniques.

\section*{An Efficient Two-Digit BCD to Eight-Bit Binary Routine}

Figure 5-19 is the flow chart for a very efficient routine for converting a two-digit BCD number to its binary equivalent. The routine uses only two digits of RAM, replacing the BCD number with its binary representation. The simple RAM map is indicated below:

Bd
\(15 \quad 14\)
Br 0
\begin{tabular}{|c|}
\hline 15 \\
\hline BCD NUMBER \\
BINARY RESULT \\
\hline
\end{tabular}

The routine is as follows:
```

BCDBIN: LBI 0,15 ; clear MSD of BCD number, save value in A
CLRA
NOCARY: X
LBI 0,14 ; point to LSD of BCD number
AISC 15 ; if MSB (saved in A) = 0, done
RET
X ; else subtract l from it
AISC 10 ; add 10 to the ""binary'' number
JP NOCARY
XIS ; if carry, must add l to binary ""MSB"'
X
AISC 1
JP NOCARY ; loop unt1l done. This word never
; can be skipped since max BCD number = 99
NOCARY: X
LBI 0,14 ; point to LSD of BCD number
AISC 15 ; if MSB (saved in $A$ ) $=0$, done
RET
; else subtract 1 from it
JP NOCARY
XIS ; if carry, must add 1 to binary ""MSB'"
X
AISC
JP NOCARY ; loop until done. This word never
; can be skipped since max BCD number $=99$

```

This is a simple routine implemented in an "obscure" manner. The routine takes only 13 words, uses 2 RAM digits only, and has a worst case execution time of 104 instruction cycles. The execution time is data dependent. The minimum execution time is 6 instruction cycles.
Some attention should be given to this routine. It is a good example of code sharing, efficient use of memory, and clever use of the instructions. The routine uses the accumulator both as temporary storage and as work space for the arithmetic. The two RAM digits also serve multifunctions such as accumulate the result, temporary storage, and the input number. To be sure, a great deal of this routine's efficiency comes from the fact that we are working with only two digits. However, the techniques with the accumulator illustrated in this routine have much broader applicability.

TL/DD/8800-32
FIGURE 5-19. Two-Digit BCD to Binary Conversion


\section*{BCD to Binary Conversion-Multiply By 10}

This routine is the counterpart to the binary to BCD conversion by the doubling technique. As written, the routine will convert a five-digit number ( \(\leq 65535\) ) to its 16 -bit binary equivalent. The routine again comes from the standard expansion
\(d_{4} d_{3} d_{2} d_{1} d_{0}=d_{4} 10^{4}+d_{3} 10^{3}+d_{2} 10^{2}+d_{1} 10^{1}+d_{0}\)
\(d_{n}=\) digit within a decimal number.
The preceding expression can be rewritten in the following form:
\(d_{4} d_{3} d_{2} d_{1}=10\left\{10\left[10<10\left(d_{4}\right)+d_{3}>+d_{3}>+d_{2}\right]+d_{1}\right\}+d_{0}\)
By merely evaluating the right-hand expression above (and adding and multiplying by 10 in binary), the conversion is accomplished. For general information, the scheme is number base independent and can, therefore, be used to convert a decimal number to any desired number base: merely carry out the adds and multiplies in the desired base.
Analysis of the expression above yields the following iterative procedure: Multiply MSD of decimal number by 10, add the next MSD to that quantity, multiply the result by 10 , add the next MSD to that result, multiply the result by 10 , etc. until the LSB of the decimal number is added. The conversion is complete after this final addition.

The Straightforward Implementation
The flow chart of Figure \(5-20\) is the direct expression of the preceding math. The first example will be a straightforward implementation of that flow chart. The routine is written to convert a five-digit BCD number ( \(<65536\) ) to a 16 -bit binary number. The RAM map is shown below.


The routine uses the following subroutines, assumed to be located in Page 2.
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{4}{*}{\begin{tabular}{l}
CLEAR: \\
CLEAR2:
\end{tabular}} & CLRA & & \\
\hline & XIS & & \\
\hline & JP & CLEAR & \\
\hline & RET & & \\
\hline \multirow[t]{2}{*}{BINADD:} & RC & & ; RI + RO \(\rightarrow \mathrm{Rl}, 16 \mathrm{bit}\) \\
\hline & LBI & 0,12 & \\
\hline \multirow[t]{6}{*}{BINADI:} & ID & 1 & \\
\hline & ASC & & \\
\hline & NOP & & \\
\hline & XIS & 1 & \\
\hline & JP & BINADI & \\
\hline & RET & & \\
\hline \multirow[t]{2}{*}{BINDBI:} & IBI & 1,12 & ; \(2 \times \mathrm{Rl} \rightarrow \mathrm{Rl}\), binary \\
\hline & RC & & \\
\hline \multirow[t]{6}{*}{DBL :} & LD & & \\
\hline & ASC & & \\
\hline & NOP & & \\
\hline & XIS & & \\
\hline & JP & DBL & \\
\hline & RET & & \\
\hline
\end{tabular}


FIGURE 5-20. BCD to Binary Conversion-Multiply by 10
The main body of the routine is as follows:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{3}{*}{BCDBIN :} & LBI & 1,11 & ; load digit counter \\
\hline & STII & 15 & ; position of BCD MSD \\
\hline & JSRP & CLEAR & ; \(0 \rightarrow\) binary number \\
\hline \multirow[t]{15}{*}{DECBIN:} & LBI & 1,11 & \\
\hline & LD & 3 & \\
\hline & CAB & & ; point to digit in BCD number \\
\hline & LD & & \\
\hline & LBI & 0,12 & ; and put it into R0 \\
\hline & JSRP & CLEAR2 & ; note call into middle of subroutine \\
\hline & JSRP & BINADD & ; add the digit to the rest of the number \\
\hline & LBI & 1,11 & ; now test if finished \\
\hline & LD & & \\
\hline & AISC & 4 & ; if digit counter \(<12\) done \\
\hline & RET & & \\
\hline & AISC & 11 & ; this results in net subtract 1 \\
\hline & X & & ; save new value of digit counter \\
\hline & JSRP & BINDBL & ; now multiply by 10 , first do \(2 \times \mathrm{Rl} \rightarrow \mathrm{Rl}\) \\
\hline & LBI & 1,12 & \\
\hline \multirow[t]{7}{*}{XFER :} & LD & 1 & ; transfer Rl \(\rightarrow\) Ro, could be a subroutine \\
\hline & XIS & 1 & \\
\hline & JP & XFERI & \\
\hline & JSRP & BINDBL & ; \(2 \times \mathrm{Rl} \rightarrow \mathrm{Rl}\) \\
\hline & JSRP & BINDBL & ; \(2 \times \mathrm{Rl} \rightarrow \mathrm{Rl}\) \\
\hline & JSRP & BINADD & ; result after all this is \(10 \times \mathrm{Rl} \rightarrow \mathrm{Rl}\), binary \\
\hline & JP & DECBIN & \\
\hline
\end{tabular}

The routine uses 25 ROM words, not counting the 20 words of subroutine. The routine uses 14 RAM digits and executes in 709 instruction cycles. The original number is preserved and the routine uses one subroutine level.

\section*{The Shifting Approach}

Consider a slightly modified version of the preceding routine. Figure 5-21 shows this modification. The important differences are 1) there is no digit counter or pointer and 2) the original number is lost. The RAM map follows Figure 5-21.


TL/DD/8800-34
FIGURE 5-21. BCD to Binary Conversion—Multiply by 10—the Shifting Approach


This version of the routine uses the same subroutines as given in the preceding section.
```

BCDBIN: LBI 1,12 ; clear binary number
JSRP CLEAR
LSHBCD: CLRA ; left shift BCD number, MSD }->\mathrm{ A;
COMP ; marker to LSD
LBI 2,11
ISH:
XIS
JP LSH ; A }->\mathrm{ RO, digit 12, O to rest of RO
LBI 0,12
JSRP CLEAR2
JSRP BINADD ; add the digit to converted value
LBI 2,15
LD ; test for done, if BCD MSD=15, finished
AISC 1
JP TIMESIO
RET
TIMES10: JSRP BINDBL ;multiply by 10
LBI 1,12

```
\begin{tabular}{lll} 
XFER: & LD & 1 \\
& XIS & 1 \\
& JP & XFERI \\
& JSRP & BINDBL \\
& JSRP & BINDBL \\
& JSRP & BINADD \\
& JP & LSHBCD
\end{tabular}

This outline uses 24 ROM words, not counting the 20 subroutine words and 13 RAM digits. It executes in 731 instruction cycles. This second approach, a slightly different implementation of the same basic algorithm, uses slightly less memory and executes slightly slower than the straightforward approach.

\section*{A "Paper and Pencil" Method and a Common Mistake}

One of the standard methods for base conversion, at least on paper, is the technique of successively dividing the original number by the destination base. The remainders constitute the digits of the converted number. Thus to convert from BCD to binary, simply divide the BCD number by two repeatedly. See the simple example below:
NUMBER \(\quad\) REMAINDER

Thus, \(17_{10}=1000_{12}\). The technique is well established and useful in instruction.
A conversion sheme using this algorithm is presented. This scheme is presented for comparison and for illustration techniques, e.g., a decimal divide by two without a divide routine. This particular scheme for BCD to binary conversion is not recommended since it is neither more memory efficient nor faster than techniques previously shown. This approach is simply the implementation of a well known conversion technique and serves to illustrate the effect of the algorithm itself on the code.
The flow chart for this algorithm is given in Figure 5-22. The RAM map is given below.


The routine uses the following subroutines, assumed to be located in Page 2.
\begin{tabular}{|c|c|c|c|}
\hline RSH: & XDS & & ; a simple 5- or 6-digit right shift \\
\hline \multirow[t]{6}{*}{RSH2:} & XDS & & \\
\hline & XDS & & \\
\hline & XDS & & \\
\hline & XDS & & \\
\hline & X & & \\
\hline & RET & & \\
\hline \multirow[t]{2}{*}{BINDBL:} & RC & & ; \(2 \times \mathrm{R} 2 \rightarrow \mathrm{R} 2\); binary \\
\hline & LBI & 2,11 & \\
\hline \multirow[t]{6}{*}{BDLOOP:} & LD & & \\
\hline & ASC & & \\
\hline & NOP & & \\
\hline & XIS & & \\
\hline & JP & BDLOOP & \\
\hline & RET & & \\
\hline \multirow[t]{2}{*}{ADD :} & RC & & ; Rl+RO \(\rightarrow\) R0, decimal \\
\hline & LBI & 1,10 & \\
\hline \multirow[t]{7}{*}{ADLOOP:} & LD & 1 & \\
\hline & AISC & 6 & \\
\hline & ASC & & \\
\hline & ADT & & \\
\hline & XIS & 1 & \\
\hline & JP & ADL00P & \\
\hline & RET & & \\
\hline
\end{tabular}

The main body of the routine follows:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{4}{*}{\begin{tabular}{l}
BCDBIN: \\
CLEAR:
\end{tabular}} & LBI & 2,10 & ; \(0 \rightarrow\) binary number and initialize \\
\hline & CLRA & & \\
\hline & XIS & & ; bit counter \\
\hline & JP & CLEAR & \\
\hline \multirow[t]{4}{*}{DIVBY2:} & LBI & 0,15 & ; divide BCD number by 2, by first \\
\hline & CLRA & & ; divide by 10 (right digit shift) and \\
\hline & JSRP & RSH & ; then multiply by 5 \\
\hline & LBI & 0,10 & \\
\hline \multirow[t]{17}{*}{XFERI:} & LD & 1 & ; RO \(\rightarrow \mathrm{Rl}\), for subsequent adds \\
\hline & XIS & 1 & \\
\hline & JP & XFER1 & \\
\hline & JSRP & ADD & ; \(2 \times \mathrm{RO}\) \\
\hline & JSRP & ADD & ; \(3 \times \mathrm{RO}\) \\
\hline & JSRP & ADD & ; \(4 \times \mathrm{RO}\) \\
\hline & JSRP & ADD & ; \(5 \times \mathrm{RO}\), therefore have net divide by 2 \\
\hline & CLRA & & \\
\hline & LBI & 0,10 & ; fetch the remainder \\
\hline & RMB & 2 & ; make sure it is only 0 or 1 \\
\hline & X & & \\
\hline & LBI & 2,15 & ; load remainder to binary number and \\
\hline & JSRP & RSH2 & ; shift right 4 bits \\
\hline & JSRP & BINDBL & ; now shift left 3 bits \\
\hline & JSRP & BINDBL & \\
\hline & JSRP & BINDBL & ; net effect is l-bit right shift of \\
\hline & & & ; binary number with divide remainder going into MSB \\
\hline \multirow[t]{5}{*}{TSTFIN:} & LBI & 2,10 & \\
\hline & LD & & ; test bit counter for done, if not \\
\hline & AISC & 1 & ; increment bit counter \\
\hline & JP & TFIN2 & \\
\hline & RET & & \\
\hline TFIN2: & X & & \\
\hline & JP & DIVBY2 & \\
\hline
\end{tabular}

This routine takes 31 ROM words, plus 24 words in the subroutine page; uses 18 RAM digits; and executes in approximately 5500 instruction cycles.
There is little reason to recommend this routine over the others presented. It takes significantly more memory and executes significantly slower. The only benefit, if it can be so termed, is that it implements a commonly known procedure. The lesson is obvious: Do not assume that the "standard" procedure will yield the most efficient implementation. The programmer should be prepared to investigate various algorithms and approaches in the interest of efficiency.

\subsection*{5.3 TIMEKEEPING ROUTINES}

Several routines for keeping time are presented. These include routines for a 12- or 24 -hour clock based on internal or external timing references.

\subsection*{5.3.1 Basic Clock Routines - External Input}

The following two routines implement a basic clock. The two routines do the same thing. One is written as a 12 -hour clock, the other as a 24 -hour clock. This, however, is not the significant difference between them. Both routines use the RAM map below, and it is assumed that both the routines are called once per second on the basis of a \(1 \cdot \mathrm{~Hz}\) input signal.
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline & \multicolumn{6}{|c|}{Bd} \\
\hline & 15 & 14 & 13 & 12 & 11 & 10 \\
\hline Br 3 & Hours MSD & Hours LSD & Minutes MSD & Minutes LSD & Seconds MSD & Seconds LSD \\
\hline
\end{tabular}

The flow chart of Figure 5-23 applies to both routines. The flow chart indicates the minor differences when implementing a 12- or 24 -hour clock. Note that both routines have implemented the same flow chart in different ways.


FIGURE 5-23. Basic Block Flow Chart

The first implementation, Version I, uses a master increment loop which increments seconds, minutes, and hours as required. The loop handles the overflow from 60 to 00 in the seconds and minutes. Version I is written as a 24 -hour clock.
```

INCTIME: LBI 3,10 ; point to seconds LSD
CLRA
AISC 6
ASC
ADT
XIS ; LSD incremented, point to MSD
CLRA
AISC 6 ; increment saved in C
ASC ; increment MSD of seconds, minute or hours
ADT
X
test = 6, if so correct to 0 and move
LD ; to next digit. If not, exit
AISC 10
JP HOURS ; will always escape loop here if get to hours
STII 0
JP PLUSI
HOURS: LBI 3,15 ; test if hours need to be corrected
ID ; here testing for hours }\geq2
AISC 14
RET ; hours \geq20
IBI 3,14
ID
AISC 12
RET ; hours < 24
STII 0 ; hours }\geq\mathrm{ , therefore set to 0
STII 0
RET

```

This routine takes 28 ROM words, 6 RAM digits, and has a worst case execution time of 58 instruction cycle times. The routine uses no subroutines and execution time is data dependent. Minimum execution time is 19 instruction cycle times.
The second implementation, Version II, is a more direct implementation of the flow chart shown in Figure 5-23. It moves sequentially through the clock data, incrementing and adjusting as required.
```

INCTIME: LBI 3,10 ; point to seconds LSD
JSRP PLUSI ; 2 digit BCD increment
LD
AISC 10 ; mod 6 correct
RET ; seconds MSD < 6, exit
XIS
JSRP PLUSL ; increment minutes
LD ; mod 6 correct
AISC 10
RET ; minutes MSD < 6, exit
XIS
JSRP PLUSI ; increment hours
LD ; now do hours adjust
AISC 15
RET ; exit if hours MSD = 0
LBI 3,14 ; hours MSD = 1, test hours LSD < 3
LD
AISC 13
RET ; hours s - exit
STII 1 ; hours = 13, set to 0l and exit
STII 0
RET

```

The routine uses the following subroutines, assumed to be located in Page 2.
```

PLUSl: SC ; 2 digit BCD increment
CLRA
AISC 6
ASC

```
```

ADT
XIS
CLRA
AISC 6
ASC
ADT
X
RET

```

The routine takes a total of 34 ROM words, 22 in the main routine and 12 in the subroutine; uses 6 RAM digits; and has a worst case execution time of 58 instruction cycle times. Execution time is data dependent with the minimum execution time being 17 instruction cycles. The routine uses one subroutine level.
\(\mathbf{1 - H z}\) Input and \(50-\) or \(\mathbf{6 0 - H z}\) Input
The two routines provided are written assuming they are called as a result of a \(1-\mathrm{Hz}\) signal. It is a simple task to modify the routines for a 50 - or \(60-\mathrm{Hz}\) input signal. As Version I is the more code efficient routine, the necessary modifications will only be illustrated for that implementation.

\section*{60-Hz Only Input}

If the signal source is a \(60 \cdot \mathrm{~Hz}\) signal, the modification is trivial. By simply changing the first LBI from LBI 3,10 to LBI 3,8 , the routine becomes a clock increment based on a \(60-\mathrm{Hz}\) input. The rest of the routine is completely unchanged. Of course, two extra RAM digits are used, digits 3,9 and 3,8 , to count the \(60-\mathrm{Hz}\) signal. Also, as should be expected, worst case execution time increases.

\section*{A General \(\mathbf{5 0 -}\) or \(\mathbf{6 0 - H z}\) Input}

It is fairly simple to modify the routine to operate with either a \(50-\mathrm{Hz}\) or \(60-\mathrm{Hz}\) reference input. The modification will use the characteristic described in the preceding paragraph. For a \(50-\mathrm{Hz}\) input, the frequency counter is set to 10 rather than 00. Otherwise, the routine remains the same. The routine arbitrarily selects G 2 as the input line to define whether the input is \(50-\mathrm{Hz}\) or \(60-\mathrm{Hz}\). Figure \(5-24\) is the flow chart shown in Figure \(5-23\) modified to indicate the specific implementation and the \(50-\) or \(60-\) Hz feature.

Bd
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline & 15 & 14 & 13 & 12 & 11 & 10 & \(\bigcirc\) & 8 \\
\hline Br 3 & Hours MSD & Hours LSD & Minutes MSD & Minutes LSD & Seconds MSD & Seconds LSD & Counter MSD & Counter LSD \\
\hline
\end{tabular}


FIGURE 5-24. Clock Based on 50- or \(\mathbf{6 0 - H z}\) Input
\begin{tabular}{|c|c|c|c|}
\hline INCTIME: & LBI & 3,8 & ; point to counter LSD \\
\hline \multirow[t]{17}{*}{PLUSI:} & SC & & \\
\hline & CLRA & & ; 2 digit BCD increment by 1 \\
\hline & AISC & 6 & \\
\hline & ASC & & \\
\hline & ADT & & \\
\hline & XIS & & \\
\hline & CLRA & & \\
\hline & AISC & 6 & \\
\hline & ASC & & \\
\hline & ADT & & \\
\hline & X & & \\
\hline & CLRA & & \\
\hline & AISC & 6 & ; now test MSD \(\geq 6\) \\
\hline & SKE & & \\
\hline & JP & HOURS & \\
\hline & STII & 0 & \\
\hline & JP & PLUS1 & ; is \(\geq 6\), correct to 0 and continue \\
\hline \multirow[t]{7}{*}{HOURS :} & LBI & 3,9 & ; test counter MSD \(=0\) \\
\hline & CLRA & & \\
\hline & SKE & & \\
\hline & JP & HOURS2 & \\
\hline & OGI & 15 & ; now test 50 - or \(60-\mathrm{Hz}\), set G2 high \\
\hline & SKGBZ & 2 & \\
\hline & STII & 1 & ; if \(50-\mathrm{Hz}, 1 \rightarrow\) counter MSD \\
\hline \multirow[t]{11}{*}{HOURS2:} & LBI & 3,15 & ; G2 = 1 indicates 50-Hz input \\
\hline & LD & & \\
\hline & AISC & 14 & \\
\hline & RET & & ; hours MSD < 2 \\
\hline & LBI & 3,14 & ; hours MSD \(=2\), test hours LSD \(<4\) \\
\hline & LD & & \\
\hline & AISC & 12 & \\
\hline & RET & & ; hours < 24 \\
\hline & STII & 0 & \\
\hline & STII & 0 & ; hour \(\geq 24\), set to 0 \\
\hline & RET & & \\
\hline
\end{tabular}

The routine uses 39 ROM words, the extra words being used to read the input and adjust the counter accordingly, and 8 RAM digits. Input \(\mathrm{G}_{2}=1\) indicates a \(50-\mathrm{Hz}\) input signal.

\section*{12- or 24-Hour Capability}

It is a trivial matter to expand the routine further to give it the option of 12- or 24 -hour capability. Figure 5 -23 indicates the differences, which are minor. One need only test another input and alter the hours digits accordingly.

\subsection*{5.3.2 Clock Routines Based on Internal Timer}

The internal timer of COPS microcontrollers can be used as the time reference for a clock. Routines using this feature must count timer overflows. These overflows are dependent, of course, on the operating frequency of the microcontroller. This points out a major restriction on this type of clock routine: It is impossible for the clock to be more accurate than the oscillator frequency. Another difficulty is that the selection of operating frequency may give a fractional SKT, timer overflow, frequency. This complicates the routine by requiring compensation for this fractional frequency.

\section*{An SKT-Based Timekeeping Routine}

The following routine is representative of the worst case conditions when using the internal timer as a clock time base: A common, inexpensive crystal is used for the oscillator and creates a fractional SKT frequency. The following information is essentially a duplication of Section 4.9 of the COPS Family User's Guide. It is presented here for completeness.
The routine presented here is a 12 -hour clock using the SKT overflow as the time base. The oscillator used will be based on a 3.579545 MHz -crystal, the inexpensive, readily available TV crystal. Therefore, a high-speed part (e.g., COP420) with the divide by 16 option must be used. The SKT overflow frequency is the instruction cycle frequency (here 3.579545 MHz divided by 16) divided by 1024 or, in this case, 218.478 Hz . Therefore, the timekeeping calling routine must execute an SKT instruction at an approximate \(218-\mathrm{Hz}\) rate to guarantee detection of every SKT overflow. The routine must compensate for the non-integer SKT overflow frequency to provide timing accuracy.

Compensation is achieved by establishing a counter for the SKT overflows. Seconds are incremented when this counter reaches 0 . This counter is preset to various values, from which it is counted down, at various points in the routine. The details of the compensation are as follows:
- Every odd second in the range of 0-59 seconds, the counter is set to 218.
- Every even second in the range of \(0-59\) seconds, the counter is set to 219.
- Every minute in the range of \(0-59\) minutes, the counter is set to 218.
- Every hour the counter is set to 199.

Regardless of the preset, the counter is decremented every time the SKT instruction skips, i.e., an SKT overfow is detected. The technique previously described will provide accuracy at the end of each hour. The short term inaccuracies during the hour are small. The COPS Family User's Guide explains why this particular compensation scheme works and the reader is referred to the manual for explanation.
Figure \(5-25\) is the flow chart and RAM map for this routine. Note that the counter for SKT overflows is binary. Also note that the hours portion of the clock is binary, to save RAM, and that the minutes and seconds portions of the clock are BCD. The routine is located outside Page 2 and uses a subroutine located in Page 2.


TL/DD/8800-38
FIGURE 5-25. Flow Chart for Internal Time Base Clock (Oscillator Frequency \(=\mathbf{3 . 5 7 9 5 4 5} \mathbf{~ M H z )}\)
```

TIMEKP: LBI 2,14 ; point to low-order digit of counter
DECR: LD ; decrement the counter by l
AISC 15
JP NEXTDIG
X ; counter = 0 return to main routine
RET
NEXTDIG: XIS ; if skip executed, counter is 0
JP DECR
SECONDS: LBI 2,9 ; points to seconds LSD
JSRP INC2 ; 2 digit BCD increment with MOD6 adjust
JP TSEC ; seconds < 60, test ODD or EVEN
STII 0 ; seconds = 60, 0 }->\mathrm{ seconds, increments mins.
JSRP INC2
JP C218 ; minutes < 60, set counter = 218
STII 0 ; 0 m minutes, increment hours
LD
AISC 1
X
AISC 4 ; test hours > 12
JP Cl99 ; no, set counter to 199
STII 1 ; yes, set hours to l and counter to 199
Cl99: LBI 2,14
STII 7 ; set counter = 199 (binary 12,7)
STII 12
RET
TSEC: LBI 2,9 ; point to seconds LSD to test ODD/EVEN
SKMBZ O
JP C218 ; seconds ODD, set counter to 218
C219: LBI 2,14 ; seconds EVEN, set counter to 219
STII 11 ; 219 = binary 13,11
C21X: STII 13
RET 2,14 ; 218 = binary 13,10
STII 10
JP C21X

```

This routine uses the following subroutine:
```

INC2: SC ; 2-digit BCD increment
CLRA
AISC 6
ASC
ADT
XIS
CLRA
AISC 6
ASC
ADT
X ; now test if reached 60
ID
AISC 10
RET ; 2 digits < 60
RETSK ; 2 digits = 60

```

It should be clear that a more convenient choice of oscillator frequency would significantly reduce the code in this routine. An integer SKT overflow frequency would reduce the routine to, essentially, one of the routines shown initially.

\subsection*{5.4 DATA MANIPULATION AND STRING OPERATIONS}

\subsection*{5.4.1 Register Transfers}

Several routines are provided for transferring data between registers. Some more or less specialized routines are presented along with a completely general routine.

\section*{Four Register Blocks}

The LD, XIS, XDS, and X instructions have an exclusive OR argument which permits easy data transfer among the registers within a four register block, registers \(0-3,4-7\), etc. Moving data across a register block boundary is less efficient and the general purpose routines have to be used. Within the register block, the following routines can be used:
\begin{tabular}{lllllll} 
XFER1: & LD & 1 & XFER2: & LD & 2 & XFER3: \\
& LD & 3 \\
XIS & 1 & & XIS & 2 & & XIS \\
JP & XFER1 & & JP & XFER2 & & JP \\
RET & & & RET & & XFER3
\end{tabular}

Note: LDS can be used in place of XIS in any of these routines.
Routine XFER1 will transfer data from R0 to R1, R1 to R0, R2 to R3, or R3 to R2. Routine XFER2 will transfer data from R0 to R2, R2 to R0, R1 to R3, R3 to R1. Routine XFER3 will transfer data from R0 to R3, R3 to R0, R1 to R2, or R2 to R1. The direction of the transfer depends only on the status of the \(B\) register when the routine is executed. In fact, the routines are commonly preceded by one or more LBI instructions. The successive skip feature of the LBI instruction is very powerful when used in conjunction with these routines.
Register exchanges within the four register blocks are written in much the same way as the following routine indicates.
\begin{tabular}{lll} 
SWAP1: & LD & 1 \\
& X & 1 \\
& XIS & 1 \\
& JP & SWAPI \\
& RET &
\end{tabular}

This routine will exchange the contents of the R0 and R1 or R2 and R3. Similar routines for the other registers can also be written in the same manner as the data transfers. Again, XDS may be used in place of XIS.

\section*{Completely General Transfers}

A completely general register transfer routine is indicated below. The routine uses a RAM digit for temporary storage. The routine is called by setting up the source register with an LBI and establishing the destination register number in the accumulator. RAM digit TEMP is any convenient digit.
LOOP: \begin{tabular}{lll} 
& XAD & TEMP \\
& XABR & \\
& XAD & TEMP \(\quad\) XFER is the entry point for the routine \\
& LD & \\
& XAD & TEMP \\
& XABR & \\
& XAD & TEMP \\
& XIS & \\
& JP & LOOP \\
& RET
\end{tabular}

The calling sequence for the routine is as follows:
\begin{tabular}{lll} 
LBI & SOURCE & \\
CLRA & & \\
AISC & \(N\) & \(N\) defines destination register \\
JSRP & XFER &
\end{tabular}

Obviously, if a transfer from RN to RK is common, the setup can be included in the subroutine.
The routine can be rewritten in the following form and the calling sequence modified as follows:
\begin{tabular}{lll} 
CALLING & SEQUENCE: & \\
LBI & TEMP & \\
STII & N & ; destination register \\
LBI & SOURCE & \\
JSRP & XFER &
\end{tabular}

The subroutine is as follows:
\begin{tabular}{llllll} 
LOOP: & JSR & EXCH & EXCH: & XAD & TEMP \\
XFER: & LD & & & XABR & \\
& JSR & EXCH & & XAD & TEMP \\
& XIS & & & RET & \\
& JP & LOOP & & & \\
& RET & & & &
\end{tabular}

There is no particular benefit in doing this for the simple register transfer but it will result in code savings where register swaps, general purpose swaps, are also required.

The routine for a general purpose register swap and the calling sequence are given below.
\begin{tabular}{|c|c|c|}
\hline CALLING & SEQUENCE: & \\
\hline LBI & TEMP & \\
\hline STII & N & ; one register number \\
\hline LBI & SOURCE & \\
\hline JSRP & SWAP & \\
\hline \multicolumn{3}{|l|}{The SWAP subroutine is:} \\
\hline SWAP2: & JSR EXCH & \\
\hline \multirow[t]{7}{*}{SWAP:} & LD & ; entry point for the routine \\
\hline & JSR EXCH & \\
\hline & X & \\
\hline & JSR EXCH & \\
\hline & XIS & \\
\hline & JP SWAP2 & \\
\hline & RET & \\
\hline
\end{tabular}

Subroutine EXCH is the same routine as indicated in the general purpose transfer.

\subsection*{5.4.2 Shift Routines}

\section*{Right Digit Shift}

The following routines will perform right digit shifts. The first routine shifts right one digit from the starting \(B\) address to the end of the register. The second routine shifts an arbitrary four-digit group right one digit. Both routines place a " 0 " in the starting digit and leave the previous contents of the last digit in the accumulator.


\section*{Left Digit Shift}

The following routines will perform left digit shifts. The first routine shifts left one digit from the starting B address to the end of the register. The second routine shifts an arbitrary four-digit group left one digit. Both routines place a " 0 " in the starting digit and leave the previous contents of the last digit in the accumulator.


NOTE: The left and right digit shift routines are written in the sense that the direction of increasing Bd value is "left". The direction of decreasing Bd value is "right". It is entirely possible that the user may, for his or her application, wish to reverse this directional sense. This causes no problem and the routines above are merely reversed (i.e., the left shifts become right shifts and vice-versa).

\section*{Right Bit Shift}

A right bit shift is one of those very few things that COPS microcontrollers do not do well. If the algorithm or approach chosen involves right bit shifting, it is strongly recommended that an alternative approach be used or developed. An alternative nearly always exists and will commonly be COPS code efficient. Rarely, if ever, does the failure to find an alternative to right bit shifting mean that no alternative exists. The programmer should think in broader terms than the specific function of right bit shifting; if an algorithm requires right bit shifting, consider other algorithms for the same function.

However, if there is no choice and right bit shifting must be performed, some routines to perform the shift are presented. Note, right shift has the same directional sense here as in digit right shift; data movement is in the direction of decreasing Bd.

\section*{Right Shift Memory Digit 1 Bit}

This routine is a simple, straightforward approach to shift a memory digit right one bit. The shifted data is formed in the accumulator and then exchanged into memory. The routine can be written for a simple shift or a right circular shift. Both versions are indicated. The routines take advantage of the bit testing capability of COPS microcontrollers.
\begin{tabular}{llll} 
I - Simple Shift & II - Circular Bit Shift \\
RBSHIFT: CLRA & & RBSHIFT: CLRA & \\
SKMBZ & 3 & SKMBZ & 3 \\
AISC & 4 & AISC & 4 \\
SKMBZ & 2 & SKMBZ & 2 \\
AISC & 2 & AISC & 2 \\
SKMBZ & 1 & SKMBZ & 1 \\
AISC & 1 & AISC & 1 \\
X & & SKMBZ & 0 \\
RET & & AISC & 8 \\
& & RET & \\
& & &
\end{tabular}

These routines are not particularly long nor complex and work well. They form the most efficient basis for general right bit shifting in COPS microcontrollers.

\section*{Right Shift Using SIO}

If the SIO register is not otherwise being used, it can be used to perform a right circular shift of the data in the accumulator. This technique requires that pins SO and SI of the microcontroller be tied together externally. The routine is then reduced.
```

RSHIFT: XAS ; SIO must be in shift register mode
NOP
NOP
XAS
RET

```

The SIO register shifts left one bit each instruction cycle when it is enabled as a shift register. Thus, a right bit shift is achieved by three left bit shifts.

\section*{Left Bit Shifts}

Left bit shifts are easy to perform even though there is no bit shift instruction. Bit left shift has the same directional sense as digit left shift; data movement is in the direction of increasing Bd.
Left Bit Shift by Means of Binary Double
Left shifting a value by one bit is equivalent to a binary doubling of that value. Thus, a binary doubling routine can be used for left bit shifting. Two routines are provided; one simply left shifts a single digit 1 bit; the other shifts several digits left 1 bit.
```

I - Single Digit
LBSHIFT: ID LBSHIFT: RC
ADD LSHFT: LD
X ASC
RET NOP
XIS
JP LSHFT
RET

```

These two routines perform the left shift in the same manner. The number is added to itself to do a binary double. The second version remembers the state of the MSB of a given digit in C so shifting can be performed across the digits.

\section*{Use of SIO for Left Bit Shifting}

The SIO register can be used to shift the data in the accumulator left one bit. In the shift register mode, SIO is always shifting left. This normal operational feature can be used to advantage. The routine is simplicity itself:
```

LBSHIFT: XAS ; SIO must be in shift register mode
XAS
RET

```

A and SIO are simply swapped twice. Since SIO is always shifting (in shift register mode), this results in a net one bit left shift. This routine does not require that SI and SO be tied together and is therefore more or less unrestricted in its use. The user must remember that the state of SI, whatever it may be, is shifted into SIO and that the LSB of the accumulator after this routine will be controlled by the state of SI during the shift. Tying SI to SO will result in a left circular shift of one bit, the MSB of the accumulator will be moved to the LSB as the left bit shift occurs.

\subsection*{5.4.3 Data/String Compare}

A routine to compare two strings of data or characters is provided. It is the same routine that would be used to compare two registers (within the four register blocks). The RAM map for this routine is indicated below:


The routine is setup as a subroutine. It will simply return if the strings are not equal and return and skip if the two strings are identical. By changing the starting LBI, larger strings can be tested.
```

COMPARE: LBI l,ll ; initialize B
CMPR: LD 3 ; load value to A, point to other register
SKE ; test equal
RET ; not equal, return
XIS 3
JP CMPR
RETSK ; all digits equal, return and skip

```

The preceding routine is excellent if the data is placed so that it can be used. The programmer should strive to place data in RAM so that routines such as the one previously illustrated can be used. However, data is not always located in the most efficient places. Therefore, a general purpose compare routine is provided. This routine will compare a three-digit string located in \((1,10),(1,11)\) and \((1,12)\) to another three-digit string located in \((3,7),(3,8)\), and \((3,9)\).
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{6}{|c|}{Bd} \\
\hline \multirow[t]{3}{*}{\(\mathrm{Br}^{1}\)\begin{tabular}{|} 
\\
\\
\\
\\
\\
\end{tabular}} & 11 & 10 & 9 & 8 & 7 \\
\hline & String 1 & \multicolumn{4}{|c|}{Not Used} \\
\hline & Not Used & & & String 2 & \\
\hline \multirow[t]{13}{*}{COMPARE :} & LBI 1,10 & \multicolumn{4}{|r|}{; initialize B register} \\
\hline & LDD
SKE & \multicolumn{4}{|r|}{; fetch first digit to compare} \\
\hline & SKE & & & & \\
\hline & RET & \multicolumn{4}{|c|}{; not equal} \\
\hline & XIS & \multicolumn{4}{|c|}{; point to next digit} \\
\hline & LDD 3,8 & \multicolumn{4}{|c|}{; fetch second digit} \\
\hline & SKE & \multicolumn{4}{|c|}{\multirow[t]{3}{*}{; not equal}} \\
\hline & & & & & \\
\hline & XIS & & & & \\
\hline & LDD 3,9 & \multicolumn{4}{|c|}{; fetch third digit} \\
\hline & SKE & \multicolumn{4}{|c|}{\multirow[t]{2}{*}{; not equal}} \\
\hline & RET & & & & \\
\hline & RETSK & \multicolumn{4}{|c|}{; strings equal} \\
\hline
\end{tabular}

This routine is general and the two strings could be located anywhere. By merely supplying the proper values in the LBI and LDD instructions, the routine is modified for data in locations other than those indicated here.

\subsection*{5.4.4 String Search}

It is often necessary to search data memory for a string of characters. This routine will search register 0 for the three character string located in digits \((2,15),(2,14)\), and \((2,13)\). The routine simply returns if no match and returns and skips if the string is found.
\begin{tabular}{|c|c|c|c|}
\hline SEARCH: & LBI & 0,15 & ; initialize B register \\
\hline \multirow[t]{6}{*}{CHAR1:} & LDD & 2,15 & ; fetch first character \\
\hline & SKE & & \\
\hline & JP & DECR & ; not equal, move \(B\) register \\
\hline & XDS & & \\
\hline & JP & CHAR2 & ; matched first character, test second \\
\hline & RET & & ; string not found in register 0 \\
\hline \multirow[t]{6}{*}{CHAR2:} & LDD & 2,14 & ; fetch second character \\
\hline & SKE & & \\
\hline & JP & CHARI & ; no match \\
\hline & XDS & & \\
\hline & JP & CHAR3 & \\
\hline & RET & & ; string not found in register \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{4}{*}{CHAR3:} & LDD & 2,13 & ; fetch third character \\
\hline & SKE & & \\
\hline & JP & INCR & \\
\hline & RETSK & & ; string found \\
\hline \multirow[t]{4}{*}{DECR:} & LD & & ; no match, move Bd down \\
\hline & XDS & & \\
\hline & JP & CHARI & ; and start over \\
\hline & RET & & ; moved over the end, string not found \\
\hline \multirow[t]{3}{*}{INCR} & LD & & \\
\hline & XIS & & \\
\hline & JP & CHARI & \\
\hline
\end{tabular}

Remember, the routine is searching for the contiguous three-digit group and exists via RETSK when that group is found.

\subsection*{5.4.5 RAM Clear Routines}

Routines that clear the data memory are commonly required in programs. Some of the more standard techniques are indicated here.

\section*{Single Register Clear}

The following routines will clear all or part of a register. They are normally preceded by an LBI instruction.
\begin{tabular}{llllll} 
& \multicolumn{1}{c}{ I } & & & \multicolumn{1}{c}{ II } & \\
CLEARX: & LBI & START & CLEARX: & LBI & START \\
CLR: & CLRA & & CLR: & CLRA & \\
& XIS & & & XDS & \\
& JP & CLR & & JP & CLR \\
& RET & & & RET &
\end{tabular}

The routines are equivalent. Routine I clears the data in the register from the digit defined by START up to and including digit 15. Routine II clears the data in the register from the digit defined by START down to and including digit 0.

\section*{Clearing Entire RAM}

It is a common requirement that the entire RAM be cleared at power up or on the basis of a master clear operation or both. This can be done by calling the register clear instructions provided previously. It will usually be more code efficient to use the routine provided here.
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{4}{*}{MCLEAR :} & LBI & \multicolumn{2}{|l|}{0,0} \\
\hline & CLRA & & \\
\hline & AISC & N & ; \(N=\) highest number of register in device \\
\hline & & & ; \(N=3\) for COP420, \(N=7\) for COP444L, etc. \\
\hline LOOP: & XABR & & \\
\hline \multirow[t]{6}{*}{CLR:} & CLRA & & ; these three words could be replaced \\
\hline & XIS & & ; with a subroutine call to CLR \\
\hline & JP & CLR & ; subroutine defined above \\
\hline & XARR & & \\
\hline & AISC & 15 & ; decrement BR \\
\hline & JP & L00P & \\
\hline
\end{tabular}

The routine merely establishes the maximum value of BR allowed in the device-or desired to be cleared-and successively clears each register.

\subsection*{5.5 INPUT/OUTPUT}

This section deals with the techniques for getting data in and out of COPS microcontrollers. Some of this is straightforward since COPS devices have independent instructions for input and output.

\subsection*{5.5.1 Table Look Up}

The LQID instruction makes outputting converted data very simple. It is powerful in its own right as a table look-up instruction but that power is increased if it is necessary to output the table values. A routine to output information is shown below. The table is not shown but is obviously required. Note that the table may be any kind of code conversion: BCD to Seven Segment, ASCII conversion, etc. The output is not affected by the table contents. By virtue of the successive LBI feature, the routine is set up to output either of two data streams.

\begin{tabular}{|c|c|c|c|}
\hline OUTDS1: & LBI & 0,8 & ; this entry point will output data stream 1 \\
\hline \multirow[t]{3}{*}{OUTDS2:} & LBI & 1,8 & ; this entry point will output data stream 2 \\
\hline & CLRA & & \\
\hline & AISC & N & ; setup accumulator for Table location \\
\hline \multirow[t]{6}{*}{OUTPUT :} & OBD & & ; output digit position on D lines \\
\hline & LQID & & \\
\hline & X & & ; this allows movement through \\
\hline & XIS & & ; the data without disturbing the data \\
\hline & JP & OUTPUY & ; or the accumulator \\
\hline & RET & & \\
\hline
\end{tabular}

The routine assumes that the \(L\) drivers have been enabled prior to calling the routine. Note that the LQID instruction loads the \(Q\) register. The L drivers must be enabled to output the data in Q. Remember also that the LQID instruction uses a subroutine level in some COPS microcontrollers.

\subsection*{5.5.2 Microbus I/O}

Microbus I/O is, of course, relevant only to those COPS microcontrollers which have the Microbus option implemented. This option makes the code required for the interface simplicity itself. Only one caution is necessary: Do not enable the L drivers, i.e., do not set \(E N_{2}\), on Microbus parts. COPS Microbus devices are structured to be peripheral devices for some host processor. The host has control over the L drivers via the chip select, read strobe, and write strobe.
As stated earlier G0 is the handshake line for the Microbus interface. It is the responsibility of the COPS program to set G0 to a 1 level to indicate the COPS device is ready for access by the host. A write to the COPS Microbus peripheral by the host will set G0 low. A typical sequence for this is as follows:
```

    \bullet
    -
    OGI 1 ; GO assumed low, O prior to this
        ; set GO high to indicate COPS ready
    WAIT: SKGBZ 0 ; wait for a write by host
JP WAIT
CQMA ; GO was low, a write was performed
- ; read the data and continue with
. ; the program
-

```

Note that when the host processor writes to a COPS Microbus device, the host writes directly into the \(Q\) register. The COPS microcontroller then merely reads the Q register.
A read by the host is equally simple. Upon seeing G0 high, the host will execute a read operation which takes the Q data out to the eight-bit bus. The only possible difficulty is that the COPS microcontroller does not know that a read has been performed. If it is necessary for the microcontroller to know a read has been performed, the following sequence is recommended.
```

    •
    -
    CAMQ ; load Q ; could use LQID
    OGI 1 ; set GO high to indicate data ready
    JP WAIT ; host acknowledges ready by a dummy write
        JMP MAIN
        •
        •
    ```
WAIT: SKGBZ 0

This sequence outputs the data to \(Q\) and then sets \(G 0\) high to indicate ready. The host reads the data and then does a dummy write to indicate the data has been read. The microcontroller detects this and then returns to the main loop where G0 is set high and the device waits for the next write.
The procedure above is, of course, not necessary if there is no requirement that the COPS microcontroller know that a read operation by the host has taken place.

\subsection*{5.5.3 Serial I/O—MICROWIRE}

Routines for handling serial I/O are provided. Two versions of output routines are provided: a destructive output and a nondestructive output. The routines are written for 16 -bit transmissions but are trivially expandable up to 64 -bit transmissions by merely changing the initial LBI instruction. The routines are written using the XIS instruction, but the XDS instruction could be used equally well.
The routines arbitrarily select register 0 as the \(/ / O\) register. It is assumed that the external device requires a logic low chip select. It is further assumed that chip select is high, SK is low, and SO is low on entry to the routines. The routines exit with chip select high, SK low, and SO low. G0 is arbitrarily chosen as the chip select for the external device.

\section*{Destructive Data Output}

This routine outputs the data under the conditions specified above. The output data is destroyed after it is transmitted.
```

OUTl: LBI 0,12 ; point to start of data word
SC ; set C to enable SK clock
OGI 14 ; select external device by 0 }->\mathrm{ GO
LEI 8 ; enable shift register output
SEND:
LD
XAS ; data transmission loop, first
XIS ; XAS turns on SK clock
JP SEND
RC
XAS ; turn off SK clock, transmission done
OGI 15 ; deselect external device
LEI 0 ; set SO to 0
RET

```

Note that this is a general purpose routine and handles all the overhead except loading the data into R0. The routine takes a total of 17 ROM words and can undoubtedly be reduced in specific applications.

\section*{Nondestructive Data Output}

This routine is identical to the destructive data output routine except that the transmitted data is preserved in the microcontroller.
```

OUT2: LBI 0,12 ; point to start of data word
SC
OGI 14 ; select the external device
LEI 8 ; enable shift register mode
JP SEND2
SENDI: XAS
SEND2: LD ; data output loop
XIS
JP SENDI
XAS ; send last data
RC ; wait 4 cycles to data to get out
CLRA
NOP
XAS ; turn SK clock off
OGI 15 ; deselect the device
LEI 0 ; turn SO low
RET

```

The nondestructive routine takes 21 ROM words, four more than the destructive routine. Again, this is a general purpose routine which can probably be reduced in specific applications.

\section*{Serial Data Input}

The code for reading serial data is almost the same as the write code. This should be expected because of the nature of the SIO register and the XAS instruction.
The first routine enables shift register mode, selects the external device, and reads the data in. Register 0 is the input register and the routine, as written, is for a 16-bit data stream. As before, the routine is trivially expandable up to 64 bits. G0 is arbitrarily selected as the chip select for the external device. SK is 0 , and GO is high or entry to the routine.
```

READ: LEI 0 ; enable shift register mode, SO is 0
OGI 14
SC
XAS ; turn on the clock
LBI 0,13 ; initialize the B register
NOP ; NOPs to preserve the timing
LOOP: NOP
XAS
XIS ; read all but last four bits in this loop
JP LOOP
RC
XAS ; turn off the clock and read last four bits
OGI 15 ; deselect the device
RET

```

The routine exits with the data in digits \(0,13,0,14,0,15\), and the accumulator.

A variation on this routine which places the input data in digits 0,12 through 0,15 is presented below. This routine uses one subroutine level.
```

READ: LEI 0 ; enable shift register mode 0 T SO
OGI 14 ; select external device
LBI 0,12 ; initialize B register
LOOP: JSRP SIO
LD ; data read loop
XIS
JP L00P
OGI 15 ; deselect the devices
RET

```

The following subroutine is used:
```

SIO: SC ; turn on SK clock
RC ; wait 4 cycles for the data to full SIO and
NOP ; turn off the clock
NOP
XAS
X ; put data to memory
RET

```

These are two implementations of the same basic routine. The first version reads the data in one continuous stream; the second version reads the data in four-bit groups. The second routine uses a little more code. The choice of routine is entirely governed by the application, the peripheral devices used, and not by the microcontroller.
It is fairly common that the peripheral device must be sent some command or instruction directing it to output some data to the MICROWIRE interface. A typical routine of this type is given below. G0 is again chosen as the chip select. It is assumed that the peripheral device requires a start bit followed by four bits of instruction information. Location 0,0 is arbitrarily selected for storage of the instruction data. The routine is again written for 16 data bits. The input portion of the routine is essentially the same routine as the first version above. There is a subtle difference: the data is all placed in RAM and four extra clocks are generated. This is not normally a problem, but if it is, use another form of the input routine. There is no requirement that the input routine must be in this form:
```

READ: OGI 14 ; select the device
LEI 8 ; enable shift register
CLRA ; setup start bit in A
AISC 1
SC ; turn on clock and send start bit
XAS
LDD 0,0 ; fetch command/instruction
LBI 0,12 ; initialize B register
XAS ; send command/instruction
NOP ; wait 4 cycles for data to get to
CLRA ; the peripheral
XAS ; just maintaining the timing, send Os
NOP ; delay - typical required 0 to 3 instruction cycles
NOP ; now wait 4 cycles for data to fill SIO
NOP
LOOP: CLRA
XAS ; data read loop
XIS
JP LOOP
RC
XAS ; turn off the clock
OGI 15
LEI 0 ; deselect the device and turn SO off
RET

```

\subsection*{5.5.4 SI as a General Purpose Input}

When not used as part of the MICROWIRE interface, SI can be used as a general purpose input. There are two ways in which this can be done:
1. Leave SIO in shift register mode. SO may be enabled or disabled depending on system requirements. Then reading SI is simple:
\begin{tabular}{ll} 
CLRA & ; this clear not absolutely necessary \\
XAS & \\
AISC & 15 \\
JP & SIEQO \\
- test \(S I O\) for \(0, i f ~\) & \\
- &
\end{tabular}
2. Put SIO in counter mode. Then SI will capture pulses that meet minimum width requirements. Load SIO with 0 and test for 15 . Sample code for this is as follows:
```

CLRA ; CLRA required here
XAS
AISC l
JP NOPULSE
PULSE .

```

Remember that this mode captures and remembers the occurrences of a high to low transition at SI input. SIO is in binary counter mode for this method to work.
Some devices have the SKSZ instruction. This makes testing SI, or SIO, particularly easy. SKSZ tests the contents of SIO without affecting those contents and generates a skip if SIO is 0 . This is essentially the same test as above except that it is a single instruction.

\subsection*{5.6 DISPLAY CONTROL}

It is frequently required to control a display as part of an application using COPS microcontrollers. There are several approaches to this and this section will attempt to illustrate those approaches.

\subsection*{5.6.1 A Four-Digit Multiplexed Display}

This routine will output a four-digit number to a standard seven segment display. The \(D\) lines will be the digit strobes, with D3 being the most significant display digit. The \(L\) lines will provide the segment data with the following format:


The interconnect and flow chart are shown in Figures 5-26 and 5-27. The code is written independently and simply displays the data. In a real application, the routine would have to be merged with the main code. The routine provides both segment and digit interdigit blanking. A simple delay routine is used to control display ON/OFF time.


The RAM map for this routine is shown above. The display data is in BCD.


FIGURE 5-26. Interconnect for Sample and Multiplexed Display Code


FIGURE 5-27. Multiplexed Display Flow Chart
```

DISPLAY: LBI 0,ll ; initialize digit strobe
STII l
JSR OUT ; output first digit - LSD
LBI 0,13
JSR OUT ; second digit
LBI 0,14
JSR OUT ; third digit
LBI 0,15
JSR OUT ; fourth digit - MSD
JP DISPLAY

```

The subroutine OUT does most of the work:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{11}{*}{OUT :} & CLRA & & ; set up address for table \\
\hline & AISC & 4 & \\
\hline & LQID & & \\
\hline & LDD & 0,11 & ; output digit strobe \\
\hline & CAB & & \\
\hline & OBD & & \\
\hline & LEI & 4 & ; enable segment outputs \\
\hline & LBI & 0,11 & \\
\hline & LD & & \\
\hline & ADD & & ; shift the strobe to next digit \\
\hline & \(X\) & & \\
\hline \multirow[t]{7}{*}{WAIT:} & CLRA & & ; delay time arbitrary for display \\
\hline & SKT & & ; on time \\
\hline & JP & WAIT & \\
\hline & LBI & 0,15 & ; turn off the digits; all high \\
\hline & OBD & & \\
\hline & LEI & 0 & ; turn off the segments; L drives off \\
\hline & RET & & ; return for the next digit \\
\hline
\end{tabular}

The preceding routine uses a subroutine level. A routine that performs the same function but does not use a subroutine level is indicated below. As the RAM map indicates, an extra RAM digit is used in this implementation of the multiplexed display routine.
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline & \multicolumn{6}{|c|}{BD} \\
\hline & 15 & 14 & 13 & 12 & 11 & 10 \\
\hline Br 0 & DISPLAY
MSD & & & \[
\left\lvert\, \begin{gathered}
\text { DISPLAY } \\
\text { LSD }
\end{gathered}\right.
\] & \[
\begin{gathered}
\text { DIGIT } \\
\text { STROBE }
\end{gathered}
\] & \begin{tabular}{l}
DISPLAY \\
POSITION
\end{tabular} \\
\hline
\end{tabular}

As before, the data is assumed to be in BCD.
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{3}{*}{DISPLAY} & LBI & 0,10 & ; initialize display pointer and digit strobe \\
\hline & STII & 12 & \\
\hline & STII & 1 & \\
\hline \multirow[t]{11}{*}{DSP1:} & CLRA & & \\
\hline & AISC & 4 & ; set up address for table \\
\hline & LQID & & ; loop up segments \\
\hline & LDD & 0,11 & ; output digit strobe \\
\hline & CAB & & \\
\hline & OBD & & \\
\hline & LEI & 4 & ; enable L to output segment data \\
\hline & LBI & 0,11 & ; increment digit strobe (left shift) \\
\hline & LD & & \\
\hline & ADD & & \\
\hline & X & & \\
\hline \multirow[t]{2}{*}{WAIT :} & CLRA & & ; delay arbitrary for display ON time \\
\hline & SKT & & \\
\hline
\end{tabular}
```

JP WAIT
LBI 0,10 ; increment display pointer
LD
AISC 1
JP DSP2
JP DISPLAY ; have outputted MSD, start over
DSP2:
X
LD
CAB
JP DSPI

```

This routine is completely equivalent to the preceding routine but does not have a subroutine call. Both routines use the following BCD to seven-segment code conversion table:
```

.=0140 ; set up table location - address
.WORD 03F ; 0
.WORD 006 ; 1
.WORD 05B ; 2
.WORD 04F ; 3
.WORD 066 ; 4
.WORD 06D ; 5
.WORD O7D ; 6
.WORD 007 ; 7
.WORD 07F ; 8
.WORD 067 ; 9

```

Both routines assume that the \(L\) drivers are off and that the digit strobes are high on entry to the routine. Some display types do not require both digit and segment blanking. If this is the case, the routines can be shortened by removing the unnecessary blanking code. Note that the routines do not alter the BCD data. Remember, also, that the LQID instruction uses a subroutine level on some COPS microcontrollers. Also note that the delay time included in the routine may not be necessary for some display types. In these cases, that code may be eliminated. The delay, if required at all, may be implemented in any convenient manner.

\subsection*{5.6.2 Peripheral Display Drivers}

Several display drivers are available which are compatible with the COPS MICROWIRE and remove the burden of display control from the microcontroller to an inexpensive driver.

\section*{The COP470 and COP472}

The COP470 is a four-digit multiplexed vacuum fluorescence display driver. The device is loaded with 32 bits of segment data and controls the display directly. Updating the display merely requires loading the new data. Note that any required code conversion must be performed by the microcontroller.
The COP472 is a similar device intended for use with a multiplexed (three backplane) liquid crystal display. The COP472 is a \(41 / 2\) digit driver and can drive 36 segments of data. Again, any required code conversion must be done in the microcontroller.
Both the COP470 and COP472 may be cascaded to drive somewhat larger displays. The COP470 and COP472 are software compatible devices. Code can be written that works with either the COP470 or the COP472 either alone or cascaded. The four extra data bits in the COP472 correspond to brightness control in the COP470.
Both the COP470 and COP472 load data eight bits at a time. The format for the data is as follows:


SH for digit 1 is the first data bit shifted into the device. SA for digit four is the last data bit (i.e., 32nd data bit) shifted into the device. The segments are mapped into a standard numeric seven-segment plus decimal point display. There is, of course, no requirement that the display be configured in this manner.
The fifth and final group of eight bits sent to the device(s) is as follows:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
C 4 & C 3 & C 2 & C 1 & SP 4 & SP 3 & SP 2 & SP 1 \\
\hline
\end{tabular}

SP1 is the first data bit sent in this group, C4 is the last bit sent.
The COP470 and COP472 display drivers may be "cascaded" to provide more digits and "stacked" to provide more segments per digit. Both the COP472 and COP470 are code compatible devices even when they are used in expanded form.

Single COP470, COP472 Control Bits:
The control bits for the COP470 and COP472 are listed below in Table VII. These control bits were positioned to allow for common software operations.
The COP470 also contains four bits of intensity information which is in the same bit locations corresponding to the four special segments of the COP472. In code compatible routines, the four special segments of the LCD display will reflect the intensity information of the COP470. The control bits that enable code compatible operation with four-digit displays are given in Table VII.

TABLE VII. Control Bits
C4 C3 C2 C1
SP4 SP3 SP2 SP1
INTENSITY INFORMATION
COP470
CONTROL

\begin{tabular}{l|l|c} 
COP472 & COP470 & CONTROL BIT \\
\hline SYNC & SYNC & 0 \\
Q7 & OSC & 0 \\
Q6 & RT & 1 \\
X & LT & 1
\end{tabular}

\section*{Eight Digit}

COP470 and COP472 devices are cascadable to obtain more digits of display. The control codes for a multiple device display driver configuration are listed in Table VIII.

TABLE VIII. Control Codes
\begin{tabular}{|c|c|c|c|c|}
\hline \multicolumn{2}{|c|}{} & \multicolumn{3}{|c|}{ Control Codes } \\
\hline COP472 & COP470 & \begin{tabular}{c} 
Initiallze \\
(Both Devices)
\end{tabular} & \begin{tabular}{c} 
Master \\
(Left Device)
\end{tabular} & \begin{tabular}{c} 
Slave \\
(Right Device)
\end{tabular} \\
\hline Sync & Sync & 1 & 0 & 0 \\
07 & Osc & 1 & 0 & 1 \\
06 & RT & 1 & 0 & 1 \\
X & LF & 0 & 1 & 0 \\
\hline
\end{tabular}

The sequence of operations to load a single COP470 or COP472 is as follows:
1. Turn \(\overline{\mathrm{CS}}\) low.
2. Clock in eight bits of data for digit 1.
3. Clock in eight bits of data for digit 2.
4. Clock in eight bits of data for digit 3.
5. Clock in eight bits of data for digit 4.
6. Clock in eight bits of data for special segments/brightness and the control function.
\[
\begin{array}{lllllllll}
0 & 0 & 1 & 1 & S P 4 & S P 3 & S P 2 & S P 1
\end{array}
\]

\section*{7. Turn \(\overline{C S}\) high.}
\(\overline{\mathrm{CS}}\) may be turned high after any step. It is not necessary to continuously reload the control bits but they must be loaded at least once. If the special segments or brightness bits are changed, the control bits must be reloaded.
\(\overline{\mathrm{CS}}\) must toggle between writes. \(\overline{\mathrm{CS}}\) is the state that resets the internal counters in the device which controls data loading.
Typical code to write a single COP470 or COP472 is shown below. The look-up table is not shown but is obviously required. The routine is written as in-line code. It does the code conversion and writes to the display driver. The original values are destroyed in the operation. DO is arbitrarily chosen as a chip select for the device. Note that chip select is an essential connection for these devices. Chip select must toggle between accesses for proper operation. The data to be displayed is in locations 0,12 through 0,15 . The special segments or brightness bits are in location 0,0 .

DISPLAY: LBI 0,12 ; point to first display data
OBD ; turn \(\overline{\mathrm{CS}}\) low (DO) to select drive
LOOP: CLRA
LQID ; look up segment data
CQMA ; copy data from Q to M \& A
SC ; set \(C\) to turn on SK
XAS ; output lower four bits of data
NOP ; delay
NOP ; delay
LD ; load A with upper four bits
XAS ; output four bits of data
NOP ; delay
NOP ; delay
RC ; reset C
XAS ; turn off SK clock
XIS ; increment \(B\) for next data
JP LOOP ; skip this jump after last digit
SC ; set C
LBI 0,0 ; address special segments or brightness
LD ; load into A
XAS ; output special segments or brightness
NOP
CLRA
AISC 12 ; 12 to A=code for single chip operation

LBI 0,15 ; 15 to \(B\) to deselect the device
RC reset C
XAS ; turn off SK
OBD ; turn \(\overline{\mathrm{CS}}\) high (DO)

This code works with either the COP470 or COP472.
The sequence to drive two COP470s or COP472s in an eight-digit display is outlined below. There is an initialization procedure required in order to set up the two devices properly. The control bits are different during the initialization sequence than they are during subsequent data loads. For the COP472s, this sequence sets up the left chip as the master and the right chip as the slave. For the COP470s, the left chip provides the oscillator for the right chip. The sequence is as follows:
1. Turn \(\overline{C S}\) low to both devices.
2. Shift in 32 bits of data-slave's four digits for COP472, right four digits for COP470.
3. Shift in four bits of special segment/brightness data, a zero and three ones.


This synchronizes and stops both chips. Both chips are expecting an external oscillator.
4. Turn \(\overline{\mathrm{CS}}\) high to both chips.
5. Turn \(\overline{\mathrm{CS}}\) low to left device-(master COP472, left COP470).
6. Shift in 32 bits of data for that device.
7. Shift in four bits of special segment/brightness data, a one and three zeroes.


This set this device to internal oscillator and provides an oscillator output to the other device.
8. Turn CShigh.

The chips are now synchronized and driving eight digits of display. New data is loaded in the normal manner. Care must be taken to keep the control bits in the proper state. For the master COP472 or left COP470, the control bits specified in Step 7 are the proper state. For the slave COP472 or right COP470, the following must be sent in every case except the initialization sequence:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
0 & 1 & 1 & 0 & SP 4 & SSP 3 & SP 2 & SP 1 \\
\hline
\end{tabular}

Figure 5-28 provides system diagrams for the dual COP470/COP472 systems.


FIGURE 5-28. Dual COP470/472 Systems
Typical code to write to the devices in this way is shown below. The display data for the slave (right) device is in register 0 , digits 12 through 15. The display data for the master (left) device is in register 1, digits 12 through 15. Digit 0,0 contains special segment/brightness data for the slave. Digit 1,0 contains special segment/brightness data for the master. DO is used as the chip select for the master; D1 is the chip select for the slave. The code is again shown as in-line code.
Display Initialization Sequence:
\begin{tabular}{|c|c|c|c|}
\hline INIT : & LBI & 0,15 & \\
\hline & OBD & & ; turn both \(\overline{\text { CS }}\) high \\
\hline & LEI & 8 & ; enable SO out of S.R. \\
\hline & RC & & \\
\hline & XAS & & ; turn off SK clock \\
\hline & LBI & 3,15 & ; use \(M(3,15)\) for control bits \\
\hline & STII & 7 & ; store 7 to sync both chips \\
\hline & LBI & 0,12 & ; set B to turn both CSs low \\
\hline & JSR & OUT & ; call output subroutine \\
\hline
\end{tabular}

Main Display Sequence:
\begin{tabular}{llll} 
DISPLAY: & LBI & 3,15 & \\
STII & 8 & ; set control bits for slave right devices \\
LBI & 0,13 & ; set B to turn slave \(\overline{C S}\) low \\
JSR & \(0 U T\) & ; output data from register 0 \\
LBI & 3,15 & \\
STII 6 & ; set control bits for master left device \\
LBI & 1,14 & ; set B to turn master \(\overline{C S}\) low \\
JSR \(0 U T\) & ; output data from register 1
\end{tabular}

Output Subroutine:
```

OUT: OBD ; output B to \overline{CS}
CLRA
AISC 12 ; 12 to A
CAB ; point to display digit ( }\textrm{BD}=12

```
```

LOOP: CLRA
LQID ; look up segment data
CQMA ; copy data from Q to M\&A
SC
XAS ; output lower four bits of data
NOP ; delay
NOP ; delay
LD ; load A with upper four bits
XAS ; output four bits of data
NOP ; delay
NOP ; delay
RC ; reset C
XAS ; turn off SK
XIS ; increment B for next display digit
JP LOOP ; skip this jump after last digit
SC ; set C
NOP
LD
XAS
NOP
LBI 3,15
LD ; load A
XAS ; output control bits
NOP
NOP
RC
XAS ; turn off SK
OBD ; turn \overline{CSs high (BD=15)}
RET

```

The MM54XX and MM58XXX Series Display Drivers
The MM54XX and MM58XXX series drives are a family of status display drivers for vacuum fluorescent, liquid crystal, and LFD displays. All of these devices require a start bit and 35 data bits. All the devices are MICROWIRE compatible. Table IX indicates the present devices that comprise the MM54XX and MM58XXX series. The code here is applicable to all similar type devices. The MM54XX and MM58XXX devices are static segment drivers and must be loaded with the appropriate segment information.

TABLE IX. MM54XX Series Devices
\begin{tabular}{|l|}
\hline MM58241 - Static Vacuum Fluorescent \\
MM58242 - Static Vacuum Fluorescent \\
MM58248 - Static Vacuum Fluorescent \\
MM58341 - Static Vacuum Fluorescent \\
MM58342 - Static Vacuum Fluorescent \\
MM58348 - Static Vacuum Fluorescent \\
MM5450 - Static LED \\
MM5451 - Static LED \\
MM5452 - Static Liquid Crystal \\
MM5453 - Static Liquid Crystal \\
MM5480 - Static LED (Smaller Package) \\
MM5481 - Static LED (Smaller Package) \\
\hline
\end{tabular}

Two basic output techniques can be used. The first approach is the same as that illustrated for the COP470 and COP472: turn the clock on and off and convert the number on the fly. This example will use G0 as the data enable control: G0 must go low to enable the device. The routine assumes GO high, SO low, and SK low on entry. The look-up table is not shown.
```

DISPLAY: CLRA ; set up start bit
AISC 1
SC
DGI }14\mathrm{ ; select the device
XAS ; turn on clock and send start bit
RC
CLRA
NOP
XAS ; turn off the clock
LBI 0,7 ; point to start of data

```
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{19}{*}{LOOP:} & \multicolumn{2}{|l|}{CLRA} & \multirow[t]{3}{*}{; set up table address} \\
\hline & LQID & & \\
\hline & CQMA & & \\
\hline & SC & & ; send eight data bits \\
\hline & XAS & & \\
\hline & NOP & & \\
\hline & NOP & & \\
\hline & LD & & \\
\hline & XAS & & \\
\hline & NOP & & \\
\hline & CLRA & . & \\
\hline & RC & & \\
\hline & XAS & & \\
\hline & LD & & \\
\hline & XIS & & \\
\hline & JP & LOOP & \\
\hline & OGI & 15 & ; deselect the device \\
\hline & LEI & 0 & ; turn S0 low \\
\hline & RET & & \\
\hline
\end{tabular}

The other approach is to load a display buffer with the segment data and then simply send all the information out in one burst of data. This technique can also be used with the COP470 and COP472. The following routine implements this procedure. Again, the table is not shown, and GO is the data enable. The display output is the BCD number contained in locations 2,12 through 2,15 . Register 0 will be used as the display output register. The segmented data will be placed in digits 0,7 through 0,15 . Digit 0,15 will be loaded with 0 s to fill out the required 35 data bits. The code is as follows:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{25}{*}{DISPLAY:} & LBI & 2,12 & ; convert data to segment information \\
\hline & CLRA & & ; set up table address \\
\hline & LQID & & \\
\hline & LBI & 0,7 & ; save segments in register 0 \\
\hline & JSRP & INQ & \\
\hline & LBI & 2,13 & \\
\hline & LQID & & \\
\hline & LBI & 0,9 & \\
\hline & JSRP & INQ & \\
\hline & LBI & 2,14 & \\
\hline & LQID & & \\
\hline & LBI & 0,11 & \\
\hline & JSRP & INQ & \\
\hline & LBI & 2,15 & \\
\hline & LQID & & \\
\hline & LBI & 0,13 & \\
\hline & JSRP & INQ & \\
\hline & STII & 0 & ; load Os to 0,15 \\
\hline & LBI & 0,7 & ; point to first segment data \\
\hline & SC & & ; set C to turn on clock \\
\hline & AISC & 1 & ; set up start bit \\
\hline & LEI & 8 & ; enable shift register output \\
\hline & XAS & & ; send start bit \\
\hline & JSR & DATOUT & \\
\hline & RET & & \\
\hline
\end{tabular}

The following subroutines are used:
INQ: \begin{tabular}{llll} 
CQMA & DATOUT: & LD & \\
\\
& XIS & XAS & \\
\\
& XIS & XIS & \\
& CLRA & JP & DATOUT \\
& RET & RC & \\
& & XAS & \\
& & RET & \\
& & & \\
& & &
\end{tabular}

\section*{Universal Display Loading Routine}

\section*{Theory of Operation}

The universal display driver loading routine both initializes and sends 32 data bits to the display drivers. In those devices with more than 32 data bits, the extra segments are not used. The routine is compatible with the COP470, COP472, MM54XX and MM58XXX series devices.
Associated with the COP470/COP472, MM54XX and MM58XXX series are two communication protocols. The COP470 and the COP472 accept data in blocks of eight bits and require an initialization procedure. The MM54XX and MM58XXX series requires a start bit and a block of 35 bits before data is latched in the output buffers. There exists a common block of 32 data bits between all these devices (less are bonded out on the MM5480 and MM5481) and this similarity makes it possible to create universal display load routine. The control bits for the COP470 and the COP472 are sent once upon initialization, and the start bit for the MM54XX and MM58XXX series is sent on the tail end of the data load routine every time it is called.
The COP470 and COP472 have a chip select which, upon a high to low transition, clears the input register and the internal counters which route the data and control bits to their ultimate positions. (See COP470, COP472 block diagrams.) Each of these devices accepts a serial data pattern and latches that serial stream in blocks of eight. For example, once initialized, the first digit may be changed, without affecting the other digits, by chip selecting and sending eight data bits. Data streams of less than eight bits, between chip selects or after a block of eight bits has been accepted, will be ignored. The initialization routine for the COP470 and COP472, which sends 44 bits, makes use of this type of operation; the last four bits are ignored.
The MM54XX and MM58XXX series displays, unlike the COP470 and COP472, have a data enable. This input to the device does not reset any counter and functions only as a data enable. This is to say that information contained within the display buffers and the input counter are not affected by the data enable signal. It is for this reason that the start bit for MM54XX and MM58XXX series devices is sent out at the tail end of each data output routine. Initially, the MM54XX and MM58XXX devices must be cleared and this is accomplished by clocking in more than 35 zeroes. In normal operation, the MM54XX and MM58XXX type devices are automatically cleared at power up due to SIO port power up state; SK as clock and SO as a logical zero, lasting much more than 36 cycles. In the universal display routine, the MM54XX and MM58XXX series devices will contain the COP470 and COP472 control codes along with a start bit in the first position. This must be cleared out by sending 35 zeroes and a new start bit. This will clock in 32 zeroes to the COP470 and COP472, and again the last four bits will be ignored in the COPS display drivers.
Now both display device types are initialized and data may be sent out in 36 bit blocks, first 32 data, next three zeroes, and the last bit a start bit. The first 32 segment outputs of the COP472 and MM54XX and MM58XXX series devices will correspond to the COP470s segment outputs.

\subsection*{5.7 KEYBOARD SCAN}

Reading a keyboard is a common requirement. The following routine is representative of a keyboard scan routine. The four D lines provide the strobes for the keyboard. The IN lines are the keyboard return lines. Thus, this routine is structured to read a 16 -key keyboard arranged in a 4 by 4 matrix. A key is detected when one of the IN lines goes low. The strobes, D lines, are normally high and go low to strobe the keyboard. Figure \(5-29\) is the flow chart for this routine. Figure 5-30 is the interconnect. This routine uses two RAM digits: digit 0,15 for a debounce counter and digit 0,14 for temporary storage. The routine debounces the keys up and down.


FIGURE 5-29. Keyboard Scan Flow Chart


FIGURE 5-30. Interconnect for Key Scan Routine


This is a simple keyboard routine. It is a variation on the routine provided in Section 5.3 of the COPS Family User's Guide. The routine continues to scan until a key is detected and fully debounced.

\section*{Appendix A}

\section*{Data RAM in COP410L/411L/413L and COP410C/411C Devices}

\section*{A. 1 DATA RAM DESCRIPTION}

All COPS microcontrollers except the COP410L, COP411L, COP410C, and COP411C have the data RAM matrix organized as a number of registers by 16 digits. The COP410C series devices mentioned above have the data RAM organized as 4 registers by 8 digits. This is significant because the Bd portion of the RAM address register B is still four bits wide. The D output port is still a four-bit port and it is loaded by Bd as in all COPS microcontrollers.
Physically, only the lower three bits of Bd address the digit portion of RAM. The upper bit is not connected to the RAM in any way. However, the XIS and XDS instructions work on the entire Bd register. The skip conditions on these instructions is the same as always. Bd will increment from 0 to 15. Thus each RAM digit in a COP410 series device is addressed by two values of Bd. Because of this characteristic, the programmer must exercise some care in the implementation of any routine which increments or decrements through the register, e.g., shift routines. The standard digit shift routines provided earlier could actually shift a COP410 register right or left two digits if the programmer started at one end of the register and relied on the XIS or XDS skip to exit the routine. The two shift routines provided below provide one method of circumventing the problem.
\begin{tabular}{|c|c|c|c|c|}
\hline & LBI & 0,9 & LBI & 0,9 \\
\hline & LD & & LD & \\
\hline & XDS & & XDS & \\
\hline & LD & & LD & \\
\hline LSHIFT: & XIS & RSHIFT & XDS & \\
\hline & JP & LSHIFT & JP & RSHIFT \\
\hline & RET & & RET & \\
\hline
\end{tabular}

As written, these routines will shift register 0 left or right one digit. Figure A-1 below illustrates the RAM mapping in COP410 series devices.


FIGURE A-1. RAM Mapping
*Can be directly addressed by LBI instruction.

\section*{Appendix B}

\section*{Devices with Subroutine Stack in RAM}

\section*{B. 1 SUBROUTINE STACK IN RAM DESCRIPTION AND LOCATION}

As mentioned earlier, a number of COPS microcontrollers have the subroutine stack in data RAM. In these devices the stack is assigned a specific location and does not, under any circumstances, go outside of the assigned area. It is not possible for the programmer to overflow the stack and destroy some data, although it is quite possible to overflow the stack. The only information lost if the stack overflows is some previous return address. The devices which have the stack in RAM and the location of the stack in the RAM is indicated below.
\begin{tabular}{|c|c|}
\hline Device & Location \\
\hline \begin{tabular}{l} 
COP440/441/442 \\
COP404
\end{tabular} & Stack in register 8 \\
\hline
\end{tabular}

Note that the registers are numbered starting at 0 . The register number is the Br address.
Figure \(B-1\) is the strucrture for the stack in RAM. This organization is valid for all the devices with the subroutine stack in data RAM.

\(-\infty \quad \square \quad \square\)

Section 5
HPC Family

\section*{Section 5 Contents}
HPC Introduction ..... 5-3
HPC16040/HPC26040/HPC36040/HPC46040/HPC16030/HPC36030/HPC46030 High Performance Microcontroller ..... 5-4
HPC16083/HPC26083/HPC36083/HPC46083/HPC16073/HPC36073/HPC46073 High Performance Microcontrollers with Input Capture Registers ..... 5-29
HPC16400/HPC36400/HPC46400 Telecom Microcontroller ..... 5-30
HPC16740/HPC36740/HPC46740/HPC16730/HPC36730/HPC46730 High Performance Microcontroller with Gate Array ..... 5-50
HPC16900 Port Expansion and Recreation Logic ..... 5-51

\section*{The HPC Family}

National offers the first 16-bit CMOS High Performance microController (HPC). The HPC family brings innovative solutions to the problem of making a single microcontroller family satisfy the demands of the highest performance in a wide range of end-user products.
And because the controllers are members of the same family, the user learns only one architecture, one programming language and maintains only one development system to produce products in a wide spectrum of applications.
With this 16 -bit architecture implemented in microCMOS, the HPC is the highest speed microcontroller available and capable of operating at speeds beyond 17 MHz -with execution times of less than 240 nanoseconds. The HPC tackles products applications previously considered out of the range of any microcontroller. The HPC is designed for highthroughput computation. Its powerful "RISC-like" instruction set includes a 16 -bit multiply and divide, single-byte jumps and calls, nine addressing modes, and versatile bit manipulation instructions.
Backing up this number-crunching power is a large set of on-board peripherals. This integration means that systems using the HPC will require fewer components, will be more reliable, and will be easier to test.
Designed with National's latest and scaleable VLSI microCMOS technology, the HPC will be an ever expanding family. With this microCMOS technology and the modularity of the core design allows for expansion in ROM, RAM and I/O. The latter includes on-board EEPROM and A/D as well as logic intensive functions and customer specific gate arrays. And because the HPC is a microCMOS device, it uses very little power, and will operate over a wide range of supply voltages and over a wide range of temperatures. With the low power dissipation of CMOS also comes higher reliability.
CORE: The foundation of all HPC family members is a common CPU or "core". This Von Neumann-architecture core consists of an arithmetic logic unit (ALU), six 16 -bit working registers, eight interrupts, three 16-bit timers, control logic, watch-dog circuitry and a MICROWIRE/PLUSTM interface.
The six CPU registers (accumulator, program counter, stack pointer, two indirect address registers and the unique program looping register, K), the internal data paths and the ALU are all 16 -bits wide. This allows direct addressing that simplifies interfacing to external hosts, memory, or peripherals. Presently the core allows for 64 K direct addressing.
For more responsive and flexible system control every HPC controller has been provided with eight independently-vectored interrupts. There are five external interrupts: a reset interrupt, a non-maskable interrupt and three general purpose maskable interrupts. In addition, there are three internal interrupts: one for the timers and two for on-board peripherals.
An interrupt pending register allows the programmer to determine the priorities of these interrupts in software.

EFFICIENT INSTRUCTION SET: The HPC instruction set has been designed for maximum code efficiency since on chip memory allocated to the program, in single-chip systems, is always at a premium.
The instruction set features a wide variety of single-byte multi-function instructions with nine addressing modes for complete flexibility. Running at 17 MHz , single-byte instructions execute in only 240 ns and 16 -bit multiply or divide takes just \(7 \mu \mathrm{~s}\). To accomplish the same task, benchmarks show that programs will require roughly half the memory used by other 16 -bit or high-end 8 -bit microcontrollers.
MEMORY: All memory, I/O, on-board peripherals and registers are memory-mapped into the controller's present 64 k address space. This allows great flexibility in the control of data and makes it possible for program code to be executed from RAM as well as ROM. Program patches or board diagnostics can be quickly added or changed in RAM at any time. To accommodate nesting even for the most complicated subroutine, stack depth and location are defined by the programmer. Bit manipulation instructions are effective anywhere in memory including the registers and I/O. To make interfacing to the outside world even easier, the external data bus can be configured for either 8 - or 16-bit operation. The size of the on-board ROM varies for current family members from 0 to 8 k bytes. Memory can be accessed in bytes or 16 -bit words. The modularity of the HPC will allow future members of the family to have significantly different memory sizes as the target application requires it.
TIMERS: All members of the HPC family have at least three 16-bit timers as part of the "core", each timer with:
- external event counting - input capture

MICROWIRE/PLUS Serial, Interface: MICROWIRE/PLUS is an enhancement of National's proven MICROWIRETM three-wire serial interface and is being included on all new National controllers. This synchronous interface serially handles data by using an 8-bit, parallel-loaded shift register with separate input, output and synchronous clock. It allows the HPC to take advantage of the wide variety MICROWIRE peripherals now offered by National and other manufacturers, such as A/D converters, EEPROMs, display drivers, etc., and can be used for multiprocessing between 4, 8 and 16 Microcontrollers.
LOW-POWER OPERATION: Because the HPC utilized microCMOS technology it consumes very little power. Even at full speed ( 17 MHz ) the HPC draws less than 20 mA . To further reduce power, the device can be operated at lower speeds and/or lower voltage.
For even more stringent power conservation, the HPC has two power-down modes: IDLE and HALT. Resulting power is as low as 125 microwatts.
DEVELOPMENT SUPPORT: National offers complete development system support for the HPC. See section 8 for a complete description of the hardware and software tools.

\section*{HPC16040/HPC26040/HPC36040/HPC46040/HPC16030/ HPC36030/HPC46030 High-Performance Microcontrollers}

\section*{General Description}

The HPC16040 is a member of the HPCTM family of High Performance microControllers. Each member of the family has the same identical core CPU with a unique memory and 1/O configuration to suit specific applications. Each part is fabricated in National's advanced microCMOS technology. This process combined with an advanced architecture provides fast, flexible I/O control, efficient data manipulation, and high speed computation.
The HPC16040 is a complete microcomputer on a single chip. All system timing, internal logic, ROM, RAM, and I/O are provided on the chip to produce a cost effective solution for high performance applications. On-chip functions such as UART, eight 16 -bit timers, vectored interrupts, WATCHDOGTM logic and MICROWIRE/PLUSTM provide a high level of system integration. The ability to address up to 64 k bytes of external memory enables the HPC16040 to be used in powerful applications typically performed by microprocessors and expensive peripheral chips.
The microCMOS process results in very low current drain and enables the user to select the optimum speed/power product for his system. The IDLE and HALT modes provide further current savings. The HPC16040 is available in 68-pin PCC, LCC and PGA packages.

\section*{Features}
- HPC family-core features:
- 16-bit architecture, both byte and word
-16 -bit data bus, ALU, and registers
- 64k bytes of external memory addressing
- FAST!-240 ns for register instructions when using 17.0 MHz clock
- High code efficiency-most instructions are single byte
\(-16 \times 16\) multiply and \(32 \times 16\) divide
- Eight vectored interrupt sources
- Four 16-bit timer/counters with 3 input capture registers and 4 synchronous outputs
- WATCHDOG logic monitors processor
- MICROWIRE/PLUS serial I/O interface
- CMOS-very low power with two power save modes: IDLE and HALT (2 mA, \(250 \mu A\)-typ.)
- UART-full duplex, programmable baud rate
- Four additional 16 -bit timer/counters with pulse width modulated outputs
E 52 general purpose I/O lines (memory mapped)
- 4k bytes of ROM, 256 bytes of RAM on chip

■ ROMless versions available
- Wide voltage supply range: 3 V to 5.5 V
- Industrial \(\left(-40^{\circ} \mathrm{C}\right.\) to \(\left.+85^{\circ} \mathrm{C}\right)\) and military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(+125^{\circ} \mathrm{C}\) ) temperature ranges

\section*{Block Diagram}


\section*{Absolute Maximum Ratings}

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliabillty electrical test speclfications document.
\(\begin{array}{lr}\text { Total Allowable Source or Sink Current } & 100 \mathrm{~mA} \\ \text { Storage Temperature Range } & -65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C} \\ \text { Lead Temperature (Soldering, } 10 \mathrm{sec} \text { ) } & 300^{\circ} \mathrm{C}\end{array}\)
\(V_{\text {CC }}\) with Respect to GND
-0.5 V to 7.0 V All Other Pins \(\left(\mathrm{V}_{\mathrm{CC}}+0.5\right) \mathrm{V}\) to \((\mathrm{GND}-0.5) \mathrm{V}\) Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics \(\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 10 \%\) unless otherwise specified, \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) for
HPC \(46040,-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) for HPC36040, \(-40^{\circ} \mathrm{C}\) to \(+105^{\circ} \mathrm{C}\) for HPC26040, \(-55^{\circ} \mathrm{C}\) to \(+125^{\circ} \mathrm{C}\) for HPC16040
\begin{tabular}{l|l|l|c|c|c|c}
\hline yymbol & \multicolumn{1}{|c|}{ Parameter } & \multicolumn{1}{|c|}{ Test Conditlons } & Min & Typ & Max & Units \\
\hline \(\mathrm{CC}_{1}\) & \multirow{2}{*}{ Supply Current } & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\mathrm{in}}=17.0 \mathrm{MHz}\) & & 20 & & mA \\
\cline { 3 - 6 } & & \(\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\mathrm{in}}=2.0 \mathrm{MHz}\) & & 2.4 & & mA \\
\hline \(\mathrm{CC}_{2}\) & IDLE Mode Current & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\mathrm{in}}=17.0 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}^{*}\) & & 2 & & mA \\
\cline { 3 - 6 } & & \(\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\mathrm{in}}=2.0 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) & & 0.2 & & mA \\
\hline \(\mathrm{CC}_{3}\) & \multirow{2}{*}{ HALT Mode Current } & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\mathrm{in}}=0 \mathrm{kHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}^{*}\) & & 250 & & \(\mu \mathrm{~A}\) \\
\cline { 3 - 6 } & & \(\mathrm{~V}_{\mathrm{CC}}=2.5 \mathrm{~V}, \mathrm{f}_{\mathrm{in}}=0 \mathrm{kHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) & & 150 & \(\mu \mathrm{~A}\) \\
\hline
\end{tabular}

INPUT VOLTAGE LEVELS RESET, NMI, CKI AND WO (SCHMITT TRIGGERED)
\begin{tabular}{l|l|l|l|l|l|c}
\hline \(\mathrm{V}_{\mathrm{IH}_{1}}\) & Logic High & & \(0.9 \mathrm{~V}_{\mathrm{CC}}\) & & & V \\
\hline \(\mathrm{V}_{\mathrm{IL}_{1}}\) & Logic Low & & & & \(0.1 \mathrm{~V}_{\mathrm{CC}}\) & V \\
\hline
\end{tabular}

\section*{ALL OTHER INPUTS}
\begin{tabular}{l|l|l|c|c|c|c}
\hline \(\mathrm{V}_{\mathrm{IH}_{2}}\) & Logic High & & \(0.7 \mathrm{~V}_{\mathrm{CC}}\) & & & V \\
\hline \(\mathrm{V}_{\mathrm{IL}_{2}}\) & Logic Low & & & & \(0.2 \mathrm{~V}_{\mathrm{CC}}\) & V \\
\hline \(\mathrm{I}_{\mathrm{LI}}\) & Input Leakage Current & & & & \(\pm 1\) & \(\mu \mathrm{~A}\) \\
\hline \(\mathrm{C}_{\mathrm{I}}\) & Input Capacitance & & & 10 & & pF \\
\hline \(\mathrm{C}_{\mathrm{IO}}\) & I/O Capacitance & & & 20 & & pF \\
\hline
\end{tabular}

OUTPUT VOLTAGE LEVELS CMOS OPERATION
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \(\mathrm{VOH}_{1}\) & Logic High & \(\mathrm{l}_{\mathrm{OH}}=-10 \mu \mathrm{~A}\) & \(V_{C C}-0.1\) & & & V \\
\hline \(\mathrm{V}_{\mathrm{OL}_{1}}\) & Logic Low & \(\mathrm{I}_{\mathrm{OH}}=10 \mu \mathrm{~A}\) & & & 0.1 & V \\
\hline \(\mathrm{VOH}_{2}\) & \multirow[t]{2}{*}{Port A/B Drive, CK2
\[
\left(A_{0}-A_{15}, B_{10}, B_{11}, B_{12}, B_{15}\right)
\]} & \(\mathrm{I}_{\mathrm{OH}}=-7 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) & 2.4 & & & V \\
\hline \(\mathrm{VOL}_{2}\) & & \(\mathrm{I}_{\mathrm{OL}}=3 \mathrm{~mA}\) & & & 0.4 & V \\
\hline \(\mathrm{VOH}_{3}\) & \multirow[t]{2}{*}{Other Port Pin Drive, WO (open drain) ( \(\left.\mathrm{B}_{0}-\mathrm{B}_{9}, \mathrm{~B}_{13}, \mathrm{~B}_{14}, \mathrm{P}_{0}-\mathrm{P}_{3}\right)\)} & \(\mathrm{l}_{\mathrm{OH}}=-1.6 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) & 2.4 & & & V \\
\hline \(\mathrm{VOL}_{3}\) & & \(\mathrm{l}_{\mathrm{OL}}=0.5 \mathrm{~mA}\) & & & 0.4 & V \\
\hline \(\mathrm{V}_{\mathrm{OH} 4}\) & \multirow[t]{2}{*}{ST1 and ST2 Drive} & \(\mathrm{IOH}=-6 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) & 2.4 & & & V \\
\hline \(\mathrm{VOL}_{4}\) & & \(\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}\) & & & 0.4 & V \\
\hline \(\mathrm{V}_{\text {RAM }}\) & RAM Keep-Alive Voltage & & & 2.5 & & V \\
\hline loz & TRI-STATE Leakage Current & & & \(\pm 5\) & & \(\mu \mathrm{A}\) \\
\hline
\end{tabular}
"Note: \(\mathrm{I}_{\mathrm{CC}_{1}}, \mathrm{ICC}_{2}, \mathrm{I}_{\mathrm{CC}_{3}}\) measured with no external drive ( \(\mathrm{IOH}_{\mathrm{OH}}\) and \(\mathrm{I}_{\mathrm{OL}}=0, \mathrm{I}_{\mathrm{IH}}\) and \(\mathrm{I}_{\mathrm{IL}}=0\) ).

\section*{AC Electrical Characteristics}
\(V_{C C}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{f}_{\mathrm{C}}=17.0 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) for HPC46040, \(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) for HPC36040
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \(\mathrm{f}_{\mathrm{C}}=\) CKI freq. & Operating Frequency & 2 & & 17.0 & MHz \\
\hline \(\mathrm{t}_{\mathrm{C} 1}=1 / \mathrm{f}_{\mathrm{C}}\) & Clock Period & 59 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{C}}=2 / \mathrm{f}_{\mathrm{C}}\) & Timing Cycle & 118 & 120 & & ns \\
\hline \(t_{L L}=1 / 2 t_{C}-9\) & ALE Pulse Width & 50 & 60 & & ns \\
\hline \(\mathrm{t}_{\text {ST }}=1 / 4 \mathrm{t}_{\mathrm{C}}-6\) & Address Valid to ALE Trailing Edge & 23 & 30 & & ns \\
\hline \(t_{\text {WAIT }}=t_{C}=W S\) & Wait State Period & 118 & 120 & & ns \\
\hline \[
f_{\mathrm{XIN}}=\frac{1}{19 \mathrm{t}_{\mathrm{C} 1}}
\] & External Timer Input Frequency & & 877 & & kHz \\
\hline \(t_{\text {XIN }}=3 t_{\text {C1 }}\) & Pulse Width for Timer Inputs & & 180 & & ns \\
\hline \[
f_{\text {XOUT }}=\frac{1}{16 \mathrm{t}_{\mathrm{Ct}}}
\] & Timer Output Frequency & & 1.04 & & MHz \\
\hline \[
f_{M W}=\frac{1}{19 \mathrm{t}_{\mathrm{C} 1}}
\] & External MICROWIRE/PLUS Clock Input Frequency & & 877 & & kHz \\
\hline \[
f_{U}=\frac{1}{19 \mathrm{t}_{\mathrm{Cl}}}
\] & External UART Clock Input Frequency & & 877 & & kHz \\
\hline \(t_{\mathrm{DC}_{1}}\) & CK2 Delay from CK1 & & & 55 & ns \\
\hline
\end{tabular}

Read Cycle Timing with One Wait State
\begin{tabular}{l|l|l|l|c|c}
\hline \multicolumn{1}{c|}{ Symbol } & \multicolumn{1}{|c|}{ Parameter } & Min & Typ & Max & Units \\
\hline\(t_{\text {ARR }}=1 / 4 t_{C}-5\) & ALE Trailing Edge to \(\overline{R D}\) Falling Edge & 24 & & & ns \\
\hline\(t_{R W}=1 / 2 t_{C}+W S-10\) & \(\overline{R D}\) Pulse Width & 167 & & & ns \\
\hline\(t_{D R}=3 / 4 t_{C}-15\) & Data Hold after Rising Edge of \(\overline{R D}\) & 0 & & 75 & ns \\
\hline\(t_{A C C}=t_{C}+W S-55\) & Address Valid to Input Data Valid & & & 181 & ns \\
\hline\(t_{R D}=1 / 2 t_{C}+W S-65\) & \(\overline{R D}\) Falling Edge to Data in Valid & & & 112 & ns \\
\hline\(t_{R D A}=t_{C}-5\) & \(\overline{R D}\) Rising Edge to Address Valid & 111 & & & ns \\
\hline\(t_{V P R}=1 / 4 t_{C}-5\) & \begin{tabular}{l} 
Address Valid from ALE \\
Trailing Edge Prior to \(\overline{R D}\)
\end{tabular} & 24 & 35 & & ns \\
\hline
\end{tabular}

\section*{Write Cycle Timing with One Wait State}
\begin{tabular}{c|l|c|c|c|c}
\hline \multicolumn{1}{c|}{ Symbol } & \multicolumn{1}{|c|}{ Parameter } & Min & Typ & Max & Units \\
\hline\(t_{\text {ARW }}=1 / 2 t_{C}-5\) & \begin{tabular}{l} 
ALE Trailing Edge to \\
WR Falling Edge
\end{tabular} & 54 & & ns \\
\hline\(t_{W W}=3 / 4 t_{c}+W S-15\) & WR Pulse Width & 192 & & ns \\
\hline\(t_{H W}=1 / 4 t_{C}-5\) & \begin{tabular}{l} 
Data Hold after \\
Trailing Edge of \(\overline{W R}\)
\end{tabular} & 24 & & ns \\
\hline \(\mathrm{t}_{\mathrm{V}}=1 / 2 \mathrm{t}_{\mathrm{C}}+W S-5\) & \begin{tabular}{l} 
Data Valid before \\
Trailing Edge of \(\overline{W R}\)
\end{tabular} & 172 & & ns \\
\hline \(\mathrm{t}_{\mathrm{VPW}}=1 / 4 \mathrm{t}_{\mathrm{C}}+20\) & \begin{tabular}{l} 
Address Valid from \\
Trailing Edge Prior to \(\overline{W R}\)
\end{tabular} & 50 & & ns \\
\hline
\end{tabular}

Note: Bus Output (Port A) \(\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}\), CK2 Output \(\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}\), other Outputs \(\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}\).

Ready/Hold Timing \(\mathrm{f}_{\mathrm{C}}=16.78 \mathrm{MHz}^{\text {with One Wait State }}\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & MIn & Typ & Max & Units \\
\hline \(t_{D A R}=1 / 4 t_{C}+W S-50\) & Falling Edge of ALE to Falling Edge of \(\overline{\text { RDY }}\) & & 100 & & ns \\
\hline \(t_{\text {RWP }}=t_{C}\) & RDY Pulse Width & & 120 & & ns \\
\hline \(t_{\text {SALE }}=1 / 4 t^{\text {c }}+40\) & Falling Edge of \(\overline{\mathrm{HLD}}\) to Rising Edge of ALE & & 70 & & ns \\
\hline \(t_{H W P}=t_{C}+10\) & HLD Pulse Width & & 130 & & ns \\
\hline \(t_{\text {HAD }}\) & Rising Edge on HLD to Rising Edge on \(\overline{\text { HLDA }}\) & & 120 & & ns \\
\hline \(t_{\text {HAE }}=\mathrm{t}_{\mathrm{C}}+100\) & Falling Edge on HLD to Falling Edge on HLDA & & 220 & * & ns \\
\hline \(t_{B F}=t_{C}+30\) & Bus Float before Falling Edge on HLDA & & 150 & & ns \\
\hline \(t_{B E}=2 t_{C}+50\) & Bus Enable from Rising Edge of HLD & & 290 & & ns \\
\hline
\end{tabular}
-Note: \(t_{\text {HAE }}\) may be as long as ( \(3 t_{\mathrm{C}}+4 \mathrm{ws}+72 \mathrm{t}_{\mathrm{C}}+90\) ) depending on which instruction is being executed, the addressing mode and number of wait states.
Status Timing \(\mathrm{f}_{\mathrm{C}}=16.78 \mathrm{MHz}\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \(\mathrm{t}_{\text {SRS2 }}=40-\left(1 / 4 \mathrm{t}_{\mathrm{C}}+25\right)\) & Setup Time for ST2 on Rising Edge of ALE & & -15 & & ns \\
\hline thRS2 \(=3 / 4 \mathrm{tc}_{\text {c }}-15\) & Hold Time for ST2 on Rising Edge of ALE & & 75 & & ns \\
\hline \(\mathrm{t}_{\text {SFS2 }}=40-\left(1 / 4 \mathrm{t}_{\mathrm{C}}+25\right)\) & \begin{tabular}{l}
Setup Time for ST2 on \\
Falling Edge of ALE
\end{tabular} & & -15 & & ns \\
\hline \(t_{\text {HFS2 }}=3 / 4 \mathrm{tc}^{\text {c }}\) - 15 & Hold Time for ST2 on Falling Edge of ALE & & 75 & & ns \\
\hline tsFSt & Setup Time for ST1 on Falling Edge of \(\overline{\mathrm{RD}}\) & & 20 & & ns \\
\hline \(\mathrm{tHRS} 1=1 / 2 \mathrm{tc}_{\mathrm{C}}-15\) & Hold Time for ST1 on Rising Edge of \(\overline{\text { RD }}\) & & 45 & & ns \\
\hline
\end{tabular}

\section*{UPI Read/Write Timing}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline tuas & Address Setup Time to Falling Edge of UPIRD & & 5 & & ns \\
\hline tuat & Address Hold Time from Rising Edge of UPIRD & & 5 & & ns \\
\hline tapw & UPIRD Pulse Width & & 100 & & ns \\
\hline toe & UPIRD Falling Edge to Data Out Valid & & 60 & & ns \\
\hline tod & End of UPIRD to Data Out Valid & & 35 & & ns \\
\hline t \({ }_{\text {drdy }}\) & RDRDY Delay from Trailing Edge of UPIRD & & 70 & & ns \\
\hline twow & UPIWR Pulse Width & & 40 & & ns \\
\hline tuds & Data in Valid before Trailing Edge of UPIWR & & 10 & & ns \\
\hline tudh & Data in Hold after Trailing Edge of UPIWR & & 15 & & ns \\
\hline \(t_{\text {A }}\) & \(\overline{\text { WRRDY }}\) Delay from Trailing Edge of UPIWR & & 70 & & ns \\
\hline
\end{tabular}

Note: Bus Output (Port A) \(C_{L}=100 \mathrm{pF}\), CK2 Output \(\mathrm{C}_{\mathrm{L}}=50 \mathrm{~F}\), other Outputs \(\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}\).

Timing Waveforms


TL/DD/8340-3
FIGURE 2. Read Cycle

Timing Waveforms (Conitued)


FIGURE 3. Ready Mode Timing


FIGURE 4. Hold Mode Timing


FIGURE 5. Status Timing

Timing Waveforms (Continued)


FIGURE 6. UPI Read Timing


TL/DD/8340-9
FIGURE 7. UPI Write TIming

\section*{Pin Descriptions}

The HPC16040 is available in 68-pin PCC and LCC packages, and a 48 -pin ceramic DIP.

\section*{I/O PORTS}

Port A is a 16 -bit bidirectional I/O port with a data direction register to enable each separate pin to be individually defined as an input or output. When accessing external memory, port A is used as the multiplexed address/data bus.
Port B is a 16 -bit port with 12 bits of bidirectional I/O similar in structure to Port A. Pins B10, B11, B12 and B15 are general purpose outputs only in this mode. Port B may also be configured via a 16 -bit function register BFUN to individually allow each pin to have an alternate function.
\begin{tabular}{lll} 
B0: & TDX & UART Data Output \\
B1: & & \\
B2: & CKX & UART Clock (Input or Output) \\
B3: & T2IO & Timer2 I/O Pin \\
B4: & T310 & Timer3 I/O Pin \\
B5: & SO & MICROWIRE/PLUS Output \\
B6: & SK & MICROWIRE/PLUS Clock (Input or Output) \\
B7: & HLDA & Hold Acknowledge Output \\
B8: & TS0 & Timer Synchronous Output \\
B9: & TS1 & Timer Synchronous Output \\
B10: & UAO & Address O Input for UPI Mode \\
B11: & WRRDY & Write Ready Output for UPI Mode \\
B12: & &
\end{tabular}
\begin{tabular}{lll} 
B13: & TS2 & Timer Synchronous Output \\
B14: & TS3 & Timer Synchronous Output \\
B15: & RDRDY & Read Ready Output for UPI Mode
\end{tabular}

When accessing external memory, four bits of port B are used as follows:
\begin{tabular}{lll} 
B10: & ALE & Address Latch Enable Output \\
B11: & \(\overline{\mathrm{WR}}\) & Write Output \\
B12: & \(\overline{\mathrm{HBE}}\) & \begin{tabular}{l} 
High Byte Enable Output/Input \\
(sampled at reset)
\end{tabular} \\
B15: & \(\overline{\mathrm{RD}}\) & \begin{tabular}{l} 
Read Output
\end{tabular}
\end{tabular}

Port I is an 8-bit input port that can be read as general purpose inputs and is also used for the following functions:
10:
11: NMI Nonmaskable Interrupt Input
12: INT2 Maskable Interrupt/Input Capture/URD
I3: INT3 Maskable Interrupt/Input Capture/UWR
14: INT4 Maskable Interrupt/Input Capture
15: SI MICROWIRE/PLUS Data Input
16: RDX UART Data Input
17:
Port \(D\) is an 8 -bit input port that can be used as general purpose digital inputs.
Port \(P\) is a 4-bit output port that can be used as general purpose data, or selected to be controlled by timers 4

\section*{Pin Descriptions (Continued)}
through 7 in order to generate frequency, duty cycle and pulse width modulated outputs.

\section*{POWER SUPPLY PINS}

VCC Positive Power Supply ( 3 V to 5.5 V )
GND Ground for On-Chip Logic
DGND Ground for Output Buffers
Note: There are two electrically connected \(\mathrm{V}_{\mathrm{CC}}\) pins on the chip, GND and DGND are electrically isolated. Both \(V_{C C}\) pins and both ground pins must be used.

\section*{CLOCK PINS}

CKI The Chip System Clock Input
CKO The Chip System Clock Output (inversion of CKI)
Pins CKI and CKO are usually connected across an external crystal.
CK2 Clock Output (CKI divided by 2)

\section*{OTHER PINS}

WO This is an active low open drain output that signals an illegal situation has been detected by the Watch Dog logic.
ST1 Bus Cycle Status Output: indicates first opcode fetch.
ST2 Bus Cycle Status Output: indicates machine states (skip, interrupt and first instruction cycle).
RESET is an active low input that forces the chip to restart and sets the ports in a TRI-STATE \({ }^{\circledR}\) mode.
RDY/HLD has two uses, selected by a software bit. It's either a READY input to extend the bus cycle for slower memories, or a HOLD request input to put the bus in a high impedance state for DMA purposes.

NC (no connection) unused at this time.
EXM External memory enable (active high) disables internal ROM and maps it to external memory.
El External interrupt with vector address FFF1:FFF0. (active high)
EXUI External interrupt which is internally OR'ed with the UART interrupt with vector address FFF3:FFF2 (Active Low).

\section*{Connection Diagrams}


Top View
Order Number HPC16040E or V See NS Package Number E68B or V68A

\section*{Ports A and B}

The highly flexible \(A\) and \(B\) ports are similarly structured. The Port A (see Figure 9), consists of a data register and a direction register. Port B (see Figure 10) has an alternate function register in addition to the data and direction registers. All the control registers are read/write registers.
The associated direction registers allow the port pins to be individually programmed as inputs or outputs. Port pins selected as inputs, are placed in a TRI-STATE mode by resetting corresponding bits in the direction register.
A write operation to a port pin configured as an input causes the value to be written into the data register, a read operation returns the value of the pin. Writing to port pins configured as outputs causes the pins to have the same value, reading the pins returns the value of the data register.
Primary and secondary functions are multiplexed onto Port \(B\) through the alternate function register (BFUN). The secondary functions are enabled by setting the corresponding bits in the BFUN register.

\section*{Operating Modes}

To offer the user a variety of 1/O and expanded memory options, the HPC16040 has four operating modes. The four modes are Single-Chip, Expanded, Single-Chip ROMless, and Expanded ROMless. The four modes are determined by the state of both the External Memory (EXM) pin and the External Access (EA) bit in the PSW Register. The HPC16040 System bus consists of port A and four bits of port \(B\). Port \(A\) is defined as the address/data bus and the four bits of port \(B\) are referred to as the control bus.

\section*{SINGLE-CHIP MODE}

In this mode, the HPC16040 functions as a self-contained microcomputer. It can address internal memory consisting of 256 bytes of RAM and 4 kbytes of ROM. All ports are configured as memory mapped I/O ports. The HPC16040 reads 8 bits or 16 bits of data from the ports, depending on whether a byte or word format instruction is used (see Figure 11). The EXM pin and EA bit of the PSW Register are both logic " 0 " during Single-Chip mode signifying that onchip ROM is being addressed and the range is limited to 4 k (see Table II).

TABLE II. Operating Modes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
External Memory \\
Pin (EXM)
\end{tabular} & \begin{tabular}{c} 
External Access \\
Bit (EA)
\end{tabular} & Operation Mode \\
\hline 0 & 0 & Single Chip \\
\hline 0 & 1 & Expanded \\
\hline 1 & 0 & Single Chip ROMless \\
\hline 1 & 1 & Expanded ROMless \\
\hline
\end{tabular}

\section*{EXPANDED MODE}

The Expanded mode (see Figures 12 and 13) is entered by setting the EA bit in the PSW Register. The HPC16040 can operate within the full 64 kbytes of address space. The 64 kbytes of addressable memory includes all on-chip memory because the EXM pin is grounded during this mode. The external memory may be any combination of RAM and ROM. External memory can be accessed with the data bus defined as either 8 bits wide or 16 bits wide. The System bus may be configured in the 8 -bit mode by pulling the \(\overline{\mathrm{HBE}}\) pin high at reset. Upon entering the expanded mode, port A


TL/DD/8340-13
FIGURE 9. Port A: I/O Structure


Operating Modes (Continued)


TL/DD/8340-33
FIGURE 10b. Structure of Port B Pins B3, B4, B8, B9, B13 and B14 (Timer Synchronous Pins)


TL/DD/8340-34
FIGURE 10c. Structure of Port B Pins B10, B11, B12 and B15 (Pins with Bus Control Roles)

\section*{Operating Modes (Continued)}
becomes the Address/Data bus. Four bits of port B become \(A L E, \overline{W R}, \overline{H B E}\) and \(\overline{R D}\) signals. The \(\overline{R D}\) and \(\overline{W R}\) signals are generated only if the selected address is off-chip. The HBE is generated only in the 16-bit bus configuration.

\section*{ROMless MODES}

There are two ROMless modes; Single-Chip ROMless and Expanded ROMless. Both ROMless modes are entered by pulling the EXM pin high, (see Figure 12 and 13). The EA bit in the PSW Register determines whether the HPC16040 addresses the Single-Chip memory range of 4 kbytes or the Expanded range of 64 kbytes, (see Table II for this information). In both ROMless modes, the HPC16040 continues to use the internal 256 bytes of RAM. The external 4 k or 64 k of addressed memory may be any combination of RAM and ROM. The address space corresponding to internal ROM is mapped into external memory.
Note: The HPC16040 uses 16-bit words for stack memory. Therefore, when using the 8-bit mode, User's Stack must be in internal RAM.


TL/DD/8340-15
FIGURE 11. Single-Chip Mode

FIGURE 12. 8-Bit External Memory

\section*{Operating Modes (Continued)}


FIGURE 13. 16-Bit External Memory

\section*{Wait States}

The HPC16040 provides four software selectable Wait States that allow access to slower memories. The Wait States are selected by the state of two bits in the PSW register. Additionally, the RDY input may be used to extend the instruction cycle, allowing the user to interface with slow memories and peripherals.

\section*{Power Save Modes}

Two power saving modes are available on the HPC16040: HALT and IDLE. In the HALT mode, all processor activities are stopped. In the IDLE mode, the on-board oscillator and timer TO are active but all other processor activities are stopped. In either mode, all on-board RAM, registers and I/O are unaffected.

\section*{HALT MODE}

The HPC16040 is placed in the HALT mode under software control by setting bits in the PSW. All processor activities, including the clock and timers, are stopped. In the HALT mode, power requirements for the HPC16040 are minimal and the applied voltage ( \(\mathrm{V}_{\mathrm{CC}}\) ) may be decreased without altering the state of the machine. There are two ways of exiting the HALT mode: via the RESET or the NMI. The RESET input reinitializes the processor. Use of the NMI input will generate a vectored interrupt and resume operation from that point with no initialization. The HALT mode can be enabled or disabled by means of a control register HALT enable. To prevent accidental use of the HALT mode the HALT enable register can be modified only once.

\section*{IDLE MODE}

The HPC16040 is placed in the IDLE mode through the PSW. In this mode, all processor activity, except the onboard oscillator and Timer TO, is stopped. External interrupt (EXUI) is shared with the UART interrupt. This interrupt is level-low sensitive. To select this interrupt disable the ERI and ETI UART interrupt bits in the ENUI register. To select the UART interrupt leave this pin floating or tie it high. As with the HALT mode, the processor is returned to full operation by the RESET or NMI inputs, but without waiting for oscillator stabilization. A timer TO overflow will also cause the HPC16040 to resume normal operation.

\section*{HPC16040 Interrupts}

Complex interrupt handling is easily accomplished by the HPC16040's vectored interrupt scheme. There are eight possible interrupt sources as shown in Table III.

TABLE III. Interrupts
\begin{tabular}{|c|c|c|}
\hline Vector Address & Interrupt Source & Arbitration Ranking \\
\hline \$FFFF:FFFE & RESET & 0 \\
\hline \$FFFD:FFFC & Nonmaskable external on rising edge of l1 pin & 1 \\
\hline \$FFFB:FFFA & External interrupt on 12 pin & 2 \\
\hline \$FFF9:FFF8 & External interrupt on 13 pin & 3 \\
\hline \$FFF7:FFF6 & External interrupt on 14 pin & 4 \\
\hline \$FFF5:FFF4 & Overflow on internal timers & 5 \\
\hline \$FFF3:FFF2 & Internal on the UART transmit/receive complete or external on EXUI & 6 \\
\hline \$FFF1:FFF0 & External interrupt on El pin & 7 \\
\hline
\end{tabular}

\section*{Interrupt Arbitration}

The HPC16040 contains arbitration logic to determine which nterrupt will be serviced first if two or more interrupts occur simultaneously. The arbitration ranking is given in Table III. The interrupt on Reset has the highest rank and is serviced irst.

\section*{Interrupt Processing}
nterrupts are serviced after the current instruction is comjleted except for the RESET, which is serviced immediately. ZESET and EXUI are level-LOW-sensitive interrupts and EI s level-HIGH-sensitive. All other interrupts are edge-sensiive. NMI is positive-edge sensitive. The external interrupts on I2, I3 and 14 can be software selected to be rising or alling edge.

\section*{Interrupt Control Registers}

The HPC16040 allows the various interrupt sources and zonditions to be programmed. This is done through the varizus control registers. A brief description of the different conrol registers is given below.

\section*{NTERRUPT ENABLE REGISTER (ENIR)}

ZESET and the External Interrupt on I1 are non-maskable nterrupts. The other interrupts can be individually enabled or disabled. Additionally, a Global Interrupt Enable Bit in the ENIR Register allows the Maskable interrupts to be collectively enabled or disabled. Thus, in order for a particular nterrupt to be serviced, both the individual enable bit and the Global Interrupt bit (GIE) have to be set.

\section*{INTERRUPT PENDING REGISTER (IRPD)}

The IRPD register contains a bit allocated for each interrupt vector. The occurrence of specified interrupt trigger conditions causes the appropriate bit to be set. There is no indication of the order in which the interrupts have been received. The bits are set independently of the fact that the interrupts may be disabled. IRPD is a Read/Write register. The bits corresponding to the maskable, external interrupts
are normally cleared by the HPC16040 after servicing the interrupts.
For the interrupts from the on-board peripherals, the user has the responsibility of resetting the interrupt pending flags through software.
The NMI bit is read only and 12,13 , and 14 are designed as to only allow a zero to be written to the pending bit (writing a one has no affect). A LOAD IMMEDIATE instruction is to be the only instruction used to clear a bit or bits in the IRPD register. This allows a mask to be used, thus ensuring that the other pending bits are not affected.

\section*{INTERRUPT CONDITION REGISTER (IRCD)}

Three bits of the register select the input polarity of the external interrupt on 12,13 , and 14 .

\section*{Servicing the Interrupts}

The Interrupt, once acknowledged, pushes the program counter ( PC ) onto the stack thus incrementing the stack pointer (SP) twice. The Global Interrupt Enable bit (GIE) is copied into the CGIE bit of the PSW register; it is then reset, thus disabling further interrupts. The program counter is loaded with the contents of the memory at the vector address and the processor resumes operation at this point. At the end of the interrupt service routine, the user does a RETI instruction to pop the stack and re-enable interrupts if the CGIE bit is set, or RET to just pop the stack if the CGIE bit is clear, and then returns to the main program. The GIE bit can be set in the interrupt service routine to nest interrupts if desired. Figure 14 shows the Interrupt Enable Logic.

\section*{Reset}

The RESET input initializes the processor and sets ports A, \(B\), and \(P\) in the TRI-STATE condition. RESET is an activelow Schmitt trigger input. The processor vectors to FFFF:FFFE and resumes operation at the address contained at that memory location (which must correspond to an on board location).


TL/DD/8340-18
FIGURE 14. Interrupt Enable Logic

\section*{Timer Overview}

The HPC16040 contains a powerful set of flexible timers enabling the HPC16040 to perform extensive timer functions; not usually associated with microcontrollers.
The HPC16040 contains eight 16-bit timers. Each timer has an associated 16 -bit register. Timer T0 is a free-running timer, counting up at a fixed CKI/16 (Clock Input/16) rate. It is used for Watch Dog logic, high speed event capture, and to exit from the IDLE mode. Consequently, it cannot be stopped or written to under software control. Timer T0 permits precise measurements by means of the capture registers I2CR, I3CR, and I4CR. A control bit in the register TMMODE configures timer T1 and its associated register R1 as capture registers I3CR and I2CR. The capture registers I2CR, I3CR, and I4CR respectively, record the value of timer TO when specific events occur on the interrupt pins 12, 13, and I4. The control register IRCD programs the capture registers to trigger on either a rising edge or a falling edge of its respective input. The specified edge can also be programmed to generate an interrupt (see Figure 15).
The timers T2 and T3 have selectable clock rates. The clock input to these two timers may be selected from the following two sources: an external pin, or derived internally by dividing the clock input. Timer T2 has additional capability of being clocked by the timer T3 underflow. This allows the user to cascade timers T3 and T2 into a 32-bit timer/ counter. The control register DIVBY programs the clock input to timers T2 and T3 (see Figure 16).
The timers T1 through T7 in conjunction with their registers form Timer-Register pairs. The registers hold the pulse duration values. All the Timer-Register pairs can be read from or written to. Each timer can be started or stopped under software control. Once enabled, the timers count down, and upon underflow, the contents of its associated register are automatically loaded into the timer.


FIGURE 15. Timers T0-T1 Block

\section*{SYNCHRONOUS OUTPUTS}

The flexible timer structure of the HPC16040 simplifies pulse generation and measurement. There are four synchronous timer outputs (TS0 through TS3) that work in conjunction with the timer T2. The synchronous timer outputs can be used either as regular outputs or individually programmed to toggle on timer T2 underflows (see Figure 16). Timer/register pairs 4-7 form four identical units which can generate synchronous outputs on port P (see Figure 17).


FIGURE 16. Timers T2-T3 Block

\section*{Timer Overview (Continued)}


TL/DD/8340-21
FIGURE 17. Timers T4-T7 Block

\section*{Timer Registers}

There are four control registers that program the timers. The divide by (DIVBY) register programs the clock input to timers T2 and T3. The timer mode register (TMMODE) contains control bits to start and stop timers T1 through T3. It also contains bits to latch and enable interrupts from timers TO through T3. The control register PWMODE similarly programs the pulse width timers T4 through T7 by allowing them to be started, stopped, and to latch and enable interrupts on underflows. The PORTP register contains bits to preset the outputs and enable the synchronous timer output functions.

\section*{Timer Applications}

The use of Pulse Width Timers for the generation of various waveforms is easily accomplished by the HPC16040.
Frequencies can be generated by using the timer/register pairs. A square wave is generated when the register value is a constant. The duty cycle can be controlled simply by changing the register value.


TL/DD/8340-22
FIGURE 18. Square Wave Frequency Generation
Synchronous outputs based on Timer T2 can be generated on the 4 outputs TSO-TS3. Each output can be individually programmed to toggle on T2 underflow. Register R2 contains the time delay between events. Figure 19 is an example of synchronous pulse train generation.

\section*{Watch Dog Logic}

The Watch Dog Logic monitors the operations taking place and signals upon the occurrence of any illegal activity. The illegal conditions that trigger the Watch Dog logic are potentially infinite loops and illegal addresses. Should the Watch Dog register not be written to before Timer TO overflows


FIGURE 19. Synchronous Pulse Generation
twice, or more often than once every 4096 counts, an infinite loop condition is assumed to have occurred. An illegal condition also occurs when the processor generates an offchip address when in the Single-Chip mode. The illegal condition forces the Watch Out (WO) pin low. The WO pin is an open drain output and can be connected to the RESET or NMI inputs or to the users external logic.

\section*{MICROWIRE/PLUS}

MICROWIRE/PLUS is used for synchronous serial data communications (see Figure 20). MICROWIRE/PLUS has an 8 -bit parallel-loaded, serial shift register using SI as the input and SO as the output. SK is the clock for the serial shift register (SIO). The SK clock signal can be provided by an internal or external source. The internal clock rate is programmable by the DIVBY register. A DONE flag indicates when the data shift is completed.


TL/DD/8340-24
FIGURE 20. MICROWIRE/PLUS
The MICROWIRE/PLUS capability enables it to interface with any of National Semiconductor's MICROWIRE peripherals (i.e., A/D converters, display drivers, EEPROMs).

\section*{MICROWIRE/PLUS Operation}

The HPC16040 can enter the MICROWIRE/PLUS mode as the master or a slave. A control bit in the IRCD register determines whether the HPC16040 is the master or slave. The shift clock is generated when the HPC16040 is configured as a master. An externally generated shift clock on the SK pin is used when the HPC16040 is configured as a slave. When the HPC16040 is a master, the DIVBY register programs the frequency of the SK clock. The DIVBY register allows the SK clock frequency to be programmed in 15 selectable steps from 64 Hz to 1 MHz with CKI at 16.0 MHz .

The contents of the SIO register may be accessed through any of the memory access instructions. Data waiting to be transmitted in the SIO register is clocked out on the falling edge of the SK clock. Serial data on the SI pin is clocked in on the rising edge of the SK clock.

\section*{MICROWIRE/PLUS Application}

Figure 21 illustrates a MICROWIRE/PLUS arrangement for an automotive application. The microcontroller-based sys-
tem could be used to interface to an instrument cluster and various parts of the automobile. The diagram shows two HPC16040 microcontrollers interconnected to other MICROWIRE peripherals. HPC16040 \#1 is set up as the master and initiates all data transfers. HPC16040 \#2 is set up as a slave answering to the master.
The master microcontroller interfaces the operator with the system and could also manage the instrument cluster in an automotive application. Information is visually presented to the operator by means of a VF display controlled by the COP470 display driver. The data to be displayed is sent serially to the COP470 over the MICROWIRE/PLUS link. Data such as accumulated mileage could be stored and retrieved from the EEPROM COP494. The slave HPC16040 could be used as a fuel injection processor and generate timing signals required to operate the fuel valves. The master processor could be used to periodically send updated values to the slave via the MICROWIRE/PLUS link. To speed up the response, chip select logic is implemented by connecting an output from the master to the external interrupt input on the slave.


FIGURE 21. MICROWIRE/PLUS Application

\section*{HPC16040 UART}

The HPC16040 contains a software programmable UART. The UART (see Figure 22) consists of a transmit shift register, a receiver shift register and five addressable registers, as follows: a transmit buffer register (TBUF), a receiver buffer register (RBUF), a UART control and status register (ENU), a UART receive control and status register (ENUR) and a UART interrupt and clock source register (ENUI). The ENU register contains flags for transmit and receive functions; this register also determines the length of the data frame ( 8 or 9 bits) and the value of the ninth bit in transmission. The ENUR register flags framing and data overrun errors while the UART is receiving. Other functions of the ENUR register include saving the ninth bit received in the data frame and enabling or disabling the UART's Wake-up Mode of operation. The determination of an internal or external clock source is done by the ENUI register, as well as selecting the number of stop bits and enabling or disabling transmit and receive interrupts.
The baud rate clock for the Receiver and Transmitter can be selected for either an internal or external source using two bits in the ENUI register. The internal baud rate is programmed by the DIVBY register. The baud rate may be selected from a range of 8 Hz to 64 kHz in binary steps or T3 underflow. By selecting a 9.83 MHz crystal, all standard baud rates from 75 baud to 38.4 kBaud can be generated. The external baud clock source comes from the CKX pin. The Transmitter and Receiver can be run at different rates by selecting one to operate from the internal clock and the other from an external source.
The HPC16040 UART supports two data formats. The first format for data transmission consists of one start bit, eight data bits and one or two stop bits. The second data format for transmission consists of one start bit, nine data bits, and one or two stop bits. Receiving formats differ from transmission only in that the Receiver always requires only one stop bit in a data frame.

\section*{UART Wake-up Mode}

The HPC16040 UART features a Wake-up Mode of operation. This mode of operation enables the HPC16040 to be networked with other processors. Typically in such environments, the messages consist of addresses and actual data. Addresses are specified by having the ninth bit in the data frame set to 1 . Data in the message is specified by having the ninth bit in the data frame reset to 0 .
The UART monitors the communication stream looking for addresses. When the data word with the ninth bit set is received, the UART signals the HPC16040 with an interrupt. The processor then examines the content of the receiver buffer to decide whether it has been addressed and whether to accpet subsequent data.


FIGURE 22. UART Block Dlagram

\section*{Universal Peripheral Interface}

The Universal Peripheral Interface (UPI) allows the HPC16040 to be used as an intelligent peripheral to another processor. The UPI could thus be used to tightly link two HPC16040's and set up systems with very high data exchange rates. Another area of application could be where a HPC16040 is programmed as an intelligent peripheral to a host system such as the Series 32000 microprocessor. FIGURE 23 illustrates how a HPC16040 could be used an an intelligent peripherial for a Series 32000-based application.
The interface consists of a Data Bus (port A), a Read Strobe ( \(\overline{\mathrm{URD}}\) ), a Write Strobe ( \(\overline{\mathrm{UWR}})\), a Read Ready Line ( \(\overline{\text { RDRDY }}\) ), a Write Ready Line (WRRDY) and one Address Input (UAO). The data bus can be either eight or sixteen bits wide.
The URD and \(\overline{U W R}\) inputs may be used to interrupt the HPC16040. The RDRDY and WRRDY outputs may be used to interrupt the host processor.
The UPI contains an Input Buffer (IBUF), an Output Buffer (OBUF) and a Control Register (UPIC). In the UPI mode, port A on the HPC16040 is the data bus. UPI can only be used if the HPC16040 is in the Single-Chip mode.

\section*{Shared Memory Support}

Shared memory access provides a rapid technique to exchange data. It is effective when data is moved from a peripheral to memory or when data is moved between blocks of memory. A related area where shared memory access proves effective is in multiprocessing applications where two CPUs share a common memory block. The HPC16040 supports shared memory access with two pins. The pins are the RDY/ \(\overline{H L D}\) input pin and the \(\overline{\text { HLDA }}\) output pin. The user can software select either the Hold or Ready function by the state of a control bit. The HLDA output is multiplexed onto port B.

The host uses DMA to interface with the HPC16040. The host initiates a data transfer by activating the \(\overline{\mathrm{HLD}}\) input of the HPC16040. In response, the HPC16040 places its system bus in a TRI-STATE Mode, freeing it for use by the host. The host waits for the acknowledge signal (HLDA) from the HPC16040 indicating that the sytem bus is free. On receiving the acknowledge, the host can rapidly transfer data into, or out of, the shared memory by using a conventional DMA controller. Upon completion of the message transfer, the host removes the HOLD request and the HPC16040 resumes normal operations.
FIGURE 24 illustrates an application of the shared memor, interface between the HPC16040 and a Series 32000 system.

\section*{Memory}

The HPC16040 has been designed to offer flexibility in memory usage. A total address space of 64 kbytes can be addressed with 4096 bytes of ROM and 256 bytes of RAN available on the chip itself. The ROM may contain program instructions, constants or data. The ROM and RAM share the same address space allowing instructions to be executed out of RAM.
Program memory addressing is accomplished by the 16 -bil program counter on a byte basis. Memory can be addressed directly by instructions or indirectly through the B, X and SP registers. Memory can be addressed as words or bytes. Words are always addressed on even-byte boundaries. The HPC16040 uses memory-mapped organization to suppori registers, I/O and on-chip peripheral functions.
The HPC16040 memory address space extends to 64 kbytes and registers and I/O are mapped as shown in Table IV.


FIGURE 23. HPC16040 as a Peripheral: (UPI Interface to Series 32000 Application)

Shared Memory Support (Continued)
\begin{tabular}{|c|c|c|}
\hline FFFF:FFFO & Interrupt Vectors & \\
\hline FFEF:FFD0 & JSRP Vectors & \\
\hline \begin{tabular}{l}
FFCF:FFCE \\
F001:F000
\end{tabular} & On-Chip ROM & \\
\hline EFFF:EFFE
0201:0200 & External Expansion Memory & USER MEMORY \\
\hline 01FF:01FE 01C1:01C0 & On-Chip RAM & \\
\hline 0195:0194 & Watchdog Address & Watchdog Logic \\
\hline 0192 & TOCON Register & \\
\hline 0191:0190 & TMMODE Register & \\
\hline 018F:018E & DIVBY Register & \\
\hline 018D:018C & T3 Timer & \\
\hline 018B:018A & R3 Register & Timer Block T0:T3 \\
\hline 0189:0188 & T2 Timer & Timer Block T0:T3 \\
\hline 0187:0186 & R2 Register & \\
\hline 0185:0184 & I2CR Register/ R1 & \\
\hline 0183:0182 & I3CR Register/ T1 & \\
\hline 0181:0180 & 14CR Register & \\
\hline 0153:0152 & Port P Register & \\
\hline 0151:0150 & PWMODE Register & \\
\hline 014F:014E & R7 Register & \\
\hline 014D:014C & T7 Timer & \\
\hline 014B:014A & R6 Register & Timer Block T4:T7 \\
\hline 0149:0148 & T6 Timer & \\
\hline 0147:0146 & R5 Register & \\
\hline 0145:0144 & T5 Timer & \\
\hline 0143:0142 & R4 Register & \\
\hline 0141:0140 & T4 Timer & \\
\hline
\end{tabular}
\begin{tabular}{|l|l|l|}
\hline 0128 & ENUR Register & \\
0126 & TBUF Register & UART \\
0124 & RBUF Register & \\
0122 & ENUU Register & \\
0120 & ENU Register & \\
\hline 0104 & Port D Input Register & \\
\hline 00F5:00F4 & BFUN Register & PORTS A \& B \\
00F3:00F2 & DIR B Register & CONTROL \\
00F1:00F0 & DIR A Register / IBUF & \\
\hline 00E6 & UPIC Register & UPI CONTROL \\
\hline 00E3:00E2 & Port B & PORTS A \& B \\
00E1:00E0 & Port A / OBUF & \\
\hline 00DE & Microcode ROM Dump & \\
00DD:00DC & HALT Enable Register & PORT CONTROL \\
00D8 & Port I Input Register & \& INTERRUPT \\
00D6 & SIO Register & CONTROL \\
00D4 & IRCD Register & REGISTERS \\
00D2 & IRPD Register & \\
00D0 & ENIR Register & \\
\hline 00CF:00CE & X Register & \\
00CD:00CC & B Register & \\
00CB:00CA & K Register & HPC16040 CORE \\
00C9:00C8 & A Register & REGISTERS \\
00C7:00C6 & PC Register & \\
00C5:00C4 & SP Register & \\
00C3:00C2 & (reserved) & \\
00C0 & PSW Register & \\
\hline 00BF:00BE & On-Chip & \\
: & USER RAM \\
0001:0000 & RAM & \\
\hline
\end{tabular}

\section*{HPC16040 CPU}

The HPC16040 CPU has a 16 -bit ALU and six 16-bit registers

\section*{Arithmetic Logic Unit (ALU)}

The ALU is 16 bits wide and can do 16 -bit add, subtract and shift or logic AND, OR and exclusive OR in one timing cycle. The ALU can also output the carry bit to a 1-bit C register.

\section*{Accumulator (A) Register}

The 16-bit A register is the source and destination register for most I/O, arithmetic, logic and data memory access operations.

\section*{Address ( B and X ) Registers}

The 16 -bit \(B\) and \(X\) registers can be used for indirect addressing. They can automatically count up or down to sequence through data memory.

\section*{Boundary (K) Register}

The 16 -bit K register is used to set limits in repetitive loops of code as register B sequences through data memory.

\section*{Stack Pointer (SP) Register}

The 16 -bit SP register is the pointer that addresses the stack. The SP register is incremented by two for each push or call and decremented by two for each pop or return. The stack can be placed anywhere in user memory and be as deep as the available memory permits.

\section*{Program (PC) Register}

The 16-bit PC register addresses program memory.

\section*{Addressing Modes}

ADDRESSING MODES-ACCUMULATOR AS DESTINATION

\section*{Register Indirect}

This is the "normal" mode of addressing for the HPC16040 (instructions are single-byte). The operand is the memory addressed by the B register (or X register for some instructions).
Direct
The instruction contains an 8 -bit or 16 -bit address field that directly points to the memory for the operand.

\section*{Indirect}

The instruction contains an 8-bit address field. The contents of the WORD addressed points to the memory for the operand.

\section*{Indexed}

The instruction contains an 8-bit address field and an 8- or 16 -bit displacement field. The contents of the WORD addressed is added to the displacement to get the address of the operand.

\section*{Immediate}

The instruction contains an 8 -bit or 16 -bit immediate field that is used as the operand.

\section*{Register Indirect (Auto Increment and Decrement)}

The operand is the memory addressed by the \(X\) register. This mode automatically increments or decrements the \(X\) register (by 1 for bytes and by 2 for words).
Register Indirect (Auto Increment and Decrement) with Conditional Skip
The operand is the memory addressed by the \(B\) register. This mode automatically increments or decrements the B register (by 1 for bytes and by 2 for words). The B register is then compared with the K register. A skip condition is generated if \(B\) goes past \(K\).

\section*{ADDRESSING MODES-DIRECT MEMORY AS DESTINATION}

\section*{Direct Memory to Direct Memory}

The instruction contains two 8 - or 16 -bit address fields. One field directly points to the source operand and the other field directly points to the destination operand.

\section*{Immediate to Direct Memory}

The instruction contains an 8- or 16-bit address field and an 8 - or 16 -bit immediate field. The immediate field is the operand and the direct field is the destination.

\section*{Double Register Indirect Using the \(B\) and \(X\) Registers}

Used only with Reset, Set and IF bit instructions; a specific bit within the 64 kbyte address range is addressed using the B and X registers. The address of a byte of memory is formed by adding the contents of the B register to the most significant 13 bits of the \(X\) register. The specific bit to be modified or tested within the byte of memory is selected using the least significant 3 bits of register X .

HPC Instruction Set Description
\begin{tabular}{|c|c|c|}
\hline Mnemonic & Description & Action \\
\hline \multicolumn{3}{|l|}{ARITHMETIC INSTRUCTIONS} \\
\hline ADD & Add & \(\mathrm{MA}+\mathrm{Meml} \rightarrow\) MA \(\quad\) carry \(\rightarrow\) C \\
\hline ADC & Add with carry & \(\mathrm{MA}+\mathrm{Meml}+\mathrm{C} \rightarrow \mathrm{MA} \quad\) carry \(\rightarrow \mathrm{C}\) \\
\hline DADC & Decimal add with carry & \(\mathrm{MA}+\mathrm{Meml}+\mathrm{C} \rightarrow \mathrm{MA}\) (Decimal) carry \(\rightarrow \mathrm{C}\) \\
\hline SUBC & Subtract with carry & MA-Meml \(+\mathrm{C} \rightarrow\) MA \(\quad\) carry \(\rightarrow\) C \\
\hline DSUBC & Decimal subtract w/carry & MA - Meml \(+\mathrm{C} \rightarrow\) MA (Decimal) carry \(\rightarrow\) C \\
\hline MULT & Multiply (unsigned) & MA* Meml \(\rightarrow\) MA \& \(\mathrm{X}, \mathrm{O} \rightarrow \mathrm{K}, 0 \rightarrow \mathrm{C}\) \\
\hline DIV & Divide (unsigned) & MA/Meml \(\rightarrow\) MA, rem. \(\rightarrow \mathrm{X}, 0 \rightarrow \mathrm{~K}, 0 \rightarrow \mathrm{C}\) \\
\hline IFEQ & If equal & Compare MA \& Meml, Do next if equal \\
\hline IFGT & If greater than & Compare MA \& Meml, Do next if MA > Meml \\
\hline AND & Logical and & MA and Meml \(\rightarrow\) MA \\
\hline OR & Logical or & MA or Meml \(\rightarrow\) MA \\
\hline XOR & Logical exclusive-or & MA xor Meml \(\rightarrow\) MA \\
\hline \multicolumn{3}{|l|}{MEMORY MODIFY INSTRUCTIONS} \\
\hline INC & Increment & Mem + \(1 \rightarrow\) Mem \\
\hline DECSZ & Decrement, skip if 0 & Mem -1 \(\rightarrow\) Mem, Skip next if Mem \(=0\) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|l|}{HPC Instruction Set Description (Continued)} \\
\hline Mnemonic & Description & Action \\
\hline \multicolumn{3}{|l|}{IT INSTRUCTIONS} \\
\hline \[
\begin{aligned}
& \hline \text { SET } \\
& \text { RESET } \\
& \text { IF } \\
& \hline
\end{aligned}
\] & Set bit Reset bit If bit & \begin{tabular}{l}
\(1 \rightarrow\) Mem. bit (bit is 0 to 7 immediate) \(0 \rightarrow\) Mem.bit \\
If Mem.bit is true, do next instr.
\end{tabular} \\
\hline \multicolumn{3}{|l|}{EMORY TRANSFER INSTRUCTIONS} \\
\hline \begin{tabular}{l}
LD \\
ST \\
x \\
PUSH \\
POP \\
LDS \\
xs
\end{tabular} & \begin{tabular}{l}
Load \\
Load, incr/decr X \\
Store to Memory \\
Exchange \\
Exchange, incr/decr X Push Memory to Stack Pop Stack to Memory \\
Load A, incr/decr B, Skip on condition Exchange, incr/decr B, Skip on condition
\end{tabular} & \begin{tabular}{l}
Meml \(\rightarrow\) MA \\
\(\operatorname{Mem}(\mathrm{X}) \rightarrow \mathrm{A}, \mathrm{X} \pm 1\) (or 2) \(\rightarrow \mathrm{X}\) \\
\(A \rightarrow\) Mem \\
\(A \longleftrightarrow M e m\) \\
\(A \longleftrightarrow \operatorname{Mem}(X), X \pm 1\) (or 2) \(\rightarrow X\) \\
\(\mathrm{W} \rightarrow \mathrm{W}(\mathrm{SP}), \mathrm{SP}+2 \rightarrow \mathrm{SP}\) \\
\(\mathrm{SP}-2 \rightarrow \mathrm{SP}, \mathrm{W}(\mathrm{SP}) \rightarrow \mathrm{W}\) \\
\(\operatorname{Mem}(B) \rightarrow A, B \pm 1\) (or 2\() \rightarrow B\), \\
Skip next if \(B\) greater/less than \(K\) \\
\(\operatorname{Mem}(B) \longleftrightarrow A, B \pm 1\) (or 2) \(\rightarrow B\), \\
Skip next if B greater/less than K
\end{tabular} \\
\hline \multicolumn{3}{|l|}{EGISTER LOAD IMMEDIATE INSTRUCTIONS} \\
\hline \begin{tabular}{l}
LD A \\
LD B \\
LDK \\
LD X \\
LD BK
\end{tabular} & Load A immediate Load B immediate Load K immediate Load X immediate Load B and K immediate & \[
\begin{aligned}
& \mathrm{imm} \rightarrow A \\
& \mathrm{imm} \rightarrow \mathrm{~B} \\
& \mathrm{imm} \rightarrow \mathrm{~K} \\
& \mathrm{imm} \rightarrow \mathrm{X} \\
& \mathrm{imm} \rightarrow \mathrm{~B}, \mathrm{imm} m^{\prime} \rightarrow \mathrm{K}
\end{aligned}
\] \\
\hline \multicolumn{3}{|l|}{CCUMULATOR AND C INSTRUCTIONS} \\
\hline \begin{tabular}{l}
CLRA \\
INC A \\
DEC A \\
COMP A \\
SWAP A \\
RRC A \\
RLC A \\
SHR A \\
SHLA \\
SET C \\
RESET C \\
IF C \\
IFNC
\end{tabular} & \begin{tabular}{l}
Clear A \\
Increment A \\
Decrement A \\
Complement A \\
Swap nibbles of A \\
Rotate A right thru C \\
Rotate A left thru C \\
Shift A right \\
Shift A left \\
Set C \\
Reset C \\
IF C \\
IF not C
\end{tabular} & \begin{tabular}{l}
\[
\begin{aligned}
& 0 \rightarrow A \\
& A+1 \rightarrow A \\
& A-1 \rightarrow A
\end{aligned}
\] \\
1 's complement of \(A \rightarrow A\) \\
\(\mathrm{A} 15: 12 \leftarrow \mathrm{~A} 11: 8 \longleftarrow \mathrm{~A} 7: 4 \longleftrightarrow \mathrm{~A} 3: 0\)
\[
\begin{aligned}
& C \rightarrow A 15 \rightarrow \ldots \rightarrow A O \rightarrow C \\
& C \leftarrow A 15 \leftarrow \ldots \leftarrow A 0 \leftarrow C \\
& 0 \rightarrow A 15 \rightarrow \ldots \rightarrow A 0 \rightarrow C \\
& C \leftarrow A 15 \leftarrow \ldots \leftarrow A 0 \leftarrow 0 \\
& 1 \rightarrow C \\
& 0 \rightarrow C
\end{aligned}
\] \\
Do next if \(\mathrm{C}=1\) \\
Do next if \(\mathrm{C}=0\)
\end{tabular} \\
\hline \multicolumn{3}{|l|}{「RANSFER OF CONTROL INSTRUCTIONS} \\
\hline \begin{tabular}{l}
JSRP \\
JSR \\
JSRL \\
JP \\
JMP \\
JMPL \\
JID \\
JIDW \\
NOP \\
RET \\
RETS \\
RETI
\end{tabular} & \begin{tabular}{l}
Jump subroutine from table \\
Jump subroutine relative \\
Jump subroutine long \\
Jump relative short \\
Jump relative \\
Jump relative long \\
Jump indirect at PC \(+A\) \\
No Operation \\
Return \\
Return then skip next \\
Return from interrupt
\end{tabular} & ```
\(\mathrm{PC} \rightarrow \mathrm{W}(\mathrm{SP}), \mathrm{SP}+2 \rightarrow \mathrm{SP}\)
    W(table \#) \(\rightarrow\) PC
\(\mathrm{PC} \rightarrow \mathrm{W}(\mathrm{SP}), \mathrm{SP}+2 \rightarrow \mathrm{SP}, \mathrm{PC}+\# \rightarrow \mathrm{PC}\)
    (\# is +1025 to -1023 )
\(\mathrm{PC} \rightarrow \mathrm{W}(\mathrm{SP}), \mathrm{SP}+2 \rightarrow \mathrm{SP}, \mathrm{PC}+\# \rightarrow \mathrm{PC}\)
\(\mathrm{PC}+\# \rightarrow \mathrm{PC}(\#\) is +32 to -31\()\)
\(\mathrm{PC}+\# \rightarrow \mathrm{PC}(\) ( is +257 to -255\()\)
\(\mathrm{PC}+\# \rightarrow \mathrm{PC}\)
\(P C+A+1 \rightarrow P C\)
    then \(\operatorname{Mem}(\mathrm{PC})+\mathrm{PC} \rightarrow \mathrm{PC}\)
\(P C+1 \rightarrow P C\)
\(\mathrm{SP}-2 \rightarrow \mathrm{SP}, \mathrm{W}(\mathrm{SP}) \rightarrow \mathrm{PC}\)
\(\mathrm{SP}-2 \rightarrow \mathrm{SP}, \mathrm{W}(\mathrm{SP}) \rightarrow \mathrm{PC}, \&\) skip
\(S P-2 \rightarrow S P, W(S P) \rightarrow P C\), interrupt re-enabled
``` \\
\hline
\end{tabular}

Note: \(W\) is 16 -bit word of memory
MA is Accumulator \(A\) or direct memory ( 8 or 16 -bit)
Mem is 8 -bit byte or 16 -bit word of memory
Meml is 8 - or 16 -bit memory or 8 or 16 -bit immediate data
imm is 8 -bit or 16 -bit immediate data

\section*{Memory Usage}

Number Of Bytes For Each Instruction (number in parenthesis is 16-Bit field)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{7}{|c|}{Using Accumulator A} & \multicolumn{4}{|c|}{To Direct Memory} \\
\hline & \multicolumn{2}{|l|}{\begin{tabular}{l}
Reg Indir. \\
(B) \\
(X)
\end{tabular}} & Direct & Indir & Index & Immed. & & & & \\
\hline LD & 1 & 1 & 2(4) & 3 & 4(5) & 2(3) & 3(5) & 5(6) & 3(4) & 5(6) \\
\hline \(X\) & 1 & 1 & 2(4) & 3 & 4(5) & - & - & - & - & - \\
\hline ST & 1 & 1 & 2(4) & 3 & 4(5) & - & - & - & - & - \\
\hline ADC & 1 & 2 & 3(4) & 3 & 4(5) & 4(5) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline SBC & 1 & 2 & 3(4) & 3 & 4(5) & 4(5) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline DADC & 1 & 2 & 3(4) & 3 & 4(5) & 4(5) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline DSBC & 1 & 2 & 3(4) & 3 & 4(5) & 4(5) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline ADD & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline MULT & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline DIV & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline IFEQ & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline IFGT & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline AND & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline OR & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline XOR & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline
\end{tabular}
* 8 -bit direct address
**16-bit direct address
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{7}{|c|}{Instructions that modify memory directly} & \multicolumn{2}{|l|}{Immediate Load Instructions} \\
\hline & (B) & (X) & Direct & Indir & Index & B\&X & & Immed. \\
\hline SET & 1 & 2 & 3(4) & 3 & 4(5) & 1 & LD B,* & 2(3) \\
\hline RESET & 1 & 2 & 3(4) & 3 & 4(5) & 1 & LD X,* & 2(3) \\
\hline IF & 1 & 2 & 3(4) & 3 & 4(5) & 1 & LD K,* & 2(3) \\
\hline DECSZ & 3 & 2 & 2(4) & 3 & 4(5) & & LD BK,*,* & 3(5) \\
\hline INC & 3 & 2 & 2(4) & 3 & 4(5) & & & \\
\hline
\end{tabular}

Register Indirect Instructions with
Auto Increment and Decrement Auto Increment and Decrement
\begin{tabular}{|l|c|c|}
\hline \multicolumn{3}{|c|}{ Register B With Sklp } \\
\hline & \((\mathbf{B}+)\) & \((\mathbf{B}-)\) \\
\hline LDS A,* & 1 & 1 \\
XS A,* & 1 & 1 \\
\hline
\end{tabular}


Instructions Using A and C
\begin{tabular}{|ll|l|}
\hline CLR & A & 1 \\
INC & A & 1 \\
DEC & A & 1 \\
COMP & A & 1 \\
SWAP & A & 1 \\
RRC & A & 1 \\
RLC & A & 1 \\
SHR & A & 1 \\
SHL & A & 1 \\
SET & C & 1 \\
RESET & C & 1 \\
IF & C & 1 \\
IFN & C & 1 \\
\hline
\end{tabular}

Transfer of Control Instructions
\begin{tabular}{|l|l|}
\hline JSRP & 1 \\
JSR & 2 \\
JSRL & 3 \\
JP & 1 \\
JMP & 2 \\
JMPL & 3 \\
JID & 1 \\
JIDW & 1 \\
NOP & 1 \\
RET & 1 \\
RETS & 1 \\
RETI & 1 \\
\hline
\end{tabular}

Stack Reference Instructions
\begin{tabular}{|l|c|}
\cline { 2 - 2 } \multicolumn{1}{c|}{} & Direct \\
\hline PUSH & 2 \\
POP & 2 \\
\hline
\end{tabular}

\section*{Code Efficiency}

One of the most important criteria of a single chip microcontroller is code efficiency. The more efficient the code, the more features that can be put on a chip. The memory size on a chip is fixed so if code is not efficient, features may have to be sacrificed or the programmer may have to buy a larger, more expensive version of the chip.
The HPC16040 has been designed to be extremely codeefficient. The HPC16040 looks very good in all the standard coding benchmarks; however, it is not realistic to rely only on benchmarks. Many large jobs have been programmed onto the HPC16040, and the code savings over other popular microcontrollers has been considerable-often the jobs take less than one-half the memory!
Reasons for this saving of code include the following:

\section*{SINGLE BYTE INSTRUCTIONS}

The majority of instructions on the HPC16040 are singlebyte. There are two especially code-saving instructions:
JP is a 1-byte jump. True, it can only jump within a range of plus or minus 32, but many loops and decisions are often within a small range of program memory. Most other micros need 2 -byte instructions for any short jumps.
JSRP is a 1 -byte call subroutine. The user makes a table of his 16 most frequently called subroutines and these calls will only take one byte. Most other micros require two and even three bytes to call a subroutine. The user does not have to decide which subroutine addresses to put into his table; the assembler can give him this information.

\section*{EFFICIENT SUBROUTINE CALLS}

The 2-byte JSR instructions can call any subroutine within plus or minus 1 k of program memory.

\section*{MULTIFUNCTION INSTRUCTIONS FOR DATA MOVEMENT AND PROGRAM LOOPING}

The HPC16040 has single-byte instructions that perform multiple tasks. For example, the XS instruction will do the following:
1. Exchange \(A\) and memory pointed to by the \(B\) register
2. Increment the \(B\) register
3. Compare the B register versus the K register
4. Generate a conditional skip if \(B\) is greater than \(K\)

The value of this multipurpose instruction becomes evident when looping through sequential areas of memory and exiting when the loop is finished.

\section*{BIT MANIPULATION INSTRUCTIONS}

Any bit of memory, I/O or registers can be set, reset or tested by the single byte bit instructions. The bits can be addressed directly or indirectly. Since all registers and I/O are mapped into the memory, it is very easy to manipulate specific bits to do efficient control.
The one exception to the above is with the IRPD register. A LOAD IMMEDIATE instruction is to be the only instruction used to clear a bit or bits in this register (see Interrupt Pending Register section).

\section*{DECIMAL ADD AND SUBTRACT}

This instruction is needed to interface with the decimal user world.
It can handle both 16 -bit words and 8 -bit bytes.
The 16 -bit capability saves code since many variables can be stored as one piece of data and the programmer does not have to break his data into two bytes. Many applications store most data in 4 -digit variables. The HPC16040 supplies 8 -bit byte capability for 2-digit variables and literal variables.

\section*{MULTIPLY AND DIVIDE INSTRUCTIONS}

The HPC16040 has 16 -bit multiply, 16 -bit by 16 -bit divide, and 32 -bit by 16 -bit divide instructions. This saves both code and time. Multiply and divide can use immediate data or data from memory. The ability to multiply and divide by immediate data saves code since this function is often needed for scaling, base conversion, computing indexes of arrays, etc.

\section*{Development Support}

The MOLE (Microcontroller On-Line Emulator) is a low cost development system and emulator for all microcontroller products. These include COPs, TMP, 8050 U and the HPC Family of Products. The MOLE consists of a BRAIN Board, Personality Board and optional host software.
The purpose of a MOLE is to provide the user with a tool to write and assemble code, emulate code for the target microcontroller and assist in both the software \& hardware debugging of the system.
It is a self-contained computer with its own firmware which provides for all system operation, emulation control, communication, PROM programming and diagnostic operations. it contains three serial ports because multiple ports are usually needed to optionally connect to a terminal, a host system, a printer or modem, or to connect to other MOLEs in a multi-MOLE environment.
MOLE can be used in either a stand alone mode or in conjunction with selected host systems, i.e., those using CP/M or PC-DOS. Communicating via RS-232 port.
Dial-A-Helper is a service provided by the MOLE applications group. If a user is having difficulty in getting a MOLE to operate in a particular mode or it is acting peculiar, he can contact us via his system and a modem. He can leave messages on our electronic bulletin board which we will respond to, or he can arrange for us to actually take control of his system via modem for debugging purposes.
The applications group can then cause his system to execute various commands and try to resolve the customer's problem by actually getting the customer's system to respond. \(99 \%\) of the time the problem is resolved. This allows us to respond in minutes instead of days when applications help is needed.
The system can also be used to download available applications software.

\section*{Part Selection}

The HPC family includes devices with many different options and configurations to meet various application needs. The number HPC16040 has been generically used throughout this datasheet to represent the whole family of parts. The following chart explains how to order various options available when ordering HPC family members.
Note: All options may not currently be available.


TL/DD/8340-12
FIGURE 8. HPC Family Part Numbering Scheme

\section*{Examples}

HPC46030E17 - ROMless, Commercial temp. \(\left(0^{\circ} \mathrm{C}\right.\) to \(\left.70^{\circ} \mathrm{C}\right)\), LCC
HPC16040XXX/U17-4k masked ROM, Military temp. \(\left(-55^{\circ} \mathrm{C}\right.\) to \(\left.+125^{\circ} \mathrm{C}\right)\), PGA
HPC26040XXX/V17 - 4 k masked ROM, Automotive temp. \(\left(-40^{\circ} \mathrm{C}\right.\) to \(\left.+105^{\circ} \mathrm{C}\right)\), PCC

\section*{HPC16083/HPC26083/HPC36083/HPC46083/HPC16073/ HPC36073/HPC46073 High-Performance Microcontroller with Input Capture Registers}

\section*{General Description}

The HPC16083 is a member of the HPCTM family of High Performance Microcontrollers. Each member of the family has the same identical core CPU with a unique memory and 1/O configuration to suit specific applications. Each part is fabricated in National's advanced microCMOS technology. This process combined with an advanced architecture provides fast, flexible I/O control, efficient data manipulation, and high speed computation.
The HPC16083 is a complete microcomputer on a single chip. All system timing, internal logic, ROM, RAM, and I/O are provided on the chip to produce a cost effective solution for high performance applications. On-chip functions such as UART, up to Eight 16 -bit timers with up to 4 input capture registers, vectored interrupts, WATCHDOG logic and MICROWIRE/PLUSTM provide a high level of system integration. The ability to address up to 64 k bytes of external memory enables the HPC16083 to be used in powerful applications typically performed by microprocessors and expensive peripheral chips.
The microCMOS process results in very low current drain and enables the user to select the optimum speed/power product for his system. The IDLE and HALT modes provide further current savings. The HPC16083 is available in 68-pin PCC, LCC and PGA packages.

\section*{Features}
- HPC family-core features:
- 16-bit architecture, both byte and word
-16 -bit data bus, ALU, and registers
- 64k bytes of external memory addressing
- FASTI-240 ns for register instructions when using 17.0 MHz clock
- High code efficiency-most instructions are single byte
\(-16 \times 16\) multiply and \(32 \times 16\) divide
- Eight vectored interrupt sources
- Four 16-bit timer/counters with 4 synchronous outputs and WATCHDOG logic
- MICROWIRE/PLUS serial I/O interface
- CMOS-very low power with two power save modes: IDLE and HALT ( \(2 \mathrm{~mA}, 250 \mu \mathrm{~A}\)-typ.)
■ UART-full duplex, programmable baud rate
■ Four additional 16 -bit timer/counters with pulse width modulated outputs
- Four input capture registers
- 52 general purpose I/O lines (memory mapped)
\(\square 8 \mathrm{k}\) bytes of ROM, 256 bytes of RAM on chip
- ROMless versions available

■ Wide voltage supply range: 3 to 5.5 V
- Industrial \(\left(-40^{\circ} \mathrm{C}\right.\) to \(+85^{\circ} \mathrm{C}\) ) and military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(+125^{\circ} \mathrm{C}\) ) temperature ranges

\section*{Block Diagram}


\section*{HPC16400/HPC36400/HPC46400 High-Performance Microcontrollers with HDLC Controller}

\section*{General Description}

The HPC16400 is a member of the HPCTM family of High Performance microControllers. Each member of the family has the same identical core CPU with a unique memory and I/O configuration to suit specific applications. Each part is fabricated in National's advanced microCMOS technology. This process combined with an advanced architecture provides fast, flexible I/O control, efficient data manipulation, and high speed computation.
The HPC16400 has 4 functional blocks to support a wide range of communication application-2 HDLC channels, 4 channel DMA controller to facilitate data flow for the HDLC channels, programmable serial interface and UART.
The serial interface decoder allows the 2 HDLC channels to be used with devices using interchip serial link for point-topoint \& multipoint data exchanges. The decoder generates enable signals for the HDLC channels allowing multiplexed \(D\) and \(B\) channel data to be accessed.
The HDLC channels manage the link by providing sequencing using the HDLC framing along with error control and retransmission based upon a cyclic redundancy check (CRC). Multiple frame addressing, and both bit and byte modes of operation are supported.
The HPC16400 is available in 68-pin PCC, LCC and PGA packages.

\section*{Features}
- HPC family-core features:
- 16 -bit data bus, ALU, and registers
- 64 kbytes of external memory addressing
- FAST!-17.0 MHz system clock
- High code efficiency
- \(16 \times 16\) multiply and \(32 \times 16\) divide
- Eight vectored interrupt sources
- Four 16-bit timer/counters with WATCHDOG logic
- MICROWIRE/PLUS serial I/O interface
- CMOS-low power with two power save modes
- Two full duplex HDLC channels
- Optimized or X. 25 and LAPD applications
- Programmable frame address recognition
- Up to 4.1 Mbps aggregate serial data rate
- Built in diagnostics
- Programmable interchip serial data decoder
a Four channel DMA controller
■ UART-full duplex, programmable baud rate
- 544 kbytes of extended addressing
- Easy interface to National's ' \(U\) ' and ' \(S\) ' transceiverTP3400, TP3410 and TP3420
- Wide voltage supply range: 3 to 5.5 V
- Industrial \(\left(-40^{\circ} \mathrm{C}\right.\) to \(+85^{\circ} \mathrm{C}\) ) and military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(+125^{\circ} \mathrm{C}\) ) temperature ranges

\section*{Block Diagram}


\section*{Absolute Maximum Ratings}

Specifications for Milltary/Aerospace products are not contalned in this datasheet. Refer to the assoclated rellability electrical test specifications document.
Total Allowable Source or Sink Current Storage Temperature Range \(\quad-65^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}\) Lead Temperature (Soldering, 10 sec ) \(300^{\circ} \mathrm{C}\)
\(V_{C C}\) with Respect to GND
-0.5 V to 7.0 V All Other Pins \(\left(V_{C C}+0.5\right) V\) to \((G N D-0.5) V\) Note: Absolute maximum ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications are not ensured when operating the device at absolute maximum ratings.

DC Electrical Characteristics \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%\) unless otherwise specified, \(T_{A}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) for HPC46040, \(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) for \(\mathrm{HPC} 36040,-40^{\circ} \mathrm{C}\) to \(+105^{\circ} \mathrm{C}\) for \(\mathrm{HPC} 26040,-55^{\circ} \mathrm{C}\) to \(+125^{\circ} \mathrm{C}\) for HPC16400
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Test Conditions & Min & Typ & Max & Units \\
\hline \multirow[t]{2}{*}{\(\mathrm{ICC}_{1}\)} & \multirow[t]{2}{*}{Supply Current} & \(V_{C C}=5.0 \mathrm{~V}, \mathrm{f}_{\text {in }}=17.0 \mathrm{MHz}^{*}\) & & 20 & & mA \\
\hline & & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\mathrm{in}}=2.0 \mathrm{MHz}\) & & 2.4 & & mA \\
\hline \multirow[t]{2}{*}{\(\mathrm{ICC}_{2}\)} & \multirow[t]{2}{*}{IDLE Mode Current} & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\text {in }}=17.0 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}^{*}\) & & 2 & & mA \\
\hline & & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\text {in }}=2.0 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) & & 0.2 & & mA \\
\hline \multirow[t]{2}{*}{\(\mathrm{ICC}_{3}\)} & \multirow[t]{2}{*}{HALT Mode Current} & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{f}_{\text {in }}=0 \mathrm{kHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}^{*}\) & & 25 & & \(\mu \mathrm{A}\) \\
\hline & & \(\mathrm{V}_{\mathrm{CC}}=2.5 \mathrm{~V}, \mathrm{f}_{\text {in }}=0 \mathrm{kHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) & & 10 & & \(\mu \mathrm{A}\) \\
\hline
\end{tabular}

INPUT VOLTAGE LEVELS RESET, NMI, CKI AND WO (SCHMITT TRIGGERED)
\begin{tabular}{l|l|l|l|l|l}
\hline \(\mathrm{V}_{\mathrm{H}_{1}}\) & Logic High & & & \(0.9 \mathrm{~V}_{\mathrm{CC}}\) & \\
\hline \(\mathrm{V}_{\mathrm{IL}_{1}}\) & Logic Low & & & \(0.1 \mathrm{~V}_{\mathrm{CC}}\) & V \\
\hline
\end{tabular}

ALL OTHER INPUTS
\begin{tabular}{l|l|l|c|c|c}
\hline \(\mathrm{V}_{\mathrm{IH}_{2}}\) & Logic High & & & \(0.7 \mathrm{~V}_{\mathrm{CC}}\) & \\
\hline \(\mathrm{V}_{\mathrm{IL} 2}\) & Logic Low & & & \(0.2 \mathrm{~V}_{\mathrm{CC}}\) & \\
\hline \(\mathrm{I}_{\mathrm{LI}}\) & Input Leakage Current & & & \(\pm 1\) & V \\
\hline \(\mathrm{C}_{\mathrm{I}}\) & Input Capacitance & & & 10 & \(\mu \mathrm{~A}\) \\
\hline \(\mathrm{C}_{\mathrm{IO}}\) & I/O Capacitance & & & 20 & pF \\
\hline
\end{tabular}

OUTPUT VOLTAGE LEVELS CMOS OPERATION
\begin{tabular}{|c|c|c|c|c|}
\hline \(\mathrm{VOH}_{1}\) & Logic High & \(\mathrm{IOH}=-10 \mu \mathrm{~A}\) & \(\mathrm{V}_{\mathrm{CC}}-0.2\) & V \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Logic Low & \(\mathrm{IOH}=10 \mu \mathrm{~A}\) & 0.2 & V \\
\hline \(\mathrm{VOH}_{2}\) & \multirow[t]{2}{*}{Port A/B Drive
\[
\left(A_{0}-A_{15}, B_{10}, B_{11}, B_{12}, B_{15}\right)
\]} & \(\mathrm{IOH}=-7 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) & 2.4 & V \\
\hline \(\mathrm{V}_{\mathrm{OL} 2}\) & & \(\mathrm{IOL}^{2}=3 \mathrm{~mA}\) & 0.4 & V \\
\hline \(\mathrm{VOH}_{3}\) & \multirow[t]{2}{*}{Other Port Pin Drive
\[
\left(B_{0}-B_{9}, B_{13}, B_{14}, P_{0}-P_{3}\right)
\]} & \(\mathrm{l}_{\mathrm{OH}}=-1.6 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) & 2.4 & V \\
\hline \(\mathrm{VOL}_{3}\) & & \(\mathrm{lOL}^{2}=0.5 \mathrm{~mA}\) & 0.4 & V \\
\hline \(\mathrm{VOL}_{4}\) & WO (Watchdog Out) Drive & \(\mathrm{IOL}=0.5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) & 0.4 & V \\
\hline \(\mathrm{VOH}_{6}\) & \multirow[t]{2}{*}{CK2 Drive} & \(\mathrm{l}_{\mathrm{OH}}=-12 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) & 2.4 & V \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & & \(\mathrm{IOL}=3.5 \mathrm{~mA}\) & 0.4 & \(V\) \\
\hline \(\mathrm{VOH}_{7}\) & \multirow[t]{2}{*}{ST1 and ST2 Drive} & \(\mathrm{I}_{\mathrm{OH}}=-6 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) & 2.4 & V \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & & \(\mathrm{lOL}=1.6 \mathrm{~mA}\) & 0.4 & V \\
\hline \(V_{\text {RAM }}\) & RAM Keep-Alive Voltage & & 2.5 & V \\
\hline loz & TRI-STATE Leakage Current & & \(\pm 5\) & \(\mu \mathrm{A}\) \\
\hline
\end{tabular}

\footnotetext{
\({ }^{*}\) Note: \(\mathrm{ICC}_{1}, \mathrm{ICC}_{2}, \mathrm{ICC}_{3}\) measured with no external drive ( \(\mathrm{IOH}_{\mathrm{OH}}\) and \(\mathrm{IOL}^{2}=0, \mathrm{I}_{\mathrm{H}}\) and \(\mathrm{I}_{\mathrm{LL}}=0\) ).
}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \(\mathrm{f}_{\mathrm{C}}=\) CKI freq. & Operating Frequency & & 16.78 & 17.0 & MHz \\
\hline \(\mathrm{t}_{\mathrm{C} 1}=1 / \mathrm{f}_{\mathrm{C}}\) & Clock Period \(\dagger 20\) & & 60 & & ns \\
\hline \(\mathrm{t}_{\mathrm{C}}=2 / / \mathrm{f}_{\mathrm{C}}\) & Timing Cycle 750 & & 120 & & ns \\
\hline \(t_{L L}=1 / 2 t_{C}\) & ALE Pulse Width & & 60 & & ns \\
\hline \(\mathrm{tST}^{\text {c }}=1 / 4 \mathrm{t}_{\mathrm{C}}\) & Address Valid to ALE Trailing Edge & & 30 & & ns \\
\hline \(t_{\text {WAIT }}=t_{C}=W S\) & Wait State Period ? 7 \% & & 120 & 1 & ns \\
\hline \(\mathrm{f}_{\mathrm{XIN}}=1 / 19 \mathrm{t}_{\mathrm{C} 1}\) & External Timer Input Frequency & & 877 & & kHz \\
\hline \(\mathrm{t}_{\mathrm{XIN}}=3 \mathrm{t}_{\mathrm{C} 1}\) & Pulse Width for Timer Inputs & & 180 & & ns \\
\hline \(f_{\text {XOUT }}=1 / 16 \mathrm{t}_{1} 1\) & Timer Output Frequency & & 1.04 & & MHz \\
\hline \(\mathrm{f}_{\text {MW }}=1 / 19 \mathrm{t}_{\mathrm{C} 1}\) & \begin{tabular}{l}
External MICROWIRE/PLUS \\
Clock Input Frequency
\end{tabular} & & 877 & & kHz \\
\hline \(f_{U}=1 / 19 t_{C 1}\) & External UART Clock Input Frequency & & 877 & & kHz \\
\hline
\end{tabular}

Read Cycle Timing \(\mathrm{fc}_{\mathrm{c}}=16.78 \mathrm{MHz}\) with One Wait State
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \(t_{\text {ARR }}=1 / 4 \mathrm{t}_{\mathrm{C}}+5\) & ALE Trailing Edge to RD Falling Edge & & 35 & & ns . \\
\hline \(t_{\text {RW }}=1 / 2 \mathrm{t}_{\mathrm{C}}+\mathrm{WS}\) & \(\overline{\mathrm{RD}}\) Pulse Width & & 180 & & ns \\
\hline \(t_{\text {DR }}\) & \begin{tabular}{l}
Data Valid before \\
Trailing Edge of \(\overline{\mathrm{RD}}\)
\end{tabular} & & 15 & & ns \\
\hline \(t_{A C C}=t_{C}+W S-55\) & Address Valid to Input Data Valid & & 185 & & ns \\
\hline \(t_{R D}=1 / 2 t_{C}+W S-65\) & \(\overline{R D}\) Falling Edge to Data in Valid & & 115 & & ns \\
\hline \(\mathrm{t}_{\text {RDA }}=W S=\mathrm{t}_{\mathrm{C}}\) & \(\overline{\mathrm{RD}}\) Falling Edge to Address Valid & & 120 & & ns \\
\hline \(t_{V P R}=1 / 4 t_{C}+5\) & Address Valid from ALE Trailing Edge Prior to \(\overline{\mathrm{RD}}\) & & 35 & & ns \\
\hline \(t_{H Z}=3 / 4 t_{C}-10\) & End of \(\overline{\mathrm{RD}}\) to Input Data Float & & 80 & & ns \\
\hline
\end{tabular}

Write Cycle Timing \(\mathrm{f}_{\mathrm{C}}=16.78 \mathrm{MHz}\) with One Wait State
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \(t_{\text {ARW }}=1 / 2 t_{C}\) & ALE Trailing Edge to \(\overline{\text { WR Falling Edge }}\) & & 60 & & ns \\
\hline \(t_{W W}=3 / 4 t_{c}+W S+5\) & WR Pulse Width & & 215 & & ns \\
\hline \(\mathrm{t}_{\text {HW }}\) & \begin{tabular}{l}
Data Hold after \\
Trailing Edge of \(\overline{W R}\)
\end{tabular} & & 20 & & ns \\
\hline \(t v=1 / 2 t_{C}+W S+5\) & \begin{tabular}{l}
Data Valid before \\
Trailing Edge of \(\overline{W R}\)
\end{tabular} & & 185 & & ns \\
\hline \(t_{\text {VPW }}=1 / 4 t_{C}+25\) & \begin{tabular}{l}
Address Valid from \\
Trailing Edge Prior to WR
\end{tabular} & & 55 & & ns \\
\hline
\end{tabular}

Ready/Hold Timing \(\mathrm{f}_{\mathrm{C}}=16.78 \mathrm{MHz}\) with One Wait State
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \(t_{\text {DAR }}=1 / 4 t_{C}+W S-50\) & Falling Edge of ALE to Falling Edge of \(\overline{\mathrm{RDY}}\) & & 100 & & ns \\
\hline \(\mathrm{t}_{\text {RWP }}=\mathrm{t}_{\mathrm{C}}\) & \(\overline{\text { RDY Pulse Width }}\) & & 120 & & ns \\
\hline \(\mathrm{t}_{\text {SALE }}=1 / 4 \mathrm{t}^{\prime}+40\) & Falling Edge of \(\overline{\text { LD }}\) to Rising Edge of ALE & & 70 & & ns \\
\hline \(t_{\text {HWP }}=t_{C}^{17}+10{ }^{10}\) & HLD Pulse Width & & 130 & & ns \\
\hline \(t_{\text {HAD }}\) & Rising Edge on \(\overline{H L D}\) to Rising Edge on \(\overline{\text { HLDA }}\) & & 120 & & ns \\
\hline \[
\mathrm{t}_{\text {HAE }}=\mathrm{t}_{\mathrm{C}}+100 \quad 350
\] & Falling Edge on \(\overline{\text { HLD to }}\) Falling Edge on HLDA & & 220 & * & ns \\
\hline \(\mathrm{t}_{\mathrm{BF}}=\mathrm{t}_{\mathrm{C}}+30\) & Bus Float before Falling Edge on HLDA & & 150 & & ns \\
\hline \(\mathrm{t}_{\mathrm{BE}}=2 \mathrm{t}_{\mathrm{C}}+50\) & Bus Enable from Rising Edge of \(\overline{\text { HLD }}\) & & 290 & & ns \\
\hline
\end{tabular}
"Note: \(t_{\text {HAE }}\) may be as long as (3tc \(+4 \mathrm{ws}+72 \mathrm{t} \mathrm{c}+90\) ) depending on which instruction is being executed, the addressing mode and number of wait states.

Status Timing \(\mathrm{f}_{\mathrm{C}}=16.78 \mathrm{MHz}\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \(t_{\text {SRS2 }}=40-\left(1 / 4 t_{\mathrm{C}}+25\right)\) & Setup Time for ST2 on Rising Edge of ALE & & -15 & & ns \\
\hline \(t_{\text {HRS } 2}=3 / 4 \mathrm{t}_{\mathrm{C}}-15\) & Hold Time for ST2 on Rising Edge of ALE & & 75 & & ns \\
\hline \[
\mathrm{t}_{\mathrm{SFS} 2}=40-\left(1 / 4 \mathrm{t}_{\mathrm{C}}+25\right)
\] & Setup Time for ST2 on Falling Edge of ALE & & -15 & & ns \\
\hline \(t_{\text {HFS2 }}=3 / 4 t_{C}-15\) & Hold Time for ST2 on Falling Edge of ALE & & 75 & & ns \\
\hline \({ }_{\text {t }}\) SSS 1 & Setup Time for ST1 on Falling Edge of \(\overline{\mathrm{RD}}\) & & 20 & & ns \\
\hline \(\mathrm{t}_{\mathrm{HRS} 1}=1 / 2 \mathrm{t}_{\mathrm{C}}-15\) & Hold Time for ST1 on Rising Edge of \(\overline{\mathrm{RD}}\) & & 45 & & ns \\
\hline
\end{tabular}

\section*{Timing Waveforms}


Timing Waveforms (Continued)


TL/DD/8802-3


TL/DD/8802-4
FIGURE 3. Ready Mode Timing


FIGURE 4. Hold Mode TIming

\section*{Timing Waveforms (Continued)}


FIGURE 5. Status Timing

\section*{Pin Descriptions \({ }^{\dagger}\)}

\section*{I/O PORTS}

Port A is a 16-bit multiplexed address/data bus used for accessing external program and data memory. Four associated bus control signals are available on port B. The Address Latch Enable (ALE) signal is used to provide timing to demultiplex the bus. Reading from and writing to external memory are signalled by RD* and WR* respectively. External memory can be addressed as either bytes or words with the decoding controlled by two lines, Bus High Byte enable (HBE*) and Address/Data Line 0 (AO).
Port \(B\) is a 16 -bit port, with 12 bits of bidirectional I/O similar in structure to port A. Pins B10, B11, B12 and B15 are the control bus signals for the address/data bus. Port B may also be configured via a function register BFUN to individually allow each bidirectional I/O pin to have an alternate function.
\begin{tabular}{lll} 
B0: & TDX & UART Data Output \\
B1: & & \\
B2: & CKX & UART Clock (Input or Output) \\
B3: & T2IO & Timer2 I/O Pin \\
B4: & T3IO & Timer3 I/O Pin \\
B5: & SO & MICROWIRE/PLUS Output \\
B6: & SK & MICROWIRE/PLUS Clock (Input or Output) \\
B7: & HLDA* & Hold Acknowledge Output \\
B8: & TS0 & Timer Synchronous Output \\
B9: & TS1 & Timer Synchronous Output \\
B10: & ALE & Address Latch Enable Output for Address/ \\
& & Data Bus \\
B11: & WR* & Address/Data Bus Write Output \\
B12: & HBE* & High Byte Enable Output for Address/Data \\
& & Bus \\
B13: & TS2 & Timer Synchronous Output \\
B14: & TS3 & Timer Synchronous Output \\
B15: & RD* & Address/Data Bus Read Output
\end{tabular}

When operating in the extended memory addressing mode, four bits of port B can are used as follows-
\begin{tabular}{lll} 
B8: & BS0 & Memory bank switch output 0 (LSB) \\
B9: & BS1 & Memory bank switch output 1
\end{tabular}
\begin{tabular}{lll} 
B13: & BS2 & Memory bank switch output 2 \\
B14: & BS3 & Memory bank switch output 3 (MSB)
\end{tabular}

Port I is an 8 -bit input port that can be read as general purpose inputs and can also be used for the following functions:
\begin{tabular}{lll} 
10: & & \\
11: & NMI & Nonmaskable Interrupt Input \\
12: & INT2 & Maskable Interrupt/Input Capture \\
13: & INT3 & Maskable Interrupt/Input Capture \\
15: & SI & MICROWIRE/PLUS Data Input \\
16: & RDX & UART Data Input \\
17: & FS & IDL Frame Sync Input Signal
\end{tabular}

Port \(D\) is an 8 -bit input port that is used for the following functions:
\begin{tabular}{lll} 
D0: & RX1 & HDLC \# 1 Receive Data Input \\
D1: & CLK1 & HDLC \# 1 Clock Input \\
D2: & REN1 & HDLC \# 1 Receiver Enable Input \\
D3: & TEN1 & HDLC \# 1 Transmit Enable Input \\
D4: & RX2 & HDLC \# 2 Receive Data Input \\
D5: & CLK2 & HDLC \# 2 Clock Input \\
D6: & REN2 & HDLC \# 2 Receiver Enable Input \\
D7: & TEN2 & HDLC \# 2 Transmit Enable Input
\end{tabular}

Port R is an 8 -bit bidirectional I/O port available for general purpose I/O operation. Additional functions are present as indicated.
\begin{tabular}{lll} 
R0: & TX1 & HDLC \# 1 Transmit Output \\
R1: & TX2 & HDLC \# 2 Transmit Output
\end{tabular}

R2:
R3:
R4:
R5:
R6:
R7:

\footnotetext{
\({ }^{\dagger}\) The formation of the various functions into specified ports has changed. Please contact factory for updated port configurations.
}

\section*{Pin Descriptions (Continued)}

POWER SUPPLIES
\(V_{C C} \quad\) Positive Power Supply (two pins)
GND Ground for On-Chip Logic
DGND Ground for Output Buffers
CLOCK PINS
CKI The System Clock Input
CKO The System Clock Output (Inversion of CKI)
Pins CKI and CKO are usually connected across an external crystal.
CK2 Clock Output (CKI divided by 2)

\section*{OTHER PINS}

WO This is an active low open drain output which signals an illegal situation has been detected by the Watch Dog logic.
ST1 Bus Cycle Status Output indicates first opcode fetch.
ST2 Bus Cycle Status Output indicates machine states (skip and interrupt).
RESET Active low input that forces the chip to restart and sets the ports in a TRI-STATE mode.
RDY/HLD Has two uses, selected by a software bit. This pin is either a READY input to extend the bus cycle for slower memories or a HOLD-REQUEST input to put the bus in a high impedance state for external DMA purposes.
EXM External memory enable which must be tied high for normal operation.

\section*{Connection Diagram *}

Plastic and Leadless Chip Carriers

*The Pin Configuration has changed. Please contact factory for updated pin placement information.

\section*{Wait States}

The HPC16400 provides four software selectable Wait States that allow access to slower memories. The Wait States are selected by the state of two bits in the PSW register. Additionally, the RDY input may be used to extend the instruction cycle, allowing the user to interface with slow memories and peripherals.

\section*{Power Save Modes}

Two power saving modes are available on the HPC16400: HALT and IDLE. In the HALT mode, all processor activities are stopped. In the IDLE mode, the on-board oscillator and timer TO are active but all other processor activities are stopped. In either mode, all on-board RAM, registers and I/O aretunaffected.

\section*{HALT MODE}

The HPC16400 is placed in the HALT mode under software control by setting bits in the PSW. All processor activities,
including the clock and timers, are stopped. In the HALT mode, power requirements for the HPC16400 are minimal and the applied voltage ( \(\mathrm{V}_{\mathrm{CC}}\) ) may be decreased without altering the state of the machine. There are two ways of exiting the HALT mode: via the RESET or the NMI. The RESET input reinitializes the processor. Use of the NMI input will generate a vectored interrupt and resume operation from that point with no initialization. The HALT mode can be enabled or disabled by means of a control register HALT enable. To prevent accidental use of the HALT mode the HALT enable register can be modified only once.

\section*{IDLE MODE}

The HPC16400 is placed in the IDLE mode through the PSW. In this mode, all processor activity, except the onboard oscillator and Timer TO, is stopped. The HPC16400 resumes normal operation upon timer T0 overflow. As with the HALT mode, the processor is returned to full operation by the RESET or NMI inputs, but without waiting for oscillator stabilization.

\section*{HPC16400 Interrupts}

Complex interrupt handling is easily accomplished by the HPC16400's vectored interrupt scheme. There are eight possible interrupt sources as shown in Table I.

TABLE I. Interrupts
\begin{tabular}{|c|l|c|}
\hline \begin{tabular}{c} 
Vector/ \\
Address
\end{tabular} & \multicolumn{1}{|c|}{ Interrupt Source } & \begin{tabular}{c} 
Arbltration \\
Ranking
\end{tabular} \\
\hline FFFF|FFFE & Reset & 0 \\
\hline FFFD|FFFC & Nonmaskable Ext (NMI) & 1 \\
\hline FFFB|FFFA & External on I2 & 2 \\
\hline FFF9|FFF8 & External on I3 & 3 \\
\hline FFF7|FFF6 & HDLC/DMA Error & 4 \\
\hline FFF5|FFF4 & Overflow on Timers & 5 \\
\hline FFF3|FFF2 & Internal on UART & 6 \\
\hline FFF1|FFF0 & End of Message (EOM) & 7 \\
\hline
\end{tabular}

The 16400 contains arbitration logic to determine which interrupt will be serviced first if two or more interrupts occur simultaneously. Interrupts are serviced after the current instruction is completed except for the RESET which is serviced immediately.
The NMI interrupt will immediately stop DMA activity-byte transfers in progress will finish thereby allowing an orderly transition to the interrupt service vector (see DMA description). The HDLC channels continue to operate, and the user must service data errors that might have occurred during the NMI service routine.

\section*{Interrupt Processing}

Interrupts are serviced after the current instruction is completed except for the RESET, which is serviced immediately.
RESET is a level-sensitive interrupt. All other interrupts are edge-sensitive. NMI is positive-edge sensitive. The external interrupts on I2, 13 can be software selected to be rising or falling edge.

\section*{Interrupt Control Registers}

The HPC16400 allows the various interrupt sources and conditions to be programmed. This is done through the various control registers. A brief description of the different control registers is given below.

\section*{INTERRUPT ENABLE REGISTER (ENIR)}

RESET and the External Interrupt on 11 are non-maskable interrupts. The other interrupts can be individually enabled or disabled. Additionally, a Global Interrupt Enable Bit in the ENIR Register allows the Maskable interrupts to be collectively enabled or disabled. Thus, in order for a particular interrupt to be serviced, both the individual enable bit and the Global Interrupt bit (GIE) have to be set.

\section*{INTERRUPT PENDING REGISTER (IRPD)}

The IRPD register contains a bit allocated for each interrupt vector. The occurrence of specified interrupt trigger conditions causes the appropriate bit to be set. There is no indication of the order in which the interrupts have been received. The bits are set independently of the fact that the interrupts may be disabled. IRPD is a Read/Write register. The bits corresponding to the maskable, external interrupts are normally cleared by the HPC16400 after servicing the interrupts.

For the interrupts from the on-board peripherals, the user has the responsibility of resetting the interrupt pending flags through software.

\section*{INTERRUPT CONDITION REGISTER (IRCD)}

Three bits of the register select the input polarity of the external interrupt on 12,13 , and 14 .

\section*{Servicing the Interrupts}

The Interrupt, once acknowledged, pushes the program counter (PC) onto the stack thus incrementing the stack pointer (SP) twice. The Global Interrupt Enable (GIE) bit is reset, thus disabling further interrupts. The program counter is loaded with the contents of the memory at the vector address and the processor resumes operation at this point. At the end of the interrupt service routine, the user does a RETI instruction to pop the stack, set the GIE bit and return to the main program. The GIE bit can be set in the interrupt service routine to nest interrupts if desired. Figure 6 shows the Interrupt Enable Logic.

\section*{Reset}

The RESET input initializes the processor and sets ports \(A\), \(B\), and \(P\) in the TRI-STATE condition. RESET is an activelow Schmitt trigger input. The processor vectors to FFFF:FFFE and resumes operation at the address contained at that memory location.

\section*{Timer Overview}

The HPC16400 contains a powerful set of flexible timors enabling the HPC16400 to perform extensive timer functions; not usually associated with microcontrollers.
The HPC16400 contains eight 16-bit timers. Each timer has an associated 16 -bit register. Timer TO is a free-running timer, counting up at a fixed CKI/16 (Clock Input/16) rate. It is used for Watch Dog logic, high speed event capture, and to exit from the IDLE mode. Consequently, it cannot be stopped or written to under software control. Timer TO permits precise measurements by means of the capture registers I2CR, I3CR, and I4CR. A control bit in the register TMMODE configures timer T1 and its associated register R1 as capture registers I3CR and I2CR. The capture registers I2CR, I3CR, and I4CR respectively, record the value of timer TO when specific events occur on the interrupt pins I2, 13 , and 14 . The control register IRCD programs the capture registers to trigger on either a rising edge or a falling edge of its respective input. The specified edge can also be programmed to generate an interrupt (see Figure 7).
The timers T2 and T3 have selectable clock rates. The clock input to these two timers may be selected from the following two sources: an external pin, or derived internally by dividing the clock input. Timer T2 has additional capability of being clocked by the timer T3 underflow. This allows the user to cascade timers T3 and T2 into a 32-bit timer/ counter. The control register DIVBY programs the clock input to timers T2 and T3 (see Figure 8).
The timers T1 through T7 in conjunction with their registers form Timer-Register pairs. The registers hold the pulse duration values. All the Timer-Register pairs can be read from or written to. Each timer can be started or stopped under software control. Once enabled, the timers count down, and upon underflow, the contents of its associated register are automatically loaded into the timer.

Timer Overview (Continued)


TL/DD/8802-8
FIGURE 6. Interrupt Enable Logic


FIGURE 8. TImers T2-T3 Block

Timer Overview (Continued)


TL/DD/8802-9
FIGURE 7. Timers T0-T1 Block

\section*{SYNCHRONOUS OUTPUTS}

The flexible timer structure of the HPC16400 simplifies pulse generation and measurement. There are four synchronous timer outputs (TS0 through TS3) that work in conjunction with the timer T2. The synchronous timer outputs can be used either as regular outputs or individually programmed to toggle on timer T2 underflows (see Figure 8).
Timer/register pairs 4-7 form four identical units which can generate synchronous outputs on port P (see Figure 9).


TL/DD/8802-11
FIGURE 9. TImers T4-T7 Block

\section*{Timer Registers}

There are four control registers that program the timers. The divide by (DIVBY) register programs the clock input to timers T2 and T3. The timer mode register (TMMODE) contains control bits to start and stop timers T1 through T3. It also contains bits to latch and enable interrupts from timers TO through T3. The control register PWMODE similarly programs the pulse width timers T4 through T7 by allowing them to be started, stopped, and to latch and enable interrupts on underflows. The PORTP register contains bits to
preset the outputs and enable the synchronous timer output functions.

\section*{Timer Applications}

The use of Pulse Width Timers for the generation of various waveforms is easily accomplished by the HPC16400.
Frequencies can be generated by using the timer/register pairs. A square wave is generated when the register value is a constant. The duty cycle can be controlled simply by changing the register value.


TL/DD/8802-12
FIGURE 10. Square Wave Frequency Generation
Synchronous outputs based on Timer T2 can be generated on the 4 outputs TSO-TS3. Each output can be individually programmed to toggle on T2 underflow. Register R2 contains the time delay between events. Figure 11 is an example of synchronous pulse train generation.


FIGURE 11. Synchronous Pulse Generation

\section*{Watch Dog Logic}

The Watch Dog Logic monitors the operations taking place and signals upon the occurrence of any illegal activity. The illegal conditions that trigger the Watch Dog logic are potentially infinite loops and illegal addresses. Should the Watch Dog register not be written to before Timer TO overflows twice, or more often than once every 4096 counts, an infinite loop condition is assumed to have occurred. The illegal condition forces the Watch Out (WO) pin low. The WO pin is an open drain output and can be connected to the RESET or NMI inputs or to the users external logic.

\section*{MICROWIRE/PLUS}

MICROWIRE/PLUS is used for synchronous serial data communications (see Figure 12). MICROWIRE/PLUS has an 8-bit parallel-loaded, serial shift register using SI as the input and SO as the output. SK is the clock for the serial shift register (SIO). The SK clock signal can be provided by an internal or external source. The internal clock rate is programmable by the DIVBY register. A DONE flag indicates when the data shift is completed.
The MICROWIRE/PLUS capability enables it to interface with any of National Semiconductor's MICROWIRE peripherals (i.e., A/D converters, display drivers, EEPROMs).


TL/DD/8802-14

\section*{FIGURE 12. MICROWIRE/PLUS}

\section*{MICROWIRE/PLUS Operation}

The HPC16400 can enter the MICROWIRE/PLUS mode as the master or a slave. A control bit in the IRCD register determines whether the HPC16400 is the master or slave. The shift clock is generated when the HPC16400 is configured as a master. An externally generated shift clock on the SK pin is used when the HPC16400 is configured as a slave. When the HPC16400 is a master, the DIVBY register programs the frequency of the SK clock. The DIVBY register allows the SK clock frequency to be programmed in 15 selectable steps from 64 Hz to 1 MHz with CKI at 17.0 MHz .
The contents of the SIO register may be accessed through any of the memory access instructions. Data waiting to be transmitted in the SIO register is clocked out on the falling edge of the SK clock. Serial data on the SI pin is clocked in on the rising edge of the SK clock.

\section*{HPC16400 UART}

The HPC16400 contains a software programmable UART. The UART (see Figure 13) consists of a transmit shift register, a receiver shift register and five addressable registers, as follows: a transmit buffer register (TBUF), a receiver buffer register (RBUF), a UART control and status register (ENU), a UART receive control and status register (ENUR) and a UART interrupt and clock source register (ENUI). The ENU register contains flags for transmit and receive functions; this register also determines the length of the data frame ( 8 or 9 bits) and the value of the ninth bit in transmission. The ENUR register flags framing and data overrun errors while the UART is receiving. Other functions of the ENUR register include saving the ninth bit received in the data frame and enabling or disabling the UART's Wake-up Mode of operation. The determination of an internal or external clock source is done by the ENUl register, as well as selecting the number of stop bits and enabling or disabling transmit and receive interrupts.
The baud rate clock for the Receiver and Transmitter can be selected for either an internal or external source using two bits in the ENUI register. The internal baud rate is programmed by the DIVBY register. The baud rate may be selected from a range of 8 Hz to 128 kHz in binary steps or T3 underflow. By selecting a baud rate crystal, all standard
baud rates from 75 baud to 38.4 kbaud can be generated. The external baud clock source comes from the CKX pin. The Transmitter and Receiver can be run at different rates by selecting one to operate from the internal clock and the other from an external source.
The HPC16400 UART supports two data formats. The first format for data transmission consists of one start bit, eight


FIGURE 13. UART Block Diagram

\section*{HPC16400 UART (Continued)}
lata bits and one or two stop bits. The second data format or transmission consists of one start bit, nine data bits, and me or two stop bits. Receiving formats differ from transmis;ion only in that the Receiver always requires only one stop it in a data frame.

\section*{JART Wake-up Mode}

The HPC16400 UART features a Wake-up Mode of operaion. This mode of operation enables the HPC16400 to be retworked with other processors. Typically in such environnents, the messages consist of addresses and actual data. tddresses are specified by having the ninth bit in the data rame set to 1 . Data in the message is specified by having he ninth bit in the data frame reset to 0 .
The UART monitors the communication stream looking for addresses. When the data word with the ninth bit set is eceived, the UART signals the HPC16400 with an interrupt. The processor then examines the content of the receiver uuffer to decide whether it has been addressed and whether o accept subsequent data.

\section*{Programmable Serial Decoder Interface}

The programmable serial decoder interface allows the two -IDLC channels to be used with devices employing several oopular serial protocols for point-to-point and multipoint data exchanges. These protocols combine the ' \(B\) ' and ' \(D\) ' shannels onto common pins-received data, transmit data, slock and Sync, which normally occurs at an 8 KHz rate and provides framing for the particular protocol.
The decoder uses the serial link clock and Sync signals to generate internal enables for the ' \(D\) ' and ' \(B\) ' channels, thereby allowing the HDLC channels to access the appropriate channel data from the multiplexed link.

\section*{HDLC Channel Description}

HDLC/DMA Structure
\begin{tabular}{|c|c|c|c|}
\multicolumn{2}{c}{ HDLC 1 } & \multicolumn{2}{c}{ HDLC 2 } \\
\begin{tabular}{|c|c|c|}
\hline HDLC1 & HDLC1 & HDLC2 \\
Receive & Transmit & Receive \\
\hline Transmit \\
\hline DMAR1 & DMAT1 & DMAR2
\end{tabular} DMAT2 \\
\hline
\end{tabular}

\section*{GENERAL INFORMATION}

Both HDLC channels on the HPC16400 are identical and operate up to 4.1 Mbps. When used in an ISDN basic access application, HDLC channel \#1 has been designated for use with the 16 Kbps D-channel or the B1 channel and HDLC \#2 can be used with either of the 64 Kbps B-channels. If the ' \(D\) ' and ' \(B\) ' channels are present on a common serial link, the programmable serial decoder interface generates the necessary enable signals needed to access the D and B channel data.
LAPD, the Link Access Protocol for the D channel is derived from the X. 25 packet switching LAPB protocol. LAPD specifies the procedure for a terminal to use the \(D\) channel for the transfer of call control or user-data information. The procedure is used in both point-to-point and point-to-multipoint configurations. On the 16400, the HDLC controller contains user programmable features that allow for the efficient processing of LAPD Information.

\section*{HDLC Channel Pin Description}

RX - Receive Serial Data Input. Data clocked in on positive CLK edge.
CLK - HDLC Channel Clock Input Signal.
REN - HDLC Channel Receiver Enable Input.
TX - Transmit Serial Data Output. Data clocked out on negative CLK edge.
TEN - HDLC Channel Transmitter Enable Input.

\section*{HDLC Functional Description}

\section*{TRANSMITTER DESCRIPTION}

Data information is transferred from external memory through the DMA controller into the transmit buffer register from where it is loaded into a 8 -bit serial shift registers. The CRC is computed and appended to the frame prior to the closing flag being transmitted. Data is output at the TX output pin. If no further transmit commands are given the transmitter sends out continous flags or the idle pattern as selected by the control register.
An interrupt is generated when the transmit shift register is empty or on a transmit error condition. An assoicated transmit status register will contain the status information indicating the specific interrupt source.

\section*{TRANSMITTER FEATURES}

Interframe fill: the transmitter can send either continuous ' 1 's or repeated flags between the closing flag or one packet and the opening flag of the next. When the CPU commands the transmitter to open a new frame, the interframe fill is terminated immediately.
Abort: the 7 ' 1 's abort sequence will be immediately sent on command from the CPU. If required it may be followed by a new opening flag to resend the aborted packet.
Bit/Byte boundaries: The message length between packet headers may have any number of bits and is not confined to byte boundaries. Three bits in the control register are used to indicate the number of valid bits in the last byte when operating in the bit mode. These bits are loaded by the users software.

\section*{RECEIVER DESCRIPTION}

Data is input to the receiver on the RX pin. The receive clock can be externally input at the HDLC CLK pin, or it can be internally generated via the programmable timer chain.
Incoming data is routed through one of several paths depending on whether it is the flag, data, or CRC.
Once the receiver is enabled it waits for the opening flag of the incoming frame, then starts the zero bit deletion, addressing handling and CRC checking. All data between the flags is shifted through two 8 -bit serial shift registers before being loaded into the buffer register. The user programmable address register values are compared to the incoming data while it resides in the shift registers. If an address match occurs or if operating in the transparent mode, the DMA channel is signaled that attention is required and the byte is transferred by it to external memory. Appropriate interrupts are generated to the CPU on the reception of a complete frame as indicated by a correct CRC, or on the occurance of a frame error.

\section*{HDLC Functional Description}
(Continued)

There are two sources for the receive channel enable signal. It can be internally generated from the serial interface or it can be externally enabled.
The receive interrupt, in conjunction with status data in the control registers allows interrupts to be generated on the following conditions-CRC error, receive error and receive complete.

\section*{RECEIVER FEATURES}

Flag sharing: the closing flag of one packet may be shared as the opening flag of the next. Receiver will be able to share a zero between flags- 0111111011111110 is a valid two flag sequence for receive (not transmit).

Interframe fill: the receiver automatically accepts either repeated flags or all ' 1 's as the interframe fill.
Idle: Reception of successive 1's as the interframe fill sequence to be signaled to the user by setting the Idle bit in the Receive control and status register.
Short Frame Rejection: Reception of less than 4 bytes between flags will generate a frame error, terminating reception of the current frame and setting the Frame Error (FER) status bit in the Receive Control and Status register.
Abort: the 7 ' 1 's abort sequence (received with no zero insertion) will be immediately recognized and will cause the receiver to reinitialize and return to searching the incoming data for an opening flag. Reception of the abort will cause the abort status bit in the Interrupt Error Status register to be set.
Bit/Byte boundaries: The message length between packet headers may have any number of bits and it is not confined to byte boundaries. Three bits in the status register are used to indicate the number of valid bits in the last byte when operating in the bit mode.
Addressing: Two user programmable bytes are available to allow frame address recognition on the two bytes immediately following the opening flag. When the received address matches the programmed value(s), the frame is passed through to the DMA channel. If no match occurs, the received frame address information is disregarded and he receiver returns to searching for the next opening flag and the address recognition process starts anew.

Support is provided to allow recognition of the broadcast address sequence of seven consecutive 1's. Additionally, a transparent mode of operation is available where no address decoding is done.

\section*{HDLC INTERRUPT CONDITIONS}

The end of message interrupt (EOM) indicates that a complete frame has been received or transmitted by the HDLC controller. Thus, there are four separate sources for this interrupt, two each from each HDLC channel. The Message Control Register contains the pending bits for each source.
The HDLC/DMA error interrupt groups several related error conditions. Error conditions from both transmit/receiver channels can cause this interrupt, and the possible sources each have a status bit in the below register that is set on the occurrence of an error. The bit must then be serviced by the user.

\section*{HDLC CHANNEL CLOCK}

Each HDLC channel uses the rising edge of the clock to sample the receive data. Outgoing transmit data is shifted

\footnotetext{
*The specific registers and/or register names may have changed. Please contact the factory for updated information.
}
out on the falling edge of the external clock. The maximum data rate when using the externally provided clocks is 4.1 \(\mathrm{Mb} / \mathrm{s}\).

\section*{CYCLIC REDUNDACY CHECK}

There are two standard CRC codes used in generating the 16-bit Frame Check Sequence (FCS) that is appended tc the end of the data frame. Both codes are supported anc the user selects the error checking code to be used througr software control (Configuration reg). The two error checkins polynomials available are:
```

(1) CRC-16 (x16 + x15 + x2 +1)
(2) CCITT CRC (x16 + x12 + x5 + 1)

```

\section*{LOOP BACK OPERATIONAL MODE}

The user has the ability, by appropriately configuring the control registers, to internally route the transmitter output a the TX pin to the receiver input at the RX pin. The transmi clock would then be internally connected to the receive clock.

\section*{DMA Controller*}

\section*{GENERAL INFORMATION}

The HPC16400 uses Direct Memory Access (DMA) logic to facilitate data transfer between the 2 full Duplex HDLC channels and external packet RAM. There are four DMA channels to support the four individual HDLC channels. Control of the DMA channels is accomplished through registers which are configured by the CPU. These control registers define specific operation of each channel and changes are immediately reflected in DMA operation. In addition to individual control registers, a global control bit (MSS in Message Control Register) is available so that the HDLC channels may be globally controlled.
The DMA issues a bus request to the CPU when one or more of the individual HDLC channels request service. Upon receiving a bus acknowledge from the CPU, the DMA completes all requests pending and any requests that may have occurred during DMA operation before returning control to the CPU. If no further DMA transfers are pending, the DMA relinquishes the bus and the CPU can again initiate a bus cycle.

Four memory expansion bits have been added for each of the four channels to support data transfers into the expanded memory bank areas.
The DMA has priority logic for a DMA requesting service. The priorities are:

```

2nd priority . . . . . . . . . . . . . . . . . Transmit channel 1
3rd priority . . . . . . . . . . . . . . . . . . . Receive channel 2
4th priority
Transmit channel 2

```

\section*{RECEIVER DMA OPERATION}

A receiver DMA operation is initiated by the Buffer register. Once a byte has been placed in the Buffer register from the HDLC, it generates a request and upon obtaining control of the bus, the DMA places the byte in external memory.

\section*{RECEIVER REGISTERS}

All the following registers are Read/Write
A. Frame Length Register

This user programmable 16-bit register contains the maximum number of bytes to be placed in a data "block". If

\section*{JMA Controller (Continued)}
this number is exceeded, a Frame Too Long (FTLR1, FTLR2) error is generated. This register is decremented by one each Receiver DMA cycle.
3. CNTRL ADDR 1 The CNTRL ADDR register contains DATA ADDR 1 CNTRL ADDR 2 DATA ADDR 2 the external memory address where the Frame Header (Control \& Address fields) are to be stored and the DATA ADDR register contains an equivalent
address for the Information field.

\section*{'RANSMITTER DMA OPERATION}

I transmitter DMA cycle is initiated by the TX Data Buffer TDB). The TX Data Buffer generates a request when empty ind the DMA responds by placing a Byte in the TDB. The IDLC transmitter can then accept the Byte to send when leeded, upon which the TDB will issue another request, reulting in a subsequent DMA cycle.

\section*{-RANSMITTER REGISTERS}
he following registers are Read/Write:
1. Field Address 1 (FA1) \# Bytes Field 1 (NBF1) Field Address (FA2) \# Bytes Field 2 (NBF2)

FA1 and FA2 are starting addresses of blocks of information to transmitter.
NBF1 and NBF2 are the number of bytes in the block to be transmitted starting the FA1.

The following registers are Read only:
3. Working Field Address (WFA)

Working Number of Bytes (WNB)
WFA is the present value of the Field address and will be the next memory location where the next byte will be accessed. WNB is the present value of the number of
bytes to be transmitted. The value will be the number of bytes to be fetched from memory before the block information transfer is completed. On each transmit DMA cycle, WFA is incremented and WNB is decremented.

\section*{Shared Memory Support}

Shared memory access provides a rapid technique to exchange data. It is effective when data is moved from a peripheral to memory or when data is moved between blocks of memory. A related area where shared memory access proves effective in multiprocessing applications where two CPUs share a common memory block. The HPC16400 supports shared memory access with two pins. The pins are the RDY/ \(\overline{H L D}\) input pin and the \(\overline{H L D A}\) output pin. The user can software select either the Hold or Ready function by the state of a control bit. The HLDA output is multiplexed onto port B.
The host uses DMA to interface with the HPC16400. The host initiates a data transfer by activating the HLD input of the HPC16400. In response, the HPC16400 places its system bus in a TRI-STATE Mode, freeing it for use by the host. The host waits for the acknowledge signal ( HLDA ) from the HPC16400 indicating that the sytem bus is free. On receiving the acknowledge, the host can rapidly transfer data into, or out of, the shared memory by using a conventional DMA controller. Upon completion of the message transfer, the host removes the HOLD request and the HPC16400 resumes normal operations.
Figure 14 illustrates an application of the shared memory interface between the HPC16400 and a Series 32000 system.


TL/DD/8802-16
FIGURE 14. Shared Memory Application: HPC16400 Interface to Series 32000 System

\section*{Memory}

The HPC16400 has been designed to offer flexibility in memory usage. A total address space of 64 kbytes can be addressed with 256 bytes of RAM available on the chip itself.
Program memory addressing is accomplished by the 16 -bit program counter on a byte basis. Memory can be addressed directly by instructions or indirectly through the \(B, X\) and SP registers. Memory can be addressed as words or bytes. Words are always addressed on even-byte boundaries. The HPC16400 uses memory-mapped organization to support registers, I/O and on-chip peripheral functions.
The HPC16400 memory address space extends to 64 kbytes and registers and I/O are mapped as shown in Table II.
lows four I/O lines of Port B (B9, B10, B13, B14) to be used in extending the address range. This gives the user a main routine area of 32 k and 16 banks of 32 k each for subroutine and data, thus getting a total of 544 k of memory.
The Extended Memory Addressing mode is entered by setting the EMA control bit in the Message Control Register. If this bit is not set, the port B lines (B9, B10, B13, B14) are available as general purpose I/O or synchronous outputs as selected by the BFUN register.
The main memory area contains the interrupt vectors \& service routines, stack memory, and common memory for the bank subroutines to use. The 16 banks of memory can contain program or data memory (note- since the on chip resources are mapped into addresses \(0000-01 \mathrm{FF}\), the first 512 bytes of each bank are not usable).

\section*{Extended Memory Addressing}

If more than' 64 k of addressing is desired in a HPC16400 system, on board bank select circuitry is available that al-

TABLE II. Memory Map*
\begin{tabular}{|c|c|c|}
\hline FFFF:FFFO FFEF:FFD0 & Interrupt Vectors JSRP Vectors & \\
\hline \[
\begin{gathered}
\text { FFCF:FFCE } \\
\vdots \vdots \\
\vdots \\
0201: 0200
\end{gathered}
\] & External expansion Memory & USER MEMORY \\
\hline \[
\begin{gathered}
\text { 01FF:01FE } \\
\vdots \\
\vdots \\
01 \mathrm{C} 1: 01 \mathrm{C0}
\end{gathered}
\] & On Chip RAM & \\
\hline \begin{tabular}{l}
01BB:01BA \\
0189:01B8 \\
01B7:01B6 \\
01B5:01B4 \\
01B3:01B2 \\
01B1:01B0
\end{tabular} & Configuration Reg Rec Addr Comp Reg 2 Rec Addr Comp Reg 1 Interrupt Error Stat Xmit Cntrl \& Status Recv Cntrl \& Status & HDLC \# 2 \\
\hline \begin{tabular}{l}
01AB:01AA \\
01A9:01A8 \\
01A7:01A6 \\
01A5:01A4 \\
01A3:01A2 \\
01A1:01A0
\end{tabular} & Configuration Reg Rec Addr Comp Reg 2 Rec Addr Comp Reg 1 Interrupt Error Stat Xmit Cntrl \& Status Recv Cntri \& Status & HDLC \# 1 \\
\hline 0195:0194 & Watch Dog Address & Watch Dog Logic \\
\hline \begin{tabular}{l}
0193:0192 \\
0191:0190 \\
018F:018E \\
018D:018C \\
018B:018A \\
0189:0188 \\
0187:0186 \\
0185:0184 \\
0183:0182 \\
0181:0180
\end{tabular} & \begin{tabular}{l}
TOCON Register TMMODE Register DIVBY Register \\
T3 Timer R3 Register T2 Timer R2 Register I2CR Register/ R1 I3CR Register/ T1 14CR Register
\end{tabular} & Timer Block T0:T3 \\
\hline \begin{tabular}{l}
017D:017C \\
017B:017A \\
0179:0178 \\
0177:0176 \\
0175:0174 \\
0173:0172 \\
0171:0170
\end{tabular} & \begin{tabular}{l}
Working \# Bỹtes \\
Working Field Addr \\
\# Bytes 2 \\
Field Addr 2 \\
\# Bytes 1 \\
Field Addr 1 \\
Xmit Cntrl \& Status
\end{tabular} & DMAT \# 2 (Xmit) \\
\hline \begin{tabular}{l}
016B:016A \\
0169:0168 \\
0167:0166 \\
0165:0164 \\
0163:0162 \\
0161:0160
\end{tabular} & \begin{tabular}{l}
Frame Length \\
Data Addr 2 \\
Cntrl Addr 2 \\
Data Addr 1 \\
Cntrl Addr 1 \\
Recv Cntrl \& Status
\end{tabular} & DMAR \# 2 (Recv) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline \[
\begin{aligned}
& \hline 015 \mathrm{D}: 015 \mathrm{C} \\
& 015 \mathrm{~B}: 015 \mathrm{~A} \\
& 015: 0158 \\
& 0157: 0156 \\
& 0155: 0154 \\
& 015: 0152 \\
& 0151: 0150 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
Working \# Bytes \\
Working Field Addr \\
\# Bytes 2 \\
Field Addr 2 \\
* Bytes 1 \\
Field Addr 1 \\
Xmit Cntrl \& Status
\end{tabular} & DMAT \# 1 (Xmit) \\
\hline \[
\begin{aligned}
& \hline \text { 014B:014A } \\
& 0149: 0148 \\
& \text { 0147:0146 } \\
& \text { 0145:0144 } \\
& 0143: 0142 \\
& 0141: 0140
\end{aligned}
\] & \begin{tabular}{l}
Frame Length Data Addr 2 \\
Cntrl Addr 2 \\
Data Addr 1 \\
Cntrl Addr 1 \\
Recv Cntrl \& Status
\end{tabular} & DMAR \# 1 (Recv) \\
\hline 0131:0130 & Message Control & \\
\hline \[
\begin{aligned}
& 0128 \\
& 0126 \\
& 0124 \\
& 0122 \\
& 0120
\end{aligned}
\] & ENUR register TBUF register RBUF register ENIU register ENU register & UART \\
\hline \begin{tabular}{l}
0107:0106 \\
0105:0104 \\
0103:0102 \\
0101:0100
\end{tabular} & DIR R register Port R register Serial Decoder Port D register & PORTS \\
\hline 00F5:00F4 00F3:00F2 00F1:00F0 & BFUN register DIR B register DIR A register & PORTS A \& B CONTROL \\
\hline 00E7:00E6 & Reserved & \\
\hline \[
\begin{aligned}
& \text { OOE3:00E2 } \\
& \text { OOE1:00E0 }
\end{aligned}
\] & Port B Port A & PORTS A \& B \\
\hline \begin{tabular}{l} 
OODE \\
OODD:00DC \\
OOD8 \\
00D6 \\
00D4 \\
00D2 \\
OODO \\
\hline
\end{tabular} & \begin{tabular}{l}
Microcode ROM dump \\
Halt Enable register \\
Port I input register \\
SIO register \\
IRCD register \\
IRPD register \\
ENIR register
\end{tabular} & PORT CONTROL \& INTERRUPT CONTROL REGISTERS \\
\hline 00CF:00CE 00CD:00CC 00CB:00CA 00C9:00C8 00C7:00C6 00C5:00C4 00C3:00C2 00C1:00C0 & X register B register K register A register PC register SP register (reserved) PSW register & HPC10640 CORE REGISTERS \\
\hline \[
\begin{gathered}
\text { OOBF:00BE } \\
\vdots \\
0001: 0000
\end{gathered}
\] & On Chip RAM & USER RAM \\
\hline
\end{tabular}

\footnotetext{
*The Memory Map has changed. Please contact factory for an updated version of the Memory Map.
}

\section*{HPC16400 CPU}

The HPC16400 CPU has a 16 －bit ALU and six 16 －bit regis－ ters．

\section*{Arlthmetic Logic Unit（ALU）}

The ALU is 16 bits wide and can do 16 －bit add，subtract and shift or logic AND，OR and exclusive OR in one timing cycle． The ALU can also output the carry bit to a 1 －bit C register．

\section*{Accumulator（A）Register}

The 16 －bit A register is the source and destination register for most I／O，arithmetic，logic and data memory access op－ erations．

\section*{Address（ B and X ）Registers}

The 16 －bit \(B\) and \(X\) registers can be used for indirect ad－ dressing．They can automatically count up or down to se－ quence through data memory．

\section*{Boundary（K）Register}

The 16 －bit K register is used to set limits in repetitive loops of code as register B sequences through data memory．

\section*{Stack Pointer（SP）Register}

The 16 －bit SP register is the stack pointer that addresses the stack．The SP register is incremented by two for each push or call and decremented by two for each pop or return． The stack can be placed anywhere in user memory and be as deep as the available memory permits．

\section*{Program（PC）Register}

The 16 －bit PC register addresses program memory．

\section*{Addressing Modes}

\section*{ADDRESSING MODES－ACCUMULATOR AS DESTINATION}

\section*{Register Indirect}

This is the＂normal＂mode of addressing for the HPC16400 （instructions are single－byte）．The operand is the memory addressed by the \(B\) register（or \(X\) register for some instruc－ tions）．

\section*{Direct}

The instruction contains an 8 －bit or 16 －bit address field that directly points to the memory for the operand．

\section*{Indirect}

The instruction contains an 8 －bit address field．The contents of the WORD addressed points to the memory for the oper－ and．

\section*{Indexed}

The instruction contains an 8－bit address field and an 8－or 16 －bit displacement field．The contents of the WORD ad－ dressed is added to the displacement to get the address of the operand．
Immediate
The instruction contains an 8 －bit or 16 －bit immediate field that is used as the operand．

\section*{Register Indirect（Auto Increment and Decrement）}

The operand is the memory addressed by the X register． This mode automatically increments or decrements the X register（by 1 for bytes and by 2 for words）．
Register Indirect（Auto Increment and Decrement）with Conditional Skip
The operand is the memory addressed by the B register． This mode automatically increments or decrements the B register（by 1 for bytes and by 2 for words）．The B register is then compared with the K register．A skip condition is gener－ ated if \(B\) goes past \(K\) ．

\section*{ADDRESSING MODES－DIRECT MEMORY AS DESTINATION \\ Direct Memory to Direct Memory}

The instruction contains two 8 －or 16 －bit address fields．One field directly points to the source operand and the other field directly points to the destination operand．

\section*{Immediate to Direct Memory}

The instruction contains an 8 －or 16 －bit address field and an 8 －or 16 －bit immediate field．The immediate field is the oper－ and and the direct field is the destination．

\section*{Double Register Indirect using the \(B\) and \(X\) Registers}

Used only with Reset，Set and IF bit instructions；a specific bit within the 64 kbyte address range is addressed using the \(B\) and \(X\) registers．The address of a byte of memory is formed by adding the contents of the B register to the most significant 13 bits of the X register．The specific bit to be modified or tested within the byte of memory is selected using the least significant 3 bits of register X ．


HPC Instruction Set Description (Continued)
\begin{tabular}{|c|c|c|}
\hline Mnemonic & Description & Action \\
\hline \multicolumn{3}{|l|}{TRANSFER OF CONTROL INSTRUCTIONS} \\
\hline JSRP & Jump subroutine from table & \[
\begin{gathered}
\mathrm{PC} \rightarrow \mathrm{~W}(\mathrm{SP}), \mathrm{SP}+2 \rightarrow \mathrm{SP} \\
\mathrm{~W}(\text { table } \#) \rightarrow \mathrm{PC}
\end{gathered}
\] \\
\hline JSR & Jump subroutine relative & \[
\begin{aligned}
& \mathrm{PC} \rightarrow \mathrm{~W}(\mathrm{SP}), \mathrm{SP}+2 \rightarrow \mathrm{SP}, \mathrm{PC}+\# \rightarrow \mathrm{PC} \\
& (\# \text { is }+1024 \text { to }-1023 \text { ) }
\end{aligned}
\] \\
\hline JSRL & Jump subroutine long & \(\mathrm{PC} \rightarrow \mathrm{W}(\mathrm{SP}), \mathrm{SP}+2 \rightarrow \mathrm{SP}, \mathrm{PC}+\# \rightarrow \mathrm{PC}\) \\
\hline JP & Jump relative short & PC+ \# \(\rightarrow\) PC(\# is + 32 to -31 ) \\
\hline JMP & Jump relative & \(\mathrm{PC}+\) \# \(\rightarrow \mathrm{PC}(\#\) is +256 to -255) \\
\hline JMPL & Jump relative long & PC+ \# \(\rightarrow\) PC \\
\hline JID & Jump indirect at PC + A & \(P C+A+1 \rightarrow P C\) \\
\hline JIDW & & then \(\mathrm{Mem}(\mathrm{PC})+\mathrm{PC} \rightarrow \mathrm{PC}\) \\
\hline NOP & No Operation & \(P C \leftarrow P C+1\) \\
\hline RET & Return & \(\mathrm{SP}-2 \rightarrow \mathrm{SP}, \mathrm{W}(\mathrm{SP}) \rightarrow \mathrm{PC}\) \\
\hline RETS & Return then skip next & SP-2 \(\rightarrow\) SP,W(SP) \(\rightarrow\) PC, \& skip \\
\hline RETI & Return from interrupt & \(S P-2 \rightarrow S P, W(S P) \rightarrow P C\), interrupt re-enabled \\
\hline
\end{tabular}

Vote: W is 16 -bit word of memory
MA is Accumulator A or direct memory (8 or 16-bit)
Mem is 8 -bit byte or 16 -bit word of memory
Meml is 8 - or 16 -bit memory or 8 or 16 -bit immediate data
imm is 8 -bit or 16 -bit immediate data

\section*{Memory Usage}

Number Of Bytes For Each Instruction (number in parenthesis is 16-Bit field)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{7}{|c|}{Using Accumulator A} & \multicolumn{4}{|c|}{To Direct Memory} \\
\hline & \multicolumn{2}{|l|}{Reg Indir.
(B)} & Direct & Indir & Index & Immed. & & & \({ }^{1}\) & \\
\hline LD & 1 & 1 & 2(4) & 3 & 4(5) & 2(3) & 3(5) & 5(6) & 3(4) & 5(6) \\
\hline X & 1 & 1 & 2(4) & 3 & 4(5) & - & - & - & - & - \\
\hline ST & 1 & 1 & 2(4) & 3 & 4(5) & - & - & - & - & - \\
\hline ADC & 1 & 2 & 3(4) & 3 & 4(5) & 4(5) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline SBC & 1 & 2 & 3(4) & 3 & 4(5) & 4(5) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline DADC & 1 & 2 & 3(4) & 3 & 4(5) & 4(5) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline DSBC & 1 & 2 & 3(4) & 3 & 4(5) & 4(5) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline ADD & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline MULT & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline DIV & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline IFEQ & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline IFGT & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline AND & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline OR & 1 & 2 & \(3(4)\) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline XOR & 1 & 2 & 3(4) & 3 & 4(5) & 2(3) & 4(5) & 5(6) & 4(5) & 5(6) \\
\hline
\end{tabular}
* 8 -bit direct address
**16-bit direct address

Immediate Load Instructions
\begin{tabular}{|l|c|}
\hline & Immed. \\
\hline LD B,* & \(2(3)\) \\
LD X,* & \(.2(3)\) \\
LD K,* & \(2(3)\) \\
\hline LD BK, \({ }^{*},{ }^{*}\) & \(3(5)\) \\
\hline
\end{tabular}

Memory Usage (Continued)
Register Indirect Instructions with Auto Increment and Decrement
\begin{tabular}{|l|c|c|}
\hline \multicolumn{3}{|c|}{ Register B With Skip } \\
\hline & \((B+)\) & \((B-)\) \\
\hline LDS A,* & 1 & 1 \\
XS A,* & 1 & 1 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|c|}{ Register X } \\
\hline & \((X+)\) & \((X-)\) \\
\hline LD A,* \(^{*}\) & 1 & 1 \\
XA, \({ }^{*}\) & 1 & 1 \\
\hline
\end{tabular}

Instructions Using A and C
\begin{tabular}{|ll|l|}
\hline CLR & A & 1 \\
INC & A & 1 \\
DEC & A & 1 \\
COMP & A & 1 \\
SWAP & A & 1 \\
RRC & A & 1 \\
RLC & A & 1 \\
SHR & A & 1 \\
SHL & A & 1 \\
SET & C & 1 \\
RESET & C & 1 \\
IF & C & 1 \\
IFN & C & 1 \\
\hline
\end{tabular}

Transfer of Control Instructions
\begin{tabular}{|l|l|}
\hline JSRP & 1 \\
JSR & 2 \\
JSRL & 3 \\
JP & 1 \\
JMP & 2 \\
JMPL & 3 \\
JID & 1 \\
JIDW & 1 \\
NOP & 1 \\
RET & 1 \\
RETS & 1 \\
RETI & 1 \\
\hline
\end{tabular}

\section*{Stack Reference Instructions}
\begin{tabular}{|l|c|}
\cline { 2 - 2 } \multicolumn{1}{c|}{} & Direct \\
\hline PUSH & 2 \\
POP & 2 \\
\hline
\end{tabular}

\section*{Code Efficiency}

One of the most important criteria of a single chip microcontroller is code efficiency. The more efficient the code, the more features that can be put on a chip. The memory size on a chip is fixed so if code is not efficient, features may have to be sacrificed or the programmer may have to buy a larger, more expensive version of the chip.
The HPC16400 has been designed to be extremely codeefficient. The HPC16400 looks very good in all the standard coding benchmarks; however, it is not realistic to rely only on benchmarks. Many large jobs have been programmed onto the HPC16400, and the code savings over other popular microcontrollers has been considerable-often the jobs take less than one-half the memory!
Reasons for this saving of code include the following:

\section*{SINGLE BYTE INSTRUCTIONS}

The majority of instructions on the HPC16400 are singlebyte. There are two especially code-saving instructions:
JP is a 1-byte jump. True, it can only jump within a range of plus or minus 32, but many loops and decisions are often within a small range of program memory. Most other micros need 2-byte instructions for any short jumps.
JSRP is a 1-byte call subroutine. The user makes a table of his 16 most frequently called subroutines and these calls will only take one byte. Most other micros require two and even three bytes to call a subroutine. The user does not have to decide which subroutine addresses to put into his table; the assembler can give him this information.

\section*{EFFICIENT SUBROUTINE CALLS}

The 2-byte JSR instructions can call any subroutine within plus or minus 1 k of program memory.

\section*{MULTIFUNCTION INSTRUCTIONS FOR DATA MOVEMENT AND PROGRAM LOOPING}

The HPC16400 has single-byte instructions that perform multiple tasks. For example, the XS instruction will do the following:
1. Exchange \(A\) and memory pointed to by the \(B\) register
2. Increment the \(B\) register
3. Compare the \(B\) register versus the \(K\) register
4. Generate a conditional skip if \(B\) is greater than \(K\)

The value of this multipurpose instruction becomes evident when looping through sequential areas of memory and exiting when the loop is finished.

\section*{BIT MANIPULATION INSTRUCTIONS}

Any bit of memory, I/O or registers can be set, reset or tested by the single byte bit instructions. The bits can be addressed directly or indirectly. Since all registers and I/O are mapped into the memory, it is very easy to manipulate specific bits to do efficient control.

\section*{DECIMAL ADD AND SUBTRACT}

This instruction is needed to interface with the decimal user world.
It can handle both 16-bit words and 8-bit bytes.
The 16 -bit capability saves code since many variables can be stored as one piece of data and the programmer does not have to break his data into two bytes. Many applications store most data in 4 -digit variables. The HPC16400 supplies 8 -bit byte capability for 2-digit variables and literal variables.

\section*{MULTIPLY AND DIVIDE INSTRUCTIONS}

The HPC16400 has 16 -bit multiply and divide instructions. This saves both code and time. Multiply and divide can use immediate data or data from memory. The ability to multiply and divide by immediate data saves code since this function is often needed for scaling, base conversion, computing indexes of arrays, etc.

\section*{Development Support}

The MOLE (Microcontroller On-Line Emulator) is a low cost development system and emulator for all microcontroller products. These include COPs, TMP, 8050U and the HPC Family of Products. The MOLE consists of a BRAIN Board, Personality Board and optional host software.

The purpose of a MOLE is to provide the user with a tool to write and assemble code, emulate code for the target microcontroller and assist in both the software \& hardware debugging of the system.
It is a self-contained computer with its own firmware which provides for all system operation, emulation control, communication, PROM programming and diagnostic operations. It contains three serial ports because multiple ports are usually needed to optionally connect to a terminal, a host system, a printer or modem, or to connect to other MOLEs in a multi-MOLE environment.
MOLE can be used in either a stand alone mode or in conjunction with selected host systems, i.e., those using CP/M or PC-DOS. Communicating via RS-232 port.
Dial-A-Helper is a service provided by the MOLE applications group. If a user is having difficulty in getting a MOLE to operate in a particular mode or it is acting peculiar, he can contact us via his system and a modem. He can leave messages on our electronic bulletin board which we will respond to, or he can arrange for us to actually take control of his system via modem for debugging purposes.
The applications group can then cause his system to execute various commands and try to resolve the customer's problem by actually getting the customer's system to respond. \(99 \%\) of the time the problem is resolved. This allows us to respond in minutes instead of days when applications help is needed.

\section*{Part Selection}

The HPC family includes devices with many different options and configurations to meet various application needs. The number HPC16400 has been generally used throughout this datasheet to represent the whole family of parts. The following chart explains how to order various options available when ordering HPC family members.
Note: All options may not currently be available.


FIGURE 15. HPC Family Part Numbering Scheme Examples
HPC46400V17-Commercial temp ( \(0^{\circ}\) to \(+70^{\circ} \mathrm{C}\) ), PCC HPC16400E17-Military temp ( \(-55^{\circ} \mathrm{C}\) to \(+125^{\circ} \mathrm{C}\) ), LCC

\title{
HPC16740/HPC36740/HPC46740/ HPC16730/HPC36730/HPC46730 High-Performance Microcontroller with Gate Array
}

\section*{General Description}

The HPC16740 is a member of the HPCTM family of High Performance Microcontrollers. Each member of the family has the same identical core CPU with a unique memory and I/O configuration to suit specific applications. Each part is fabricated in National's advanced microCMOS technology. This process combined with an advanced architecture provides fast, flexible I/O control, efficient data manipulation, and high speed computation.
The HPC16740 contains an on-chip gate array giving the user the ability to customize the logic function of his chip. With it the designer can replace external glue logic or implement a complex device like a digital phase lock loop (PLL). The gate array peripheral includes: 1) 280 user programmable gates, 2) 650 gates making 68 -bit configurable functions consisting of; counters, shift registers, latches or D flipflops 3) 270 gates for built-in logic to interface to the HPC core and Port C I/O. This offers an on-chip gate array comparable to an external array of about 1200 gates.
The HPC16740 is available in 68-pin PCC, LCC and PGA packages.

\section*{Features}
- HPC family-core features:
- 16-bit architecture, both byte and word
- 16-bit data bus, ALU, and registers
- 64k bytes of external memory addressing
- FASTI-240 ns for register instructions when using 17.0 MHz clock
- High code efficiency-Most instructions are single byte
\(-16 \times 16\) multiply and \(32 \times 16\) divide
- Eight vectored interrupt sources
- Four 16-bit timer/counters with 3 input capture registers and 4 synchronous outputs
- WATCHDOG logic monitors processor
- MICROWIRE/PLUS serial I/O interface
- CMOS-very low power with two power save modes: IDLE and HALT ( \(2 \mathrm{~mA}, 250 \mu \mathrm{~A}\)-typ.)
- 1200 equivalent gates
- 55 general purpose I/O lines (memory mapped)
- 4k bytes of ROM, 256 bytes of RAM on chip
- ROMless versions available
- Wide voltage supply range: 3 V to 5.5 V
- Industrial \(\left(-40^{\circ} \mathrm{C}\right.\) to \(\left.+85^{\circ} \mathrm{C}\right)\) and military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(+125^{\circ} \mathrm{C}\) ) temperature ranges

\section*{Block Diagram}


TL/DD/8803-1

\section*{HPC16900/HPC36900/HPC46900 Port Expansion and Recreation Logic}

\section*{General Description}

The HPC16900 is a support chip for the HPC family of High Performance Microcontrollers. It is fabricated using National's advanced microCMOS technology.
The HPC16900 is a Port Expansion and Recreation Logic (PEARL) chip intended for use as a port expander when the user requires Port A on the HPC microcontroller to serve as an address/data bus. It recreates the entire Port A and 4 bits of Port B. In optional mode, it provides an additional 16bit I/O port.
The HPC16900 is available in 68-pin PCC, LCC and PGA packages.

\section*{Features}

■ Supports 17.0 MHz HPC operation
- Supports all operating modes of Port A
- Multiplexed Address/Data bus
- Supports UPI (Universal Peripheral Interface)
- Provides up to 36 I/O pins in expanded mode
- Up to 4 PEARL chips may be used in parallel
m Provides direct interface to external memory
- CMOS-very low power consumption
- Wide voltage supply range: 3 to 5.5 V
- Industrial \(\left(-40^{\circ} \mathrm{C}\right.\) to \(+85^{\circ} \mathrm{C}\) ) and military \(\left(-55^{\circ} \mathrm{C}\right.\) to \(+125^{\circ} \mathrm{C}\) ) temperature ranges

\section*{Block Diagram}


TL/DD/9122-1

Section 6 NS8050 Family

\section*{Section 6 Contents}
NS8050 ..... 6-3
INS8048/INS8049/INS8048L/INS8049L/INS8048I/INS8049I/NS8050U/NS8040U/
NS87P50U/NS8050UL/NS8050UI/NS87P50 Microcomputer/Microprocessor Family ..... 6-4
INS8243 Input/Output Expander ..... 6-25
AB-17 Using E2PROMS with ROMless Single-Chip Microcontroller ..... 6-32
AN-345 Internal ROM Verification for the 48-Series Microcontrollers ..... 6-34
AN-358 NS8050U MICROWIRE/PLUS Interface ..... 6-37

The 8050 Family
These products include the 8048, 8049 and 8050U. The 8050 U provides MICROWIRE/PLUSTM for serial communication. Features include:
- Self-contained system timing
- Control logic
- RAM program memory
- RAM data memory
- 27 I/O lines (used to implement dedicated control functions)
- 8048 instruction set
- Memory capacity- \(1 \mathrm{k} \times 8\) ROM and \(64 \times 8\) RAM to \(4 \mathrm{k} \times 8\) ROM and \(256 \times 8\) RAM
- Low-cost emulators-NS87P50 Piggyback devices MICROWIRETM Peripherals
The variety of functions available through serial communication are:
- Memory (CMOS RAMs and EEPROMs)
- Display Drivers (LCD, LED, VF)
- A/D converters
- Timer/Counters
- AM/FM digital phase-locked loop frequency synthesizer The 8050 Family is the industry standard microcontroller.

\title{
INS8048/8049/8048L/8049L/8048I/8049I NS87P50/8050U/8040U/87P50U/8050UI/8050UL Microcomputer/Microprocessor Family
}

\section*{General Description}

The members of this family of microcomputers are self-contained, 8 -bit parallel, 40-pin dual-in-line devices fabricated using National Semiconductor's scaled N-channel, silicon gate MOS process, XMOSTM. The 48 -Series devices contain the system timing, control logic, ROM (where applicable) program memory, RAM data memory and 27 I/O lines necessary to implement dedicated control functions. All 48Series devices are pin-compatible, differing only in the size of on-board ROM (where applicable) and RAM as shown below.
For applications requiring microwire serial communication, the NS8050U provides this feature.
MICROWIRE/PLUSTM consists basically of a three-wire communication port with a clocked 8 -bit shift register. The three lines consist of a Serial Output (SO), a Serial Input (SL), and a Serial Clock (SK). The shift register is referred to as the serial input/output register. One 8050U must be designated as the master. The master supplies the clock for the MICROWIRE/PLUS system and initiates all data transfers. All transfers are between the master and one or more slaves. A slave may be any MICROWIRETM peripheral or another 8050U with MICROWIRE/PLUS. MICROWIRE/ PLUS communicates with a variety of MICROWIRE peripherals, such as the COP472 LCD Display Driver, COP494 EEPROM, or other 8050's configured as a peripheral. MICROWIRE/PLUS makes efficient use of the I/O lines. Thus, the MICROWIRE/PLUS expands the capability of the 3050 f family.

\section*{Features}
- The master/slave feature is programmable

■ NS87P50 MICROWIRE/PLUS Piggy-back Microcomputer
■ NS8040U MICROWIRE/PLUS ROM-less
■ NS8050U MICROWIRE/PLUS in 40-pin package
- Transparent enhancement to the standard 8050 Microcomputer
- Ready interface to the MICROWIRE peripheral family
- Testable shifter "Done" flag available
- Selectable shift rate
- Two new MICROWIRE/PLUS control instructions
- Serial data exchange with only three wires
- 8-bit timer/control
- Binary and BCD arithmetic
- Single 5 V power supply
- Low standby power
- Low voltage standby
- Expandable memory and I/O
- \(1.36 \mu\) s cycle, 11 MHz clock
\begin{tabular}{lcc}
\multicolumn{1}{c}{ Device } & RAM Array & ROM Array \\
INS8048, 48L, 48I & \(64 \times 8\) & \(1 \mathrm{k} \times 8\) \\
INS8049, 49L, 48I & \(128 \times 8\) & \(2 \mathrm{k} \times 8\) \\
NS8050U, 50UL, 50UI & \(256 \times 8\) & \(4 \mathrm{k} \times 8\) \\
INS8035, 35L, 35I & \(64 \times 8\) & N/A \\
INS8039, 39L, 39I & \(128 \times 8\) & N/A \\
NS8040U, 40UL, 40UI & \(256 \times 8\) & N/A \\
NS87P50U & \(64 / 128 / 256 \times 8\) & \(1 \mathrm{k} / 2 \mathrm{k} / 4 \mathrm{k} \times 8\)
\end{tabular}
*Supersedes all data sheets and data books.

\section*{Block Diagram}


TL/C/5488-1

\section*{Absolute Maximum Ratings}

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the assoclated rellabillty electrical test specifications document.

Temperature Under Bias Storage Temperature All Input or Output Voltages with Respect to \(V_{\text {SS }}\) Power Dissipation
\begin{tabular}{c|c}
87 P 50 Series & \\
8048 Series & 8048 l Series \\
8048 L Series & \\
\(-20^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) & \(-50^{\circ} \mathrm{C}\) to \(+100^{\circ} \mathrm{C}\) \\
\(-65^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}\) & \(-65^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}\) \\
-0.5 V to +7 V & -0.5 V to +7 V \\
1.5 W & 1.5 W
\end{tabular}

Note: Absolute Maximum Ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended; operation should be limited to those conditions specified under DC Electrical Characteristics.


\section*{DC Electrical Characteristics}
\(T_{A}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}\), unless otherwise specified. (NS8048, INS8048L)
\(\mathrm{T}_{\mathrm{A}}=40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\), unless otherwise specified. (NS80481) (Note 2)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Test Conditions & Min & Typ & Max & Units \\
\hline \(\mathrm{V}_{\mathrm{IL}}\) & Input Low Voltage (Except XTAL1, XTAL2, \(\overline{\text { RESET }}\) ) & & -0.5 & & 0.8 & V \\
\hline VIL1 & Input Low Voltage (XTAL1, XTAL2, \(\overline{\text { RESET }}\) ) & & -0.5 & & 0.6 & V \\
\hline \(\mathrm{V}_{\mathrm{IH}}\) & Input High Voltage (Except XTAL1, XTAL2, RESET) & & 2.0 & & \(V_{C C}\) & V \\
\hline \(\mathrm{V}_{\mathrm{H} 1}\) & Input High Voltage (XTAL1, XTAL2, RESET) & & 3.8 & & \(V_{C C}\) & V \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output Low Voltage (Bus) & \(\mathrm{l}_{\mathrm{OL}}=2 \mathrm{~mA}\) & & & 0.45 & V \\
\hline VOL. & Output Low Voltage ( \(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE}\) ) & \(\mathrm{l}_{\mathrm{OL}}=1.8 \mathrm{~mA}\) & & & 0.45 & V \\
\hline \(V_{\text {OL2 }}\) & Output Low Voltage ( \(\overline{\text { PROG }}\) ) & \(\mathrm{IOL}=1.0 \mathrm{~mA}\) & & & 0.45 & V \\
\hline VOL3 & Output Low Voltage (Ports and Others) & \(\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}\) & & & 0.45 & V \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output High Voltage (Bus) & \(\mathrm{IOH}=-400 \mu \mathrm{~A}\) & 2.4 & & & V \\
\hline \(\mathrm{V}_{\mathrm{OH} 1}\) & Output High Voltage ( \(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})\) & \(\mathrm{l}_{\mathrm{OH}}=-100 \mu \mathrm{~A}\) & 2.4 & & & V \\
\hline \(\mathrm{V}_{\mathrm{OH} 2}\) & Output High Voltage (Ports and Others) & \(\mathrm{IOH}=-40 \mu \mathrm{~A}\) & 2.4 & & & V \\
\hline \(\mathrm{I}_{\mathrm{LI}}\) & Input Leakage Current (T1, INT, EA) & \(\mathrm{V}_{\mathrm{SS}} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}\) & & & \(\pm 10\) & \(\mu \mathrm{A}\) \\
\hline \(\mathrm{ILI}_{1}\) & Input Leakage Current Ports & \(\mathrm{V}_{\text {SS }}+0.45 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}\) & & & -500 & \(\mu \mathrm{A}\) \\
\hline \(\mathrm{L}_{\mathrm{L} 2}\) & Input Leakage Current ( \(\overline{\mathrm{SS}}, \overline{\mathrm{RESET}}\) ) & \(\mathrm{V}_{\mathrm{SS}}+0.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}\) & & & -300 & \(\mu \mathrm{A}\) \\
\hline Lo & \begin{tabular}{l}
Output Leakage Current (Bus, \(\mathrm{T}_{0}\) ) \\
High Impedance State
\end{tabular} & \(\mathrm{V}_{\text {SS }}+0.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\text {CC }}\) & & & \(\pm 10\) & \(\mu \mathrm{A}\) \\
\hline \(\mathrm{l}_{\text {DD }} 64\) & Standby Current (Note 1) & 8048, 8048I, 8048L & & & 5/4 & mA \\
\hline 1 ID 128 & Standby Current (Note 1) & 8049, 80491, 8049L & & & 7/5 & mA \\
\hline IDD 256 & Standby Current (Note 1) & 8050, 8050I, 8050L & & & 10/10 & mA \\
\hline \(I_{D D}+I_{C C}\) & Total Supply (Note 1) & 8048, 8048I, 8048L & & & 65/55 & mA \\
\hline \(I_{\text {DD }}+\mathrm{I}_{\mathrm{CC}}\) & Total Supply (Note 1) & 8049, 80491, 8049L & & & 70/60 & mA \\
\hline \(\mathrm{IDD}^{\text {+ }} \mathrm{ICC}\) & Total Supply (Note 1) & 8050, 80501, 8050L & & & 80/65 & mA \\
\hline \(V_{D D}\) & Standby Power Supply (8048, 80481, 8048L Series) & & 2.2 & & \(V_{C C}\) & V \\
\hline
\end{tabular}

Note 1: For industrial device \(T_{A}=-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\).
Note 2: Combination of low power and industrial temperature devices not accepted.


AC Characteristics \(T_{A}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\left(-40^{\circ} \mathrm{C}\right.\) to \(+85^{\circ} \mathrm{C}\) for 80481\(), \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{Symbol} & \multirow{2}{*}{Parameter} & \multirow[t]{2}{*}{\(f\left(\mathrm{t}_{\mathrm{C}} \mathrm{F}\right)\) (Note 3)} & \multicolumn{2}{|c|}{11 MHz} & \multirow{2}{*}{Units} \\
\hline & & & Min & Max & \\
\hline \(t_{\text {LL }}\) & ALE Pulse Width (Note 1) & \(7 / 30 \mathrm{t}_{\mathrm{CY}}-170\) & 150 & & ns \\
\hline \(t_{\text {AL }}\) & Address Setup to ALE (Note 1) & \(2 / 15 \mathrm{t}_{\mathrm{CY}}-110\) & 70 & & ns \\
\hline tLA & Address Hold from ALE (Note 1) & \(1 / 15 \mathrm{t}_{\mathrm{CY}}-40\) & 50 & & ns \\
\hline \(\mathrm{tcC}_{1}\) & Control Pulse Width ( \(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}\) ) (Note 1) & \(1 / 2 \mathrm{t}_{\mathrm{CY}}-200\) & 480 & & ns \\
\hline tcce & Control Pulse Width ( \(\overline{\text { PSEN }}\) ) ( (Note 1) & \(2 / 5 \mathrm{t}_{\mathrm{CY}}-200\) & 350 & & ns \\
\hline tow & Data Setup Before \(\overline{\text { WR }}\) (Note 1) & \(13 / 30 \mathrm{t}_{\mathrm{CY}}-200\) & 390 & & ns \\
\hline two & Data Hold After WR (Notes 1, 2) & \(1 / 15 \mathrm{t}_{\mathrm{CY}}-50\) & 40 & & ns \\
\hline \(t_{\text {DR }}\) & Data Hold ( \(\overline{\mathrm{RD}}, \overline{\text { PSEN }}\) ) (Notes 1, 4) & 1/10 t \(\mathrm{t}_{\mathrm{CY}}-30\) & 0 & 110 & ns \\
\hline \(\mathrm{t}_{\mathrm{RD} 1}\) &  & \(2 / 5 \mathrm{t}_{\mathrm{CY}}-170\) & & 370 & ns \\
\hline \(t_{\text {RD2 }}\) & PSEN to Data in (Note 1) & \(3 / 10 \mathrm{t}_{\mathrm{CY}}-170\) & & 240 & ns \\
\hline \(t_{\text {AW }}\) & Address Setup to \(\overline{\mathrm{WR}}\) (Note 1) & \(1 / 3 \mathrm{t}_{\mathrm{CY}}-150\) & 300 & & ns \\
\hline \(t_{\text {AD1 }}\) & Address Setup to Data ( \(\overline{\mathrm{RD}})\) (Note 1) & \(21 / 30 \mathrm{t}_{\mathrm{CY}}-220\) & & 730 & ns \\
\hline \(t_{\text {AD2 }}\) & Address Setup to Data ( \(\overline{\text { PSEN }}\) ) (Note 1) & \(1 / 2 \mathrm{t}_{\mathrm{CY}}-200\) & & 480 & ns \\
\hline \(t_{\text {AFC1 }}\) & Address Float to \(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}\) (Notes 1, 2) & \(2 / 15 \mathrm{t}_{\mathrm{CY}}-40\) & 140 & & ns \\
\hline \(t_{\text {AFC2 }}\) & Address Float to \(\overline{\text { PSEN }}\) (Notes 1, 2) & \(1 / 30 \mathrm{t}_{\mathrm{CY}}-40\) & 10 & & ns \\
\hline tLAFC1 & ALE to Control ( \(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}\) ) (Note 1) & \(1 / 5 \mathrm{t}_{\mathrm{CY}}-75\) & 200 & & ns \\
\hline t LAFC2 & ALE to Control ( \(\overline{\text { PSEN }}\) ) (Note 1) & \(1 / 10 t_{\text {CY }}-75\) & 60 & & ns \\
\hline \(t_{\text {CA1 }}\) & Control to ALE ( \(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\text { PROG }}\) ) (Note 1) & \(1 / 15 \mathrm{tcy}-40\) & 50 & & ns \\
\hline \(\mathrm{t}_{\text {CA2 }}\) & Control to ALE ( \(\overline{\text { PSEN }}\) ) (Note 1) & \(4 / 15\) t \(\bar{C} Y-40\) & 320 & & ns \\
\hline \(\mathrm{t}_{\mathrm{CP}}\) & Port Control Setup to PROG (Note 1) & \(1 / 10{ }_{\text {t }}^{\text {CY }}\) - 80 & 50 & & ns \\
\hline tpC & Port Control Hold from PROG (Note 1) & \(4 / 15 \mathrm{t}_{\mathrm{CY}}-260\) & 100 & & ns \\
\hline \(t_{\text {PR }}\) & \(\overline{\text { PROG to P2 Input Valid (Note 1) }}\) & \(17 / 30 t_{C Y}-140\) & & 630 & ns \\
\hline \(t_{\text {PF }}\) & Input Data Hold from PROG (Notes 1, 4) & \(1 / 10 t_{\text {cy }}\) & 0 & 140 & ns \\
\hline \(t_{\text {DP }}\) & Output Data Setup (Note 1) & \(2 / 5 \mathrm{t}_{\mathrm{CY}}-290\) & 260 & & ns \\
\hline \(t_{\text {PD }}\) & Output Data Hold (Note 1) & \(1 / 10 \mathrm{t}_{\mathrm{CY}}-90\) & 40 & & ns \\
\hline tpp & \(\overline{\text { PROG Pulse Width (Note 1) }}\) & \(7 / 10 \mathrm{t}_{\mathrm{CY}}-250\) & 700 & & ns \\
\hline \(t_{\text {PL }}\) & Port \(21 / \mathrm{O}\) Setup to ALE (Note 1) & \(4 / 15 \mathrm{t}_{\mathrm{cY}}-200\) & 160 & & ns \\
\hline tLP & Port \(21 / \mathrm{O}\) Hold to ALE (Note 1) & \(1 / 10 \mathrm{t}_{\mathrm{CY}}-120\) & 15 & & ns \\
\hline tpV & Port Output From ALE (Note 1) & \(3 / 10 t_{\text {CY }}+100\) & & 510 & ns \\
\hline \(t_{C Y}\) & Cycle Time (Note 3) & & 1.36 & 15 & \(\mu \mathrm{S}\) \\
\hline toprn & To Rep Rate & \(3 / 15 t^{\text {cy }}\) & 270 & & ns \\
\hline
\end{tabular}

Note 1: Control outputs \(C_{L}=80 \mathrm{pF}\). Bus outputs \(\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}\).
Note 2: Bus High Impedance Load \(=20 \mathrm{pF}\).
Note 3: \(\mathrm{t}_{\mathrm{CY}}=15 / \mathrm{f}\) (assumes \(50 \%\) duty cycle).
Note 4: Maximum spec listed is for user information only to prevent system bus contention.
Note 5: \(\mathrm{V}_{\mathrm{IH}}=3.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.45 \mathrm{~V}\).

AC Electrical Characteristics for NSB050U/NS8040U
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{Symbol} & \multirow{2}{*}{Parameter} & \multirow[t]{2}{*}{\[
\begin{gathered}
f\left(\mathrm{t}_{\mathrm{CY}}\right) \\
\mathrm{t}_{\mathrm{CY}}=1.36 \mu \mathrm{~s}
\end{gathered}
\]} & \multicolumn{2}{|c|}{11 MHz} & \multirow{2}{*}{Units} \\
\hline & & & Min & Typ & \\
\hline tc \(\div 1\) & Divide by One SK & \(\mathrm{t}_{\mathrm{CY}}\) & 1360 & 1360 & ns \\
\hline tc \(\div 4\) & Divide by Four SK & \(4 t_{C Y}\) & 5440 & 5440 & ns \\
\hline \(\mathrm{t}_{\text {setup }}\) & SI Setup to SK \(\uparrow\) & & 200 & 140 & ns \\
\hline \(t_{\text {hold }}\) & SI Hold from SK \(\uparrow\) & & 100 & 50 & ns \\
\hline \(t_{\text {valid }} \div 1\) & SO Valid Setup to Next SK \(\uparrow\) & \(1 / 2 t_{C Y}-180\) & 500 & 650 & ns \\
\hline \(\mathrm{t}_{\text {valid }} \div 4\) & SO Valid Setup to Next SK \(\uparrow\) & \(1 / 2 \mathrm{t}_{\text {CY }}-180\) & 1860 & 2000 & ns \\
\hline
\end{tabular}

Note: Absolute Maximum Ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended; operation should be limited to those conditions specified under DC Electrical Characteristics. DC Electrical Characteristics are specified in INS8048-Series Data Sheet.

\section*{Input and Output for AC Tests}


TL/C/5488-3
Note: AC testing inputs are driven at 2.4 V for a logic " 1 " and 0.45 V for a logic " 0 ". Output timing measurements are made at 2.0 V for a logic " 1 " and 0.8 V for a logic " 0 " (except \(\mathrm{X}_{1}, \mathrm{X}_{2}\), and RESET) (Note 5).

\section*{The INS8048/49/50-Series}

The devices are designed to be efficient controllers. They have extensive bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory is derived from an instruction set comprised predominantly of single bytes. The remaining instructions are two bytes in length. Additional external memory may be added up to a maximum of 4 k bytes of program memory and 256 bytes of data memory without paging.

\section*{The INS8048L/49L/50L-Series}

The XMOS 8048L Family now makes it possible for the designers to significantly reduce their power supply requirements. This will allow new designs where low power operation is a requirement for portability or battery back-up. The

8048 Low Power Family will also mean longer product life and reliability because of the reduction in chip temperature within the package.
Due to the capabilities of the XMOS process and improvements in circuit design, the 8048L devices consume approximately \(25 \%\) les than normal N -channel MOS devices available to the marketplace.

\section*{The INS8048I/49I/501-Series}

These devices are designed to be efficient controllers in extended temperature range environments \(\left(-40^{\circ} \mathrm{C}\right.\) to \(+85^{\circ} \mathrm{C}\) ). Similar in every way to the standard devices, the industrial parts are differentiated only by extensive testing and screening to guarantee full functionality in the extended industrial temperature range.

\section*{Timing Waveforms}


Timing Waveforms (Continued)
Instruction Fetch from External Program Memory


TL/C/5488-5
Note: Diagonal lines indicate interval of high impedance.


TL/C/5488-6
Note: Diagonal lines indicate interval of high impedance.


TL/C/5488-7
Note: Diagonal lines indicate interval of high impedance.
Port 2 Timing


\section*{Timing Waveforms (Continued)}

ROM Verify Mode Timing


Recommended Test Methods:
1. \(\overline{R E S E T}\) must be low before EA goes high.
2. Sync to falling edge of ALE. Falling edge of ALE is machine cycle 4.
3. Force address in with RESET low for 21 machine cycles starting machine cycle 5.
4. Force address in with \(\overline{\text { RESET }}\) high for 4 machine cycles.
5. Force RESET high for 12 machine cycles.
6. Force RESET high for 4 machine cycles. Data is valid on bus.
7. Force RESET low for 4 machine cycles.
8. Repeat steps 3 through 7 for other addresses.

\section*{NS8050U MICROWIRE/PLUS Timing}


TL/C/5488-10

NS87P50U Piggy－Back Microcomputer EPROM Timing


TL／C／5488－11
Frequency \(=11 \mathrm{MHz}\)

\section*{AC Electrical Characteristics}
\(T_{A}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=3.6 \mathrm{~V}\) to 5.5 V ，unless otherwise specified．
\begin{tabular}{l|l|l|l|c|c|c}
\hline Symbol & \multicolumn{1}{|c|}{ Parameter } & Test Conditions & Min & Typ & Max & Units \\
\hline\(t_{\text {ACC }}\) & \begin{tabular}{l} 
ROM Address Setup to ROM Data \\
\((6 \mathrm{MHz}\) Access Time）
\end{tabular} & 6 MHz & & 850 & ns \\
\hline\(t_{\text {ACC }}\) & \begin{tabular}{l} 
ROM Address Setup to ROM Data \\
\((11 \mathrm{MHz}\) Access Time）
\end{tabular} & 11 MHz & & & 450 & ns \\
\hline\(t_{\text {CE }}\) & Chip Enable and Output Enable Active & 11 MHz & & & 870 & ns \\
\hline\(t_{\text {AA }}\) & ALE to ROM Address Setup & 11 MHz & & & 260 & ns \\
\hline\(t_{\text {ARL }}\) & ALE to ROM Data Latch & 11 MHz & & & 810 & ns \\
\hline
\end{tabular}

Other AC Electrical Characteristics same as 48 －Series．
DC Electrical Characteristics
\(T_{A}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\) ，unless otherwise specified．
\begin{tabular}{l|l|l|l|l|c|c}
\hline \multicolumn{1}{|c|}{ Symbol } & \multicolumn{1}{|c|}{ Parameter } & Test Conditions & Min & Typ & Max & Units \\
\hline\(I_{C C 1}\) & Current Available to EPROM & \(V_{C C}=5 \mathrm{~V}\) & & & 150 & mA \\
\hline\(I_{P P}\) & \(V_{P P}\) Current & \(V_{P P}=5 \mathrm{~V}\) & & & 5 & mA \\
\hline\(I_{D D}\) & 256 Words on Standby Current & & & & 20 & mA \\
\hline\(I_{D D}+I_{C C}\) & Total Supply Current（without EPROM） & \begin{tabular}{l}
\(T_{A}=25^{\circ} \mathrm{C}\) \\
All Outputs Open
\end{tabular} & & 60 & 100 & mA \\
\hline\(V_{D D}\) & Standby Power Supply & & 2.6 & & \(V_{C C}\) & V \\
\hline
\end{tabular}

\footnotetext{
Other DC Electrical Characteristics same as 48－Series．
}

Connection Diagrams


EPROM Pin Descriptions
\begin{tabular}{|l|l|}
\hline\(A_{0}-A_{9}\) & Addresses \\
\hline\(\overline{\mathrm{CE}} / \mathrm{PGM}\) & Chip Enable Program \\
\hline\(\overline{\mathrm{OE}}\) & Output Enable \\
\hline \(\mathrm{O}_{0}-\mathrm{O}_{7}\) & Outputs \\
\hline \(\mathrm{A}_{R}\) & Select Reference Input Level- \(\mathrm{V}_{\mathrm{SS}}\) \\
\hline \(\mathrm{V}_{\mathrm{PP}}\) & +5 V \\
\hline \(\mathrm{~V}_{\mathrm{CC}}\) & +5 V \\
\hline GND & Power Ground \\
\hline \(\mathrm{A}_{R}\) & Ground \\
\hline
\end{tabular}

TL/C/5488-12


INS8049 Emulation


NS8050 Emulation


\section*{EPROM}


\section*{Functional Pin Descriptions}

\section*{INPUT SIGNALS}

Reset ( \(\overline{\operatorname{RESET}}\) ): An active low ( 0 ) input that initializes the processor and is used to verify program memory.
Single Step ( \(\overline{\mathbf{S S}}\) ): Active low ( 0 ) input which, in conjunction with ALE, can single step the processor through each instruction.
External Access (EA): An active high (1) input that forces all program memory fetches to reference external program memory.
Testable Input 0 (TO): Testable input pin using conditional branch functions JTO \((\mathrm{TO}=1)\) or \(\mathrm{JNTO}(\mathrm{TO}=0)\). TO can be designated as the clock output using instruction ENTO CLK. For NS8050U, T0 is also used as the SK clock output for MASTER and SK clock input for SLAVE in the MICROWIRE/PLUS mode. Done FLIP FLOP is tested by testing TO.
Testable Input 1 (T1): Testable input pin using conditional branch functions JT1 ( \(\mathrm{T} 1=1\) ) or JNT1 \((\mathrm{T} 1=0)\). T1 can be designated as the Timer/Counter input from an external source using instruction STRT CNT.
Interrupt (INT): An active low input that initiates an interrupt when interrupt is enabled. Interrupt is disabled after a RESET. Also can be tested with instruction JNI (INT \(=0\) ).

\section*{OUTPUT SIGNALS}

Read Strobe ( \(\overline{\mathrm{RD}}\) ): An active low output strobe activated during a Bus read. Can be used to enable data onto the Bus from an external device. Used as a Read Strobe to External Data Memory.
Write Strobe ( \(\overline{\mathrm{WR}}\) ): An active low output strobe activated during a Bus write. Used as a Write Strobe to External Data Memory.
Program Store Enable ( \(\overline{\text { PSEN }}\) ): An active low output that occurs only during an external program memory fetch.
Address Latch Enable (ALE): An active high output that occurs once during each cycle and is useful as a clock output. The negative going edge of ALE strobes the address into External Data or Program Memory.
Program ( \(\overline{\mathbf{P R O G}}\) ): This output (active out) provides the output strobe for INS8243 I/O Expander.

\section*{INPUT/OUTPUT SIGNALS}

Crystal Input (XTAL1, XTAL2): These two pins connect the crystal for internal oscillator operation. XTAL1 is the timing input for external source.
Port 1 (P10-P17): 8-bit quasi-bidirectional port.
Port 2 (P20-P27): 8-bit quasi-bidirectional port. During an external program memory fetch, the 4 high-order program counter bits occur at P20-P23. They also serve as a 4 -bit I/O Expander Bus when the INS8243 I/O Expander is used. Bus ( \(\mathrm{DB}_{0}-\mathrm{DB}_{7}\) ): True bidirectional port, either statically latched or synchronous. Can be written to using WR Strobe, or Read from using \(\overline{\operatorname{RD}}\) Strobe. During an External Program Memory fetch, the 8 lower-order program counter bits are present at this port. The addressed instruction appears on this bus when PSEN is low. During an external RAM data transaction, this port presents address and data under control of ALE, \(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}\).
\(\mathrm{V}_{\mathrm{SS}}\) : Processor Ground potential.
\(V_{D D}\) : \(V_{D D}\) functions as the Low Power Standby Voltage. Can be tied to \(V_{C C}\) if power-down operation is not required.
\(\mathbf{V}_{\text {cc }}\) (Pin 40): Primary power source for 48-Series devices.

\section*{NS8050U MICROWIRE Mode Pin Descriptions}

Pin 1, Serial Clock (SK): Input or output clocking signal to the MICROWIRE/PLUS serial circuitry.
Pin 38, Serial Input (SI): Serial input to the 8 -bit MICROWIRE/PLUS shift register.
Pin 37, Serial Output (SO): Serial output from the 8-bit MICROWIRE/PLUS shift register.
Pin 3, XTAL2: High-impedance input to oscillator circuit.
Pin 2, XTAL1: Low-impedance output from oscillator circuit.

\section*{Connection Diagram}


TL/C/5488-15
Order Number INS8048, INS8048J, INS8048L, INS8049, INS8049I, INS8049L, NS8040U, NS80501, NS8050L, NS8050U, NS87P50, NS87P501 and NS87P50U See NS Package Number D40G or N40A

\section*{Functional Description}

The following paragraphs contain the functional description of the major elements of the 48-Series microcomputer/ microprocessor. (Figure 1) is a block diagram of the 48-Series devices. The data paths are illustrated in simplified form
to show how the various logic elements communicate with each other to implement the instruction set common to all devices.

\section*{48-Series Block Diagram}


TL/C/5488-16
FIGURE 1. 48-Series Detalled Block Diagram

\section*{Functional Description（Continued）}

\section*{PROGRAM MEMORY}

The Program Memory（ROM）contained on the INS8048／ \(49 / 50\) devices is comprised of 1024， 2048 or 40968 －bit jytes，respectively．As is seen by examining the 48 －Series nstruction set，these bytes may be program instructions， Jrogram data or ROM addressing data．The ROM for the above devices must be mask programmed at the National Semiconductor factory．The ROMless microcomputers， NS8035，INS8039 and INS8040，use external program nemory．This makes program development straightforward dsing standard UV erasable PROMs to emulate a possible uture single chip（using the on－board ROM）system．ROM addressing，up to a maximum of 4 k ，is accomplished by a 12－bit Program Counter（PC）．The INS8048 and INS8049 nill automatically address external memory when the joundary of their internal memories， 1 k and 2 k respectively， are exceeded．The binary value of the address selects one of the 8 －bit bytes contained in ROM．A new address is load－
ed into the PC register during each instruction cycle．Unless the instruction is a transfer of control instruction，the PC register is loaded with the next sequential binary count val－ ue．

With reference to the Program Memory Map（see Figure 2） there are three ROM addresses which provide for the con－ trol of the microcomputer．
1．Memory Location 0000－Asserting the RESET（negative true）input to the microcomputer forces the first instruc－ tion to be fetched from address 0000.

2．Memory Location 0003－Asserting the interrupt（negative true）input to the microcomputer（when interrupt is en－ abled）forces a jump to subroutine．
3．Memory Location 0007－A Timer／Counter interrupt that results from Timer／Counter overfow（when enabled）forc－ ing a jump to subroutine．

\section*{Functional Decscription (Continued)}

\section*{DATA MEMORY (RAM)}

The resident RAM data memory is arranged as 64 (INS8035/8048), 128 (INS8039/8049), or 256 (NS8040/ 8050) bytes. RAM addressing is implemented indirectly via either of two 8-bit RAM pointer registers R0 and R1. These pointer registers are essentially the first two locations in the RAM (see Figure 3), addressing 00 and 01. RAM addressing may also be performed directly by 11 direct register instructions. The register area of the RAM array is made up of eight working registers that occupy either the first bank ( 0 ), locations 0 to 7, or the second bank (1), locations 24 to 31. The second bank of working registers is selected by using the Register Bank Switch instruction (SEL RB). If this bank is not used for working registers, it can be used as user RAM.
There is an 8 -level stack after Bank 0 that occupies address locations 8 to 23. These RAM locations are addressed indirectly through R0, R1 or the 3-bit Stack Pointer (SP). The stack pointer keeps track of the return address and pushes each return address down into the stack. There are 8 levels of subroutine nesting possible in the stack because each address occupies 10 bits or more using two bytes in RAM. When the level of subroutine nesting is less than 8 , the stacks not used may be utilized as user RAM locations.

addressed INDIRECTLY Y R1 OR RO

TL/C/5488-18
FIGURE 3. 8048-Series Resident RAM Data Memory Map

\section*{INPUT/OUTPUT}

The 48 -series devices have 27 lines of input/output organized as three 8 -bit ports plus three test inputs. The three ports may be used as inputs, outputs or bidirectional ports. Ports 1 and 2 differ from Port 3 (Bus Port) in that they are quasi-bidirectional ports. Ports 1 and 2 can be used as input and output while being statically latched. If more I/O lines are required, Port 2 can also serve as a 4 -bit I/O bus expander when used in conjunction with the INS8243 I/O Expander.
The bus port is a true bidirectional port and is either statically latched or synchronous. It can be written to using WR strobe or read from using \(\overline{\mathrm{RD}}\) strobe. During an external program memory fetch, the 8 lower-order program counter bits are present at this port. The addressed instruction appears on this bus when PSEN is low. During an external RAM data transaction, this port presents address and data under control of ALE, \(\overline{\text { RD, }}\), and \(\overline{W R}\).

\section*{POWER-DOWN MODE}

During the power-down mode, \(V_{D D}\), which normally maintains the RAM cells, is the only pin that receives power. \(V_{C C}\), which serves the CPU and ports, is dropped from a voltage of nominal 5 to 0 after the CPU is reset, so that the RAM cells are unaltered by the loss of power. When power is restored, the processor goes through the normal poweron procedure.

\section*{MICROWIRE FUNCTIONS}

New functions applicable to microwire mode are as follows:
The SK output frequency is selected by writing into the P27 latch as follows:
\[
\begin{aligned}
& 0=\text { Instruction Cycle Divided by } 1 \\
& 1=\text { Instruction Cycle Divided by } 4
\end{aligned}
\]

The SO output is enabled or disabled by writing into the P26 latch as follows:
\[
\begin{aligned}
& 0=\text { Enabled } \\
& 1=\text { Disabled }
\end{aligned}
\]

The DONE flip-flop is tested with the JTO, JNTO instructions.


TL/C/5488-19
FIGURE 4. Ports 1 and 2 Input/Output Circult

\section*{Instruction Set}

Table I details the 96 instructions common to both the microcomputers and the microprocessors. The table provides the mnemonic, function, and description, instruction code, number of cycles and, where applicable, flag settings.

TABLE I．Instruction Set
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Mnemonic} & \multirow{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & C & AC & F0 & F1 \\
\hline
\end{tabular}

\section*{3ONTROL}
\begin{tabular}{l|l|l|l|l|l|l|l}
\hline ENI & & Enable the External Interrupt Input． & 1 & 1 & & & \\
\hline JSI & & Disable the External Interrupt Input． & 1 & 1 & & & \\
\hline ENTO CLK & & Enable T0 as the Clock Output． & 1 & 1 & & & \\
\hline 3EL MB0 & （DBF）\(\leftarrow 0\) & \begin{tabular}{l} 
Select Bank 0（locations 0－2047）of \\
Program Memory．
\end{tabular} & 1 & 1 & & & \\
\hline 3EL MB1 & \((D B F) \leftarrow 1\) & \begin{tabular}{l} 
Select Bank 1（locations 2048－4095）of \\
Program Memory．
\end{tabular} & 1 & 1 & & & \\
\hline SEL RB0 & \((B S) \leftarrow 0\) & \begin{tabular}{l} 
Select Bank 0（locations 0－7）of Data \\
Memory．
\end{tabular} & 1 & 1 & & & \\
\hline SEL RB1 & （BS）\(\leftarrow 1\) & \begin{tabular}{l} 
Select Bank 1（locations 24－31）of Data \\
Memory．
\end{tabular} & 1 & 1 & & & \\
\hline
\end{tabular}

\section*{DATA MOVES}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline MOV A，\＃data & （A）\(\leftarrow\) data & Move Immediate the specified data into the Accumulator． & 2 & 2 & & & & \\
\hline MOV A，Rr & \((A) \leftarrow(\mathrm{Rr}) ; \mathrm{r}=0-7\) & Move the contents of the designated register into the Accumulator． & 1 & 1 & & & & \\
\hline MOV A，＠Rr & （A）\(\leftarrow((\mathrm{Rr}) \mathrm{)} ; \mathrm{r}=0-1\) & Move Indirect the contents of data memory location into the Accumulator． & 1 & 1 & & & & \\
\hline MOV A，PSW & （A）\(\leftarrow(\) PSW \()\) & Move contents of the Program Status Word into the Accumulator． & 1 & 1 & & & & \\
\hline MOV Rr，\＃data & \((\mathrm{Rr}) \leftarrow\) data； \(\mathrm{r}=0-7\) & Move Immediate the specified data into the designated register． & 2 & 2 & & & & \\
\hline MOV Rr，A & \((\mathrm{Rr}) \leftarrow(\mathrm{A}) ; \mathrm{r}=0-7\) & Move Accumulator contents into the designated register． & 1 & 1 & & & & \\
\hline MOV＠Rr，A & \(((\mathrm{Rr})) \leftarrow(\mathrm{A}) ; \mathrm{r}=0-1\) & Move Indirect Accumulator contents into data memory location． & 1 & 1 & & & & \\
\hline MOV＠Rr，\＃data & \(((\mathrm{Rr})) \leftarrow\) data； \(\mathrm{r}=0-7\) & Move Immediate the specified data into data memory． & 2 & 2 & & & & \\
\hline MOV PSW，A & \((\mathrm{PSW}) \leftarrow(\mathrm{A})\) & Move contents of Accumulator into the Program Status Word． & 1 & 1 & \(\bullet\) & \(\bullet\) & － & \\
\hline MOVP A，＠A & \[
\begin{aligned}
& (\mathrm{PC} 0-7) \leftarrow(\mathrm{A}) \\
& (\mathrm{A}) \leftarrow((\mathrm{PC}))
\end{aligned}
\] & Move the content of program memory location in the current page addressed by the content of Accumulator into the Accumulator． & 2 & 1 & & & & \\
\hline MOVP3 A，＠A & \[
\begin{aligned}
& (P C 0-7) \leftarrow(A) \\
& (P C 8-10) \leftarrow 011 \\
& (\mathrm{~A}) \leftarrow((\mathrm{PC}))
\end{aligned}
\] & Move the content of program memory location in page 3 addressed by the content of Accumulator into the Accumulator． & 2 & 1 & & & & \\
\hline MOVX A，＠R & \((\mathrm{A}) \leftarrow((\mathrm{Rr})\) ） \(\mathrm{r}=0-1\) & Move Indirect the contents of external data memory into the Accumulator． & 2 & 1 & & & & \\
\hline MOVX＠R，A & \(((\mathrm{Rr})) \leftarrow(\mathrm{A}) ; \mathrm{r}=0-1\) & Move Indirect the contents of the Accumulator into external data memory． & 2 & 1 & & & & \\
\hline XCH A，Rr & \((\mathrm{A}) \longleftrightarrow(\mathrm{Rr}) ; \mathrm{r}=0-7\) & Exchange the Accumulator and designated register＇s contents． & 1 & 1 & & & & \\
\hline XCH A，＠Rr & \((A) \longleftrightarrow((R r)) ; r=0-1\) & Exchange Indirect contents of Accumulator and location in data memory． & 1 & 1 & & & & \\
\hline XCHD A，＠Rr & \[
\begin{aligned}
& (A 0-A 3) \leftarrow(((\mathrm{Rr})) 0-3) ; \\
& R=0-1
\end{aligned}
\] & Exchange Indirect 4－bit contents of Accumulator and data memory． & 1 & 1 & & & & \\
\hline
\end{tabular}

TABLE I. Instruction Set (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Mnemonic} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow[t]{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & C & AC & F0 & F1 \\
\hline
\end{tabular}

\section*{TIMER COUNTER}
\begin{tabular}{|l|l|l|l|l|l|l|l}
\hline EN TCNTI & & \begin{tabular}{l} 
Enable Internal Interrupt Flag for Timer/ \\
Counter output.
\end{tabular} & 1 & 1 & & & \\
\hline DIS TCNTI & & \begin{tabular}{l} 
Disable Internal Interrupt Flag for Timer/ \\
Counter output.
\end{tabular} & 1 & 1 & & & \\
\hline MOV A, T & \((\mathrm{A}) \leftarrow(\mathrm{T})\) & \begin{tabular}{l} 
Move contents of Timer/Counter into \\
Accumulator.
\end{tabular} & 1 & 1 & & & \\
\hline MOV T, A & \((\mathrm{T}) \leftarrow(\mathrm{A})\) & \begin{tabular}{l} 
Move contents of Accumulator into Timer/ \\
Counter.
\end{tabular} & 1 & 1 & & & \\
\hline STOP TCNT & & Stop Count for Event Counter. & 1 & 1 & & & \\
\hline STRT CNT & & Start Count for Event Counter. & 1 & 1 & & & \\
\hline STRT T & & Start Count for Timer. & 1 & 1 & & & \\
\hline
\end{tabular}

\section*{ACCUMULATOR}


TABLE I．Instruction Set（Continued）
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Unemonic} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Descriptlon} & \multirow[t]{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & c & AC & F0 & F1 \\
\hline \multicolumn{9}{|l|}{SCUMULATOR（Continued）} \\
\hline －A & \[
\begin{aligned}
& (A n+1) \leftarrow(A n) \\
& \text { for } n=0-6 \\
& (A 0) \leftarrow(A 7) \\
& \hline
\end{aligned}
\] & Rotate Accumulator left by 1 －bit without carry． & 1 & 1 & & & & \\
\hline －CA & \[
\begin{aligned}
& (A n+1) \leftarrow(A n) ; n=0-6 \\
& (A 0) \leftarrow(C) \\
& (C) \leftarrow(A 7)
\end{aligned}
\] & Rotate Accumulator left by 1－bit through carry． & 1 & 1 & \(\bullet\) & & & \\
\hline 7 A & \[
\begin{aligned}
& (A n) \leftarrow(A n+1) ; n=0-6 \\
& (A 7) \leftarrow(A 0)
\end{aligned}
\] & Rotate Accumulator right by 1 －bit without carry． & 1 & 1 & & & & \\
\hline RCA & \begin{tabular}{l}
\((A n) \leftarrow(A n+1) ; n+0-6\) \\
\((\mathrm{A} 7) \leftarrow(\mathrm{C})\) \\
（C）\(\leftarrow(A O)\)
\end{tabular} & Rotate Accumulator right by 1 －bit through carry． & 1 & 1 & － & & & \\
\hline NAP & \((A 4-A 7) \longleftrightarrow(A 0-A 3)\) & Swap the 2 4－bit nibbles in the Accumulator． & 1 & 1 & & & & \\
\hline RL A，\＃data & \((A) \leftarrow(A)\) XOR data & Logical XOR Immediate specified data with Accumulator． & 2 & 2 & & & & \\
\hline RL A，Rr & \[
\begin{aligned}
& (A) \leftarrow(A) \times O R(\mathrm{Rr}) \\
& \text { for } r=0-7 \\
& \hline
\end{aligned}
\] & Logical XOR contents of designated register with Accumulator． & 1 & 1 & & & & \\
\hline RL A，＠Rr & \[
\begin{aligned}
& (A) \leftarrow(A) \text { XOR }((R r)) \\
& \text { for } r=0-1
\end{aligned}
\] & Logical XOR Indirect the contents of data memory location with Accumulator． & 1 & 1 & & & & \\
\hline \multicolumn{9}{|l|}{RANCH} \\
\hline JNZ Rr，addr & \[
\begin{aligned}
& \text { (Rr) } \leftarrow(\mathrm{Rr})-; r=0-7 \\
& \text { if }(\mathrm{Rr}) \neq 0 ; \\
& \text { (PC 0-7) } \leftarrow \text { addr } \\
& \hline
\end{aligned}
\] & Decrement the specified register and test contents． & 2 & 2 & & & & \\
\hline Bb addr & \[
\begin{aligned}
& (\mathrm{PC} 0-7) \leftarrow \text { addr if } \mathrm{Bb}=1 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { If } \mathrm{BB}=0
\end{aligned}
\] & Jump to specified address if Accumulator bit is set． & 2 & 2 & & & & \\
\hline C addr & \[
\begin{aligned}
& (\mathrm{PC} 0-7) \leftarrow \text { addr if } \mathrm{C}=1 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { If } \mathrm{C}=0 \\
& \hline
\end{aligned}
\] & Jump to specified address if carry flag is set． & 2 & 2 & & & & \\
\hline FO addr & \[
\begin{aligned}
& (\mathrm{PC} 0-7) \leftarrow \text { addr if } \mathrm{FO}=1 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { If } \mathrm{FO}=0
\end{aligned}
\] & Jump to specified address if Flag F0 is set． & 2 & 2 & & & & \\
\hline Fl addr & \[
\begin{aligned}
& (\mathrm{PC} 0-7) \leftarrow \operatorname{addr} \text { if } \mathrm{F} 1=1 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { If } \mathrm{F} 1=0
\end{aligned}
\] & Jump to specified address if Flag F1 is set． & 2 & 2 & & & & \\
\hline MP addr． & \[
\begin{aligned}
& (P C 8-10) \leftarrow 8-10 \\
& (P C \text { 0-7) } \leftarrow \text { addr } 0-7 \\
& (P C \text { 11) } \leftarrow \text { DBF } \\
& \hline
\end{aligned}
\] & Direct Jump to specified address with the 2 k address block． & 2 & 2 & & & & \\
\hline MPP＠A & \((\mathrm{PC} 0-7) \leftarrow((\mathrm{A}))\) & Jump Indirect to specified address pointed to by the Accumulator in current page． & 2 & 1 & & & & \\
\hline NC addr & \[
\begin{aligned}
& \text { (PC 0-7) } \leftarrow \text { addr if } \mathrm{C}=0 \\
& \text { (PC) } \leftarrow(\mathrm{PC})+2 \text { if } \mathrm{C}=1 \\
& \hline
\end{aligned}
\] & Jump to specified address if carry flag is low． & 2 & 2 & & & & \\
\hline Nl addr & \[
\begin{aligned}
& (\mathrm{PC} 0-7) \leftarrow \text { addr if } I=0 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { if } \mathrm{I}=1
\end{aligned}
\] & Jump to specified address if interrupt is low． & 2 & 2 & & & & \\
\hline NT0 addr & \[
\begin{aligned}
& (\mathrm{PC} 0-7) \leftarrow \text { addr if } \mathrm{TO}=0 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { if } \mathrm{TO}=1
\end{aligned}
\] & Jump to specified address if Test 0 is low． & 2 & 2 & & & & \\
\hline NT1 addr & \[
\begin{aligned}
& (\mathrm{PC} 0-7) \leftarrow \text { addr if T1 }=0 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { if } \mathrm{T} 1=1
\end{aligned}
\] & Jump to specified address if Test 1 is low． & 2 & 2 & & & & \\
\hline
\end{tabular}

\section*{TABLE I. Instruction Set (Continued)}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Mnemonic} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow[t]{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & C & AC & F0 & \\
\hline
\end{tabular}

\section*{BRANCH (Continued)}


\section*{INPUT/OUTPUT}


\section*{REGISTERS}
\begin{tabular}{|l|l|l|l|l|l|l|l}
\hline DEC Rr & \((\mathrm{Rr}) \leftarrow(\mathrm{Rr})-1 ; r=0-7\) & \begin{tabular}{l} 
Decrement by 1 contents of designated \\
register.
\end{tabular} & 1 & 1 & & & \\
\hline \(\operatorname{INC~Rr}\) & \((\mathrm{Rr}) \leftarrow(\mathrm{Rr})+1 ; r=0-7\) & \begin{tabular}{l} 
Increment by 1 contents of designated \\
register.
\end{tabular} & 1 & 1 & & & \\
\hline INC @ Rr & \begin{tabular}{l}
\(((\mathrm{Rr})) \leftarrow((R r))+1 ;\) \\
\(\mathrm{r}=0-1\)
\end{tabular} & \begin{tabular}{l} 
Increment Indirect by 1 the contents of \\
data memory location.
\end{tabular} & 1 & 1 & & & \\
\hline
\end{tabular}

TABLE I. Instruction Set (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Anemonic} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow[t]{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & c & AC & F0 & F1 \\
\hline
\end{tabular}
iUBROUTINE
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline ;ALL addr & \[
\begin{aligned}
& ((S P)) \leftarrow(P C) \\
& ((\mathrm{SP})) \leftarrow(\mathrm{PSW} 4-7) \\
& (\mathrm{SP}) \leftarrow(\mathrm{SP})+1 \\
& (\mathrm{PC} 8-10) \leftarrow \text { addr } 8-10 \\
& (\mathrm{PC} 0-7) \leftarrow \text { addr } 0-7 \\
& (\mathrm{PC} 11) \leftarrow \text { DBF } \\
& \hline
\end{aligned}
\] & Call designated Subroutine. & 2 & 2 & & & & \\
\hline 3ET & \[
\begin{aligned}
& (\mathrm{SP}) \leftarrow(\mathrm{SP})-1 \\
& (\mathrm{PC}) \leftarrow((\mathrm{SP})) \\
& \hline
\end{aligned}
\] & Return from Subroutine without restoring Program Status Word. & 2 & 1 & & & & \\
\hline 3ETR & \[
\begin{aligned}
& (\mathrm{SP}) \leftarrow(\mathrm{SP})-1 \\
& (\mathrm{PC}) \leftarrow((\mathrm{SP})) \\
& (\mathrm{PSW} 4-7) \leftarrow((\mathrm{SP}))
\end{aligned}
\] & Return from Subroutine restoring Program Status Word. & 2 & 1 & - & - & & \\
\hline \multicolumn{9}{|l|}{:LAGS} \\
\hline JPLC & (C) \(\leftarrow \operatorname{NOT}\) (C) & Complement Content of carry bit. & 1 & 1 & - & & & \\
\hline JPL FO & \((\mathrm{FO}) \leftarrow \operatorname{NOT}(\mathrm{FO})\) & Complement Content of Flag F0. & 1 & 1 & & & \(\bullet\) & \\
\hline JPL F1 & (F1) \(\leftarrow \operatorname{NOT}(\mathrm{F} 1)\) & Complement Content of Flag F1. & 1 & 1 & & & & - \\
\hline JLR C & (C) \(\leftarrow 0\) & Clear content of carry bit to 0 . & 1 & 1 & - & & & \\
\hline 3LR F0 & (F0) \(\leftarrow 0\) & Clear content of Flag 0 to 0. & 1 & 1 & & & - & \\
\hline JLR F1 & \((\mathrm{F} 1) \leftarrow 0\) & Clear content of Flag 1 to 0. & 1 & 1 & & & & - \\
\hline \multicolumn{9}{|l|}{UISCELLANEOUS} \\
\hline VOP & & No operation & 1 & 1 & & & & \\
\hline \multicolumn{9}{|l|}{UICROWIRE INSTRUCTIONS} \\
\hline XCHM & \(A \longleftrightarrow\) SIO & Reset DONE flip-flop, Clock counter. SK designated as an output. MICROWIRE/PLUS mode selected. & & & & & & \\
\hline XCHS & \(A \longleftrightarrow \mathrm{SIO}\) & Reset DONE flip-flop, Clock counter. SK designated as an input. MICROWIRE/PLUS mode selected. & & & & & & \\
\hline
\end{tabular}

\section*{Symbol Definitions}
\begin{tabular}{|l|l|}
\hline Symbol & \multicolumn{1}{|c|}{ Description } \\
\hline A & Accumulator \\
\hline AC & Auxiliary Carry Flag \\
\hline addr & Program Memory Address (12 bits) \\
\hline b & Bit Designator (b \(=0-7\) \\
\hline BS & Bank Switch \\
\hline Bus & Bus Port \\
\hline C & Carry Flag \\
\hline CLK & Clock Signal \\
\hline CNT & Event Counter \\
\hline D & Nibble Designator (4 bits) \\
\hline data & Number of Expression (8 bits) \\
\hline DBF & Memory Bank Flip-Flop \\
\hline \(\mathrm{F}_{0}, \mathrm{~F}_{1}\) & Flags 0,1 \\
\hline I & Interrupt \\
\hline P & "In-Page" Operation Designator \\
\hline
\end{tabular}
\begin{tabular}{|l|l|}
\hline Symbol & \multicolumn{1}{c|}{ Description } \\
\hline\(p\) & Port Designator ( \(p=1,2\) or 4-7) \\
\hline PSW & Program Status Word \\
\hline\(r\) & Register Designator ( \(r=0,1\) or 0-7) \\
\hline SP & Stack Pointer \\
\hline\(T\) & Timer \\
\hline TF & Timer Flag \\
\hline\(T 0, \mathrm{T1}\) & Testable Flags 0, 1 \\
\hline\(X\) & External RAM \\
\hline\(\#\) & Prefix for Immediate Data \\
\hline\(@\) & Prefix for Indirect Address \\
\hline\(S\) & Program Counter's Current Value \\
\hline\((x)\) & Contents of Register \\
\hline\(((x x))\) & \begin{tabular}{l} 
Contents of Memory Location \\
Addressed by the Contents of \\
Register
\end{tabular} \\
\hline & Replaced by \\
\hline
\end{tabular}


\section*{Typical Applications}

Figure 5 shows a typical remote data acquisition system with an INS8250 Programmable Asynchronous Communication System, which can receive commands or update information from a supervisory computer. The figure also shows an INS8294 CMOS DVM that receives data at VIN and displays the data on the 7 -segment local display unit. Data is transferred from the INS8294 to the INS8094 via National's MICROBUSTM.
Figure 6 offers an example system that utilizes the unique capacity of these parts. With the addition of an ADC0837 serial A/D converter and a DM74LS138 3-to-8 decoder, the basic INS8048 and MM5445/MM5446/MM5447/MM5448, MM5450/MM5451/MM5452/MM5453 system can display
inputs from 8 separate I/O devices using only one of the INS8048's I/O ports. The other port and the bus can handle any number of tasks. Shown here is the use of Port 2 to control a keyboard, used to enter limits on the inputs. The bus is used to control relay drivers which will regulate the 1/O devices when the limits (previously set on the keyboard) are met.
Figure 7 shows a typical way to use the 48-Series microcontrollers in a stand-alone system.
Crystal used is parallel resonant, AT cut and 1 MHz to 6 MHz . All outputs are standard TTL compatible at 5 V .


FIGURE 5. Data Acquisition System


TL/C/5488-21
FIGURE 6. Typical Application

Typical Applications (Continued)


TL/C/5488-22
FIGURE 7. Stand-Alone 48-Series
NS8050U Applications
Block and Connection Diagrams


NS8050U Applications (Coninued)
MICROWIRE/PLUS consists of a three wire communications port with a clocked 8-bit shift register. The three lines consist of Serial Output (SO), Serial Input (SI) and Serial Clock (SK) and the Shift register is referred to as the Serial Input/Output Register. One 8050 U is designated the master and it supplies the clock for the MICROWIRE/PLUS system and initiates data transfer. All transfers are between the master and one or more slaves. A slave can be any MICROWIRE peripheral or another 8050U with MICROWIRE/ PLUS.

MICROWIRE Peripherals
DATA ACQUISITION
COP43X 8-bit A/D converters
FREQUENCY GENERATORS AND COUNTERS
COP452 Frequency generator and counter
DISPLAY DRIVERS
COP470 Four-digit vacuum fluorescent display driver

COP472 Triplex liquid crystal display controller

MM5445, 5446, Vacuum fluorescent display driver 5447, 5448
MM5450, 5451 LED display driver
MM5452, 5453 Liquid crystal display driver
MM5480, 5481 LED display driver
MM5484, 5485 16- and 11-segment LED display driver
MM58201 Multiplexed LCD driver
MM58248 High-voltage display driver
MEMORIES
COP498 Low-power CMOS RAM and timer
COP499 Low-power CMOS RAM
COP494 256-bit, 5V only EEPROM
COP495 1024-bit, 5V only EEPROM
RADIO TUNING
DS890X AM/FM digital phase-locked loop synthesizer

Peripheral device information may be found in the COPS Microcontrollers Databook.

\section*{INS8243 Input/Output Expander}

\section*{General Description}

The INS8243 is an input/output device specifically designed to furnish input/output expansion capabilities for the INS8048, INS8049 and NS8050 single chip microcomputer family. The INS8243 is fabricated using XMOSTM (high density N -channel silicon gate) technology, operates from a single 5 V supply and is TTL compatible. It is housed in a \(24-\) pin, dual-in-line package and provides high drive current capabilities at low cost.
The INS8243 expander consists of five, 4-bit bidirectional ports. One port provides the interface with the INS8048/49/50 microcomputer. The remaining four ports provide the input/output expansion.
The INS8243 I/O ports function as a direct extension for the resident I/O port of the INS8048/49/50 microcomputer
series and are accessed by the MOV, ANL or ORL instructions of the INS8048/49/50.

\section*{Features}
- XMOS technology
- Single 5V supply
- Low cost I/O expansion

■ Easy interface with INS8048/49/50 microcomputers
- High fanout capability
- 24-Pin DIP

■ Direct extension of INS8048/49/50 I/O ports

\section*{Basic System Configuration}

Single Expander Interface


\section*{Absolute Maximum Ratings}

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Ambient Temperature Under Bias
\(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\)
Storage Temperature Range \(\quad-65^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}\)
Voltage on Any Pin with Respect to GND \(\quad-0.5 \mathrm{~V}\) to +7.0 V

Note: Absolute maximum ratings indicate limits beyon which permanent damage may occur. Continuous operatio at these limits is not intended; operation should be limited \(t\) those conditions specified under DC Electrical Characteris tics.

DC Electrical Characteristics \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} 10+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Test Conditions & Min & Typ & Max & Units \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Low Voltage & & -0.5 & & 0.8 & V \\
\hline \(\mathrm{V}_{\text {IH }}\) & Input High Voltage & & 2.0 & & \(\mathrm{V}_{C C}+0.5\) & V \\
\hline \(\mathrm{V}_{\mathrm{OL} 1}\) & Output Low Voltage Ports 4-7 & \(\mathrm{IOL}^{\prime}=5 \mathrm{~mA}\) & & & 0.45 & V \\
\hline \(\mathrm{V}_{\mathrm{OL} 2}\) & Output Low Voltage Port 7 & \(1 \mathrm{OL}=20 \mathrm{~mA}\) & & & 1 & V \\
\hline \(\mathrm{V}_{\mathrm{OH} 1}\) & Output High Voltage Ports 4-7 & \(\mathrm{I}_{\mathrm{OH}}=240 \mu \mathrm{~A}\) & 2.4 & & & V \\
\hline ILL1 & Input Leakage Ports 4-7 & \(V_{\text {IN }}=V_{\text {CC }}\) to 0 V & -10 & & 20 & \(\mu \mathrm{A}\) \\
\hline \(11 / 2\) & Input Leakage Port 2, \(\overline{\mathrm{CS}}, \mathrm{PROG}\) & \(\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}\) to 0 V & -10 & & 10 & \(\mu \mathrm{A}\) \\
\hline \(\mathrm{V}_{\text {OL3 }}\) & Output Low Voltage Port 2 & \(\mathrm{l}_{\mathrm{OL}}=0.6 \mathrm{~mA}\) & & & 0.45 & V \\
\hline Icc & \(V_{C C}\) Supply Current & & & 10 & 20 & mA \\
\hline \(\mathrm{V}_{\mathrm{OH} 2}\) & Output Voltage Port 2 & \(\mathrm{IOH}=100 \mu \mathrm{~A}\) & 2.4 & & & V \\
\hline lol & Sum of all loL from 16 Output Ports & At 5 mA per pin & & & 100 & mA \\
\hline
\end{tabular}

AC Electrical Characteristics \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} 10+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\), \(\mathrm{GND}=0 \mathrm{~V}\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Test Conditions & Min & Typ & Max & Units \\
\hline tSC & Code Valid Before PROG & 80 pF Load & 100 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{HC}}\) & Code Valid After PROG & 20 pF Load & 60 & & & ns \\
\hline tSD & Data Valid Before PROG & 80 pF Load & 200 & & & ns \\
\hline \(t_{H D}\) & Data Valid After PROG & 20 pF Load & 20 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{FLT}}\) & TRI-STATE After PROG & 20 pF Load & 0 & & 150 & ns \\
\hline tw & PROG Negative Pulse Width & & 700 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{CS}}\) & \(\overline{\text { CS }}\) Valid Before/After PROG & & 50 & & & ns \\
\hline tpo & Ports 4-7 Valid After PROG & 100 pF Load & & & 700 & ns \\
\hline tLP1 & Ports 4-7 Valid Beforé/After PROG & & 100 & & & ns \\
\hline \(t_{\text {ACC }}\) & Port 2 Valid After PROG & 80 pF Load & & & 650 & ns \\
\hline
\end{tabular}

Timing Waveforms (*These signals are generated by the INS8048/49/50.)

Expander Input Timing


Input/Output Waveforms


TL/C/7998-3

\section*{Functional Pin Descriptions}

The following describes the function of the INS8243 input/ output pins. Some of these descriptions reference internal circuits.

\section*{CONTROL SIGNALS}

Chip Select ( \(\overline{\mathrm{CS}}\) ): When \(\overline{\mathrm{CS}}\) is low (negative true), the 4-bit input to port 2 is enabled. A high on \(\overline{\mathrm{CS}}\) inhibits any input to port 2 and no change to internal status and output can occur.
Strobe Input (PROG): The low to high transition on the PROG indicates data is available at port 2; a high to low transition on PROG signifies command and address information is at port 2.

\section*{INPUT/OUTPUT SIGNALS}

Port 2: Port 2 is a 4-bit bidirectional port that provides the interface between the INS8048/49/50 and the input/output ports 4-7. Communication between the INS8048/49/50 and the INS8243 is accomplished with 4-bit nibbles. A 4-bit nibble consists of two bits that comprise a functional command and two bits that indicate the address of a specific input/output port (P4-P7), or it consists of four data bits. The high to low transition of the PROG input indicates address and command bits are present at port P2. The low to high transition of the PROG input indicates that data bits are present at port P2. If the operation is a read function, data from a selected port (P4-P7) is read to the microcomputer via port 2, prior to the low to high transition of the PROG input. The tables below show the binary inputs for port and command selection.

Port Selection Table
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{\begin{tabular}{c} 
Input/Output \\
Address Code
\end{tabular}} & \multirow{2}{*}{\begin{tabular}{c} 
Selected \\
Input/Output Port
\end{tabular}} \\
\hline P21 & P20 & \\
\hline 0 & 0 & 4 \\
0 & 1 & 5 \\
1 & 0 & 6 \\
1 & 1 & 7 \\
\hline
\end{tabular}

Functional Command Selection Table
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{ Command Code } & \multirow{2}{*}{ Function } \\
\hline P23 & P22 & \\
\hline 0 & 0 & Read \\
0 & 1 & Write \\
1 & 0 & ORLD \\
1 & 1 & ANLD \\
\hline
\end{tabular}

Ports 4-7 (PI): These are four, 4-bit bidirectional input/output ports. Each port is addressable and may be programmed to perform a read (input data) or write (output data) via a low impedance latched output. Data presented to port 2 during a write operation may be output directly to the addressed output port or logically ANDed or ORed with data existing in the selected port. For a read operation, data at the addressed port (P4-P7) is transferred to port 2.

\section*{Connection Diagram}


TL/C/7998-4
Order Number INS8243J
See NS Package J24A
Order Number INS8243N See NS Package N24A

\section*{PROTECTION CIRCUITS}

Figure 1 illustrates the protection circuits for the input and output pins.


FIGURE 1. Protection Circuits for I/O Pins

\section*{Eunctional Description}
-he INS8243 (Figure 2) consists of four, 4-bit I/O ports that unction as the extension of the INS8048/49/50 on-chip inut/output port. The four I/O ports (P4 through P7) are adIressable and the following programmed INS8048/49/50 istructions are used to access these ports. The instructions nove data to/from the INS8048/49/50 accumulator via the NS8243. Timing for the transfer of data is provided by the NS8048/49/50 PROG output.
I. MOVD \(\mathrm{Pi}, \mathrm{A}\)-Shift accumulator data to the addressed port.
1. MOVD A,PI-Shift addressed port data to the accumulator.
: ANLD Pi,A—ANDing accumulator data to addressed port. I. ORLD Pi,A-ORing accumulator data to addressed port. 'ort 2 of the INS8243 provides the communication interface setween the expander and the INS8048/49/50 processor. Each communications exchange is comprised of two, 4-bit libbles, one nibble consisting of command and address inormation, the second is a 4-bit data nibble. Timing for the /O expander is provided by the processor on the PROG nput pin.

\section*{'OWER-ON INITIALIZING MODE}
tpplication of DC power to the chip forces I/O port 2 to the nput mode and I/O ports 4 through 7 to the TRI-STATE \({ }^{\circledR}\)品put mode (high impedance state). The power-on sejuence is initiated when \(\mathrm{V}_{\mathrm{CC}}\) falls below 1 V . The input level נn the PROG may be high or low when DC is first applied. The initial high to low transition of the PROG input forces he chip to exit the power-on mode.

\section*{3EAD MODE}

The INS8243 I/O expander has one read mode that is inijalized by the following instruction:
- MOVDA,Pi-instruction from INS8048/49/50 takes data from the addressed I/O port (P4-P7) and moves the data into the accumulator.

The command code and port address code are latched from the input port 2 on the high to low transition of the PROG input pin. When the read command and the port address are decoded, the data from the addressed port is presented back to the INS8048/49/50 on port P2. Termination of the read command occurs on the low to high transition of the PROG input. The port (4,5,6 or 7) that was addressed switches to the high impedance state and port 2 reverts to the input (read) mode. A port will normally be in either write (output) mode or read (input) mode. To allow for the settling of the external driver on the port, the first read following a write should be discounted when modes are changed during operation. All succeeding reads are valid.

\section*{WRITE MODES}

The INS8243 has three write modes that are initialized by the following instructions:
a. MOVD Pi,A—Instruction from the INS8048/49/50 writes new data directly into the addressed port. Existing data is lost.
b. ORLD Pi,A-Instruction from the INS8048/49/50 takes port P2 data, logically ORing it with the existing data in the addressed port and writes the resultant data into the port.
c. ANLD Pi,A-Instruction from the INS8048/49/50 takes port P2 data, logically ANDing it with the existing data in the addressed port and writes the ANDed data into the port.
Command and port address codes are latched from the port 2 input on the high to low transition of the PROG input. Data on port 2 is deposited in the logic circuits of the addressed port. When the logic manipulation has been performed, data is latched and output. Old data stays latched until valid new outputs are written.


Note: Applicable pinout numbers are included within parentheses.
TL/C/7998-6
FIGURE 2. INS8243 I/O Expander Block Diagram

\section*{Functional Description (Continued)}

\section*{MULTIPLE INS8243 I/O EXPANDER USE}

To expand the resident I/O port capabilities of the INS8048/49/50 microcomputer series sixteen times, four INS8243 expanders may be connected to the microcomputer, as shown in Figure 3. By using the high order bit outputs P24 through P27 as the chip select ( \(\overline{\mathrm{CS}}\) ) input to the I/O expanders, no additional logic circuits are required. A nega-
tive true input (low) on the \(\overline{\mathrm{CS}}\) line will enable the port \(\bar{c}\) input for the selected I/O expander. A single INS8048/49/ 50 microcomputer may use many (up to twenty) I/O expanders without additional logic circuits on the same bus, limited only by the availability of chip select lines and loadins restrictions.


TL/C/7998-7
FIGURE 3. Typical Connections Using INS8243 I/O Expander

Functional Description (Continued)
Larger numbers of INS8243 expanders would require chip select decoder chips to conserve miocrocomputer I/O pins.
Operation of the INS8243 expander selected in the same as was explained in the functional description. Figure 4 is a typical system application.


FIGURE 4. Typical System Application

\section*{Using E2PROM's with ROMIess Single Chip Microcontroller}

National Semiconductor Corp. Application Brief Joel Fishman


When developing programs for single chip microcontrollers, current thinking suggests that engineers use \(\mu \mathrm{vEPROMs}\) as program memory. This technology offers the advantage of non-volatility yet allows the designer to change the program when necessary. This technology has manifested itself in ROMless versions of the COPSTM 4-bit and 8048 8-bit families with parts such as the 8035 and 87P50 piggyback version.
The major disadvantage of this technology is that the entire chip must be erased and reprogrammed regardless of the size of the change. The chip erase cycle takes 20 minutes, typically, and as such, lengthens the software development cycle. Although a number of \(\mu \mathrm{vEPROMs}\) ' may be held as spares for reprogramming this is not the most efficient method available.
Emerging Electrically Erasable PROM (E²PROM) technology solves this problem. The entire chip may be programmable using a PROM programmer such as the one you'd use for the \(\mu \mathrm{VEPROMs}\). In addition, thanks in part to the 5 V only operation, on-board address and data latches, self-timed writing, and single byte programming the E2PROM may be modified in the system with minimal hardware overhead. This application note shows how to design the hardware to interface a ROMless version of the 8048 family with the NMC9816A and NMC9817A, National's 16k (2k x 8), 5V only E2PROM.
When making program changes manually, it may be more efficient to just make patches than to reprogram large sections of memory. After the program is running, a final step would be to reassemble. This manual technique is also suitable for changing minor errors in instruction coding.

\section*{Description}

Figure 1 shows the block diagram required to implement a ROMless 8-bit microcontroller with 4 k bytes of E2PROM.
Normal operation of the system occurs when the PROG/ OPER switch is in the OPER position. This enables the output of the address latch from the microcontroller, while putting the TRI-STATE \({ }^{@}\) drivers from the DIP switches to the high impedance state. The system functions as current designs using EPROMs.
When a location in memory needs to be changed the switch is set to the PROG position. This enables the DIP SWITCH DRIVERS. The address of the byte to be modified and the data to be written are set on the binary DIP switches. The WRITE push button is pressed, generating a \(10 \mu \mathrm{sec}\) negative going pulse.
The write pulse ( \(\overline{\mathrm{WE}}\) ) latches the address and the data into the proper 2 k page of memory, as selected by ADDR11 and the write cycle takes place.
This technique may be used to change one byte, a few bytes, or to put a patch into the software. If a routine is incorrect a jump instruction to a blank area of memory can be used to create a new routine.

\section*{Block Diagram}


FIGURE 1

\section*{Internal ROM Verification For The 48-Series Microcontrollers}

\section*{INTRODUCTION}

The introduction and development of semiconductor industry has also spawned associated problems in the area of testing the devices. Testing the devices is a major expenditure. As the complexity of the device increases the testing costs escalate. This is especially true for microcontrollers since they incorporate complete microcomputer systems. Verifying the program code sequences mask programmed into the microcontroller forms an integral part of testing the devices. This note briefly discusses the ideas involved in carrying out a ROM dump for the 48 -series of microcontrollers from National Semiconductor. At the end of the discussion a procedure to ensure a successful ROM dump is recommended.

\section*{THE 48-SERIES MICROCONTROLLERS}

The 48 -series family of microcontrollers are complete 8 -bit computer systems incorporating the required ALU, RAM, ROM and 1/O with diverse technologies such as NMOS, CMOS and XMOS. The ideas and principles involved being the same, the discussion revolves around the INS8048 without any loss of generality.
The internal clock circuitry for the INS8048 accepts inputs from two pins viz XTAL1 and XTAL2. A crystal or an externally generated source can be connected across the two pins. The external clock frequency of the oscillator is divided by three to provide the basic clock for the system. Each clock comprises a single state and is referred to as a Machine Cycle. Five machine cycles comprise a single Instruction Cycle. To differentiate between the different machine cycles we refer to them as T1, T2, T3, T4 and T5. Figure 1 pictorially summarizes these relationships and indicates the sequence of operations that normally take place in an instruction cycle. The microcontroller continuously generates the Address Latch Enable (ALE) signal.

National Semiconductor Corp. Application Note 345 Venkata Gobburu

mal instruction execution mode of the microcontroller. The second step requires presenting specific ROM location addresses to the microcontroller. The microcontroller responds by placing the contents of the addressed ROM location on the bus. Reading the contents of the ROM location from the bus constitutes the final step. Repeating this sequence of three steps allows the contents of a block of ROM locations to be verified. We now detail the three steps.
The microcontroller contains logic which disables normal instruction execution mode and forces it into a special ROM verification mode. The logic triggers the changeover to the ROM verification mode when it senses the voltage at the Enable Access (EA) pin to be greater then +6 V . This condition remains active as long as the voltage at the EA pin, typically +12 V , is present.
The second step in the sequence requires specific ROM locations to be addressed. The addresses are presented as in the regular mode via the ports DBO-DB7 and P20-P23. To avoid possible bus conflicts it becomes imperative to ensure that the two ports are in an input mode. This can be very simply done by resetting the device. The microcontroller transfers the address presented at DBO-DB7 and P20P 23 to the Program Counter (PC). The transfer is done in two stages. The two stage transfer is necessitated by the fact that the PC is 12 bits wide whereas the internal data bus is only byte wide. An internal control signal clocks the lower order and the higher order sections into the PC. The data transfers are done during T2 and T3 machine cycles. The higher order bits of the PC are loaded in before the lower order bits. Obviously two complete instruction cycles are minimally required to latch in the address. Extra instruction cycles can be included to provide a wider margin of safety.

\section*{ROM VERIFICATION MODE}

In a nutshell the ROM verification program consists of three distinct steps. The first step involves suspending the nor-


FIGURE 1. Instruction Fetch from External Program Memory

The third step in the sequence consists of ensuring that the address has been latched and then reading the ROM contents placed on the bus in response. The microcontroller continues to alternately latch in the two sections of the PC. This can be discontinued by pulling the RESET pin high. Care must be exercised when doing this since a transition occurring during a transfer can latch undefined addresses. A point to be borne in mind when attempting to change the state of the RESET pin is that the microcontroller does not respond immediately. The \(\overline{\text { RESET pin is polled continuously }}\) during the T4 machine cycle, at the end of which the machine recognizes the reset signal. The next step consists of disabling the external circuitry holding the address on DBODB7 preparatory to reading the contents of the ROM location. The falling edge of the ALE signal can be used to disable the external circuitry. This is possible because of two internal conditions. First the ALE signal goes low during the T4 machine cycle and second the contents of the ROM location are enabled onto DB0-DB7 in the T1 machine cycle.

The preceding discussion highlights the different points to be borne in mind when attempting a ROM dump. The factors and their effects have been minutely described. The next section presents a ROM dump procedure.

\section*{THE RECOMMENDED ROM DUMP PROCEDURE}

A procedure to guarantee reading the contents of the internal ROM locations is presented in this section. It is assumed
that a Megatest or Fairchild type test setup is being used. The procedure is based upon the factors outlined in the previous section. The minimum timings obtained from it are suitably modified to include a margin of safety. The timings have been specified in machine cycle units rather then absolute timings so that they are valid over the entire frequency of operation.
1. \(\overline{\text { RESET }}\) must be low before EA goes high.
2. Synchronize to the falling edge of the ALE signal. Falling edge of the ALE indicates T4, the fourth machine cycle.
3. Starting in T5 force address in with RESET low for 21 machine cycles.

5. Force RESET high for 12 machine cycles.
6. Force \(\overline{\text { RESET }}\) high for 4 machine cycles. Data is valid on the bus till the falling edge of RESET.
7. Force \(\overline{\text { RESET }}\) low for 4 machine cycles.
8. Repeat steps 3 thru 7 for other addresses.

The procedure is presented pictorially Figure 2. Figure 3 gives a flowchart for the recommended procedure. The timings recommended guarantee correct operation. The timings are obviously greater then the minimum required. The ROM dump circuitry is used only for verifying the ROM contents and was not designed to, in any way, be indicative of normal instruction fetch timing.


FIGURE 2. ROM Verification Timing Diagram


FIGURE 3. Flowchart of the Recommended ROM Dump Procedure

\section*{NS8050U MICROWIRE PLUSTM Interface}

\section*{INTRODUCTION}

MICROWIRETM is a serial communications interface from National Semiconductor. Originally devised to allow the COPSTM Microcontrollers to effectively communicate with peripheral devices, it has now been extended to the 8 -bit 8048 microcontroller family. This extension is known as MICROWIRE PLUS.
The NS8050 from National Semiconductor, slated shortly for release, incorporates MICROWIRE PLUS. Its existence is entirely transparent to normal 8050 operation and is only activated upon execution of a new MICROWIRE PLUS instruction. This application note describes the features of the extension and presents programming examples to illustrate how to use MICROWIRE PLUS.

\section*{MICROWIRE PLUS}

The MICROWIRE PLUS protocol utilizes a 3-wire interface working in conjunction with a clocked eight bit input/output shift register, Figure 1. The shift register is referred to as the Serial Input/Output (SIO) register. The three interface sig-

National Semiconductor Corp. Application Note 358
Rao Gobburu James Murashige

nals are Serial Output (SO), Serial Input (SI), and Serial Clock (SK). The contents of the accumulator may be exchanged with the SIO register thus providing us a means of performing the parallel to serial data conversion. Data waiting to be transmitted in the SIO register is clocked out on the SO pin on the falling SK clock edge. Serial data is received on the SI pin and clocked into the SIO register on the rising SK clock edge.

On reset the NS8050 comes up in the normal mode of operation. The MICROWIRE mode of operation may be invoked by executing one of two new instructions, XCHM or XCHS. Both instructions cause the Accumulator and SIO register to exchange data, with the differences being in the SK clock generation. In Master mode, set by XCHM, the SK clock is generated internally and output to other devices. In Slave mode, set by XCHS, the SK clock is input into the chip from a master source. Once the MICROWIRE mode has been selected it remains in effect until a system reset restores the normal mode of operation. The only practical difference


TL/DD/6103-1
FIGURE 1. Microwire Mode Functional Configuration
between the 2 operating modes are the dedication of \(3 \mathrm{I} / \mathrm{O}\) pins to MICROWIRE operation. However, once in MICROWIRE mode, the chip may switch between Master and Slave operation at will.


TL/DD/6103-2
The 2 new instructions and their associated operations are as follows:
\(\left.\begin{array}{ccl}\begin{array}{c}\text { Mnenomic } \\ \text { XCHM }\end{array} & \begin{array}{c}\text { Opcode } \\ \text { C0 }\end{array} & \begin{array}{l}\text { A }<=>\text { SIO. Reset DONE } \\ \text { flip-flop, Clock counter. SK }\end{array} \\ \text { designated as an output. }\end{array}\right\}\)

For MICROWIRE PLUS applications, one NS8050 must be designated as the Master. The Master supplies the SK clock for the system and initiates all data transfers between itself and one of the Slave devices. A Slave may be any of the standard MICROWIRE peripheral chips or another MICROWIRE PLUS NS8050 operating in Slave mode. In a typical system the Serial Clock (SK) is tied together on all the chips. The Serial Out (SO) from the Master is tied to the Serial In (SI) on all the Slaves. Similiarly, the Serial in (SI) pin on the Master is tied to the Serial Out (SO) on all the Slaves. General purpose outputs on the Master are used to chip select various Slave devices onto the MICROWIRE PLUS bus.
Among the various standard MICROWIRE peripherals available are display drivers (LCD, VF, LED), memories (RAM, EEROM), A/D converters, and frequency generators/timers.

\section*{NS8050 HARDWARE MODIFICATIONS}

Three of the general purpose I/O pins on the NS8050 become dedicated signals when operating in MICROWIRE mode as follows:
\begin{tabular}{cl} 
NS8050 Pin & \multicolumn{1}{c}{\begin{tabular}{c} 
Function Under \\
MICROWIRE PLUS
\end{tabular}} \\
T0 & Serial Clock Input or Output \\
P26 & Serial Data Output \\
P27 & Serial Data Input
\end{tabular}

In addition, upon entering MICROWIRE mode the port latches associated with P26 and P27 are disconnected from the port and used instead as configuration registers. They are still loaded by using the NS8050 port instructions with the following MICROWIRE PLUS functions selectable:
- P36 latch is used to Enable/Disable the TRI-STATE SO output.
1 = Disabled
\(0=\) Enabled
- P27 latch is used to select the SK output frequency.
\(1=\) Instruction cycle clock divided by 4 (crystal freq/60)
\(0=\) Instruction cycle clock divided by 1 (crystal freq/15)

As in other chips in the 8048 family, RESET causes the latches associated with Ports 1 and 2 to set to a " 1 ". Consequently if the P26 and P27 latches are not otherwise initialized, upon entering MICROWIRE mode the SO output will be disabled and divide by 4 selected for SK generation. However P26 and P27 may be modified at any time, even when in MICROWIRE mode.
When in MICROWIRE mode, port pins P26 and P27 may still be read in using the IN A, P2 instruction and will reflect the state of the SO and SI pins respectively. Note however that these pins also have internal pullup devices connected to them as shown.
To facilitate data transfers a DONE flip-flop has been included in the MICROWIRE circuitry. It and the clock counter are Reset upon every exchange between the Accumulator and the SIO register. When the clock counter reaches a count of 8, indicating that the SIO has completely shifted out, DONE is set. The DONE F/F is connected internally to the TO sense line upon entering the MICROWIRE mode, thus allowing it to be tested by the JTO and JNTO instructions. Because of this any of the other TO functions such as clock generation are precluded from operation while in MICROWIRE mode. It should be noted that the SK clock may only be shut down by the DONE F/F which in turn is driven by the Clock Counter. The Clock Counter may only be preset by 0 by an XCHM or XCHS instruction after which it will immediately start counting clock pulses.

\section*{APPLICATION NOTES}

MICROWIRE PLUS may be effectively used for Local Area Networks (LANs) and Small Area Networks (SANs). Possible applications range from setting up a communications network within an automobile to home security systems. With the ability to switch between a MICROWIRE Master and Slave device at will, a multi-master NS8050 bus network may be implemented.
In NS8050 only systems MICROWIRE data may be transferred at the instruction cycle time of \(1.36 \mu \mathrm{~s}(733 \mathrm{kHz})\). When using standard MICROWIRE peripherals data transfers must generally be restricted to \(4 \mu \mathrm{~s}(250 \mathrm{kHz})\) as shown in Figure 2a. Also shown are typical MICROWIRE setup and hold times on the data lines relative to the SK clock. Figure \(2 b\) illustrates SIO bit shifting relative to instruction execution. When counting out instructions the XCH should be placed so that the last bit will be shifted in and out while the instruction is being read in as shown in Figure \(2 b\).
For both divide by 1 and divide by 4 clock generation modes the rising SK clock edge is approximately coincident with the rising ALE edge as shown in Figure 3. For divide by 1 SK clock generation the duty cycle is \(40 \%\) while for divide by 4 it is \(50 \%\) (the ALE duty cycle is approximately \(23 \%\) ).
Since the same drive circuits are used for both normal and MICROWIRE modes of operation, the DC electrical characteristics are the same for the \(3 \mathrm{I} / \mathrm{O}\) pins in either mode.
ON THE MICROWIRE 8050 THE CRYSTAL OSCILLATOR PINS ARE REVERSED FROM ORDINARY 8050s.
To facilitate 8050 MICROWIRE usage with standard COPS peripherals, a macro based I/O Driver Software Package is available. Written in 8048 assembly, it may be used directly or studied as an example of 8050 MICROWIRE peripheral interfacing.

\begin{tabular}{|l|c|c|}
\hline Parameter & Typical & Units \\
\hline t \(_{\text {SETUP }}\) & 200 & ns \\
thoLD & 200 & ns \\
t VALID & 50 & ns \\
t \(_{\mathrm{C}}\) & 4 & ns \\
\hline
\end{tabular}

FIGURE 2a. Microwire Interface Timing


TL/DD/6103-4
FIGURE 2b. 8050 Microwire Serial Sequence

FIGURE 3. NS8050 MIcrowire Clock Generation

\section*{MASTER-SLAVE PROTOCOL EXAMPLE}

A number of handshake protocols are possible between a Master and Slave NS8050 in a MICROWIRE PLUS system. The following example illustrates one possible method and discusses the timing holds and restrictions on each device. The hardware configuration for our example is shown in Figure 4 and described as follows:
- Slave SO connected to Master SI
- Slave SI connected to Master SO
- Slave SK connected to Master SK
- Master pin P24 used to chip select slave, connected to Slave interrupt input
- Slave pin 25 connected to Master pin P25, used by slave as a BUSY output indicator
- Master and Slave have the same crystal frequencies to simplify things
Before starting our example we will also assume the following initial conditions:
- Master DONE flip-flop set causing SK clock generation to be shut down
- Master Clock divide by 4 selected (P27 latch set), SO enabled (P26 latch reset)
- Master P24 (Slave chip select) is high (inactive)
- Slave BUSY output (P25) is high (active)
- Slave DONE flip-flop is indeterminate


TL/DD/6103-6

\section*{FIGURE 4. Example Master-Slave Hardware Configuration}

In our example of Figure 5 the Master is performing a 2-byte write and read from the Slave. The following is a step by step description of the key steps in code execution.
1. Master wishes to send and/or receive data from Slave. He starts by activating the Slave chip select.
2. Slave chip select causes an interrupt service call where Slave loads his first data byte into the SIO, enables SO and resets BUSY. The SIO load also clears out the clock counter and DONE flip-flop.
3. All this time the Master was checking and waiting for BUSY to go away, thus signifying that the Slave has rec-
bus
暗Y:
slave


\section*{WAIT:}


Section 7
Display/Terminal Management Processor (TMP)
空
Section 7 Contents
TMP ..... 7-3
NS405/NS32405 Series Display Terminal Management Processor (TMP) ..... 7-4
AB-14 Throughput Considerations in NS405 System Planning ..... 7-43
AB-16 NS405-Series TMP External Interrupt Processing ..... 7-44
AN-354 TMP Row and Attribute Table Lookup Operation ..... 7-46
AN-355 TMP-Dynamic RAM Interfacing ..... 7-53
AN-367 TMP External Character Generation ..... 7-58
AN-369 NS405 TMP Logic Analyzer ..... 7-61
AN-374 Building an Inexpensive But Powerful Color Terminal ..... 7-68
AN-399 TMP Extended Program Memory ..... 7-73

\section*{TMPтм}

\section*{Terminal Management Processor}

The TMP (NS405 series) is a single-chip CRT terminal display controller. The TMP is supported by the MOLETM development system and replaces all the following LSI circuits commonly found in a terminal:
- Microprocessor
- Program ROM
- \(64 \times 8\) RAM
- CRT controller
- DMA controller
- Character generator
- UART
- BAUD rate generator
- Parallel I/O controller
- Timer

The TMP offers complete CRT control over a wide scope of high-density circuit applications including phones, keyboard integration assignments, logic analyzers and more.
The NS455 Terminal Management Processor (TMP) demo board is available for design support.
Highly compact, the TMP board reduces previously necessary board space dramatically while providing 100\% emulation of a classic low-end terminal. The board can also be used for TMP evaluation or as a vehicle for designing-in the NS405 device.
The board which is controlled by a preprogrammed NS455, needs only a video monitor, ASCll encoded keyboard, and power supply to provide your complete terminal. Should you wish to write your own program, no problem.
The cross-assembler software provides the capability. The board will execute custom programs through up to 8 k of off-chip memory.
The TMP demo board comes complete with operating manual, program source listing, board schematic, board layout, and all necessary connectors.
When you're ready to design your own TMP system, turn to National's MOLE development system. By using this system-comprised of brain board, personality board and software-you bring dedicated development support to the TMP chip, making design-in extremely fast and simple.

\section*{NS405/NS32405-Series Display/Terminal Management Processor (TMP)}

\section*{General Description}

The NS405 is a CRT terminal controller on a chip. It is a microcomputer system which replaces the following LSI circuits commonly found in a CRT data terminal:
- Microcomputer
- CRT Controller
- Baud Rate Generator
- Interrupt Controller
- Parallel I/O Controller
- DMA Controller
- Timer
- UART

In addition the NS405 includes powerful attribute logic, two graphics display modes, and fast video output circuits.
The NS405 is primarily intended for use in low-cost terminals, but contains many features which make it a superior building block for "smart" terminals and word processing systems.
The NS405 interfaces easily to the display monitor, keyboard, display memory, and I/O ports. The architecture and instruction set are derived from the 8048-series microcontrollers. The instruction set has been enhanced and the architecture tailored to allow the NS405 CPU to efficiently manage a large display memory and an extensive interrupt environment.

The TMP can be used to easily and inexpensively add a display to many systems where it was previously impractical, it is not limited to terminal applications.

\section*{Features}
- Enhanced 8048 instruction set and architecture
- Up to \(8 \mathrm{k} \times 8\) ROM external with ROM expand bus
- On-board RAM \(64 \times 8\)
- Programmable display format
- On-board video memory management unit
- 16-bit bidirectional display memory bus (direct video and attribute RAM interface)
- Built-in timer
- Real-time clock (may be programmed for 1 Hz )
- Video control signals
- Eight independent attributes
- Pixel and block graphics display modes
- Programmable cursor characteristics
- Programmable CRT refresh rate
- Light pen feature
- UART, programmable baud rate up to 19.2 k baud
- Character generator ( 128 characters \(7 \times 11\) max)
- Single 5 -voit supply @ 110 mA (typ)

■ Up to 18 MHz video dot rate ( 12 MHz CPU clock)
- 48-pin package
- 8-bit parallel I/O port (multiplexed with external ROM)
- Extensive I/O expansion capabilities
- Up to 64 k by 8 or 16 video RAM

Block and Connection Diagrams



\section*{Absolute Maximum Ratings}

Specifications for Military/Aerospace products are not contained in this datasheet. Refer to the associated reliability electrical test specifications document.
Temperature Under Bias
\(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\)
Storage Temperature
\(-65^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}\)
All Input or Output Voltages
with Respect to \(\mathrm{V}_{\mathrm{SS}}\) *
-0.5 V to +7.0 V

Power Dissipation
-EA, SI and VSYNC may be subjected to \(\mathrm{V}_{\mathrm{SS}}+15 \mathrm{~V}\).
Note: Absolute maximum ratings indicate limits beyond which permanent damage may occur. Continuous operation at these limits is not intended; operations should be limited to those conditions specified under DC Electrical Characteristics.
ESD rating is to be determined.

\section*{DC Electrical Characteristics}
\(T_{A}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\), unless otherwise specified
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline jymbol & Parameter & Test Conditions & Min & Typ & Max & Units \\
\hline 1L1 & Input Low Voltage (All Except XTAL1, XTAL2, \(\overline{\text { RESET }}\) ) & & -0.5 & & 0.8 & V \\
\hline \({ }^{1 / \mathrm{IH} 1}\) & Input High Voltage (All Except XTAL1, XTAL2, \(\overline{\text { RESET }}\) ) & & 2.0 & & \(\mathrm{V}_{\mathrm{CC}}\) & V \\
\hline /1L2 & Input Low Voltage (XTAL1, XTAL2, \(\overline{\text { RESET }}\) ) & & -0.5 & & 0.6 & V \\
\hline \(1{ }^{1+2}\) & Input High Voltage (XTAL1, XTAL2, \(\overline{\text { RESET }}\) ) & & 3.8 & & \(\mathrm{V}_{\mathrm{CC}}\) & V \\
\hline 1 OL & Output Low Voltage (All Except INTENS, VO) & \(\mathrm{l}_{\mathrm{OL}}=2.0 \mathrm{~mA}\) & & & 0.4 & V \\
\hline \({ }^{1} \mathrm{OH}\) & Output High Voltage (All Except INTENS, VO) & \(\mathrm{I}_{\mathrm{OH}}=-125 \mu \mathrm{~A}\) & 2.4 & & \(\mathrm{V}_{C C}\) & V \\
\hline 1 OL & Output Low Voltage (INTENS, VO) & \(\mathrm{l}_{\mathrm{OL}}=5.0 \mathrm{~mA}\) & & & 0.4 & V \\
\hline \(\underline{\mathrm{OH}}\) & Output High Voltage (INTENS, VO) & \(\mathrm{I}_{\mathrm{OH}}=-500 \mu \mathrm{~A}\) & 2.4 & & & V \\
\hline IL & Input Leakage Current (EA, INT, Si) & \(\mathrm{V}_{S S} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{C C}\) & & & \(\pm 10\) & \(\mu \mathrm{A}\) \\
\hline OL & \begin{tabular}{l}
Output Leakage Current \\
(ROM Expand Bus, High Impedance State)
\end{tabular} & \(V_{C C} \geq V_{\text {IN }} \geq V_{S S}+0.45\) & & & \(\pm 10\) & \(\mu \mathrm{A}\) \\
\hline OL & Output Leakage Current (System Bus, High Impedance State) & \(V_{C C} \geq V_{\text {IN }} \geq V_{S S}+0.45\) & & & \(\pm 100\) & \(\mu \mathrm{A}\) \\
\hline CC & Total Supply Current & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) & & 110 & 150 & mA \\
\hline
\end{tabular}

\section*{AC Electrical Characteristics}
\(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\), unless otherwise specified
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \multicolumn{6}{|l|}{PU AND ROM EXPAND BUS TIMING} \\
\hline FXTAL & Crystal Frequency & 3 & & 18 & MHz \\
\hline \(\mathrm{F}_{\mathrm{CPU}}\) & CPU Frequency & 3 & & 12 & MHz \\
\hline \(\mathrm{t}_{\mathrm{Cl}}\) & CPU Cycle Time & 1.25 & & 7.5 & \(\mu \mathrm{s}\) \\
\hline \(t_{\text {dF }}\) & Video Dot Time & 55.5 & & 333.3 & ns \\
\hline \(t_{\text {LL }}\) & ALE Pulse Width (Note 1) & 125 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{AL}}\) & Address Setup to ALE (Note 1) & 55 & & & ns \\
\hline tLA & Address Hold from ALE (Note 1) & 40 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{CC}}\) & Control Pulse Width \(\overline{\text { PSEN, }} \overline{\mathrm{RD}}\) (Note 1) & 250 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{DR}}\) & Data Hold (Notes 1, 4) & 0 & & 100 & ns \\
\hline \(t_{\text {RD }}\) & \(\overline{\text { PSEN, }}\), \(\overline{\text { D }}\) to Data In (Note 1) & & & 220 & ns \\
\hline \(t_{A D}\) & Address Setup to Data In (Note 1) & & & 360 & ns \\
\hline \(t_{\text {AFC }}\) & Address Float to \(\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}\) (Note 1) & & 0 & & ns \\
\hline \(\mathrm{t}_{\text {CAF }}\) & \(\overline{\text { PSEN }}\) to Address Float (Note 1) & & \(\pm 10\) & & ns \\
\hline \(t_{\text {DAL }}\) & Data Setup to ALE (RE11, 12) (Note 1) & 55 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{ALD}}\) & Data Hold from ALE (RE11, 12) (Note 1) & 40 & & & ns \\
\hline \(\mathrm{t}_{\mathrm{CIS}}\) & Control Input Setup to ALE (RE8, 9, 10) (Note 1) & 240 & & & ns \\
\hline \({ }_{\text {tIH }}\) & Control Input Hold from ALE (RE8, 9, 10) (Notes 1, 4) & 0 & & 125 & ns \\
\hline
\end{tabular}

\section*{AC Electrical Characteristics}
\(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\), unless otherwise specified (Continued)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \multicolumn{6}{|l|}{SYSTEM BUS TIMING} \\
\hline \(t_{\text {EL }}\) & RAM ALE Low Time (Note 1) & 250 & 280 & & ns \\
\hline \(t_{E H}\) & RAM ALE High Time (Note 1) & 100 & 120 & & ns \\
\hline \(t_{\text {AS }}\) & Address Setup to RAM ALE (Note 1) & 20 & 70 & & ns \\
\hline \(t_{\text {AH }}\) & Address Hold from RAM ALE (Note 1) & 10 & 50 & & ns \\
\hline \(\mathrm{t}_{\mathrm{RCY}}\) & Read or Write Cycle Time (Note 1) & & 420* & & ns \\
\hline \(t_{\text {RR }}\) & RAM RD Width (Note 1) & 210 & 240 & & ns \\
\hline \(t_{\text {AR }}\) & Address Setup to \(\overline{\text { RAM RD ( }}\) ( \({ }^{\text {ate 1) }}\) & 80 & 120 & & ns \\
\hline \(t_{\text {RRD }}\) & Data Access from RAM RD (Note 1) & & & 140 & ns \\
\hline \(t_{\text {RDR }}\) & Data Hold from \(\overline{\text { RAM RD ( }}\) (Notes 1, 4) & 0 & & 60 & ns \\
\hline twFI & FIFO In Clock Width (Note 1) & 210 & 240 & & ns \\
\hline tww & RAM WR Strobe Width (Note 1) & 140 & 160 & & ns \\
\hline \(t_{\text {AW }}\) & Address Setup to \(\overline{\text { RAM WR ( }}\) ( Note 1) & 120 & 200 & & ns \\
\hline tow & Data Setup to \(\overline{\text { RAM WR ( }}\) ( 0 te 1) & 10 & 40 & & ns \\
\hline twD & Data Hold from \(\overline{\text { RAM WR ( }}\) ( \(o t e\) 1) & 20 & 40 & & ns \\
\hline
\end{tabular}

\section*{VIDEO TIMING}
\begin{tabular}{l|l|c|c|c}
\hline\(t_{D F}\) & Dot Period \(=\frac{1}{f_{\mathrm{C}}}(\) Note 1) & 55 & ns \\
\hline\(t_{\text {VID }}\) & Video Blank Time \(\frac{t_{D F}}{5}(\) Note 1) & & \(\pm 10\) & ns \\
\hline\(t_{V I}\) & Skew, Intensity to Dot 0 (Note 1) & & \(\pm 15\) & ns \\
\hline\(t_{\text {FOV }}\) & FIFO Out Clock to Dot 0 (Note 1) & & 15 & ns \\
\hline\(t_{\text {WFOH }}\) & FiFO Out Clock Width High (Note 1, Note 2) & & \(55-165^{* *}\) & ns \\
\hline
\end{tabular}
* \(1 / 3\) CPU cycle.
** 1 Dot time is 55 ns .
Note 1: Control outputs \(C_{L}=80 \mathrm{pF}\); ROM Expand Bus outputs \(\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}\); System Bus outputs \(\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} ; \mathrm{F}_{\mathrm{XTAL}}=18 \mathrm{MHz} ; \mathrm{F}_{\mathrm{CPV}}=12 \mathrm{MHz}\).
Note 2: FO CLK duty cycle is shown above.
Note 3: Hold request is latched. It is honored at the start of the next vertical retrace.
Note 4: Max spec. listed for user information only, to prevent bus contention.

\section*{Input Hold Times}
\(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\)
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Character \\
Cell Width
\end{tabular} & \begin{tabular}{c} 
FIFO Out \\
HIGH
\end{tabular} & \begin{tabular}{c} 
FIFO Out \\
LOW
\end{tabular} \\
\hline 6 & 1 dot & 5 dots \\
7 & 2 dots & 5 dots \\
8 & 2 dots & 6 dots \\
9 & 3 dots & 6 dots \\
10 & 3 dots & 7 dots \\
\hline
\end{tabular}
\left.\begin{tabular}{|l|l|}
\hline \multicolumn{1}{|c|}{ Input } & \multicolumn{1}{c|}{ Min Active Time } \\
\hline Reset & 50 ms (power up) \\
& 5 CPU Cycles (after power up)
\end{tabular}\(\right]\)\begin{tabular}{ll|}
\hline External Interrupt & 2 CPU Cycle \\
\hline \hline Light Pen & 1 CPU Cycle \\
\hline I/O Input & 1 CPU Cycle \\
\hline Hold Request & 1 CPU Cycle (Note 3) \\
\hline
\end{tabular}

\section*{FIFO}

Fall through should not be greater than 4 character times (character time \(=1 / f_{\text {XTAL }} \times \#\) dots \(/\) cell).
Throughput rate must be at least the character rate (character rate \(=1 /\) character time) .

Capacitance \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{SS}}=\mathrm{V}\)
\begin{tabular}{l|l|l|c|c|c|c}
\hline Symbol & Parameter & \multicolumn{1}{|c|}{ Test Conditions } & Min & Typ & Max & Units \\
\hline \(\mathrm{C}_{\mathrm{IN}}\) & Input Capacitance & \(\mathrm{F}_{\mathrm{C}}=1 \mathrm{MHz}\) & & 6 & 10 & pF \\
\hline \(\mathrm{C}_{\text {OUT }}\) & Output and Reset & Unmeasured Pins Returned to \(\mathrm{V}_{\mathrm{SS}}\) & & 10 & 20 & pF \\
\hline
\end{tabular}

\section*{AC Electrical Characteristics in CPU Cycle Time}

\section*{CPU AND ROM EXPAND BUS TIMING}
\begin{tabular}{|c|c|c|}
\hline Symbol & Parameter & Typ \\
\hline tL & ALE Pulse Width & \(14 \mathrm{t}_{\mathrm{CY} / 60}\) \\
\hline \(t_{\text {AL }}\) & Address Setup to ALE & \(8 \mathrm{t}_{\text {CY/60 }}\) \\
\hline tLA & Address Hold from ALE & 6 t¢Y/60 \\
\hline tcc & Control Pulse Width \begin{tabular}{l} 
PSEN \\
\\
\hline RD
\end{tabular} & 24 tey/60 36 tcy/60 \\
\hline tcy & CPU Cycle Time & \[
60 \mathrm{t}_{\mathrm{CY} / 60}=15 / \mathrm{fCPU}=\frac{15}{\mathrm{f}_{\mathrm{XTAL}} \div 1 \mathrm{or} \div 1.5}
\] \\
\hline tDR & Data Hold & -2 \(\mathrm{t}_{\mathrm{CY} / 60}\) \\
\hline \(t_{\text {RD }}\) & Control Pulse to Data In \(\frac{\overline{\text { PSEN }}}{\overline{\mathrm{RD}}}\) & \begin{tabular}{l}
18 tey/60 \\
\(30 \mathrm{t}_{\mathrm{CY} / 60}\)
\end{tabular} \\
\hline \(t_{A D}\) & Address Setup to Data In & 32 t t Y/60 \\
\hline \(t_{\text {AFC }}\) & \(\begin{array}{ll}\text { Address Float to } & \overline{\overline{P S E N}} \\ & \overline{\mathrm{RD}}\end{array}\) & \[
\begin{aligned}
& 2 \text { t CY/ } 60 \\
& 2 \mathrm{t}_{\mathrm{CY} / 60}
\end{aligned}
\] \\
\hline \(t_{\text {caf }}\) & PSEN to Address Float & \(0 \mathrm{t}_{\text {CY/ } / 60}\) \\
\hline tbal & \begin{tabular}{ll} 
Data Setup to ALE & \(\begin{array}{l}\text { REO-7 } \\
\\
\\
\\
\text { RE8-10 } \\
\\
\text { RE11-12 }\end{array}\) \\
\hline
\end{tabular} & \begin{tabular}{l}
6 tCY/60 \\
\(-2 \mathrm{t} \mathrm{CY} / 60\) \\
16 tCY/60
\end{tabular} \\
\hline \(\mathrm{t}_{\text {ALD }}\) & Data Hold from ALE \(\begin{aligned} & \text { RE0-7 } \\ & \\ & \\ & \text { RE8-12 }\end{aligned}\) & \[
\begin{aligned}
& 2 \mathrm{t}_{\mathrm{CY} / 60} \\
& 6 \mathrm{t}_{\mathrm{CY} / 60} \\
& \hline
\end{aligned}
\] \\
\hline
\end{tabular}

SYSTEM BUS TIMING
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Symbol} & \multirow[t]{2}{*}{Parameter} & \multicolumn{3}{|c|}{Ticks} \\
\hline & & Min & Typ & Max \\
\hline \(t_{E L}\) & RAM ALE Low Time & \(14 \mathrm{t}_{\mathrm{CY} / 60}-42 \mathrm{~ns}\) & \(14 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline \(\mathrm{t}_{\mathrm{EH}}\) & RAM ALE High Time & \(6 \mathrm{t}_{\mathrm{CY} / 60}-25 \mathrm{~ns}\) & \(6 \mathrm{t}_{\mathrm{C} Y / 60}\) & \\
\hline \(t_{\text {AS }}\) & Address Setup to RAM ALE & \(4 \mathrm{t}_{\mathrm{CY} / 60}-60 \mathrm{~ns}\) & \(4 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline \(t_{\text {AH }}\) & Address Hold from RAM ALE & \(2 \mathrm{t}_{\mathrm{CY} / 60}-40 \mathrm{~ns}\) & \(2 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline \(\mathrm{t}_{\mathrm{RCY}}\) & Read or Write Cycle Time & & \(20 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline \(\mathrm{t}_{\mathrm{RR}}\) & RAM RD Width & \(12 \mathrm{t}_{\mathrm{C} / 6 / 60}-40 \mathrm{~ns}\) & \(12 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline \(t_{\text {AR }}\) & Address Setup to RAM RD & \(6 \mathrm{t}_{\mathrm{CY} / 60-45 \mathrm{~ns}}\) & \(6 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline \(t_{\text {RRD }}\) & Data Access from \(\overline{\text { RAM RD }}\) & & \(10 \mathrm{t}_{\mathrm{CY} / 60}\) & \(10 \mathrm{t}_{\mathrm{CY} / 60}-70 \mathrm{~ns}\) \\
\hline \(t_{\text {RDR }}\) & Data Hold from RAM RD & & & \\
\hline \(t_{\text {WFI }}\) & FIFO In Clock Width & \(12 \mathrm{t}_{\mathrm{CY} / 60}-40 \mathrm{~ns}\) & \(12 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline tww & RAM WR Strobe Width & \(8 \mathrm{t}_{\mathrm{CY} / 60-27 \mathrm{~ns}}\) & 8 tcy/60 & \\
\hline \(t_{\text {AW }}\) & Address Setup to \(\overline{\text { RAM WR }}\) & \(10 \mathrm{t}_{\mathrm{CY} / 60}-90 \mathrm{~ns}\) & \(10 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline tow & Data Setup to RAM WR & \(2 \mathrm{t}_{\mathrm{CY} / 60}-30 \mathrm{~ns}\) & \(2 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline twD & Data Hold from RAM WR & \(2 \mathrm{t}_{\mathrm{CY} / 60}-20 \mathrm{~ns}\) & \(2 \mathrm{t}_{\mathrm{CY} / 60}\) & \\
\hline
\end{tabular}

\section*{Timing Waveforms}

*Remain 1/O OUTPUT if External ROM not used.
**I/O Data input or 2nd ROM byte of 2 byte instruction. Otherwise remain I/O OUTPUT.


Timing Waveforms (Continued)


Scan Count Clear Timing


For external character generation this edge is used to clock CLEAR into scan line counter. The edge must come before Scan Count Clear goes away, but not before the video controller has brought in all necessary display information for the last scan line.

NS405-Series Detailed


TL/DD/5526-7

\subsection*{1.0 Functional Pin Descriptions}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|l|}{I. 1 SUPPLIES} \\
\hline Pin & Name & Function \\
\hline 48 & \(V_{C C}\)-Power & \(5 \mathrm{~V} \pm 10 \%\) \\
\hline 24 & VSS - Ground Reference & \\
\hline \multicolumn{3}{|l|}{1.2 INPUT SIGNALS} \\
\hline -3, 22 & XTAL1, XTAL2 - Crystal 1, 2 : & Crystal connections for clock oscillator ( \(3-18 \mathrm{MHz}\) ). \\
\hline 29 & EA - External Access: & Pull HIGH ( \(\mathrm{V}_{\mathrm{IH}_{2}}\) ) \\
\hline 32 & RESET & An active low input that initializes the processor. The \(\overline{\text { RESET input is also }}\) used for internal ROM verification. \\
\hline 34 & SI - Serial Input: & Drives receiver section of UART (true data). \\
\hline \multicolumn{3}{|l|}{1.3 OUTPUT SIGNALS} \\
\hline 33 & SO - Serial Output: & Driven by transmitter section of UART (true data). \\
\hline 21 & ALE - Address Latch Enable: & ROM address is available on the ROM Expand Bus and may be latched on the falling edge of ALE. Port output data may be latched on the rising edge of ALE. ALE pulses are always present, even if EA is tied low. \\
\hline 30 & PSEN - Program Store Enable: & Enable external ROM output drivers when low. \(\overline{\text { PSEN }}\) is idle (high) when the CPU fetches from internal ROM. \\
\hline 31 & \(\overline{\mathrm{RD}}\) — Read Port Data: & Accept Port input data on ROM Expand Bus REO-RE7 while low. ROM Expand Bus is in high impedance state while \(\overline{R D}\) is low. \\
\hline 28 & HS - Horizontal Sync & The rising edge of HS is controlled by the Horizontal Sync Begin Register and the falling edge is controlled by the Horizontal Sync End Register. HS is disabled (low) if bit 5 of the Video Control Register \(=0\). \\
\hline 27 & \(\overline{\text { VS }}\) - Vertical Sync Output: & The falling edge of \(\overline{\mathrm{VS}}\) is controlled by the Vertical Sync Begin Register and the rising edge is controlled by the Vertical Sync End Register. \(\overline{\mathrm{VS}}\) is at TRI-STATE if bit 5 of the Video Control Register \(=0\). \\
\hline 26 & VO - Video Output: & High \(=\) beam on, low \(=\) beam off. VO is disabled (low) if bit 5 of the Video Control Register \(=0\). \\
\hline 25 & \(\overline{\text { NTENS }} / \overline{\text { FOCLK }}\) & \begin{tabular}{l}
(Shared pin) INTENS Signal under attribute control may be used to switch the bistable brightness of display characters. \\
FIFO Out Clock may be used to clock data from an external FIFO in synchronism with data from the internal FIFO. \\
Both CANNOT be used simultaneously.
\end{tabular} \\
\hline 17 & VID CLK/ \(\overline{F I C L K}\) - Video Dot Clock Out/ FIFO IN CLOCK & (Shared pin) The rising edge of the Video Dot Clock may be used to clock the data out of the video output pin. FIFO In Clock may be used to clock data from an extended attribute RAM into an external FIFO in synchronism with the data loaded into the internal FIFO. Both CANNOT be used simultaneously. \\
\hline 18 & RAM ALE - RAM Address Latch Enable: & RAM address is available on the System Bus and may be latched on the falling edge of RAM ALE. Only operational when Display RAM accesses being performed. Otherwise high. \\
\hline 20 & \(\overline{\text { RAM RD - RAM Read: }}\) & Enable display RAM data onto the System Bus when \(\overline{\mathrm{RAM}}\) RD is low. \\
\hline 19 & RAMWR - RAM Write: & Data to RAM is available on the System Bus and may be written at the rising edge of \(\overline{R A M ~ W R . ~}\) \\
\hline \multicolumn{3}{|l|}{1.4 BUS - I/O} \\
\hline 1-8 & SB0-SB7 - System Bus 0-7: & Display RAM address is output while RAM ALE is high and may be latched on the falling edge of RAM ALE. System Bus accepts data input while \(\overline{\text { RAM RD }}\) is low and outputs data while \(\overline{\text { RAM WR }}\) is low. \\
\hline 9-16 & SB8-SB15 - System Bus 8-15: & Normally, Display RAM address is output and held on these pins for the full read or write cycle. However, if bit 4 of the System Control Register is set, these pins function bidirectionally like SB0-SB7 to allow 16-bit data words for attribute operation. \\
\hline 35-47 & RE0-12-ROM Expand Bus 0-12: & Used for program ROM expansion as described below. Time multiplexed with I/O port and system control signals. I/O port and system control signals only if no external ROM used. \\
\hline 40-47 & RE0-RE7 & Low order ROM address is output and may be latched on the falling edge of ALE. Enable ROM data to this Bus when PSEN is low. Enable I/O port input data to the Bus when \(\overline{\mathrm{RD}}\) is low. Use the rising edge of ALE to latch port output data. \\
\hline
\end{tabular}

\subsection*{1.0 Functional Pin Description (Continued)}

Pin
39-35 RE8-RE12
\(37 \quad \overline{\mathbb{N T R}}\) — Interrupt: RE10
\(38 \overline{\mathrm{LP}}\) - Light Pen Interrupt: RE9

39 HOLD - HOLD request: RE8

35
HLDA - Hold Acknowledge: RE12

36
\(\overline{\text { SCCLR }}\) - Scan Count Clear: RE11

\section*{Function}

Five most significant bits of the ROM address are output during ALE and remain stable until data is read in during \(\overline{\text { PSEN }}\). These pins are multiplexed with the HLDA, \(\overline{N T T R}, \overline{\mathrm{LP}}, \overline{\mathrm{SC} C L R}\), and HOLD signals. An active low input that interrupts the processor if the external interrupt is enabled. Because it shares a pin with RE10, INTR may be driven directly only if no external ROM is used (EA is low). Otherwise must be driven through a 3.9 k resistor.*
An active low input that interrupts the processor if internal interrupts are enabled and bit 5 in the Interrupt Mask Register is set. Because it shares a pin with RE9, LP may be driven directly only if EA is low. Otherwise, must be driven through a 3.9 k resistor.*
When high, requests that the NS405 enter the Hold mode. When in the Hold mode the System Bus will be in a high impedance state. The Hold mode is granted at the beginning of the next vertical retrace. Because it shares a pin with RE8, HOLD may be driven directly only if EA is low. Otherwise, must be driven through a 3.9 k resistor.* This output is asserted in response to Hold and provides handshake capability with another processor (active high). For more detailed information see Section 3.0 Slave Processing. Because HLDA shares a pin with RE12, the HLDA state is preset only during the interval preceding the rising edge of ALE. However, if no external ROM is used, HLDA is a steady state output and need not be latched externally.
This output clears an external scan counter when used with an external character generator. It is a low going pulse which occurs during the horizontal retrace preceding the first scan line of each character row. Because \(\overline{\text { SC CLR }}\) shares a pin with the RE11, the correct \(\overline{\text { SC CLR }}\) state is present only during the interval preceding the rising edge of ALE. However, if no external ROM is used, \(\overline{\text { SC CLR }}\) is a steady state output and need not be latched externally.
*Unused control inputs must be terminated

\subsection*{2.0 Functional Description}

\subsection*{2.1 CPU}

The CPU of the NS405 is patterned after the 8048 single chip microcomputer (see Figure 1).


FIGURE 1. NS405 Series CPU Block Diagram

\section*{!.O Functional Description (Continued)}

\section*{.1.1 Accumulator - High Accumulator}

1 addition to the regular 8-bit Accumulator, there is an 8-bit ligh Accumulator extension to facilitate the 16-bit operaons required for display memory management. The HACC/ CC pair is usually used in conjunction with the 16-bit RAM ointer registers (RA, R0 and RB, R1, CURSOR, HOME, EGD and ENDD) to effect video data transfers. In addition, xternal attribute memory is loaded in a 16-bit transfer opertion. Any instruction which causes a carry or borrow out of le low accumulator will affect the high accumulator (see ïgure 2).
uxiliary carry is used only when converting the accumulaor contents from binary to BCD (binary coded decimal) usig the DA A instruction. The auxiliary carry flag can be leared by moving a zero into bit 6 of the program status ord.

HIGH ACCUMULATOR
ACCUMULATOR


TL/DD/5526-9
FIGURE 2. CPU Accumulator

\section*{:.1.2 Program Counter (PC)}
he Program Counter is a 13 -bit wide register which proides program addressing for the CPU. The lower 11 bits perate like a conventional program counter while the upper ! bits are actually latches. These 2 latches are automatically jaded from the bank select flip-flops (PSW bits 3,4) wheniver a JMP or CALL instruction is executed. The bank seect flip-flops in turn are only modified upon the execution of 1 Select Memory Bank Instruction or modification of the 'SW (see Figure 3).


BANK SELECT BITS (LATCHES)
(LOADED BY EXECUTION OF JMP OR CALL)
TL/DD/5526-10

\section*{FIGURE 3. TMP Program Counter}

\subsection*{2.1.3 Program Memory}

Memory is subdivided into \(2 k\) banks with accesses limited to the currently selected bank unless a Bank Change sequence has been executed. Upon reaching the end of a memory bank, the program counter will wrap around and point to the beginning of the current bank.
Each bank is further subdivided into pages of 256 bytes each, with 8 pages in every bank. The conditional JUMP instructions are restricted to operate within the memory page that they reside in.
Because of the sequence which the CALL instruction executes when pushing and loading the PC, it is possible to easily call and return from subroutines located in different memory banks (see Figure 4).
Upon executing an RET or RETR instruction for a call from one memory bank into another, a SEL MBx instruction should be excuted to restore the memory bank select flipflops to their original bank. However, no SEL MBx is needed after an interrupt since the flip-flops were never modified.


TL/DD/5526-11
FIGURE 4. Program Memory Map
2.1.4 Program Status Word Bit Assignments
\begin{tabular}{|c|c|}
\hline \[
\begin{gathered}
\text { Bit } \\
\text { Position }
\end{gathered}
\] & Contents \\
\hline 0 & Stack Pointer Bit, S0 \\
\hline 1 & Stack Pointer Bit, S1 \\
\hline 2 & Stack Pointer Bit, S2 \\
\hline 3* & Memory Bank Select Bit 0 \\
\hline 4* & Memory Bank Select Bit 1 \\
\hline 5* & Register Bank Select Bit \((0=\) Bank 0 ,
\(1=\) Bank 1) 1 = Bank 1) \\
\hline 6* & Auxiliary Carry. A carry from Bit 3 to Bit 4 generated by an add operation. Used only by the decimal adjust (DA A) instruction. \\
\hline 7* & Carry. A bit indicating the preceding operation resulted in an overflow or an underflow from the 8 -bit accumulator. \\
\hline
\end{tabular}
*Note 1: Bits 3 through 7 are saved on the stack by subroutine calls or interrupts. Bits 3 and 4 are restored upon execution of an RET instruction, whereas all 5 bits are restored by RETR.
Note 2: FO is not saved on the stack (as in an 8048).
Note 3: Bits \(0-5\) cleared on a RESET.

\subsection*{2.1.5 Stack Pointer (SP)}

The stack pointer is an independent 3 -bit counter which points to designated locations in the internal RAM that holds subroutine return parameters. The stack itself is located in RAM locations 8-23 (see Figure 5).
Each entry in the stack takes up two bytes and contains both the PC and status bits. When reset to zero, the stack pointer actually points to locations 8 and 9 in RAM. Since the stack pointer is a simple up/down counter, an overflow will cause the deepest stack entry to be lost (the counter overflows from 111 to 000 and underflows from 000 to 111). Note: If the level of subroutine nesting is less than eight ( 8 ), the unneeded stack locations may be used as RAM.


Note: The odd numbered RAM bytes in the stack area have two (2) extra bits to allow for storage of the bank select switch bits. This feature allows interrupt routines and subroutines to be located oulside the current 2 k program memory bank.

FIGURE 5. Typical Stack Composition

\subsection*{2.0 Functional Description (Continued)}

\subsection*{2.1.6 Data Memory (On-Chip RAM)}

The data memory nominally consists of 648 -bit locations and is utilized for working registers, the subroutine stack, pointer registers and scratch pad. There are two sets of working/pointer registers (R0-R7) which are selected by the Select RAM Bank instruction. The stack area is located in locations 8-23. Locations 32-63 contain the scratch pad memory. To facilitate 16 -bit Video Memory Management there are two 8 -bit extension registers (RA and RB) which are associated with the R0 and R1 registers respectively of whichever RAM bank is currently selected (see Figure 6). i.e., There is only one RA register and only one RB register.

hegister bank 0 or 1 IS selected under program control.
TL/DD/5526-13
FIGURE 6. RAM Memory Map

\subsection*{2.1.7 Timer}

The On-Board Timer is an 8-bit up counter which sets the Timer Overflow Flag and generates an internal interrupt (if enabled) whenever it overflows from FF to zero. The Timer may be stopped, started, loaded and read from by the CPU. The Timer clock is derived from the CPU clock as shown in Figure 7. Whenever a Start Timer instruction is executed the \(\div 32\) is initialized to its zero state to insure a full count measurement. After overflow the timer keeps counting until the next FF to zero overflow at which time the overflow flag will be set and another interrupt generated. The overflow flag can only be reset through the JTF and JNTF instructions.


TL/DD/5526-14
FIGURE 7. Timer Clock Generation

\subsection*{2.1.8 Interrupts}

The interrupt circuitry handles two generic classes of interrupt conditions called Internal and External. Either class has its own master control which can be activated through software enable and disable instructions. On an interrupt service the currently executing instruction is completed, then two CPU cycles are used as the program counter and bits 3-7 of the PSW are pushed onto the stack and stack pointer is incremented.

Then the interrupt vector address (3 or 7) is loaded into the PC and service started. Whenever an interrupt condition i: being serviced all other interrupts of either class are locker out until a RETR instruction is executed to conclude inter rupt service. If both an external and internal interrupt arrivi at the same time, the external interrupt is recognized first.

\subsection*{2.1.8.1 External Interrupt}

The External Interrupt consists solely of the shared INTR, RE10 pin. External interrupts on this pin will be detected i the setup and hold times as shown in the timing diagram: are met. This pin is a level sampled interrupt which mean: that as long as the pin is low during the sampling window at interrupt will be generated. In addition, the INTR pin is the only external pin whose logic state can be directly tester through software.

\subsection*{2.1.8.2 Internal Interrupts}

The Internal Interrupts consist of seven internal operationa conditions plus the light pen arranged in an 8 -bit wide regis ter as shown in Figure 8. Activation of an internal interrup condition causes a corresponding register bit to be set, Fig ure 9. Each internal interrupt may be individually masked ou through the Interrupt Mask register which has the same bi assignments as the Interrupt register and can be loadec from the accumulator. A zero in the Interrupt Mask registel inhibits the interrupt and a one enables it. Further interrup 1 processing is as shown. To determine which of the eigh 1 internal conditions caused the interrupt the CPU must reac the Interrupt register into the accumulator. To acknowledge receipt of the interrupt certain bits are automatically cleared on a read while others are reset upon service of the particular interrupt.
The conditions under which each of the interrupts are gen. erated and cleared are as follows:


TL/DD/5526-16
Note: The interrupt flags indicated by an asterisk (*) are cleared when the Interrupt Register is read.

\section*{FIGURE 8. Internal Interrupt Register}

Bit
0 Vertical Interrupt-Generates an interrupt at the end of the display row designated by the Vertical Interrupt Register. Interrupt bit cleared on a CPU read of the interrupt register. If VIR > Vertical Length Register no interrupt will be generated.

\subsection*{2.0 Functional Description (Continued)}


FIGURE 9. Internal Interrupt Processing

1 End of Row Interrupt-Generates an interrupt at the end of each display row when the Current Row Start Register is updated for the next row. Used in conjunction with the Row Sequencing Control Bit (5) in the System Control Register to implement Row Pointer Look-Up Tables and Horizontally Split Screens. Interrupt bit cleared on a CPU write to the Home Register. Does not generate interrupts for those rows blanked during vertical blanking.
2 UART Transmit Buffer Empty-Generates an interrupt when the Transmit Buffer empties out after dumping a character into the Transmit Shift Register. Interrupt bit cleared on a CPU write to the Transmit Buffer.
3 Transmitter Empty-Generates an interrupt when BOTH the Transmit Buffer and Transmit Shift Register are empty. The interrupt bit is cleared when the CPU loads the transmit buffer.
4 UART Receiver Buffer Full-Generates an interrupt when the Receiver Buffer fills up with a character from the Receive Shift Register. Interrupt bit cleared on a CPU read of the Receiver Buffer.
5 Light Pen Interrupt-Generates an interrupt on each falling edge detected on the shared \(\overline{\mathrm{LP}} /\) RE9 pin. Since only falling edges generate interrupts and the input is sampled each CPU Cycle, a high level must be sampled between falling edges in order to be considered a new interrupt. This interrupt is used to latch the light pen position registers. For further information see Light Pen Description. Interrupt bit cleared on a CPU read of the interrupt register.

Bit
6 Timer Interrupt-Generates an interrupt when the internal 8 -bit Timer overflows from FF to 00 . Interrupt bit cleared on a CPU read of the interrupt register.
7 Real-Time Interrupt-Generates interrupts at a software programmable frequency that is generally in the Hertz range. (See CPU Clock Generation.) Thus permitting the implementation of a real-time clock or timer. Interrupt bit cleared on a CPU read of the interrupt register.

\subsection*{2.1.9 Clock Generation}

All chip clocks are derived from the one external crystal connected between pins 22 and 23. This master clock also doubles as the video dot clock. The crystal frequency is constrained to lie within the range of 3 to 18 MHz . The CPU clock is derived from the crystal clock by either using it directly or by dividing down by a factor of 1.5 (Figure 10).


TL/DD/5526-17
FIGURE 10. CPU Clock Generation
The choice is software programmable through bit 0 in the System Control Register. The exact selection is made in consideration of the fact that the CPU clock must lie within the range of 3 to 12 MHz . In addition, the choice of divide by inodes will also impact the display character cell width due to the nature of the video controller. Specifically with \(\div 1.5\)

\subsection*{2.0 Functional Description (Continued)}
the cell width must be \(\geq 8\) dots wide whereas with \(\div 1\) the cell width must be \(\geq 6\) dots wide.
The low clock rates necessary to implement Cursor Blinking, Character Blinking and the Real-Time Interrupt are derived by passing the vertical sync frequency through a 5 -bit Blink Rate Divisor Register, (Figure 11). The resultant frequency is used as the Cursor Blink Clock. This clock is then further divided by 2 to yield the Character Blink and RealTime Interrupt Clocks. For example, to get a 1 Hz real time interrupt, with a 60 Hz system, set the 5 bit Divisor Register to 30 in order to yield a 2 Hz signal which is then divided by 2.


TL/DD/5526-18

\section*{FIGURE 11. Blink Clock Generation}

\subsection*{2.1.10 Oscillator Operation}

The on-board oscillator circuit consists of a phase inverter which, when used with an external parallel resonant tank, (Figure 12a), will yield the required oscillator clock. Crystals should be specified for AT cut and parallel resonant operation with the desired load capacitance (typically 20 pF ). If one desires to externally generate the clock and input it to the chip, he may do so by driving XTAL1 (pin 23) and XTAL2 (pin 22) as shown in Figure \(12 b\).


TL/DD/5526-19
FIGURE 12a. TMP Oscillator


TL/DD/5526-20
Note: Use AS TTL devices if faster than 12 MHz
FIGURE 12b. External Oscillator Mode

\subsection*{2.2 DISPLAY MEMORY CONTROLLER}

The video display data resides in the external Video Memory which is managed by the Display Memory Controller (DMC) through the System Bus. Either the CPU or the Video Controller may access the display memory by presenting its requests to the DMC. A maximum of three Video Memory accesses (Reads or Writes) can be performed by the DMC during each CPU instruction execution cycle. Because the CPU can access the Video Memory, one may expand CPU I/O or data memory by memory mapping into the Video

Memory space. Up to 64k locations may be addressed ove the 16 -bit System Bus. Data word widths may be 8 or 16 bit depending upon whether external character attribute selec tion is used. The actual bus multiplexing mode is controlle by bit 4 in the System Control register. The Video Controlle has the highest priority in obtaining Video Memory accesse with the CPU getting in on a space available basis. If a memory accesses are being taken by the Video Controlle (rarely), the CPU is put into a wait state should it try to ac cess video memory. To ease accessing requirements an boost throughput the Video Controller utilizes a 4-level dat FIFO which is normally kept full of display data.

\subsection*{2.2.1 Display Memory Control Registers}

In order to facilitate the management of video data for suc features as a Screen scroll, memory paging and row looku, the DMC utilizes a number of registers which address th video RAM space. Each of these pointers is 16 bits wid and writable or readable from the 16-bit HACC/ACC pair a the case may be. There are 2 video data accessing mode as determined by bit 5 in the SCR, Sequential and Tabl Lookup. The functions of the pointer registers vary depend ing upon the accessing mode selected. Their designator are:
HOME \(=\) Home address register. Read and write.
BEGD = Beginning of diplay RAM. Write only.
ENDD = End of display RAM. Write only.
CURS = Cursor address register. Read, Write, Increment Decrement.
SROW \(=\) Status section register. Write only.
CRSR = Current row start register. Not directly accessed

\subsection*{2.2.2 Sequential Access Mode}

In this mode display data is accessed from sequential ad dress locations in the video memory until the data require. ments for the current screen field are fulfilled. The locatior from which the first display character is taken is the ont pointed to by the HOME register. By modifying the contents of HOME one may implement a row scroll or paging opera. tion. The BEGD and ENDD are used to control the wrap. around condition when HOME gets near the end of available display RAM as determined by ENDD. In this instance when sequential accessing brings us to the end of memon as pointed to by ENDD, the controller wraps around by jumping back to the beginning of display memory as pointec to by BEGD. The value in ENDD should be the last location in display memory +1 . Also the size of the display memory between BEGD and ENDD (ENDD - BEGD) must be an integral number of display rows. The CURS in both accessing modes merely identifies the current cursor position in display memory so that the cursor characteristics can be inserted into the video at the appropriate character position. In addition to the display of normal video data one may elect to have a special status section displayed using data from a separate section of video memory. The status section would consist of an integral number of display rows on the bottom of the screen. This feature operates by reloading the video RAM pointer with the contents of SROW when the desired row position at which to start the status section comes up. The particular row at which the status display starts is defined in the Timing Chain. Once the video RAM pointer is jumped to SROW, data accessing again proceeds sequentially from there until the data requirements for the current field are satisfied.

\subsection*{2.0 Functional Description (Continued)}


TL/DD/5526-21

Nhether a status section is used or not, upon accessing all Jf the data necessary to display a field, the video RAM zointer is reset to HOME in preparation for the display of a lew field.

\subsection*{2.2.3 Table Lookup Mode}

The CRSR (transparent to the user) is a pointer to the adtress of the first character in a display row. It is required jecause each time a scan line is displayed, all display characters in the row must be accessed anew. Since a row is made up of a number of scan lines, we must recover the address of the first character in the row for each scan in the row. After a row is done, the CRSR is normally advanced to point to the first character in the next row.
In table look-up mode the starting memory location of the next row is loaded into the CRSR from the HOME register at the end of each row. The HOME register was presumably updated by the CPU since the last end of row.
A CRSR load also generates the internal End of Row interrupt which the CPU will use as a signal to reload HOME. Finally, reloading HOME will clear out the End of Row interrupt. If the status section feature is used, upon reaching the begin status row location the CRSR will be loaded with SROW instead of HOME for that row. After which CRSR will revert back to load from HOME for the remaining rows on the screen.

\subsection*{2.3 SYSTEM CONTROL REGISTER}

Through the System Control Register (SCR) the user specifies several important chip operational conditions. It is an 8 -bit write only register which is loaded from the CPU accumulator.


TL/DD/5526-22
*Bit 0 is set to 1 by RESET and bit 7 is set to 0 by RESET.

\section*{FIGURE 13. System Control Register}

\subsection*{2.4 VIDEO CONTROL REGISTER}

Through the Video Control Register (VCR) the user specifies several video display features to the chip. It is an 8-bit write only register which is loaded from the CPU accumulator.

\subsection*{2.0 Functional Description (Continued)}


\subsection*{2.5 CRT REFRESH LOGIC}

All video timing and clocking signals are derived from a se ries of counters and comparators called the Video Timins Chain. The chain is driven by the dot/crystal clock and ulti mately divides down to the very slow blink clock, (Figure 15). By having the program initialize the registers in the chain a user may specify all aspects of video generation.
The chain also controls the size and placement of the cur sor and underline attribute within a character cell as well a: the cell partitioning for block graphics display. All totaled the chain consists of 14 wire only registers. They are loadec indirectly by using the Timing Chain Pointer (TCP), a 4 -bi pointer to registers in the chain, and the MOV @TCP, \(t\) instruction.
*Bit 5 is set to 0 by RESET.
FIGURE 14. Video Control Register


FIGURE 15. TMP Video Timing Chain

\subsection*{2.5.1 TMP Timing Chain Registers} TCP

\section*{Horizontal Timing}

0 Horizontal Length Register - HLR 7 bits
- Total number of character cells in a horizontal scan and retrace.
- Enter desired count - 1

1 Horizontal Blank Begin Register - HBR 7 bits (Characters/Row)
- Character position in horizontal scan after which horizontal blanking begins.
- Enter desired number of displayed characters/row - 1.

2 Horizontal Sync Begin Register — HSBR 7 bits
- Character position in horizontal scan after which horizontal sync begins (rising edge), HSBR \(\leq\) HLR.
- Enter desired count +2 .
```

2.0 Functional Description (Continued)
:.5.1 TMP Timing Chain Registers (Continued)
TCP Horizontal Timing
3 Horizontal Sync End Register - HSER 7 bits
- Character position in horizontal scan after which horizontal sync ends (falling edge), HSER $\leq$ HLR.
- Enter desired count +2.
lote: The polarity of the horizontal sync signal can be inverted by switching the values in the two horizontal sync registers.
TCP

```

\section*{Character Height Definition}
```

        4 Character Scan Height Register - CSHR 4 bits (see Figure 16a)
    High - Scan line height of a character cell.
    Nibble - Enter desired number of scan lines - 1.
4 Extra Scans/Frame - ES/F 4 bits
Low - Number of extra scans to be added to a frame if desired.
Nibble - Enter desired number of extra scans -1.
- To get no extra scans make ES/F = CSHR. ES/F must be $\leq$ CSHR.
TCP

```

\section*{Vertical Timing}
```

5 Vertical Length Register - VLR 5 bits

- Total number of display and retrace rows in a frame.
- Enter desired number of rows - 1 .
6 Vertical Blank Register - VBR 5 bits (Rows/Screen)
- Row position in vertical scan after which vertical blanking begins, VBR < VLR.
- Enter desired number of displayed rows - 1 .
7 Vertical Sync Begin Register - VSBR 4 bits
High - Scan line position in first blank row at which vertical sync begins (falling edge). Sync starts 1 char time after Nibble blanking for that line starts (except when VSBR = CSHR sync will start 1 char time after blanking of the last displayed scan line).
- Enter desired scan line position - 1.
7 Vertical Sync End Register - VSER 4 bits
Low - Scan line position after start of vertical sync at which vertical sync ends (rising edge). Sync ends 1 char time
Nibble after horizontal blanking for that scan line start.
- Enter desired scan line position - 1.
vote: If VSER = VSBR there will be no vertical sync signal.
8 Status Row Begin Register - SRBR 5 bits
- Row count after which the status row is inserted.
- Enter desired row position - 1.
TCP
Blink Rate 5 bits
5 Bits - Enter desired divisor - 1.
9 Blink Duty Cycle 3 bits
Lower - Approximate ON time of blink signal.
3 Bits $\quad-000=$ shortest, $111=$ longest ( $100=50 \%$ duty cycle $)$.

```
```

Graphics Column Register — GCR 8 bits

- Assign dot positions to left, middle and right character cell columns for block graphics operation.
Graphics Row Register - GRR 8 bits
- Defines scan count at which middle row for block graphics characters begins (upper nibble) and at which bottom row begins (lower nibble). The middle row (upper nibble) must be $\geq 1$.
- Enter desired scan count - 1 .
Underline Size Register — USR 8 bits (see Figures 16a, b, c)
- Defines the beginning (upper nibble) and ending (lower nibble) scan lines for the underline attribute. Values must be $\leq$ CSHR.
Cursor Size Register - CSR 8 bits (see Figures 16a, b, c)
- Defines the beginning (upper nibble) and ending (lower nibble) scan lines for the cursor. Values must be $\leq$ CSHR.

```

\subsection*{2.0 Functional Description (Continued)}


FIGURE 16. Underline and Cursor Register Operation
Note: The internal cursor flip-flop gets set to \(O N\) whenever a scan line corresponding to the begin cursor nibble is reached, and gets set to cursor OFF whenever scan line corresponding to the end cursor nibble is reached. The cursor attributes are inserted whenever the character position being displayed corresponds to th one pointed to by the cursor address register. A similar situation applies for characters with the underline attribute selected. Therefore, care should be taken whe setting the ES/F register and setting the cursor and underline sizes. In particular the ES/F value should not be between the upper nibble and lower nibble values c the underline size register or between the upper nibble and lower nibble values of the cursor size register. To use the cursor as a pointer without displaying it, se the lower nibble of the cursor size register to a value less than CSHR and the upper nibble to a value greater than CSHR.

\subsection*{2.5.2 TIMING CHAIN LOAD VALUE EXAMPLE}

It is desired to have a display field of 80 columns by 25 rows with the last screen row being a status row. It has been determined that 25 character width times will be necessary to complete horizontal retrace and that Horizontal sync should be positioned to start a full seven character times after blanking and end twenty characters after blanking to give us a total sync width of 13 character times. (See Figure 17 for example.)
Additionally, vertical retrace will take 23 scan line times to complete with vertical sync starting three scan line times after vertical blanking begins and occupying a total period of 11 scan lines.
It is desired to make the character cells 12 scan lines tall. The cursor will be a block shape and occupy the bottom 11
scan lines in a cell. The underline attribute will actually be ; strike through dash occupying the 4th scan line from the tol in a cell.
Our line width is 80 displayed characters plus 25 for retract making HLR \(=80+25-1=104\). Blanking will start afte the 80th character so HBR \(=80-1=79\). To achievi seven character times after horizontal blanking, HSBR \(=\) \(87+2=89\). To achieve twenty character times afte blanking HSER \(=100+2=102\) (note \(102-89=1\) : total). Cell height is 12 lines so CSHR \(=12-1=11\) Since there are 12 scan lines per cell or row, vertical retrace will require \(23 / 12=1\) row and 11 scan lines. This makes our total row count VLR \(=25+1-1=25\) and \(E S / F=\) \(11-1=10\). Thus, timing chain location 4 would be coded 1011 1010. We will display 25 rows so VBR \(=25-1=\) 24. Vertical sync will start at the beginning of the fourth scar


FIGURE 17. Typical Video Screen Format Specification
TL/DD/5526-26

\subsection*{2.0 Functional Description (Continued)}
line of the row after blanking begins so VSBR \(=4-1=3\). It will run for 11 scan lines or specifically the \(4,5,6,7,8,9\), \(10,11,12,1,2\) ending at the beginning of the 3rd so VSER \(=3-1=2\). The status row will be after the 24 th so SRBR \(=24-1=23\). To specify the underline and cursor sizes one must remember that the first scan line is numbered 0 . To get our 11 line block cursor we begin after the 0 line and end at the end of the 11 line making CSR \(=0000\) 1011. The underline dash will be USR \(=00110100\). Note that the CSHR determines the scan counter modulo and if a scan compare register value (ES/F, VSBR, VSER, USR, OSR) is never reached, the signal end or begin will never be nitiated.

\subsection*{2.6 ATTRIBUTES}

Eight independent attributes may be inserted itno the video dot stream to affect display characters on either an individual or global basis. The eight attributes along with their con-


TL/DD/5526-27
FIGURE 18. Attribute Bit Assignments
trol word bit assignments are detailed in Figure 18. The scope with which a particular set of attributes affects the display depends upon whether attribute control is internal or external as determined by bit 4 in the VCR.
Attributes are present if the corresponding bit is a ZERO (low).

\subsection*{2.6.1 Internal Attribute Selection}

In internal mode attribute control comes from one of two internal attribute latches designated ALO and AL1, either of which is directly loadable from the CPU accumulator. The choice of which of the two is used for a particular display character is determined by bit 7 (MSB) in the display memory data byte with \(0=\) ALO and \(1=\) AL1. (Characters are represented in display memory as ASCII values occupying the low 7 bits of each 8 -bit byte thus leaving bit 7 free for attribute control.)

\subsection*{2.6.2 External Attribute Selection}

In external mode each display character has associated with it, a dedicated attribute field in the form of a high 8-bit extension to the regular display memory character byte. To use this mode the system bus msut be configured for 16 -bit bidirectional operation (SCR bit \(4=1\) ) and external attributes must be selected (VCR bit \(4=1\) ).

\subsection*{2.6.3 Attribute Processing}

Each of the eight attributes may be independently enabled thus yielding a number of possible combinations. The exact processing involved is shown in Figure 19. Note that attributes are always present. Whether any of them are active depends upon the particular control bit being enabled in the latch or memory.

\subsection*{2.0 Functional Description (Continued)}

\subsection*{2.6.4 Attribute Operation}

Reverse Video: A character and its surrounding cell are reversed in video from what was selected for the rest of the screen. Half Intensity: To use the half intensity function the shared INTENSITY/FO CLK pin (25) must be selected for INTENSITY operation by setting SCR bit 6 low. In operation the half intensity pin will be low whenever a character for which the attribute is active is being displayed. To perform the actual attenuation function external circuitry must be connected between the INTEN and Video Output pins. In fact the signal may be used for another purpose suct as switching between two colors.
Blink: A character or the field around it blinks as selected by VCR bit 0.
Double Height: A designated character is stretched out so that it will occupy a 2 -row tall space. This attribute is implementec by slowing down by half the scan line stepping to the internal character generator. To use this attribute the desired double high character must be placed into the two display memory locations corresponding to the tor and bottom row positions. For both locations the double high attribute is set. In addition the Blank attribute fol the bottom character is also set to tell the controller it is the bottom half of a double high character. The double high attribute has no effect on element graphics or on pixel graphics displays. If an external character generator is used special circuitry must be employed to implement double high characters.
Double Width: A designated character is stretched out so that it will occupy a 2-character cell wide space. This attribute is implemented by slowing down by half the clock to the video dot shifter. To use this attribute the desired double wide character must be placed in the left character position and the double wide attribute bit set. The following character position (right) can have any character as it will be ignored.
Underline: If set this attribute causes the underline figure to be added to the video dot stream. Since the underline, like the cursor, can be specified as to position and size in the character cell, the underline can be an overline, block, strike through or any one of a number of effects. The underline overwrites any dot where it overlaps the character.
Blank/Double A character is inhibited from being displayed while still allowing it to be stored in the display memory. If this High Bottom: attribute and the double height attribute are set for the same character, the normal blank function is disabled for that character position and the character is displayed as the bottom half of a double height character.
Graphics: This attribute determines whether the video memory data byte as accessed by the display memory controller is routed through the character generator or block graphics control logic. If routed through the block graphics logic (attribute active) the effect on the video display will be as described in the Block Graphics section. Note that because Block Graphics mode is selected as an attribute it may be mixed in with normal alphanumerics characters. Also all other attributes with the exception of double height operate on the block graphics characters.

\subsection*{2.7 CHARACTER GENERATOR}

The internal character generator holds 128 characters in a \(7 \times 11\) matrix. The standard character sets are addressed using 7-bit ASCll codes stored in the display memory. When operating with fonts smaller than the maximum of \(7 \times 11\), zeroes are encoded into the unused bits. When putting out a character the video controller always starts character generation on the second scan line of a row, leaving the first scan line blank. Similarly, the first (left) column in a character cell is blanked with character generation starting on the second column. Therefore, the specified cell size must be one greater in height and width than the display characters (including descenders) otherwise they will be chopped off. If the character cells are larger than the internal \(7 \times 11\) matrix, blank dots will be put out after exhausting the internal generator (See Figure 20 for example.)


FIGURE 20. Character Cell Format

\subsection*{2.7.1 External Character Generation}

The chip may be used with an external character generator by switching over to a pixel graphic display mode with modified address stepping as controlled by VCR bits 6, 7. In this mode an external character generator supplies pixel data to the chip as depicted in Figure 21. Character addressing comes from the display memory and scan line stepping from a 4 -bit counter clocked by the Horizontal Sync. Scan line synchronization is achieved by using the Scan Count Clear signal coming out on RE11, pin 36. After the display of a row it pulses low to initialize the scan line counter for the start of a new row. In pixel mode both the character and any spacing between characters must be encoded into the external character generator. In addition, the chip will access and use at most 8 bits of pixel data for each character cell. However, if the cell width is specified to be 9 or 10, the ninth and tenth dots will repeat what was coded into the first. Therefore, assuming at least one dot spacing between characters, external fonts can at most be seven dots wide.
No limitations apply to the height of a character as long as the external generator can supply all of the scan lines as specified by the CSHR. As in regular pixel mode the LSB brought in is the first dot put out.
Since the eighth data bit is used for character generation it cannot effectively be used for internal attribute latch selection although one of the latches will be selected every data byte. Therefore, both internal attribute latches must be loaded with the same values. If external attribute operation is specified the full 8 -bit high order attribute field is available for usage.

\subsection*{2.0 Functional Description (Continued)}


TL/DD/5526-30
FIGURE 21. External Character Set Implementation

\subsection*{2.8 BLOCK GRAPHICS}

Block graphics is an alternative display mode to normal alphanumerics which is selected through attribute bit 7. Example (Figure 22). It can operate on a character ceil by character cell basis (see Attributes) and words by rerouting display memory bytes through the Block graphics logic instead of the internal character generator.


TL/DD/5526-31
FIGURE 22. Example Block Graphics Display Patterns
The Graphics Logic operates by partitioning the character cell space into nine possible areas as shown in Figure 23 and then using the seven lower bits in the display data byte to turn these areas on or off. In this way one can draw contiguous lines or simple geometric figures while at the same time displaying alphanumeric characters in other cells.
The partitioning of the cell is controlled by two timing chain registers which specify two Horizontal and two Vertical cut off points to the graphics logic. Through these two registers one can make the sections as large or as small as desired, even eliminating sections entirely. Note that data bits 0 and 5 each control two sections as depicted in Figure 23.

\subsection*{2.8.1 Graphics Partitloning}


TL/DD/5526-32
FIGURE 23. Block Graphics Cell Partitioning
The registers defining the graphics areas function as follows:
The Graphics Row Register - 8 bits (GRR) is divided into the following two (2) registers:
- Graphics Middle Row, (GMR):

Defines the scan count at which the middle row begins (4 most significant bits of GRR).
- Graphics Bottom Row, (GBR):

Defines the scan count at which the bottom row begins (4 least significant bits of GRR).
See Figure 24.1a for row example.

\subsection*{2.0 Functional Description (Continued)}

The Graphics Column Register - 8 bits (GCR) controls vertical partitioning through bit patterns as follows: (See Figure 24.)


TL/DD/5526-33
FIGURE 24. Block Graphics Column Partitioning


FIGURE 24.1a Block Graphics Example
For all bits in the Graphics Column Register, a one assigns that bit position to the middle column. A zero in an L bit position assigns that bit position to the left column. A zero in an \(R\) bit position assigns that bit position to the right column. There is always at least one middle dot although the left and right sections may be eliminated entirely. For 10 dot wide cells the 10th bit will repeat the 9th bit. An easy way to determine the column partitioning is to fill the GCR with all ones, thereby making it one large middle section. Then, starting from the outermost \(L\) and \(R\) bit positions, put zeros in until the left and right sections are the sizes needed.

\subsection*{2.9 PIXEL GRAPHICS}

When bits 6 and 7 of the Video Control Register are both set to 1, the character generator and block graphics circuits are disabled. Video output directly reflects the contents of the display memory byte on a pixel (dot) per bit basis with data output LSB first. Example (Figure 25).
Nine bits at a time are accessed from each video memory location with as many bits being used as defined in the character cell width specification. If a cell width of 10 is specified


TL/DD/5526-34
FIGURE 25. Example Plxel Graphics
the 10th bit will merely repeat the 9th bit. Attributes are still operable in pixel mode, on a data byte basis, with internal and external operation possible. With internal attribute latch operation the same values must be loaded into both latches since the usual latch select bit is now being used for pixel control. Unless, however, only a 7 dot wide cell is used leaving the 8th bit free. With external attribute operation we are now limited to a 7 -bit attribute field since pixel data can now occupy 9 of the 16 bus bits. Because of this the LSB attribute, Reverse Video is totally disabled from operation in Pixel Graphic mode. This also applies to internal attribute latch operation. Note, however, that reverse entire screen video is still operable. Address sequencing through the video memory is sequential with as many data bytes being read in as is necessary to satisfy the pixel requirements of the screen.

\subsection*{2.10 LIGHT PEN}

Activation of the light pen interrupt causes the horizontal and vertical screen position of the currently displayed character to be latched into the Horizontal Light Pen Register HPEN (7 bits) and Vertical Light Pen Register VPEN ( 5 bits) respectively. Both HPEN and VPEN may be read into the CPU accumulator. The values latched remain in VPEN and HPEN until another light pen interrupt latches new values.

\subsection*{2.11 UART}

The UART features full duplex operation with double buffered Receive and Transmit sections. Baud rate generation is fully programmable through a 2-stage divider chain. CPU control of the UART is extensive with polled or interrupt driven operation possible.


FIGURE 26. TMP UART Block Diagram

\subsection*{2.0 Functional Description (Continued)}

\subsection*{2.11.1 UART Control}

UART Status Register (STAT): Contains error and status bits which reflect the internal state of the UART. Read into CPU accumulator. Bits 0,5 are the same as those found in the internal interrupt register.


TL/DD/5526-36
UART Status Register blts 1, 2, 3 are only cleared on a chip reset or a read of the UART Recelve Buffer. If another word were to come in before the Recelve Buffer could be read the errors assoclated with the new word would add to those already present. The receipt of a new word can cause the three blts to go from a 0 to a 1 , but not from a 1 to a 0 .

FIGURE 27. UART Status Reglster
Note: The Transmit Output Register Empty flag ls set to one whenever the transmitter is idle. The flag is reset to zero when a data character is transterred from the Transmit Buffer to the Output Register. Thls transfer does not occur until the next rising edge of the internal UART Transmit Clock. The Transmitter Output Reglster Empty flag occurs at the beginning of the last stop blt.
UART Control Register (UCR): Contains control bits which configure the format of transmitted data and tests made upon received data. Written to from CPU accumulator.


TL/DD/5526-37
*Bit 5 set to 0 by RESET.
FIGURE 28. UART Control Register

\subsection*{2.11.2 Baud Clock Generation}

The basic BAUD clock is derived from the crystal frequency through a two-stage divider chain consisting of a 3.5-11 prescale and an 11 -bit binary counter. (Figure 29). The divide factors are specified through 2 write only registers shown in Figure 30. Note that the 11-bit Baud Rate Divisior spills over into the Prescale Select Register. The correspondences between the 4-bit Prescale Select and Prescale factors is shown in Table I. There are many ways to calculate the two divisor factors but one particularly effective method would be to try to achieve a 1.8432 MHz frequency coming out of the first stage then use the BAUD Rate Divisor factors shown in Table II.


FIGURE 30. UART BAUD Clock Divider Reglsters
TABLE I. Prescale Factors
\begin{tabular}{|c|c|}
\hline \begin{tabular}{c} 
Prescale \\
Select
\end{tabular} & \begin{tabular}{c} 
Prescale \\
Factor
\end{tabular} \\
\hline 0000 & 3.5 \\
0001 & 4 \\
0010 & 4.5 \\
0011 & 5 \\
0100 & 5.5 \\
0101 & 6 \\
0110 & 6.5 \\
0111 & 7 \\
1000 & 7.5 \\
1001 & 8 \\
1010 & 8.5 \\
1011 & 9 \\
1100 & 9.5 \\
1101 & 10 \\
1110 & 10.5 \\
1111 & 11 \\
\hline
\end{tabular}

TABLE II. Baud Rate Divisors (1.8432 MHz Input)
\begin{tabular}{|c|c|}
\hline \begin{tabular}{c} 
Baud \\
Rate
\end{tabular} & \begin{tabular}{c} 
Baud Rate \\
Divisor \((\mathbf{N}-1)\)
\end{tabular} \\
\hline \(110 \quad(110.03)\) & 1046 \\
\(134.5 \quad(134.58)\) & 855 \\
150 & 767 \\
300 & 383 \\
600 & 191 \\
1200 & 95 \\
1800 & 63 \\
2400 & 47 \\
3600 & 31 \\
4800 & 23 \\
7200 & 15 \\
9600 & 11 \\
19200 & 5 \\
\hline
\end{tabular}


FIGURE 29. UART BAUD Clock Generation

\subsection*{2.0 Functional Description (Continued)}

The frequency coming out of the BAUD Rate Divisor is then passed through the UART Multiplex Register. Through the UART Multiplex Register one can specify that the Transmitter or Receiver clock be the same or a power of two multiple of the other.

UART Multiplex Register (UMX): Contains the bits which determine the divisor which is used to count down from the primary baud rate when different rates are used for send and receive (eight bits).


TL/DD/5526-40
FIGURE 31. UART Multiplex Register
The actual baud rate may be found from:
\(B R=F c /\left(16 * N^{*} P^{*} D\right)\)
Where:
BR is the Baud Rate
Fc is the external crystal frequency
N is one plus the value of the Baud Rate Divisor contained in the Baud Rate Select Register and the Prescale Select Register.
\(P\) is the Prescale Divide Factor Selected by the value in the Prescale Select Register.
D is the Multiplex Register Divide Factor

\subsection*{3.0 Slave Processing}

The TMP may be used as a slave video controller by having a host system perform Direct Memory Accesses into the display RAM. To assist in implementing such a system the chip features two DMA control pins-HOLD (Hold Request) and HLDA (Hold Acknowledge). These two signals come out on shared ROM Expand Bus pins RE8 and RE12. To request a DMA access a host would activate HOLD (active high and await the acknowledging HLDA from the TMP before proceeding with the DMA. The TMP only allows DMA operations during the vertical blanking period and will activate HLDA in response to a HOLD shortly after vertical blanking starts. In DMA mode all 16 TMP System Bus drivers are tri-stated while the bus control signals RAM ALE, RAM RD, RAM WR go to their inactive (high) states. A HOLD request must arrive two CPU cycles before vertical blanking starts; otherwise it will miss that retrace cycle and will have to wait until the next one, one frame later. Once DMA mode is entered, it is maintained for the duration of vertical blanking regardless of the state of HOLD. Near the end of vertical blanking the DMA mode will terminate in
preparation for the display of the next frame, but the HLDA will NOT turn off. Specifically, this will occur one scan time before the end of vertical blanking. It is up to the designer to be sure that the host is off the BUS before this happens or suffer bus contention with the video controller. He can do this by either predetermining the length of time the host has to remain on the bus, or by using the end of vertical sync (as shown in Figure 32) to signal the end of a safe DMA period. If during DMA the CPU attempts to do a display memory access it would be put into a wait state until DMA is concluded and normal memory accessing is resumed.


TL/DD/5526-45
Vertical sync should be programmed to end as late as possible, but must end at least one scan time before the end of vertical blanking.

FIGURE 32

\subsection*{4.0 Reset}

The TMP will reset if the RESET (32) pin is held at a logic low ( \(<0.8 \mathrm{~V}\) ) for at least five CPU cycle times. This pre-supposes that the \(V_{C C}\) is up, stable and within operational limits ( \(+5 \mathrm{~V} \pm 10 \%\) ) and that the oscillator is running. For a power on reset, time must be allowed for the power supplies to stabilize (typically 50 ms ) and the oscillator to start up. If power supply noise or ripple causes \(V_{C C}\) to exceed the \(+5 \mathrm{~V} \pm 10 \%\) limits neither reset nor operation is guaranteed.
Internally, the \(\overline{\text { RESET }}\) pin has a depletion load pullup that typically acts as a \(30 \mu \mathrm{~A}\) current source from \(\mathrm{V}_{\mathrm{CC}}\) in the voltage range of interest. A typical reset circuit with a 0.5 second reset pulse is shown in Figure 33.


TL/DD/5526-41
FIGURE 33. Typical Reset Circuit

\subsection*{4.0 Reset (Continued)}

During RESET a number of internal registers are initialized as follows:

\subsection*{4.1 CPU}

CPU Clock divide \(\quad=1.5(\) SCR bit \(0=1)\)
Shared VIDCLK/ \(\overline{\text { FICLK }}=0(S C R\) bit \(7=0, \overline{\text { FICLK }}\) gated to external pin \()\)
Program Counter \(=0\)
Stack Pointer \(\quad=0\)
Program Memory Bank \(=0\)
RAM Register Bank \(=0\)
Timer Stopped
Instruction Register cleared
F0 and F1 cleared

\subsection*{4.2 INTERRUPTS}
internal and External Interrupts disabled
Internal Interrupt Register set to 000011X0

\subsection*{4.3 UART}

Receiver initialized to look for start bit
Status Register set to 11110000
Transmitter initialized to wait for OUT XMTR instruction
Control Register bit \(5=0\) (No BREAK)

\subsection*{4.4 VIDEO}

Video generation shutdown (VCR bit \(5=0\) )
FIFO Cleared Out
Timing Chain Character Counter \(=0\)
Timing Chain Scan Counter
Timing Chain Row Counter
Timing Chain Blink Counter
\[
\left.\begin{array}{l}
=0 \\
=0
\end{array}\right\} \text { IN TEST MODE ONLY }
\]

\subsection*{4.5 PIN STATES AT RESET}

Pins 1-8 (SB0-7)
Pins 9-16 (SB8-15)

Pin 17 (VID CLK/FICLK)
Pin 18 (RAM ALE)
Pin 19 ( \(\overline{\text { RAM WR }}\) )
Pin 20 ( \(\overline{\text { RAM RD })}\)

Pin 21 (ALE)
Pin 22 (XTAL 2)
In TRI-STATE during reset and until either the CPU executes a MOVX instruction or bit 5 of the VCR is set.
If bit 4 of the SCR is set, SB8-15 will behave like SB0-7. If bit 4 of the SCR is cleared, SB815 will act as outputs (any of which may be either high or low). Note that bit 4 of the SCR may be one or zero at power-up.
High during reset and until bit 5 of the VCR is set.
High during reset and until the CPU executes a MOVX instruction or bit 5 of the VCR is set. High during reset and until the CPU executes a MOVX (of the output to display RAM variety) instruction.
High during reset and until either the CPU executes a MOVX instruction or bit 5 of the VCR is set.
Pulses continuously.
Crystal input or master clock input.
Crystal input.
Pin 24 (Gnd.)
Pin 25 (INTENS/FO CLK)
Pin 26 (VO)
Pin 27 (VS)
Pin 28 (HS)
Pin 29 (EA)
May be either high or low during reset.
Low (because of asserted blanking signals) from reset until bit 5 of the VCR is set.
In TRI-STATE mode upon RESET, enabled when bit 5 of the VCR is set.
Low from reset until bit 5 of the VCR is set.
Input only. (must be tied \(\mathrm{HIGH}\left(\mathrm{V}_{\mathrm{H}_{2}}\right)\) )

\subsection*{4.0 Reset (Continued)}

Pin 30 ( \(\overline{\text { PSEN }}\) )
Pin 31 ( \(\overline{\mathrm{RD}})\)
Pin 32 ( \(\overline{\text { RESET }}\) )
Pin 33 (SO)
Pin 34 (SI)
Pin 35 (RE12/HLDA)
Pin 36 (RE11/ \(\overline{\text { SCCLR })}\)
Pin 37 (RE10//(NTR)
Pin 38 (RE9/LPEN)
Pin 39 (RE8/HLDR)
Pins 40-47 (RE0-7; I/O0-7)
Active during reset.
High during reset and until an IN PORT instruction is executed.
Input only.
High during reset and until an OUT XMTR instruction is executed.
Input only.
If HOLD is low: low during reset. If HOLD is high: low at falling edge of ALE and during \(\overline{\text { PSEN }}\), may be low or high at rising edge of ALE.
If reset asserted: low at falling edge of ALE and during \(\overline{\text { PSEN, sampled value of internal Scan }}\) Count Clear signal is output at rising edge of ALE.

If reset asserted: low at falling edge of ALE and during PSEN. Always in TRI-STATE at rising edge of ALE.
If reset asserted: low at falling edge of ALE, in TRI-STATE during PSEN, and may be either high or low at the rising edge of ALE.
Pin 48 (VCC)

\subsection*{5.0 Extra Attributes}

One may want to expand the external attribute field by adding more blts so that functions such as color (Red-Green-Blue drive) or grey scale may be implemented. Llke the elght attributes which the chip handles internally these extra attributes would operate on a character cell basis. To add attribute bits one would have to duplicate the internal 4 level character/attrlbute FIFO externally using fast MSI chips. To assist in handling the external FIFO circuitry the TMP features two FIFO clocking signals on pins 17 and 25. The FIFO IN Clock (FICLK) is used to strobe attribute data into the external FIFO circuits in synchronism with the internal TMP FIFO. Its timing is identical to \(\overline{\text { RAM RD but is only }}\) active when the video does a display RAM read to load its FIFO. The FIFO OUT Clock ( \(\overline{\mathrm{FO} C L K}\) ) pulses for 1-3 bit times each time the video starts the display of a new character cell. The external FIFO would use the rising edge of this signal to clock out or latch the attribute output.

In order for the TMP CPU to access the additional attribute bits special bus gating arrangements would have to be worked out on the System Bus (Video Data Bus is at most 16 bits wide). Unless one were to run with internal attributes or only use a few of the external attributes in which case the unused blts could be used with the external FIFO. Whenever using the FO CLK the Intensity attribute is disabled since they both share the same pin.

\subsection*{6.0 TMP BUS Interfacing}

The two external buses on the TMP, ROM Expand and System are easily interfaced to as shown in Figures 34 and 35. Important bus information output from the chip is latched using the rising or falling edges of the various control signals. I/O port information is read in through a TRI-STATE © buffer chip such as an 81LS96.


TL/DD/5526-42
FIGURE 34. TMP ROM Expand BUS

\subsection*{6.0 TMP BUS Interfacing (Continued)}


TL/DD/5526-43
FIGURE 35. TMP System Bus
TMP Registers (Excluding Timing Chain Registers)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{2}{*}{TMP Registers}} & \multicolumn{4}{|c|}{Associated Intructions} \\
\hline & & \multicolumn{4}{|l|}{CPU SECTION} \\
\hline A & \(=\) Accumulator -8 bits & ADD A, & & MOV A,Rr & XCH A,Rr \\
\hline \# data & = data immediate & ADD A, & & MOV A,@Rr & XCH A,@Rr \\
\hline Rr & = Register & ADD A, & & MOV A, \# data & XCHD A,@Rr \\
\hline @Rr & = Register pointed to by R0 or R1 & ADDC A & & MOV Rr,A & XRL A, Rr \\
\hline & & ADDC A & & MOV Rr, \# data & XRLA, @Rr \\
\hline & & ADDC A & & MOV @Rr,A & XRL A, \# data \\
\hline & & ANL A, & & MOV @Rr, \# data & JBn addr \\
\hline & & ANL A, & & MOVP A,@A & JNZ addr \\
\hline & & ANL A, & & MOVP3 A,@A & JZ addr \\
\hline & & CLRA & & RLA & DJNZ Rr,addr \\
\hline & & CPLA & & RLCA & \\
\hline & & DAA & & RR A & \\
\hline & & DEC A & & RRC A & \\
\hline & & DEC Rr & & ORL A, Rr & \\
\hline & & INC A & & ORLA, @Rr & \\
\hline & & INC Rr & & ORL A, \# data & \\
\hline & & INC @R & & SWAP A & \\
\hline * HACC & \(=\) High Accumulator -8 bits & \multicolumn{2}{|l|}{*MOV A,HACC} & \multicolumn{2}{|l|}{*MOV HACC,A} \\
\hline C & = Carry Bit & CLR C & CPLC & JNC addr & JC addr \\
\hline *LONG RO & \(=\) Register Pair, R0, RA & \multicolumn{2}{|l|}{\begin{tabular}{l}
*DECL RO \\
*MOVL R0,A
\end{tabular}} & \begin{tabular}{l}
*INCL RO \\
*MOVX A,@RO
\end{tabular} & \begin{tabular}{l}
*MOVL A,RO \\
*MOVX @RO,A
\end{tabular} \\
\hline *LONG R1 & = Register Pair R1, RB & \multicolumn{2}{|l|}{\begin{tabular}{l}
*DECLR1 \\
*MOVL R1,A
\end{tabular}} & \begin{tabular}{l}
*INCL R1 \\
*MOVX A,@R1
\end{tabular} & \begin{tabular}{l}
*MOVL A,R1 \\
*MOVX @R1,A
\end{tabular} \\
\hline T & \(=\) Timer -8 bits & \multicolumn{2}{|l|}{MOV A,T STRT T} & \begin{tabular}{l}
MOV T,A \\
*JNTF addr
\end{tabular} & \begin{tabular}{l}
STOPT \\
JTF addr
\end{tabular} \\
\hline FO & \(=\) Flag 0 & CLR F0 & CPL F0 & JFO addr & *JNFO addr \\
\hline F1 & = Flag 1 & CLR F1 & CPLF1 & JF1 addr & *JNF1 addr \\
\hline \multirow[t]{3}{*}{INTR} & \multirow[t]{3}{*}{\(=\) Interrupt Register - 8 bits} & \multicolumn{2}{|l|}{\multirow[t]{3}{*}{MOV A,INTR *DIS II EN XI}} & JNXI addr & JXI addr \\
\hline & & & & DIS XI & *EN II \\
\hline & & & & & \\
\hline
\end{tabular}

TMP Registers (Excluding Timing Chain Registers) (Continued)
\begin{tabular}{|c|c|c|c|c|}
\hline \multicolumn{3}{|l|}{TMP Registers} & \multicolumn{2}{|l|}{Associated Instructions} \\
\hline \multicolumn{5}{|c|}{CPU SECTION (Continued)} \\
\hline MASK & \(=\) Internal Interrupt MasK - 8 bits & *MOV MASK,A & & \\
\hline PSW & \(=\) Program Status Word - 8 bits & MOV A,PSW & MOV PSW,A & \\
\hline PORT & \(=8\) bit \(1 / O\) Port & ANL PORT, \#data ORL PORT, \# data & IN PORT OUT PORT & \\
\hline \multicolumn{2}{|l|}{\multirow[t]{4}{*}{Miscellaneous Instructions}} & CALL addr & JMP addr & JMPP @A \\
\hline & & NOP & RET & RETR \\
\hline & & SEL MBO & SEL MB1 & *SEL MB2 \\
\hline & & *SEL MB3 & SEL RBO & SEL RB1 \\
\hline \multicolumn{5}{|c|}{VIDEO MANAGEMENT} \\
\hline \multicolumn{5}{|c|}{Associated Instructions} \\
\hline SCR & \(=\) System Control Register - 8 bits & & *MOV SCR,A & \\
\hline VCR & \(=\) Video Control Register - 8 bits & & *MOV VCR,A & \\
\hline HOME & = Home Address Register - 16 bits & & *MOV A,HOME & *MOV HOME,A \\
\hline \multirow[t]{2}{*}{CURS} & \(=\) Cursor Address Register - 16 bits & *DEC CURS & *INC CURS & *MOVXA,@CURS \\
\hline & & *MOV CURS,A & *MOV A,CURS & *MOVX @CURS,A \\
\hline BEGD & \multicolumn{2}{|l|}{\(=\) Beginning of Display RAM Register - 16 bits} & *MOV BEGD,A & \\
\hline ENDD & \multicolumn{2}{|l|}{= End of Display RAM Register - 16 bits} & *MOV ENDD,A & \\
\hline SROW & \multicolumn{2}{|l|}{= Status Row Register - 16 bits} & *MOV SROW,A & \\
\hline ALO & \multicolumn{2}{|l|}{\(=\) Attribute Latch 0-8 bits} & *MOV ALO,A & \\
\hline AL1 & \multicolumn{2}{|l|}{\(=\) Attribute Latch \(1-8\) bits} & *MOV AL1,A & \\
\hline HPEN & \multicolumn{2}{|l|}{\(=\) Horizontal Light Pen Register - 7 bits} & *MOV A,HPEN & \\
\hline VPEN & \multicolumn{2}{|l|}{\(=\) Vertical Light Pen Register - 5 bits} & *MOV A,VPEN & \\
\hline \multirow[t]{2}{*}{VINT} & \(=\) Vertical Interrupt Register - 5 bits & & *MOV VINT,A & \\
\hline & \multicolumn{4}{|c|}{UART CONTROL} \\
\hline PSR & \(=\) Prescale Register (UART) - 8 bits & & *MOV PSR,A & \\
\hline baUd & \(=\) Baud Rate Select Register -8 bits & & *MOV BAUD,A & \\
\hline UCR & \(=\) UART Control Register -8 bits & & *MOV UCR,A & \\
\hline UMX & \(=\) UART Multiplex Register - 8 bits & & *MOV UMX,A & \\
\hline STAT & \(=\) Status Latch (UART) -6 bits & & *MOV A,STAT & \\
\hline RCVR & \(=\) UART Receive Buffer -8 bits & & *IN RCVR & \\
\hline XMTR & \(=\) UART Transmit Buffer - 8 bits & & *OUT XMTR & \\
\hline TCP & \(=\) Timing Chain Pointer & & *MOV TCP,A & \\
\hline @TCP & \(=\) Register Pointed to by TCP & & *MOV @TCP,A & \\
\hline
\end{tabular}
*New instruction added to 8048 subset.

\section*{Symbol Definitions}
\begin{tabular}{|l|l|}
\hline Symbol & \multicolumn{1}{|c|}{ Definition } \\
\hline AC & Auxiliary Carry Flag \\
addr & Program Memory Address \\
b & Bit Designator (b \(=0-7)\) \\
BS & RAM Bank Switch \\
data & Number or Expression (8 bits) \\
DBF & Program Memory Bank Select Bits (2) \\
EXI & External Interrupt Pin \\
FO, F1 & Internal Flags \\
P & I/O Port (8 bits) \\
\hline
\end{tabular}
\begin{tabular}{|l|l|}
\hline Symbol & \multicolumn{1}{|c|}{ Definition } \\
\hline PC & Program Counter \\
SP & Stack Pointer \\
TF & Timer Flag \\
\# & Prefix for Immediate Data \\
\(@\) & Prefix for Indirect Address \\
\((\) C & Contents of Register \\
\((\) ( ) ) Contents of Memory Location pointed to by \\
& designated register \\
\(\leftarrow\) & Replaced by \\
\hline
\end{tabular}

\section*{Instruction Set}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Mnemonic} & \multirow[t]{2}{*}{Machine Code} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow[t]{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{5}{|c|}{Flags} \\
\hline & & & & & & C & AC & HACC & FO & F1 \\
\hline JD A, Rr & \(\begin{array}{llllllll}0 & 1 & 1 & 0 & 1 & \mathrm{r} & \mathrm{r} & \mathrm{r}\end{array}\) & \[
\begin{aligned}
& (\mathrm{A}) \leftarrow(\mathrm{A})+(\mathrm{Rr}) \text { for } \\
& r=0-7
\end{aligned}
\] & Add contents of designated register to the Accumulator (8-bit operation) & 1 & 1 & * & * & * & & \\
\hline JD A, \# data & \begin{tabular}{cccccccc}
0 & 0 & 0 & 0 & 0 & 0 & 1 & 1 \\
\(d 7\) & \(d 6\) & \(d 5\) & \(d 4\) & \(d 3\) & \(d 2\) & \(d 1\) & \(d 0\)
\end{tabular} & \((A) \leftarrow(A)+\) data & Add immediate the specified data to the Accumulator (8-bit operation) & 2 & 2 & * & * & * & & \\
\hline JD A, @ Rr & \(0 \begin{array}{llllllll}0 & 1 & 1 & 0 & 0 & 0 & 0 & r\end{array}\) & \[
\begin{aligned}
& (A) \leftarrow(A)+((R r)) \text { for } \\
& r=0-1
\end{aligned}
\] & Add indirect the contents of data memory pointed to by Rr to the Accumulator (8-bit operation) & 1 & 1 & * & * & * & & \\
\hline JDC A, Rr & \(\begin{array}{llllllll}0 & 1 & 1 & 1 & 1 & \mathrm{r} & \mathrm{r} & \mathrm{r}\end{array}\) & \[
\begin{aligned}
& (A) \leftarrow(A)+(C)+(R r) \\
& \text { for } r=0-7
\end{aligned}
\] & Add with carry the contents of the designated register to the Accumulator (8-bit operation) & 1 & 1 & * & * & * & & \\
\hline JDC A, \# data & \begin{tabular}{cccccccc}
0 & 0 & 0 & 1 & 0 & 0 & 1 & 1 \\
\(d 7\) & \(d 6\) & \(d 5\) & \(d 4\) & \(d 3\) & \(d 2\) & \(d\) & \(d 0\)
\end{tabular} & \((\mathrm{A}) \leftarrow(\mathrm{A})+(\mathrm{C})+\) data & Add immediate with carry the specified data to the Accumulator (8-bit operation) & 2 & 2 & * & * & * & & \\
\hline \(\overline{\mathrm{JCC}}\), @ Rr & \(\begin{array}{llllllll}0 & 1 & 1 & 1 & 0 & 0 & 0 & r\end{array}\) & \[
\left\lvert\, \begin{aligned}
& (A) \leftarrow(A)+(C)+ \\
& ((\operatorname{Rr})) \text { for } r=0-1
\end{aligned}\right.
\] & Add indirect with carry the contents of data memory pointed to by Rr to the Accumulator (8-bit operation) & 1 & 1 & * & * & * & & \\
\hline vL A; Rr & \(\begin{array}{llllllll}0 & 1 & 0 & 1 & 1 & \mathrm{r} & \mathrm{r} & \mathrm{r}\end{array}\) & \[
\begin{aligned}
& (A) \leftarrow(A) \text { AND (Rr) for } \\
& r=0-7
\end{aligned}
\] & Logical AND contents of designated register with Accumulator (8bit operation) & 1 & 1 & & & & & \\
\hline VL A, \# data & \begin{tabular}{cccccccc}
0 & 1 & 0 & 1 & 0 & 0 & 1 & 1 \\
\(d 7\) & \(d 6\) & \(d 5\) & \(d 4\) & \(d 3\) & \(d 2\) & \(d 1\) & \(d 0\)
\end{tabular} & (A) \(\leftarrow\) (A) AND data & Logical AND specified Immediate Data with Accumulator (8-bit operation) & 2 & 2 & & & & & \\
\hline . \(\mathrm{LL} A, @ \mathrm{Rr}\) & \(0 \begin{array}{llllllll} & 1 & 0 & 1 & 0 & 0 & 0 & r\end{array}\) & \[
\begin{aligned}
& (\mathrm{A}) \leftarrow(\mathrm{A}) \text { AND }((\operatorname{Rr})) \\
& \text { for } r=0-1
\end{aligned}
\] & Logical AND indirect the contents of data memory pointed to by Rr with Accumulator (8-bit operation) & 1 & 1 & & & & & \\
\hline NL PORT, \# data & \(\left|\begin{array}{cccccccc}0 & 1 & 1 & 1 & 0 & 0 & 1 & 1 \\ d 7 & d 6 & d 5 & d 4 & d 3 & d 2 & d 1 & d 0\end{array}\right|\) & \((\mathrm{P}) \leftarrow(\mathrm{P})\) AND data & Logical AND immediate specified data with output port (8-bit operation) & 2 & 2 & & & & & \\
\hline ALL addr & \[
\left\lvert\, \begin{array}{cccccccc}
a 10 & a 9 & a 8 & 1 & 0 & 1 & 0 & 0 \\
\text { a7 } & \text { a6 } & \text { a5 } & \text { a4 } & \text { a3 } & \text { a2 } & \text { a1 } & \text { a0 }
\end{array}\right.
\] & \[
\begin{aligned}
& ((\mathrm{SP})) \leftarrow(\mathrm{PCO}-12) \\
& ((\mathrm{SP})) \leftarrow(\mathrm{PSW3}-7) \\
& (\mathrm{SP}) \leftarrow(\mathrm{SP})+1 \\
& (\mathrm{PC8}-10) \leftarrow \text { addr } 8-10 \\
& (\mathrm{PCO} 0-7) \leftarrow \text { addr 0-7 } \\
& (\mathrm{PC} 11-12 \leftarrow \text { DBF 0,1 }
\end{aligned}
\] & Call designated subroutine & 2 & 2 & & & & & \\
\hline
\end{tabular}


Instruction Set (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{nemonic} & \multicolumn{8}{|c|}{\multirow[t]{2}{*}{Machine Code}} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow[t]{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{5}{|c|}{Flags} \\
\hline & & & & & & & & & & & & & C & AC & HACC & Fo & F1 \\
\hline \(\overline{C R r}\) & & & 0 & 0 & 1 & 1 r & \(r\) & r & \[
\begin{aligned}
& (\mathrm{Rr}) \leftarrow(\mathrm{Rr})+1 \text { for } \\
& \mathrm{r}=0-7
\end{aligned}
\] & Increment by 1 the contents of the designated register (8-bit increment) & 1 & 1 & * & & & & \\
\hline C @ Rr & & & 0 & 0 & 1 & 00 & 0 & r & \[
\begin{aligned}
& ((\mathrm{Rr})) \leftarrow((\mathrm{Rr}))+1 \text { for } \\
& \mathrm{r}=0-1
\end{aligned}
\] & Increment in direct the contents of data memory pointed to by \(\operatorname{Rr}(8\)-bit increment) & 1 & 1 & * & & & & \\
\hline \(\overline{\mathrm{CLRr}}\) & & & 0 & 1 & 1 & 10 & 0 & \(r\) & \[
\begin{aligned}
& (R r) \leftarrow(R r)+1 \text { for } \\
& r=0-1
\end{aligned}
\] & Increment by 1 the contents of the designated 16-bit register pair & 1 & 1 & & & & & \\
\hline PORT & & & 1 & 1 & 0 & 00 & 0 & 1 & \((\mathrm{A}) \leftarrow(\mathrm{P})\) & Input data from port into Accumulator (8-bit transfer) & 2 & 1 & & & & & \\
\hline RCVR & & & 1 & 1 & 0 & 00 & 0 & 0 & (A) \(\leftarrow(\) RCVR \()\) & Input contents of UART Receive buffer into Accumulator (8bit transfer). Also, clears Receive Buffer Full interrupt. & 1 & 1 & & & & & \\
\hline lb addr & & & & & & \[
\begin{array}{cc}
\hline 0 & 0 \\
\text { a3 } & \text { a2 }
\end{array}
\] & & & \begin{tabular}{l}
(PCO-7) \(\leftarrow\) addr if \\
(b) \(=1\) \\
\((\mathrm{PC}) \leftarrow(\mathrm{PC})+2\) if \\
(b) \(=0\) for \(b=0-7\)
\end{tabular} & Jump to specified address within page if Accumulator bit is set & 2 & 2 & & & & & \\
\hline \addr & & \[
\begin{aligned}
& 1 \\
& a 7
\end{aligned}
\] & \[
\begin{gathered}
\hline 1 \\
a 6
\end{gathered}
\] & & \[
\begin{gathered}
1 \\
\mathrm{a} 4
\end{gathered}
\] & \[
\begin{array}{cc}
\hline 0 & 1 \\
\text { a3 } & \text { a2 }
\end{array}
\] & & & \[
\begin{aligned}
& (P C 0-7) \leftarrow \text { addr if } \\
& C=1 \\
& (P C) \leftarrow(P C)+2 \text { if } \\
& C=0
\end{aligned}
\] & Jump to specified address within page if Carry flag is set & 2 & 2 & & & & & \\
\hline :0 addr & & \[
\begin{gathered}
1 \\
\text { a7 }
\end{gathered}
\] & & & & \[
\begin{array}{cc}
\hline 0 & 1 \\
\text { a3 } & \text { a2 }
\end{array}
\] & & & \[
\begin{aligned}
& (\mathrm{PCO}-7) \leftarrow \text { addr if } \\
& \mathrm{FO}=1 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { if } \\
& \mathrm{FO}=0
\end{aligned}
\] & Jump to specified address within page if Flag FO is set & 2 & 2 & & & & & \\
\hline =1 addr & & \[
\begin{gathered}
0 \\
a 7
\end{gathered}
\] & \[
\begin{gathered}
1 \\
\text { a6 }
\end{gathered}
\] & & \[
\begin{aligned}
& 1 \\
& \hline \\
& \text { a }
\end{aligned}
\] & \[
\begin{array}{cc}
\hline 0 & 1 \\
\text { a3 a2 }
\end{array}
\] & & & \[
\begin{aligned}
& (\mathrm{PCO}-7) \leftarrow \text { addr if } \\
& \mathrm{F} 1=1 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { if } \\
& \mathrm{F} 1=0
\end{aligned}
\] & Jump to specified address within page if Flag F1 is set & 2 & 2 & & & & & \\
\hline UP addr & & \[
\begin{aligned}
& 10 \\
& 97
\end{aligned}
\] & \[
\begin{aligned}
& \text { a9 } \\
& \text { a6 }
\end{aligned}
\] & & & \[
\begin{array}{cc}
\hline 0 & 1 \\
\text { a3 } & \text { a2 }
\end{array}
\] & & & \[
\begin{aligned}
& \hline(\text { PC8-10 }) \leftarrow \text { addr 8-10 } \\
& \text { (PCO-7) } \leftarrow \text { addr 0-7 } \\
& \text { (PC11-12) } \leftarrow \text { DBF 0,1 } \\
& \hline
\end{aligned}
\] & Direct Jump to specified address within 2k Bank & 2 & 2 & & & & & \\
\hline VPP @ A & & & 0 & 1 & 0 & 00 & 1 & & \((\mathrm{PCO}-7) \leftarrow((\mathrm{A})\) ) & Jump indirect within page to the address specified in the memory location pointed to by the Accumulator & 2 & 1 & & & & & \\
\hline NC addr & & \[
\begin{gathered}
1 \\
a 7
\end{gathered}
\] & \[
\begin{gathered}
1 \\
\text { a6 }
\end{gathered}
\] & & \[
\begin{gathered}
0 \\
24 \\
2
\end{gathered}
\] & \[
\begin{array}{cc}
\hline 0 & 1 \\
\text { a3 } & \text { a2 }
\end{array}
\] & \[
\begin{gathered}
1 \\
\mathrm{a} 1
\end{gathered}
\] & & \[
\begin{aligned}
& (\mathrm{PCO}-7) \leftarrow \text { addr } \\
& \text { if } \mathrm{C}=0 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \\
& \text { if } \mathrm{C}=1
\end{aligned}
\] & Jump within page to specified address if Carry flag is 0 & 2 & 2 & & & & & \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Mnemonic} & \multirow[t]{2}{*}{Machine Code} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow[t]{2}{*}{Cycles} & \multirow{2}{*}{Bytes} & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & & C & AC & HACC & F0 \\
\hline JNF0 addr & \[
\left|\begin{array}{cccccccc}
1 & 0 & 0 & 0 & 0 & 1 & 1 & 0 \\
a 7 & a 6 & a 5 & a 4 & a 3 & \text { a2 } & a 1 & a 0
\end{array}\right|
\] & \[
\begin{aligned}
& (P C 0-7) \leftarrow \text { addr if } \\
& F O=0 \\
& (P C) \leftarrow(P C)+2 \text { if } \\
& F O=1
\end{aligned}
\] & Jump within page to specified address if FO is 0 & 2 & 2 & & & & \\
\hline JNF1 addr & \[
\left|\begin{array}{cccccccc}
0 & 1 & 1 & 0 & 0 & 1 & 1 & 0 \\
a 7 & a 6 & a 5 & a 4 & a 3 & a 2 & a 1 & a 0
\end{array}\right|
\] & \[
\begin{aligned}
& (P C O-7) \leftarrow \text { addr if } \\
& F 1=0 \\
& (P C) \leftarrow(P C)+2 \text { if } \\
& F 1=1
\end{aligned}
\] & Jump within page to specified address if F 1 is 0 & 2 & 2 & & & & \\
\hline JNTF addr & \[
\left|\begin{array}{cccccccc}
0 & 0 & 0 & 0 & 0 & 1 & 1 & 0 \\
a 7 & a 6 & a 5 & a 4 & a 3 & \text { a2 } & a 1 & a 0
\end{array}\right|
\] & \[
\left\{\begin{array}{l}
(\mathrm{PCO}-7) \leftarrow \text { addr if } \\
T F=0 \\
(\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { if } \\
\mathrm{TF}=1,(\mathrm{TF}) \leftarrow 0
\end{array}\right.
\] & Jump within page to specified address if Timer flag is reset. If not, continue and reset TF & 2 & 2 & & & & \\
\hline JNXI addr & \[
\left|\begin{array}{cccccccc}
1 & 0 & 1 & 0 & 0 & 1 & 1 & 0 \\
a 7 & a 6 & a 5 & a 4 & a 3 & a 2 & a 1 & a 0
\end{array}\right|
\] & \[
\begin{aligned}
& (P C O-7) \leftarrow \text { addr if } \\
& E X I=L O W \\
& (P C) \leftarrow(P C)+2 \text { if } \\
& E X I=H I G H
\end{aligned}
\] & Jump within page to specified address if External Interrupt pin is LOW & 2 & 2 & & & & \\
\hline JNZ addr & \[
\left|\begin{array}{cccccccc}
1 & 1 & 0 & 1 & 0 & 1 & 1 & 0 \\
a 7 & a 6 & a 5 & a 4 & a 3 & a 2 & a 1 & a 0
\end{array}\right|
\] & \[
\begin{aligned}
& (P C 0-7) \leftarrow \text { addr if } \\
& A \neq 0 \\
& (P C) \leftarrow(P C)+2 \text { if } \\
& A=0
\end{aligned}
\] & Jump within page to specified address if Accumulator is not 0 & 2 & 2 & & & & \\
\hline JTF addr & \[
\left|\begin{array}{cccccccc}
0 & 0 & 0 & 1 & 0 & 1 & 1 & 0 \\
a 7 & a 6 & a 5 & a 4 & a 3 & a 2 & a 1 & a 0
\end{array}\right|
\] & \[
\begin{aligned}
& (\mathrm{PCO}-7) \leftarrow \text { addr if } \\
& T F=1,(\mathrm{TF}) \leftarrow 0 \\
& (\mathrm{PC}) \leftarrow(\mathrm{PC})+2 \text { if } \\
& T F=0
\end{aligned}
\] & Jump within page to specified address if Timer flag is set. If jump taken Timer flag reset & 2 & 2 & & & & \\
\hline JXI addr & \[
\left|\begin{array}{cccccccc}
1 & 0 & 1 & 1 & 0 & 1 & 1 & 0 \\
a 7 & a 6 & 5 & a 4 & a 3 & a 2 & a 1 & a 0
\end{array}\right|
\] & \[
\begin{aligned}
& (P C 0-7) \leftarrow \text { addr if } \\
& E X I=H I G H \\
& (P C) \leftarrow(P C)+2 \text { if } \\
& E X I=L O W
\end{aligned}
\] & Jump within page to specified address if External Interrupt pin is HIGH & 2 & 2 & & & & \\
\hline \(J Z\) addr & \[
\left|\begin{array}{cccccccc}
1 & 1 & 0 & 0 & 0 & 1 & 1 & 0 \\
a 7 & a 6 & a 5 & a 4 & a 3 & a 2 & a 1 & a 0
\end{array}\right|
\] & \[
\begin{aligned}
& (P C 0-7) \leftarrow \text { addr if } \\
& A=0 \\
& (P C) \leftarrow(P C)+2 \text { if } \\
& A \neq 0
\end{aligned}
\] & Jump within page to specified address if Accumulator is 0 & 2 & 2 & & & & \\
\hline MOV A, CURS & \(1 \begin{array}{llllllll} & 0 & 0 & 1 & 1 & 0 & 1 & 1\end{array}\) & (HACC/A) ↔ (CURS) & Copy the contents of the Cursor Address Register into the HACC/A (16-bit transfer) & 1 & 1 & & & * & \\
\hline MOV A, HACC & \(\begin{array}{llllllll}1 & 1 & 1 & 0 & 0 & 0 & 1 & 0\end{array}\) & \((\mathrm{A}) \leftarrow(\mathrm{HACC})\) & Copy contents of the High Accumulator into the Low Accumulator (8-bit transfer) & 1 & 1 & & & & \\
\hline MOV A, HOME &  & \((\mathrm{HACC} / \mathrm{A}) \leftarrow(\mathrm{HOME})\) & Copy the contents of the Home Address register into the HACC/A (16-bit transfer) & 1 & 1 & & & * & \\
\hline MOV A, HPEN & \(\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 1 & 1 & 1\end{array}\) & \[
\begin{aligned}
& (\mathrm{A} 0-6) \leftarrow(\mathrm{HPEN}) \\
& (\mathrm{A} 7) \leftarrow \mathrm{O}
\end{aligned}
\] & Copy the contents of the Horizontal Light Pen Register into the Accumulator (7-bit transfer, A7 cleared) & 1 & 1 & & & & \\
\hline
\end{tabular}

\section*{Instruction Set (Continued)}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Mnemonic} & \multirow[t]{2}{*}{Machine Code} & Function & Description & Cycles & Bytes & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & & C & AC & HACC & FO) \({ }^{1} 1\) \\
\hline OV A, INTR & \(\begin{array}{llllllll}1 & 0 & 0 & 0 & 1 & 1 & 0 & 0\end{array}\) & \((\mathrm{A}) \leftarrow(\) INTR) & Copy the contents of the Interrupt Register into the Accumulator (8-bit transfer) & 1 & 1 & & & & \\
\hline OV A, PSW & \(\begin{array}{llllllll}1 & 1 & 0 & 0 & 0 & 1 & 1 & 1\end{array}\) & (A) \(\leftarrow(\) PSW ) & Copy contents of the Program Status word into the Accumulator (8-bit transfer) & 1 & 1 & & & & \\
\hline OV A, Rr & \(\begin{array}{llllllll}1 & 1 & 1 & 1 & 1 & \mathrm{r} & \mathrm{r} & \mathrm{r}\end{array}\) & \[
\begin{aligned}
& (\mathrm{A}) \leftarrow(\mathrm{Rr}) \\
& \text { for } r=0-7
\end{aligned}
\] & Copy the contents of the designated Register into the Accumulator (8-bit transfer) & & & & & & \\
\hline OV A, STAT & \(\begin{array}{lllllllll}1 & 0 & 0 & 1 & 1 & 1 & 0 & 0\end{array}\) & \[
\begin{aligned}
& (\mathrm{AO}-5) \leftarrow(\mathrm{STAT}) \\
& (\mathrm{A} 6-7) \leftarrow 11
\end{aligned}
\] & Copy the contents of the UART Status Latch into the Accumulator (6-bit transfer, A6 and A7 set) & 1 & 1 & & & & \\
\hline OV A, T & \(0 \begin{array}{llllllll}0 & 1 & 0 & 0 & 0 & 0 & 1 & 0\end{array}\) & \((\mathrm{A}) \leftarrow(\mathrm{T})\) & Copy the contents of the Timer into the Accumulator (8-bit transfer) & 1 & 1 & & & & \\
\hline OV A, VPEN & \(\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 1 & 1 & 0\end{array}\) & \[
\begin{aligned}
& (\mathrm{AO}-4) \leftarrow(\mathrm{VPEN}) \\
& (\mathrm{A} 5-7) \leftarrow \mathrm{O}
\end{aligned}
\] & Copy contents of the Vertical Light Pen Register into the Accumulator (5-bit transfer, A5-A7 cleared) & 1 & 1 & & & & \\
\hline IOV A, @ Rr & \(\begin{array}{llllllll}1 & 1 & 1 & 1 & 0 & 0 & 0 & r\end{array}\) & \[
\begin{aligned}
& (\mathrm{A}) \leftarrow((\mathrm{Rr})) \text { for } \\
& r=0-1
\end{aligned}
\] & Copy indirect the contents of data memory pointed to by Rr into the Accumulator (8-bit transfer) & 1 & 1 & & & & \\
\hline IOV A, \# data & \[
\begin{array}{|cccccccc|}
\hline 0 & 0 & 1 & 0 & 0 & 0 & 1 & 1 \\
d 7 & d 6 & d 5 & d 4 & d 3 & d 2 & d 1 & d 0
\end{array}
\] & (A) \(\leftarrow\) data & Load immediate the specified data into the Accumulator (8-bit load) & 2 & 2 & & & & \\
\hline 10V ALO, A & \(\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 1 & 0 & 0\end{array}\) & \((\mathrm{ALO}) \leftarrow(\mathrm{A})\) & Copy the contents of the Accumulator into Attribute Latch 0 (8-bit transfer) & 1 & 1 & & & & \\
\hline IOV AL1, A & \(\begin{array}{llllllll}0 & 0 & 1 & 1 & 1 & 1 & 0 & 1\end{array}\) & \((\mathrm{AL} 1) \leftarrow(\mathrm{A})\) & Copy the contents of the Accumulator into Attribute Latch 1 (8-bit transfer) & 1 & 1 & & & & \\
\hline IOV BAUD, A & \(0 \begin{array}{llllllll}0 & 0 & 0 & 0 & 0 & 0 & 1 & 0\end{array}\) & (BAUD) \(\leftarrow(A)\) & Copy the contents of the Accumulator into the UART Baud Rate Select Register (8-bit transfer) & 1 & 1 & & & & \\
\hline IOV BEGD, A & \(\begin{array}{llllllll}0 & 0 & 0 & 0 & 1 & 1 & 0 & 1\end{array}\) & \((\mathrm{BEGD}) \leftarrow(\mathrm{HACC} / \mathrm{A})\) & Copy the contents of HACC/A into the Beginning of Display RAM Register (16-bit transfer) & 1 & 1 & & & & \\
\hline
\end{tabular}

Instruction Set (Continued)


\section*{Instruction Set (Coninumed)}

\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{10}{|l|}{Instruction Set (Continued)} \\
\hline Mnemonic & \multirow[t]{2}{*}{Machine Code} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow[t]{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & & C & AC & HACC & FOI \\
\hline MOVP A, @ A & \(1 \begin{array}{llllllll}1 & 0 & 1 & 1 & 0 & 0 & 1 & 1\end{array}\) & \[
\begin{aligned}
& (\mathrm{PCO}-7) \leftarrow(\mathrm{A}) \\
& (\mathrm{A}) \leftarrow(\mathrm{PC})) \\
& (\mathrm{PCO-7}) \leftarrow(\text { old } \mathrm{PCO}-7) \\
& +1
\end{aligned}
\] & Replace low 8 bits of PC with A. Load indirect within page the contents of the memory location pointed to by new PC into Accumulator. Restore PC with old value plus 1. Operates in all memory banks. & 2 & 1 & & & & \\
\hline MOVP3 A, @ A & \(\begin{array}{llllllll}1 & 1 & 1 & 1 & 0 & 0 & 1 & 1\end{array}\) & \[
\begin{aligned}
& (\mathrm{PCO} 0-7) \leftarrow(\mathrm{A}) \\
& (\mathrm{PCB}-10) \leftarrow 011 \\
& (\mathrm{~A}) \leftarrow(\mathrm{PC})) \\
& (\mathrm{PC}) \leftarrow(\text { old } \mathrm{PC})+1
\end{aligned}
\] & Replace low 8 bits of PC with A. Next 3 bits replaced with 011. Load indirect within page 3 the contents of the memory location pointed to by new PC into the Accumulator. Restore PC with old value plus 1. Operates in all memory banks. & 2 & 1 & & & & \\
\hline MOVX A, @ CURS & \(\begin{array}{llllllll}1 & 0 & 0 & 1 & 1 & 1 & 0 & 1\end{array}\) & \((\mathrm{HACC} / \mathrm{A}) \leftarrow(\) (CURS) \()\) & Copy indirect the contents of display memory as pointed to by CURS into HACC/A (16-bit transfer) & Min. 2 & 1 & & & * & \\
\hline MOVX A, @ RO & 100901000000 & \((\mathrm{HACC} / \mathrm{A}) \leftarrow((\mathrm{RA}, \mathrm{RO}) \mathrm{)}\) & Copy indirect the contents of display memory as pointed to by RA, RO into HACC/ A (16-bit transfer) & Min. 2 & 1 & & & * & \\
\hline MOVX A, @ R1 & \(1 \begin{array}{llllllll} & 0 & 0 & 1 & 0 & 0 & 0 & 1\end{array}\) & \((\mathrm{HACC} / \mathrm{A}) \leftarrow((\mathrm{RB}, \mathrm{R} 1))\) & Copy indirect the contents of display memory as pointed to by RB, R1 into HACC/ A (16-bit transfer) & Min. 2 & 1 & & & * & \\
\hline MOVX @ CURS, A & \(1 \begin{array}{llllllll}1 & 0 & 0 & 0 & 1 & 1 & 0 & 1\end{array}\) & ( (CURS) ) ↔ (HACC/A) & Copy indirect the contents of HACC/A into the display memory location as pointed to by CURS (16-bit transfer) & Min. 2 & 1 & & & & \\
\hline MOVX @ R0, A & 10000000000 & \((\) (RA, R0) ) \(\leftarrow(\mathrm{HACC} / \mathrm{A})\) & Copy indirect the contents of HACC/A into the display memory location as pointed to by RA, RO (16-bit transfer) & Min. 2 & 1 & & & & \\
\hline
\end{tabular}

\section*{Instruction Set (Continued)}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Mnemonic} & \multirow[t]{2}{*}{Machine Code} & Function & Description & Cycles & Bytes & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & & C & AC & HACC & F0) F 1 \\
\hline JVX @ R1, A & 100000000001 & \(((R B, R 1)) \leftarrow(H A C C / A)\) & Copy indirect the contents of HACC/A into the display memory location pointed to by RB, R1 (16-bit transfer) & Min. 2 & 1 & & & & \\
\hline P & \(0 \begin{array}{llllllll}0 & 0 & 0 & 0 & 0 & 0 & 0 & 0\end{array}\) & & No Operation & 1 & 1 & & & & \\
\hline IL A, Rr & \(\begin{array}{llllllll}0 & 1 & 0 & 0 & 1 & r & r & r\end{array}\) & \((A) \leftarrow(A)\) OR (Rr) for \(r=0-7\) & Logical OR contents of designated register with Accumulator (8-bit transfer) & 1 & 1 & & & & \\
\hline ILA, @ Rr & \(\begin{array}{llllllll}0 & 1 & 0 & 0 & 0 & 0 & 0 & r\end{array}\) & \[
\begin{aligned}
& (A) \leftarrow(A) \text { OR }((\operatorname{Rr})) \\
& \text { for } r=0-1
\end{aligned}
\] & Logical OR indirect the contents of the data memory location pointed to by Rr with Accumulator (8-bit operation) & 1 & 1 & & & & \\
\hline 3L A, \# data & \begin{tabular}{cccccccc}
0 & 1 & 0 & 0 & 0 & 0 & 1 & 1 \\
\(d 7\) & \(d 6\) & \(d 5\) & \(d 4\) & \(d 3\) & \(d 2\) & \(d 1\) & \(d 0\)
\end{tabular} & \((\mathrm{A}) \leftarrow(\mathrm{A})\) OR data & Logical OR the specified immediate data with the Accumulator (8-bit operation) & 2 & 2 & & & & \\
\hline 3L PORT, \# data & \begin{tabular}{cccccccc}
0 & 1 & 1 & 0 & 0 & 0 & 1 & 1 \\
\(d 7\) & \(d 6\) & \(d 5\) & \(d 4\) & \(d 3\) & \(d 2\) & \(d 1\) & \(d 0\)
\end{tabular} & \[
(P) \leftarrow(P) \text { OR data }
\] & Logical OR immediate specified data with output port & 2 & 2 & & & & \\
\hline JT PORT & \(1 \begin{array}{llllllll}1 & 1 & 0 & 0 & 0 & 0 & 0 & 1\end{array}\) & \((P) \leftarrow(A)\) & Output the contents of the Accumulator to the I/O Port (8-bit transfer) & 2 & 1 & & & & \\
\hline UT XMTR & \(1 \begin{array}{llllllll}1 & 1 & 0 & 0 & 0 & 0 & 0 & 0\end{array}\) & \((\) XMTR \() \leftarrow(A)\) & Copy the contents of the Accumulator into the UART Transmit Buffer (8-bit transfer). Also clears Transmit Buffer empty interrupt & 1 & 1 & & & & \\
\hline ET & \(1 \begin{array}{llllllll}1 & 0 & 0 & 0 & 0 & 0 & 1 & 1\end{array}\) & \[
\begin{aligned}
& (\mathrm{SP}) \leftarrow(\mathrm{SP})-1 \\
& (\mathrm{PCO}-12) \leftarrow((\mathrm{SP}))
\end{aligned}
\] & Return from subroutine without restoring Program Status Word bits 5-7 & 2 & 1 & & & & \\
\hline ETR & \(1 \begin{array}{llllllll}1 & 0 & 0 & 1 & 0 & 0 & 1 & 1\end{array}\) & \[
\begin{aligned}
& (\mathrm{SP}) \leftarrow(\mathrm{SP})-1 \\
& (\mathrm{PCO}-12) \leftarrow((\mathrm{SP})) \\
& (\mathrm{PSW} 3-7) \leftarrow((\mathrm{SP}))
\end{aligned}
\] & \begin{tabular}{l}
Return from \\
Subroutine restoring Program Status Word (use for all returns from interrupts)
\end{tabular} & 2 & 1 & * & * & & \\
\hline LA & \(\begin{array}{llllllllll}1 & 1 & 1 & 0 & 0 & 1 & 1 & 1\end{array}\) & \[
\begin{aligned}
& \left(A_{n}+1\right) \leftarrow(A n) \\
& \text { for } n=0-6 \\
& (A O) \leftarrow(A 7)
\end{aligned}
\] & Rotate Accumulator left by 1 bit without carry & 1 & 1 & & & & \\
\hline LCA & \(1 \begin{array}{llllllll}1 & 1 & 1 & 0 & 1 & 1 & 1\end{array}\) & \[
\begin{aligned}
& \left(A_{n}+1\right) \leftarrow(A n) \text { for } \\
& n=0-6 \\
& (A 0) \leftarrow(C) \\
& (C) \leftarrow(A 7)
\end{aligned}
\] & Rotate Accumulator left by 1 bit through carry & 1 & 1 & * & & & \\
\hline
\end{tabular}

Instruction Set (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Mnemonic} & \multirow[t]{2}{*}{Machine Code} & \multirow[t]{2}{*}{Function} & \multirow[t]{2}{*}{Description} & \multirow[t]{2}{*}{Cycles} & \multirow[t]{2}{*}{Bytes} & \multicolumn{4}{|c|}{Flags} \\
\hline & & & & & & C & AC & HACC & FI \\
\hline RR A & \(\begin{array}{llllllll}0 & 1 & 1 & 1 & 0 & 1 & 1 & 1\end{array}\) & \[
\begin{aligned}
& (\mathrm{An}) \leftarrow A_{n}+1 \\
& \text { for } n=0-6
\end{aligned}
\] & Rotate Accumulator right by 1 bit without carry & 1 & 1 & & & & \\
\hline RRC A & \(\begin{array}{llllllll}0 & 1 & 1 & 0 & 0 & 1 & 1 & 1\end{array}\) & \[
\begin{aligned}
& (\mathrm{An}) \leftarrow A_{n}+1 \\
& \text { for } n=0-6 \\
& (\mathrm{~A} 7) \leftarrow(\mathrm{C}) \\
& (\mathrm{C}) \leftarrow(\mathrm{AO})
\end{aligned}
\] & Rotate Accumulator right by 1 bit through carry & 1 & 1 & * & & & \\
\hline SEL MBO & \(1 \begin{array}{llllllll}1 & 1 & 0 & 0 & 0 & 1 & 0 & 1\end{array}\) & \((\mathrm{DBF}) \leftarrow 00\) & Select Bank 0 (0-2047) of Program Memory & 1 & 1 & & & & \\
\hline SEL MB1 & \(\begin{array}{llllllll}1 & 1 & 0 & 1 & 0 & 1 & 0 & 1\end{array}\) & \((\mathrm{DBF}) \leftarrow 01\) & Select Bank 1 (2048-4095) of Program Memory & 1 & 1 & & & & \\
\hline SEL MB2 & \(\begin{array}{llllllll}1 & 1 & 1 & 0 & 0 & 1 & 0 & 1\end{array}\) & \((\mathrm{DBF}) \leftarrow 10\) & Select Bank 2 (4096-6143) of Program Memory & 1 & 1 & & & & \\
\hline SEL MB3 & \(\begin{array}{llllllll}1 & 1 & 1 & 1 & 0 & 1 & 0 & 1\end{array}\) & \((\mathrm{DBF}) \leftarrow 11\) & Select Bank 3 (6144-8191) of Program Memory & 1 & 1 & & & & \\
\hline SEL RBn & \(1 \begin{array}{llllllll} & 1 & n & 0 & 0 & 0 & 1 & 1\end{array}\) & \[
\begin{aligned}
& \text { (BS) } \leftarrow n \\
& \text { for } n=0-1
\end{aligned}
\] & Select Data RAM Bank (0-7) or 1 (24-31) & 1 & 1 & & & & \\
\hline STOP T & \begin{tabular}{llllllll}
0 & 1 & 1 & 0 & 0 & 1 & 0 & 1 \\
\hline
\end{tabular} & & Stop Timer & 1 & 1 & & & & \\
\hline STRT T & \begin{tabular}{llllllll}
0 & 1 & 1 & 1 & 0 & 1 & 0 & 1 \\
\hline
\end{tabular} & & Start Timer & 1 & 1 & & & & \\
\hline SWAP A & \(\begin{array}{llllllll}0 & 1 & 0 & 0 & 0 & 1 & 1 & 1\end{array}\) & \((A 4-A 7) \longleftrightarrow(A 0-A 3)\) & SWAP 4 bit nibbles in Accumulator & 1 & 1 & & & & \\
\hline XCH A, Rr & \begin{tabular}{lllllllll|}
0 & 0 & 1 & 0 & 1 & \(r\) & \(r\) &
\end{tabular} & \[
\begin{aligned}
& \text { (A) } \longleftrightarrow(\mathrm{Rr}) \\
& \text { for } r=0-7
\end{aligned}
\] & Exchange the Accumulator and contents of designated register (8-bit transfer) & 1 & 1 & & & & \\
\hline XCH A, @ Rr & \(0 \begin{array}{llllllll} \\ 0 & 0 & 1 & 0 & 0 & 0 & 0 & \mathrm{r}\end{array}\) & \[
\begin{aligned}
& (A) \longleftrightarrow((\operatorname{Rr})) \\
& \text { for } r=0-1
\end{aligned}
\] & Exchange indirect the contents of the Accumulator and the data memory location pointed to by \(\operatorname{Rr}\) (8-bit transfer) & 1 & 1 & & & & \\
\hline XCHD A, @ Rr & \(0 \begin{array}{llllllll} & 0 & 1 & 1 & 0 & 0 & 0 & \mathrm{r}\end{array}\) & \[
\begin{aligned}
& (\mathrm{AO}-3) \longleftrightarrow \\
& \text { for } \mathrm{r}=0-1
\end{aligned}
\] & Exchange indirect the low 4 bits of the Accumulator and the data memory location pointed to by \(\operatorname{Rr}\) (4-bit transfer) & 1 & 1 & & & & \\
\hline XRL A, Rr & \(\begin{array}{llllllll}1 & 1 & 0 & 1 & 1 & r & r & r\end{array}\) & \[
\begin{aligned}
& (\mathrm{A}) \leftarrow(\mathrm{A}) \text { XOR }(\mathrm{Rr}) \\
& \text { for } r=0-7
\end{aligned}
\] & Logical XOR contents of designated register with Accumulator (8-bit transfer) & 1 & 1 & & & & \\
\hline XRL A, @ Rr & \(\begin{array}{llllllll}1 & 1 & 0 & 1 & 0 & 0 & 0 & r\end{array}\) & \[
\begin{aligned}
& (\mathrm{A}) \leftarrow(\mathrm{A}) \text { XOR }((\mathrm{Rr})) \\
& \text { for } r=0-1
\end{aligned}
\] & Logical XOR indirect the contents of the data memory location pointed to by Rr with the Accumulator & 1 & 1 & & & & \\
\hline XRL A, \# data & \(\left|\begin{array}{cccccccc}1 & 1 & 0 & 1 & 0 & 0 & 1 & 1 \\ d 7 & d 6 & d 5 & d & d 3 & d 2 & d 1 & d 0\end{array}\right|\) & \[
(A) \leftarrow(A) \text { XOR data }
\] & Logical XOR the immediate specified data with the Accumulator & 2 & 2 & & & & \\
\hline
\end{tabular}


\section*{Ordering Information}

ORDER PART NUMBERS
\begin{tabular}{|l|l|l|}
\hline ROMless & \begin{tabular}{l} 
NS405-A12N \\
\\
\\
\end{tabular} \begin{tabular}{l} 
NS405-B12N \\
NS405-C12N
\end{tabular} & NS405-B18N \\
\hline
\end{tabular}

\section*{Throughput Considerations In NS405 System Planning}

The intricate timing relationships inherent in video generation require that a designer have a firm grasp of the fundamentals of NS405 operation in order to achieve his design objectives. Towards this end the key facets of NS405 operation will be examined and examples given.
The NS405 is a complete video controller that reads in video data, processes it and outputs it to a CRT. Given this, one may derive all essential operating parameters from the following two statements:
1. You must be able to read in video data faster than you output it.
2. Video data accesses are based on the CPU cycle which in turn is based on the crystal or dot clock.
Application of these two statements immediately leads to a limitation on the character cell width as follows:
if \(f=\) crystal frequency or dot clock
then \((f \div 1) \div 15\) or \((f \div 1.5) \div 15=\) CPU Instruction Execution Clock Frequency
Since there are three video data accesses each CPU Instruction Execution cycle, there are \(3^{*}(f \div 1) \div 15\) or \(3^{*}\) \((f \div 1.5) \div 15\) video data accesses per second.
if \(w=\) dot width of character cell then \(f \div w=\) number of character cells being displayed per second.
Statement 1 says that video data accesses \(/ \mathrm{sec} \geq\) display characters/sec
\[
\begin{array}{cc}
\text { for CPU Clock } \div 1 & \text { for CPU Clock } \div 1.5 \\
3^{*}(f \div 1) \div 15 \geq f \div w & 3^{*}(f \div 1.5) \div 15 \geq f \div w \\
f \div 5 \geq f \div w & \left(3^{*} f\right) \div 22.5 \geq f \div w \\
1 / 5 \geq 1 / w & 3 / 22.5 \geq 1 / w \\
w \geq 5 & w \geq 7.5
\end{array}
\]

So depending on the CPU clock divide factor ( \(\div 1\) or \(\div 1.5\) ) the character cell width must be a minimum as shown.
Cell width also impacts CPU throughput since both the CPU and Video controller vie for video memory access through the DMA controller. The rules of access are simple and straightforward. The Video Controller gets as many of the accesses as it needs with the CPU getting any left over. The maximum access rate as already shown is \(f \div 5\) or \(f \div 7.5\) depending on the CPU clock divide. If the CPU attempts a video memory access when things are very busy it will be put into a wait state and remain frozen until things clear up. Of course, no display characters are necessary when the display is blanked, so during the horizontal and vertical retrace periods the CPU has unlimited access to video memory.
Normally, the CPU doesn't have to wait until horizontal retrace to get into video memory, but exactly how often it can get in during a display line requires analysis of the worst case video requirements.
Since the results can vary dramatically depending on the parameters chosen, two typical cases will be presented.
I. With a dot clock of 18 MHz the display line consists of 80 character cells, 9 dots across. Since the CPU clock divide must be 1.5 the video memory access rate is 18 \(\mathrm{MHz} \div 7.5=2.4 \mathrm{MHz}\).

National Semiconductor Corp. Application Brief 14 James Murashige

To display one line requires \((9 \times 80) / 18 \mathrm{MHz}=40\) us. In one line time there are \(2.4 \mathrm{MHz} \times 40\) us \(=96\) video memory accesses. Of the 96,80 are required for the characters displayed in the line leaving 16 available for the CPU. This is an average of one every six video memory accesses or once every two CPU instruction cycles. This would be fine since all CPU video memory instructions require two instruction cycles to execute anyway. However, in addition to the DMA controller the video circuits also employ a four level FIFO to insure a smooth data flow. The FIFO is normally kept full at four in which case it stops accessing video data and allows the CPU to have all the accesses. However, the FIFO can drop down quite far before starting to fill up again by taking all of the video memory accesses. The net effect is that instead of being evenly distributed, the accesses available to the CPU are clumped together with long gaps between clumps. Taking the worst case condition of the FIFO being completely empty and having to fill to four by taking the accesses which the CPU could have gotten, the longest gap is \((4 \times 6)+5=29\) accesses \(\approx 10\) CPU instruction cycles. Generally speaking this tends to happen towards the middle of a line since the FIFO is filled prior to the start of a line and tries to end a line empty. In fact, accesses for video are performed up to the second to the last display character. The FIFO prefetch for the next line is performed shortly after horizontal blanking starts.
II. If the dot clock is now 12 MHz with a display line of 80 character cells 7 dots across the CPU clock divide can be 1.

The video memory access rate is \(12 \mathrm{MHz} \div 5=2.4 \mathrm{MHz}\).
To do one line requires \((7 \times 80) / 12 \mathrm{MHz}=46.7 \mathrm{us}\). In one line time there are \(2.4 \mathrm{MHz} \times 46.7\) us \(=112\) video memory accesses. Of the 112, 32 are now available to the CPU. This averages out to one every 3.5. Figuring the FIFO in, the worst case wait for the CPU becomes \((4 \times 3.5)+2.5=16.5\) accesses \(\approx 6 \mathrm{CPU}\) instruction cycles. A significant improvement over the first example.
In general, to maximize CPU access to video memory one must maximize the average number of "free" accesses during the display time. The number of free accesses as a fraction of the total number available is:
\[
\begin{aligned}
(w-5 d) / w \quad \text { Where } w & =\text { character cell dot width } \\
d & =\text { CPU divide factor of } 1 \text { or } 1.5
\end{aligned}
\]

As can be seen, throughput performance depends entirely on the cell width and CPU clock divide. To maximize performance one would try to choose a large \(w\) and a d of 1.
Applying the delay imposed by the four level FIFO, the maximum CPU delay in accessing video memory becomes=
\[
(4 w+5 d) /(w-5 d) \quad \text { Memory cycles }
\]

\section*{NS405-Series TMP External Interrupt Processing}

The TMP External Interrupt (INTR) is a level sampled interrupt input. Specifically this means that the input is sampled once each CPU cycle with interrupts being generated as long as the sampled input is a logic low. INTR shares pin 37 with RE10 and is sampled on each ALE rising edge as shown in the data sheet. If a logic low level is detected, interrupt service will commence if interrupts had been previously enabled with an EN XI instruction. Service consists of finishing up the currently executing instruction, pushing the PC and other pertinent information onto the stack, disabling all interrupts while in service and finally performing a JUMP to location 003 . Upon completion of service a RETR would be executed to pop the stack and return to where we left off in the main program.
The exact timing involved may be observed through the example program of Figure 1 and its instruction execution sequence in Figure 2. In Figure 2 the numbers shown on the falling ALE edges are the program addresses put out by the TMP. As written the program will loop endlessly unless diverted by an external interrupt such as point A in Figure 2. Since it just missed the previous rising ALE edge it will not be until point \(B\) that the logic low INTR is read in. However, by then the CPU will have started execution of the first byte of the JMP 11 instruction. Since instructions are always finished once started, it will not be until point \(C\) that we begin interrupt service. At this point the next address would have been back at 11 but we now want to service the interrupt and push the stack. Stack pushing or popping takes 2 CPU

National Semiconductor Corp. Application Brief 16 James Murashige

cycles so the two address 11 's shown following point \(C\) are dummies. Finally, we start interrupt service at point \(D\) by outputting address 003 and reading in the IN PORT instruction. Since the \(\operatorname{IN}\) PORT instruction is only 1 byte long but takes 2 CPU cycles to execute, the address " 4 " at point \(E\) is a dummy and isn't really needed until point \(F\) when we read in the RETR instruction. Like IN PORT, RETR is a 1 byte instruction that takes 2 CPU cycles to execute. Therefore, the address " 5 " at point \(G\) is redundant. Upon returning from subroutine we immediately push the stack again (point \(\mathrm{H})\) since the interrupt is still there. Note that we immediately push the stack and do not execute the JMP at 11. Once more we go through the interrupt service routine but this time the interrupt ends at point I. Since it missed the preceding rising ALE edge where it was still seen as a logic low, we will immediately execute another interrupt service routine as shown. Finally, at point \(J\) as we prepare to return from service, INTR will be seen as a logic high and from point \(K\) onward execution will proceed normally.
When enabling and disabling interrupts, the rules for when you will and will not service them are predicated on the latest sampled interrupt level and last instruction executed. This is illustrated by the example program of Figure 3 and instruction execution sequences of Figure 4. As shown in Figure 4a, the interrupt goes low at point \(A\) and will be sampled at the rising ALE of point \(B\). However, since the current executing instruction (DIS XI at location 13) must be completed before starting interrupt service, the interrupt will be


FIGURE 1. INTR Service Timing Example Program


TL/DD/6972-1
FIGURE 2. INTR Service Timing
locked out. Execution continues unperturbed until the interrupt is re-enabled with an EN XI from location 11, point F. Although the interrupt went logic high at point E it was still sampled as a logic low at point \(D\).
Therefore, after executing the EN XI at location 11, interrupt service will commence as shown. If the interrupt had gone logic high before point \(D\) it would have been sampled high and no interrupt service would have been performed.

Returning to the missed interrupt at point \(A\), if the interrupt low had come in time to be sampled at point G , the instruction at 12 would have been the last one executed before interrupt service started as demonstrated in Figure \(4 b\).
Although describing the external interrupt, all of the service sequences presented may be directly applied to TMP internal interrupts.
\begin{tabular}{|c|c|c|c|}
\hline ADDRESS & OPCODE & unemonic & \\
\hline 000 & 04 & JMP 010 & :RESET VECTOR \\
\hline 001 & 10 & & \\
\hline 002 & & & \\
\hline 003 & 00 & Nop & ;EXTERNAL INTERRUPT VECTOR \\
\hline 004 & 93 & RETR & \\
\hline 005 & & & \\
\hline 008 & & & \\
\hline 007 & & & \\
\hline 008 & & & \\
\hline 009 & & & \\
\hline 00a & & & \\
\hline OOB & & & \\
\hline 00 C & & & \\
\hline OOD & & & \\
\hline 008 & & & \\
\hline 007 & & & \\
\hline 010 & 00 & NOP & ;MAIN PROGRAM \\
\hline 011 & 05 & EN XI & \\
\hline 012 & 00 & NOP & \\
\hline 013 & 15 & DIS XI & \\
\hline 014 & 04 & JMP 010 & \\
\hline 015 & 10 & & \\
\hline 016 & & & \\
\hline
\end{tabular}

FIGURE 3. INTR Enable/Disable Timing Example Program


FIGURE 4b

\section*{TMP Row and Attribute Table Lookup Operation}

This note describes in detail the operation of the TMP Attribute Demo Program - TAD. Although a short program, it nicely demonstrates row table lookup operation in the TMP while at the same time putting out a visual display of the various video attributes available in the chip. While this display management approach is much more involved than normal sequential lookup mode, it is necessary when attemping to do fast screen updates or line editing with the TMP.

The hardware environment for which the program was written is the TMP Demo board. Appropriate references to and descriptions of the hardware will be made as necessary. For those who have not seen it, the net function of the program is to put up and manage a single frame of video data. In the top half of the display the same message is repeated 5 times but each time with a different set of attributes. In the lower half of the display are 4 rows representing the 128 possible block graphics patterns. All of the attribute effects displayed are achieved by updating the internal ALO attribute latch at the end of each display row. At the same time a message table lookup is performed in order to obtain the appropriate character string that will work with the new attribute set selected.
The flowchart for the program is shown in Figure 1. As you can see, the program essentially consists of initialization and waiting for and servicing video interrupts to manage the screen display. Initialization starts at BEGIN with the Vertica! Interrupt Register and Timing Chain being loaded first. The Vertical interrupt is used for end of frame synchronization

National Semiconductor Corp.
Application Note 354
James Murashige

and is set to activate after the 27th row. The Timing Chain is loaded as follows:
\begin{tabular}{lrr} 
TCP 0 Horizontal Length & \(=104\) \\
1 Characters/Row & \(=\) & 80 \\
2 Horizontal Sync Begin & \(=\) & 84 \\
3 Horizontal Sync End & \(=\) & 100 \\
4 Character Height & \(=\) & 10 \\
Extra Scans/Frame & \(=\) & 2 \\
5 Vertical Length & \(=\) & 27 \\
6 Vertical Blank & \(=\) & 25 \\
7 Vertical Sync Begin/End & \(=\) & 7,3 \\
8 Status Row Begin & \(=31\) \\
9 Blink Rate/D.C. & \(=\mathrm{F} 4 \mathrm{H}\) \\
10 Graphics Column Register & \(=30 \mathrm{H}\) \\
11 Graphics Row Register & \(=36 \mathrm{H}\) \\
12 Underline Size Register & \(=89 \mathrm{H}\) \\
13 Cursor Size Register & \(=09 \mathrm{H}\)
\end{tabular}

Given these values, one can ascertain that the display is 80 columns across and 25 rows tall. The character cell height is 10 scan lines and no status line will be displayed. The character underline is the bottom most scan line in a cell and the cursor occupies an entire cell. The partitioning of the block graphics cells is as follows:
0011100
0011100
0011100
2233344
2233344
5566555
5566655
5566655
5566555

TAD Flowchart


TL/C/5729-1

FIGURE 1

Following timing chain initialization various system registers are set to configure the chip to operate in its hardware environment. The video memory is a \(2 k X 8\) NMC2116 located vetween addresses \(000-7 \mathrm{FF}\). The crystal dot clock is 12 Mhz allowing us to use divide by 1 to generate the CPU slock. Accordingly the SCR is set to 24 H (SB8-15 address output only, cell width \(=7\), divide by 1 for CPU clock, row table lookup operation). RAM Bank 0 is selected and HOME, BEGD, RA/RO are cleared. ENDD and CURS are set to 7FFFH and AL1 is set to FFH (no attributes selected). Video display memory ( \(80 \times 25\) char) is then cleared out by storing spaces at all of the memory locations. Along with the spaces, attribute latch 1 is specified to be used. Video is then turned on by setting the VCR to 21 H (normal alphanumeric display, internal attribute latch operation, normal video).
Next, the message tables are built up in the video memory. By updating the attribute latch ALO each row, the entire screen display can be constructed from the 7 message rows stored in memory. Each of the message rows consist of 80 consecutive characters and are called up for display by loading the HOME register with the address of the first character in the row. The background characters in each of the rows are the spaces previously stored. Each of the display characters stored use attribute latch ALO which is updated each row. The first row (0-79) consists entirely of spaces to provide us with a blank display row. The second row (80159) has the message "tmp does it BETTER!" for normal and double high display. The third row (160-239) contains "ttmmpp ddooeess iitt BBEETTTTEERR!!" for double wide and double size display. Rows 4-7 contain 32 block graphics characters per row for a total of 128 patterns. The 128 characters stored are merely all binary combinations of the low 7 data bits in ascending order. The 32 characters in each row are stored in every other memory location to achieve a blank space between characters. For all of the message rows, data is positioned to give a centered display on the screen.
With initialization accomplished, we set the interrupt mask, re-enable interrupts and wait for a video interrupt.
Video display management is performed by the internal interrupt service routine located at 007 and consists of updating the HOME register and ALO at the end of each display row. To accomplish this, a row counter (R3) is used as a pointer into the data lookup tables which follow the interrupt service routine. The R3 row counter is incremented on each End of Row interrupt or preset and incremented on a resynching Vertical Interrupt.
Because the next row pointers are pipelined in the video memory controller, an understanding of End of Row and Vertical Interrupt operation is necessary in order to correctly set up the interrupt service routine and lookup tables. In table lookup mode, the Current Row Start Register (CRSR), which is a pointer to the first character address in a row, is automatically reloaded from the HOME register after the display of the last scan line in a row, a few characters into horizontal blanking. The timing of the CRSR reload when operating in sequential lookup mode is the same but in this case the pointer is advanced by the character width of the display row. It is the reloading of CRSR either in sequential or table lookup modes that generates the End of Row interrupt. The duration of the signal is \(1 / 3\) CPU cycle making it a one time event each row. The End of Row interrupt register bit is cleared when a reload of HOME, i.e., MOV HOME, \(A\) is
executed. A simple example will illustrate the pipelining involved. In Figure 2, at the end of Row 1 (Point A) an EOR interrupt is generated. In preparation for this event HOME should have been loaded with the starting address of ROW 2 since the interrupt is generated when CRSR reloads from HOME. In service of the EOR, the program would load HOME with the starting address of ROW 3 in preparation for the EOR interrupt at Point B. However, notice that we have an entire row time from \(A\) to \(B\) to do the HOME reload. Finally note that EOR's are generated at the end of all rows except those blanked during vertical blanking. Vertical Interrupt operates with the same timing as End of Row except that it is specified to occur at the end of a particular row designated by the Vertical Interrupt Register. The row that it is specified to occur on must be \(<=\) Vertical Length Register (timing chain rows are counted starting from 0 ). Otherwise, it will never occur since the row counter will never count up that far. Usually Vertical Interrupt is specified to occur on a row blanked during vertical blanking so that it may be used as a frame sync signal.
Returning to TAD, Figure 3 shows the interrupt positioning for all of the rows on the screen including the blanked ones. There are 25 displayed rows and 2 blanked ones in a frame for a total of 27 . In addition, there are 2 extra scan lines which may be ignored as far as interrupt operation is concerned. Vertical Interrupt is set to occur at the end of the last row in the frame as shown. Row pointer operation for rows 2 to 24 is pipelined as described in Figure 2. At the end of ROW 24 (point E) the CRSR will be loading the pointer to ROW 25 and the interrupt service will load HOME with the pointer to ROW 1. At the end of ROW 25 (point F) the CRSR will load the pointer to ROW 1 and save it for the next frame. Since no EOR's are generated during vertical blanking, CRSR will remain static until ROW 1. At this point, it doesn't matter what the interrupt service loads into HOME and ALO since the Vertical Interrupt at ROW 27 will reset the row counter and perform a new lookup for HOME and ALO. A Vertical Interrupt will not do a CRSR load, thus the pointer to ROW 1 will be preserved. At Vertical Interrupt, the row counter will be reset to 0 and we will want to do a pointer lookup for ROW 2 in preparation for the CRSR load at the end of ROW 1 (point A). Correspondingly, the row pointer lookup tables are organized 2 to 25,1 . Since the attribute latches aren't pipelined, the ALO lookup table is arranged 1 to 25 since the new attribute set will be needed immediately for the display of the next row.

\section*{Row Table Lookup Pipelining}


TL/C/5729-2 FIGURE 2

TAD Interrupt Positioning


FIGURE 3

\section*{TMP Attribute Demo Program}


```

TMP Attribute Demo Program (Continued)

```

109
110
111
112
113004 FFF
1140050 FF
1150051 FF
1160052 FF
1170053 EF
1180054 FF
1190055 F7
1200056 B7
1210057 FF
1220058 E7
1230059 A7
124 005A FF
125 005B E2
126 005C 82
127 005D FF
128 005E FF
129 005F 7F
1300060 FF
13100617 F
1320062 FF
13300637 F
1340064 FF
13500657 F
1360066 FF
1370067 FF
138
139
140
141
142006815
143006935
144 006A 65
145 006B 231A
146 006D A2
147 006E 27
148 006F 87
14900702367
1500072 B7
1510073 234F
1520075 B7
15300762353
1540078 B7
15500792363
156 007B B7
157 007C 2391
158 007E B7
159007 F 231 A
1600081 B7
16100822318
1620084 B7
16300852362
1640087 B7
1650088 231E
166 008A B7
167 008B 23F4
168 008D B7
169 008E 2330
1700090 B7
17100912336
1720093 B7
17300942389
. FORM
;ATTRIBUTE LATCH 0 LOOKUP TABLE
ATTO: .BYTE OFF ;ROW 1
.BYTE OFF :ROW 2
.BYTE OFF :ROW 3
.BYTE OFF :ROW 4
-BYTE OEF :ROW 5
.BYTE OFF :ROW 6
. BYTE OF7 :ROW 7
-BYTE OB7 :ROW 8
. BYTE OFF :ROW 9
.BYTE OE7 :ROW 10
.BYTE OA7 :ROW 11
.BYTE OFF :ROW 12
.BYTE OE2 :ROW 13
.BYTE 082 :ROW 14
.BYTE OFF :ROW 15
.BYTE OFF :ROW 16
.BYTE 07F :ROW 17
.BYTE OFF :ROW 18
.BYTE 07F :ROW 19
.BYTE OFF :ROW 20
.BYTE 07F :ROW 21
-BYTE OFF :ROW 22
.BYTE 07F :ROW 23
.BYTE OFF :ROW 24
.BYTE OFF :ROW 25
. FORM
;START OF INITIALIZING CODE
BEGIN; DIS XI ;INTERRUPTS OFF FOR NOW DIS II
STOP T
MOV A, \#26
MOV VINT, A
CLR A
MOV TCP, A
MOV A, \#103
MOV @TCP, A
MOV A, \#79
MOV @TCP, A
MOV A, \#83
MOV @TCP, A
MOV A, \#99
MOV @TCP, A
MOV A, \#091
MOV @TCP, A
MOV A, \#26
MOV @TCP, A
MOV A, \# 24
MOV @TCP, A
MOV A, \#062
MOV @TCP, A
MOV A, \#30
MOV @TCP, A
MOV A, \#OF4
MOV @TCP, A
MOV A, \#030
MOV @TCP, A
MOV A, \#036
MOV @TCP, A
MOV A, \#089

;SET UP TIMING CHAIN FOR DEMO BOARD
;HORIZONTAL LENGTH
;CHARACTERS/ROW
;HORIZONTAL SYNC BEGIN
;HORIZONTAL SYNC END
;CHARACTER HEIGHT/EXTRA SCANS
;VERTICAL LENGTH
;VERTICAL BLANK
;VERTICAL SYNC BEGIN/END
;STATUS ROW BEGIN
;BLINK RATE
;GRAPHICS COLUMN REGISTER
;GRAPHICS ROW REGISTER
;UNDERLINE SIZE REGISTER

「MP Attribute Demo Program (Continued)
\begin{tabular}{|c|c|c|c|c|}
\hline 74 & 0096 B7 & & MOV @TCP, A & \\
\hline 75 & 00972309 & & MOV A, \#009 & ;CURSOR SIZE REGISTER \\
\hline . 76 & 0099 B7 & & MOV @TCP, A & \\
\hline \multicolumn{5}{|l|}{. 77} \\
\hline \multicolumn{5}{|l|}{78} \\
\hline 79 & & . FORM & & \\
\hline 80 & 009A 2324 & & MOV A, \#024 & ;SET SYSTEM CONTROL REGISTER \\
\hline 81 & 009C 55 & & MOV SCR, A & ;8 BI,7 DOTS, DIVIDE 1, TABLE LOOKUP \\
\hline \multicolumn{5}{|l|}{82} \\
\hline 83 & 009D C3 & & SEL RBO & ;SELECT RAM BANK 0 \\
\hline 84 & 009E 27 & & CLR A & ;SET RAM POINTERS \\
\hline 85 & 009F C2 & & MOV HACC, A & \\
\hline 86 & 00A0 8A & & MOV HOME, A & \\
\hline 87 & OOAl OD & & MOV BEGD, A & \\
\hline 88 & 00A2 88 & & MOVL RO, A & ;CLEAR MEMORY POINTER \\
\hline \multicolumn{5}{|l|}{89} \\
\hline 90 & 00A3 237F & & MOV A, \#07F & \\
\hline 91 & 00A5 C2 & & MOV HACC, A & \\
\hline 92 & 00A6 23FF & & MOV A, \#OFF & \\
\hline . 93 & 00A8 OC & & MOV ENDD, A & \\
\hline 94 & 00A9 8B & & MOV CURS, A & \\
\hline . 95 & OOAA 3D & & MOV ALl, A & ;NO ATTRIBUTES FOR LATCH 1 \\
\hline \multicolumn{5}{|l|}{. 96} \\
\hline . 97 & & ;CLEAR & OUT MEMORY & \\
\hline \multicolumn{5}{|l|}{. 98} \\
\hline . 99 & 00AB BD19 & & MOV R5, \#25 & ;DO 25 ROWS \\
\hline :00 & 00Ad baso & & MOV R2, \#80 & ;DO 80 CHARACTERS PER ROW \\
\hline :01 & 00AF 23A0 & & MOV A, \#OAO & ;INITIALIZE FOR A SPACE, ATTRIBUTE LATCH 1 \\
\hline \multicolumn{5}{|l|}{:02} \\
\hline :03 & 00B1 80 & LOOP: & MOVX @RO, A & ;STORE A CHARACTER \\
\hline :04 & 00B2 38 & & INCL RO & ;INCREMENT POINTER \\
\hline :05 & 00B3 EAB1 & & DJNZ R2, LOOP & ;TEST IF ROW DONE \\
\hline :06 & 00B5 BA50 & & MOV R2, \#80 & \\
\hline \(: 07\) & 00B7 EDB1 & & DJNZ R5, LOOP & ;TEST IF SCREEN DONE \\
\hline \multicolumn{5}{|l|}{\(: 08\)} \\
\hline :09 & 00B9 2321 & & MOV A, \#021 & ;SET VCR FOR INTERNAL ATTRIBUTES \\
\hline :10 & 00BB 45 & & MOV VCR, A & :INTERNAL CHARACTER GENERATOR \\
\hline \multicolumn{5}{|l|}{:11} \\
\hline \multicolumn{5}{|l|}{112} \\
\hline 213 & & ;FIRST & LINE ARE ALL BLA & NKS, SECOND LINE HAS SINGLE SPACING MESSAGE \\
\hline 214 & OOBC 2300 & & MOV A, \#H(LINE & +30) ;SET RO POINTER TO FIRST LINE \\
\hline 215 & 00BE C2 & & MOV HACC, A & \\
\hline 216 & O0BF 236E & & MOV A, \#L(LINE & +30) \\
\hline 217 & 00 Cl 88 & & MOVL RO, A & \\
\hline 318 & OOC2 BAEO & & MOV R2, \#L(MSG & ) ;SET R2 TO MESSAGE \#1 \\
\hline 219 & \(00 \mathrm{C4}\) BBl3 & & MOV R3, \#19 & ;SET R3 TO MESSAGE LENGTH \\
\hline 320 & 0006 FA & DISP1: & MOV A, R2 & \\
\hline 221 & 00078 B3 & & MOV A, @A & ;DISPLAY NORMAL MESSAGE \\
\hline 322 & 00C8 80 & & MOVX @RO,A & \\
\hline 323 & 00C9 38 & & INCL RO & \\
\hline 324 & 00CA 1A & & INC R2 & \\
\hline 225 & 00CB EBC6 & & DJNZ R3, DISP1 & \\
\hline 226 & & . FORM & & \\
\hline 227 & & ;THIRD & LINE HAS DOUBLE & WIDE MESSAGE \\
\hline 228 & OOCD 98 & & MOVL A, RO & ;SET RO POINTER \\
\hline 229 & OOCE 0334 & & ADD A, \# (31 + & 21) ;LINES3 + 21 \\
\hline 230 & 00D0 88 & & MOVL RO, A & \\
\hline 231 & OODI BAEO & & MOV R2, \#L(MSG & \\
\hline 232 & 00D3 BB13 & & MOV R3, \#19 & \\
\hline 233 & 00D5 FA & DISP2: & MOV A, R2 & \\
\hline 234 & 00D6 B3 & & MOVP A, @A & ;DISPLAY DOUBLE WIDE \\
\hline 235 & 00D7 80 & & MOVX @RO, A & \\
\hline 236 & 00D8 38 & & INCL RO & \\
\hline 237 & 00D9 80 & & MOVX @RO, A & \\
\hline 238 & 00DA 38 & & INCL RO & \\
\hline
\end{tabular}
```

TMP Attribute Demo Program (continued)
239 OODB 1A
240 OODC EBD5
241 OODE 04F3
242
243 OOEO 74 MSQI: .BYTE 'tmp does it BETTER!'
244
245 :FOURTH LINE STARTS GRAPHICS CHARACTERS DISPLAY
246 OOF3 98 FOURTH: MOVL A, RO
247 00F4 031D
248 00F6 88
249 00F7 BB04
250 00F9 BA20
251 00FB 2300
252 00FD 2400
253
254 0100 . = 0100
255
256 0100 80 BLOOP: MOVX @RO, A ;STORE CHARACTER
2570101 38 INCL RO
258 0102 38
259 0103 17
260 0104 EAOO
261
262 0106 BA2O
263 0108 AC
264 0109 98
265 010A 0310
266 010C 88
267 010D FC
268 010E EBOO
269
270
271 }0110230
272011282
273 0113 25
27401142414
275
ATTO 004F BEGI
BEGIN
00D5
HOMHIG OOLD
IINE2 0050
IINE6 0190
PAU 0ll4 RESET 0000 *
NO ERROR LINES
272 ROM BYTES USED
SOURCE CHECKSUM=CF6O
OBJECT CHECKSUM=0576
INPUT FILE A: TAD. MAC
LISTING FILE A: TAD. PRN
OBJECT FILE A: TAD. LM

```

\section*{TMP - Dynamic RAM Interfacing}

TMPs Interface easily and directly to dynamic RAMs as illustrated in the basic TMP system schematic of Figure 1. In addition to providing the necessary Read/Write cycle control, the TMP will also automatically refresh the memories through the video controller, further easing interface requirements.
The circuitry to the right of the TMP provides program memory interfacing and I/O support while to the left lie the dynamic video RAM circuits. The memory width shown here is 8 bits although 16 bits can easily be accommodated. Using the \(64 \mathrm{~K} \times 1\) dynamic RAMs shown the entire video memory space is filled with RAM. However, by using a slightly modified addressing configuration smaller memroy chips could be substituted.
The requisite dynamic RAM control signals \(\overline{\operatorname{RAS}}, \overline{\mathrm{CAS}}\) and \(\overline{W E}\) are generated directly from the system bus control signals RAM ALE, \(\overline{R A M ~ R D}\) and \(\overline{\text { RAM WR. RAM ALE is used }}\) directly as \(\overline{R A S}\) while \(\overline{R A M ~ W R ~ s e r v e s ~ a s ~} \overline{\text { WE. }} \overline{\text { CAS }}\) is the logical AND of \(\overline{\text { RAM RD }}\) and \(\overline{\text { RAM WR. The }} 16\) system bus bits are multiplexed down to the 8 bit RAM address vector by the two 74LS157's under the control of the RAM ALE. As configured, the row and column addresses strobed in are SBO-7 and SB8-15 respectively.
With the configuration shown, the pertinent TMP Read and Write cycle timing parameters for Figure 2 are listed in Table 1. Going through the table one sees that the TMP easily interfaces to 150 ns access RAMs and will routinely work with 200 ns RAMs. The four parameters which may be a tight squeeze for 200 ns RAMs are:
1. thac - Access Time from \(\overline{\mathrm{RAS}}\) is max 150 ns , typ 220 ns . This is a basic access time requirement which necessitates fast parts.
2. \(\mathrm{t}_{\text {RAH }}\) - Row Address Hold Time is min 10 ns , typ 15 ns . This parameter is entirely dependent on the switching speed of the 74LS157.
3. \(\mathrm{t}_{\mathrm{RCD}}-\overline{\mathrm{RAS}}\) to \(\overline{\mathrm{CAS}}\) Delay Time is \(\min 10 \mathrm{~ns}\), typ 50 ns . This parameter isn't too critical since most dynamic RAMs internally gate the \(\overline{\mathrm{CAS}}\) signal should it come along too early.
4. \(t_{\text {RP }}-\overline{R A S}\) Precharge Time is min 100 ns , typ 135 ns . Since \(\overline{\text { RAS }}\) is actually the RAM ALE signal \(t_{R P}\) is the high time of RAM ALE.
However, rather than getting faster RAMs one could also meet spec by running the TMP CPU slower, thereby stretching out the allowable access time.
Since the TMP video controller will regularly and automatically access video memory in order to obtain characters for display, one may have dynamic RAM refreshing performed automatically by making sure that the required number of consecutive address locations (ROW Addresses) are accessed in the alloted time. Typically this is 128 ROW addresses in 2 ms .
For example, in a typical system we may have an 80 column by 25 row display with each row consisting of 10 scan lines. Each scan line has a period of 60.67 us. The vertical blank

National Semiconductor Corp. Application Note 355
James Murashige

period consists of 25 scan lines for a total duration of 1.52 ms . Assuming sequential rather than table lookup operation, 80 consecutive character addresses are accessed each scan line and a 160 consecutive character addresses are accessed every 2 rows; more than enough to refresh all of the \(\overline{\operatorname{RAS}}\) rows. Of course one must be sure that the memory addresses of any two consecutive rows encompass all 128 possible \(\overline{\mathrm{RAS}}\) addresses. In the middle of the screen the worst case refresh period is 11 scan lines ( .667 ms ), since to do 160 consecutive addresses requires one complete row plus the first scan line of the next row. At the bottom of the screen the refresh period must also include the vertical blank time since no video characters are accessed then. In this case refresh stretches out to a worst case 2.184 ms .
Although in this example we exceeded the 2 ms refresh period, there are a number of things that we could do to get things back into spec. For example, we could cut down on vertical blank time, use memory chips with longer refresh periods, or have the CPU refresh video memory during vertical retrace. Taking the case of using different memory chips, another popular refreshing arrangement is 256 row addresses in 4 ms . In the middle of the screen this gives us a worst case period of \(10+10+10+1\) scan lines or 31 \(\times 60.67\) us \(=1.88 \mathrm{~ms}\). Adding in the vertical blanking period the absolute worst case refresh delay is \(1.88+1.52=\) 3.4 ms . Of course in this arrangement, making sure that any four consecutive rows encompass all 256 RAS addresses is much more difficult.
When operating in pixel mode meeting refresh requirements isn't as difficult since each scan line will access a different set of consecutive RAM addresses.
Returning to the circuit of Figure 1, we have assumed that SB0-7 are multiplexed address/data while SB8-15 output addresses only. Since the RAM addresses are latched in 8 bits at a time there is no need for a separate latch for SB07 since all 8 bits are clocked in on the falling ALE edge. However, when operating with smaller 8 K or 16K RAMs where only 7 bits are clocked in at a time, latching arrangements for SB7 must be made. An example of this is shown in Figure 3 where bits SBO-7 are all latched by the 74LS373.
Normally I/O registers, as well as other memory banks, will also be memory mapped into the 64 K video RAM space. In order to do this some sort of chip enabling scheme must be worked out since the dynamic RAMs have no direct enable control. One possibility is shown in Figure 4 where the RAM bank \(\overline{\mathrm{CAS}}\) and \(\overline{\mathrm{WE}}\) are disabled unless selected by the 74LS138 decoder. In this way the RAM output drivers will remain TRI-STATE \({ }^{\oplus}\) and no data will be written unless the bank is selected. However, memory refreshing as controlled by \(\overline{\mathrm{RAS}}\) will still be performed on each RAM bank.
By expanding on these basic examples a memory configuration for the TMP utilizing dynamic memories may be quickly and easily worked out.

TABLE 1. TMP Dynamic RAM Interface Timing 12 MHz CPU
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units \\
\hline \(t_{\text {AR }}\) & Column Address Hold Time Referenced to \(\overline{\text { RAS }}\) & 250 & 280 & & ns \\
\hline \(t_{\text {ASC }}\) & Column Address Set Up Time-Dependent on Switching of 74LS157 & 25 & 35 & & ns \\
\hline \(t_{\text {ASR }}\) & Row Address Set Up Time & 20 & 90 & & ns \\
\hline \(\mathrm{t}_{\text {CAC }}\) & Access Time from \(\overline{\mathrm{CAS}}\) & & 180 & 140 & ns \\
\hline \(\mathrm{t}_{\text {cah }}\) & Column Address Hold Time & 140 & 250 & & ns \\
\hline \(\mathrm{t}_{\text {CAS }}\) & \(\overline{\text { CAS Pulse Width }}\) & 140 & 160 & & ns \\
\hline \(\mathrm{t}_{\mathrm{CP}}\) & \(\overline{\text { CAS Precharge Time }}\) & 140 & 166 & & ns \\
\hline \(t_{\text {CRP }}\) & \(\overline{\mathrm{CAS}}\) to \(\overline{\mathrm{RAS}}\) Precharge Time & 100 & 136 & & ns \\
\hline \(\mathrm{t}_{\mathrm{CSH}}\) & \(\overline{\mathrm{CAS}}\) Hold Time & 250 & 280 & & ns \\
\hline \({ }_{\text {tewL }}\) & Write Command to CAS Lead Time & 140 & 160 & & ns \\
\hline \(\mathrm{t}_{\mathrm{DH}}\) & Data In Hold Time & 160 & 175 & & ns \\
\hline \(t_{\text {DHR }}\) & Data In Hold Time Referenced to \(\overline{\mathrm{RAS}}\) & 180 & 310 & & ns \\
\hline tos & Data In Set Up Time & 10 & 50 & & ns \\
\hline toff & Output Buffer Turn Off Delay & 0 & & 60 & ns \\
\hline \(t_{\text {RAC }}\) & Access Time from \(\overline{\mathrm{RAS}}\) & & 220 & 150 & ns \\
\hline \(t_{\text {RAH }}\) & Row Address Hold Time-Dependent on Switching of 74LS157 & 10 & 15 & & ns \\
\hline \(t_{\text {RAS }}\) & \(\overline{\text { RAS Pulse Width }}\) & 250 & 280 & & ns \\
\hline \(t_{\text {RC }}\) & Random Read/Write Cycle Time & 416 & & & ns \\
\hline \(t_{\text {RCD }}\) & \(\overline{\mathrm{RAS}}\) to CAS Delay Time & 10 & 50 & & ns \\
\hline \(t_{\text {RCH }}\) & Read Command Hold Time & 100 & 175 & & ns \\
\hline \(t_{\text {RCS }}\) & Read Command Set Up Time & 100 & 175 & & ns \\
\hline \(t_{\text {RP }}\) & \(\overline{\text { RAS Precharge Time }}\) & 100 & 135 & & ns \\
\hline \(t_{\text {RRH }}\) & Read Command Hold Time Referenced to \(\overline{\text { RAS }}\) & 100 & 175 & & ns \\
\hline \(t_{\text {RSH }}\) & \(\overline{\mathrm{RAS}}\) Hold Time & 140 & 160 & & ns \\
\hline \(t_{\text {RWL }}\) & Write Command to \(\overline{\mathrm{RAS}}\) Lead Time & 140 & 150 & & ns \\
\hline \({ }_{\text {twCH }}\) & Write Command Hold Time & 140 & 150 & & ns \\
\hline \(t_{\text {WCR }}\) & Write Command Hold Time Referenced to \(\overline{\mathrm{RAS}}\) & 160 & 275 & & ns \\
\hline twCs & Write Command Set Up Time-Dependent on Delay of 74LS08 & 5 & 11 & & ns \\
\hline \(t_{W P}\) & Write Command Pulse Width & 140 & 150 & & ns \\
\hline
\end{tabular}


Timing Diagrams
Read Cycle Timing Diagram


Write Cycle (Early Write)


FIGURE 2.


FIGURE 3. TMP Address Multlplexing for 16K Dynamic RAMs


TL/C/5732-5
FIGURE 4. Chip Enabling Dynamic RAMs

\section*{TMP External Character Generation}

Built into the TMP video circuitry is the ability to access an external character generator to display custom FONT sets. In addition to the flexibility afforded by user selectable FONTs, by going "external" the number of different character patterns directly addressable is virtually limitless. On the other hand the disadvantages of going external are the additional hardware necessary to control data routing and the general need to use faster memories.
Figure 1 shows a minimum configuration with which to do external character generation. In the TMP, external character generation is selected through Video Control Register bits 6, 7 and is a cross between normal alphanumeric and pixel graphics display modes. Like normal alphanumeric mode the TMP sequences through the video memory address space based upon the screen format specification. But instead of routing the data through the internal character generator, it is treated as pixel data and directly inserted into the video dot stream. In effect what we are doing externally is duplicating the internal character generator ROM. In external mode video attributes are fully operational except for double height and block graphics.
Operation of the circuit shown is straight forward and follows a pipe-line approach. On a video data read the display memory address is output onto the system bus with the 8 low order bits being latched by the 74LS373. On the RAM \(\overline{\mathrm{RD}}\) signal the 2116 display RAM ouputs a data character onto the pipeline bus which is used to address the MM52116 character generator which in turn deposits the required pixel data onto the system bus so that it may be read in. The 2116 determines which character is to be looked up in the 52116 while the 74LS163 tells the character generator which row in the character we wish to look at. The 74LS163 is a counter which is appropriately clocked by the horizontal sync pulse so that we will advance each scan line to point to the next row in the character FONT. At the end of each screen row the counter must be cleared in preparation for the display of a new row. This is the function of the Scan Count Clear signal which is available as a multiplexed output on the RE11 pin. It is a low going signal which pulses for 1 scan line time during the last scan line in a screen ROW. Its timing is shown in Figure 2. Note that since the 74LS163 is a fully synchronous counter the clear input will not be accepted until the very last H-Sync clock pulse in the screen row. Because of the necessity to not clear the counter before all pixel data is brought in, nor to delay clocking lest the Scan Count Clear pulse be missed, the starting H -Sync clock edge must be postioned close to the start of horizontal blanking.
Continuing with the read operation, we see that video RAM is only accessed if SB15 is low, i.e., the lower 32K. Note that the 52116 used here contains 128 characters in a \(5 \times 7\) FONT. Consequently, it has 5 data output lines connected

National Semiconductor Corp. Application Note 367 James Murashige
to the system bus. The other three "dummy" lines shown connected are actually output bits which are always 0 by default, thus giving us blank spaces. There are two reasons why the character bits start on SB1. The first is that since everything brought in is considered pixel data, spaces between characters must be externally inserted. The second is that the video controller always brings in 8 bits even though the cell width can be defined to be 9 or 10 . In these instances the 9th and 10th bits repeat what was encoded into the SBO bit. As a result external characters can practically be at most 7 dots wide although the cells can be up to 8,9 , or 10 dots wide. Cell and/or character heights can be up to 16 lines tall as specified by the Character Scan Height Register.
On a video memory write, data is routed through the 81LS95, onto the pipe-line bus and into the 2116. Writing into the 2116 is controlled by RAM WR as shown. Ordinarily the MSB data bit is used for internal attribute latch selection and could be directly connected to the SB7 line if character cells were specified to at most be 7 dots wide. Otherwise SB7 will be needed for pixel generation as shown in Figure 1, thereby rendering internal attribute latch selection useless. In this case both internal attribute latches would have to be loaded with the same values. As shown here, 7 video RAM data bits are used to address the 128 possible characters in the 52116. If a larger character generator were available, additional data bits could be used to select from a larger character set. Since the TMP features a 16 -bit multiplexed address/data bus, by using all 16 available data bits we could address 65,536 different character patterns!
With the video data pipe-lined as shown, very fast memory circuits are required for external character generation. With a 12 MHz CPU clock, character pixel data must be available within a max of 220 ns (typ. 300ns) after an address goes out. To accomplish this the character generator will typically have to be bipolar and the video RAM fast MOS. However, if faster memories are a problem, access times may be stretched out by slowing down the CPU clock since video RAM cycllng is based on the CPU clock. For instance with a CPU clock of 8 MHz , access time stretches out to 385 ns max, 500 ns typ. If using the divide by 1.5 factor on the crystal to obtain the slower CPU clock, remember that due to system constraints the character cell MUST BE AT LEAST 8 DOTS WIDE. In Figure 1 the 2116 output enable is shown being driven by RAM RD. Although this may seem redundant and will slow things down (why not just leave the output enabled?) it is necessary in order to avoid bus conflict when doing a memory write operation.
By expanding on this basic circuit, numerous options such as external attributes, expanded character sets and dynamic RAM may be added to achieve the desired end system.


\section*{SCAN COUNT CLEAR TIMING}


TL/C/5731-2
* Edge must come before Scan Count Clear goes away but not before the video controller has brought in all necessary display information for the last scan line Edge should not be more than 3 character widths from the beginning of blanking.

\section*{NS405 TMP Logic Analyzer}

\section*{INTRODUCTION}

The NS405 TMP is ideally suited for use in Test and Instrumentation equipment as the system or display controller. To demonstrate this, the following note describes how to turn the NS405 Demo Board into a simple 8 bit Logic State Analyzer. Featured in this system is a data capacity of 156 eight bit words, \(21 \mu \mathrm{~s}\) data acquisition time, keyboard command entry, UP/DOWN rolling scroll and 24 line data display.

\section*{SYSTEM ARCHITECTURE}

All of the necessary resources to build our system are available in a TMP Demo Board system when normally set up as a data terminal. Commands are entered through the attached ASCII encoded keyboard with data being strobed on the external interrupt. Data words are input through the switch configuration register SW2 by strobing the Light Pen interrupt. Video is output to the attached display monitor. The only real difference between our Logic Analyzer and the Data Terminal is the ROM software in U9 running the TMP. An overview of the system is shown in Figure 1.
In order to maximize the available 2 k of video RAM, a display line length of 13 was chosen. This yields 157 lines of display information \((157 \times 13=2041)\), one of which is used to display title information. Thus our display data field consists of 156 lines of information, any 24 of which may be displayed at any given time. On each line is displayed the STEP number, followed by 2 spaces and 8 bits of 1 or 0 information. A typical display pattern is illustrated in Figure 2. By manipulating the pointer registers in the TMP DMA controller, the Title line is made to be stationary while the rest of the screen scrolls. This is accomplished by reversing the roles of the HOME register and Status Section SROW pointer. Specifically HOME points to the last row in memory which holds the title information while the status section is set to start after the display of the first row. Scrolling is accomplished by bumping the SROW pointer up or down 1 line width and checking for end of memory conditions.

National Semiconductor Corp. Application Note 369 James Murashige



TL/DD/6970-2
FIGURE 2. TMP Logic Analyzer Screen Format

\section*{SYSTEM SOFTWARE}

Since the system must rely on external events at several points before proceeding with processing, an interrupt driven approach was taken in structuring the software. A flowchart for the main program is shown in Figure 3. After system initialization there are 2 levels of processing associated with our logic analyzer operation. The first is a wait for an external interrupt signifying a new keyboard command. Referring to the keyboard service routine in Figure 4, the key is first read in and decoded as to function. In our simple system there are only 3 commands:

S or s = Start data acquisition
U or \(\mathrm{u}=\) Scroll display up
I or \(\mathrm{i}=\) Scroll display down


The scrolling functions are easily handled in the service routine by bumping the memory pointers and checking for an end of memory condition. A command to start data acquisition moves us to our second level of processing-the actual acquisition and display of data.
In both the keyboard and data acquisition interrupt service routines, flags F0 and F1 are used to pass system status back and forth from the main program. In this way the main program holds at major points while the service routines accomplish their functions. The data acquisition routine does nothing more than read data in from the SW2 port, store it in video memory and check a loop counter to see whether we have read in enough data. Since the Light Pen interrupt is being used, only high to low transitions will initiate an SW2 read. While very little is being done in data acquisition, it is time consuming because it's done in software. A count of instructions yields a worst case processing
time of \(21 \mu\) s between data strobes. In addition, since the data isn't latched it must remain stable until the actual read occurs. Following data acquisition, the stored data words are disassembled into their ASCII " 1 's" and " 0 's" patterns and the data entires numbered. With data acquistion completed, the program returns to await another keyboard command.

\section*{SUMMARY}

As demonstrated, the NS405 is very effective as a display controller in a video instrumentation system. Certain functions, however, such as data acquisition are better left to dedicated hardware controllers. Nevertheless, the system as presented is still a very useful diagnostic tool. Through small enhancements to the hardware and software, features such as word recognition, number base conversion, wider data words and loop delay may readily be added.


TL/DD/6970-4
FIGURE 4. TMP Demoboard Logic Analyzer Command Input Routine


TL/DD/6970-5
FIGURE 5. TMP Demoboard Logic Analyzer Data Acquisition Routine
-TITLE MAIN,'TMP LOGIC ANALYZER DEMO'
; James Murashige 2/09/84
;This program turns the TMP Demo board into a simple 8 bit logic analyzer.
; Command inputs are entered from the attached ASCII keyboard while data
;acquisition takes place through the switch configuration socket, SW2.
;The DIP switch may have to be unsoldered from the board. Data is strobed
;in with an external clock applied to Light Pen Interrupt on W8A. Each time
; data acqusition is started 156 words of 8 bits each are acquired and displayed.
;Display is in the form of STEP location and the associated 8 bit \(1^{\prime \prime} s\) and 0 's
; pattern.
; Commands are \(S\) = Start data acqusition
; \(\quad U=\) Scroll display up
; \(\quad I=\) Scroll display down
\begin{tabular}{ll} 
LSTLIN \(=\) O7DF & \\
;START OF LAST LINE \\
MEMEND \(=07 E B\) & ;END OF MEMORY \\
STLIN \(=07 E C\) & ;START OF TITLE LINE \\
VON \(=020\) & ;VIDEO ON \\
VOFF \(=000\) & \\
\end{tabular}
. \(=00 \quad\);START AT PROGRAM LOCATION 0
RESET: JMP BEGIN ;VECTOR TO RESET CODE
. \(=03\)
EXI: JMP KEY ;VECTOR TO KEYBOARD COMMAND DECODE
- \(=07\)

0007 8C
000891
41000980
12 000A 98
3 OOOB 6B
4 OOOC 88 5 000D EA11
46
47 000F B5 8001035 49 50001193

51
52
530012 El
540013 53DF
550015 AA
560016 D353
570018 C627
58001 A FA
59 001B D355
60001 D C62B
61 001F FA
620020 D349
630022 C63C
640024 A624
65002693
66
67002795
68002815
6900290424
70
71 002B 99

INI: ;DATA STROBE INTERRUPT SERVICE


TL/DD/6970-6
\begin{tabular}{|c|c|}
\hline & OO2C 030D \\
\hline 73 & 002E 89 \\
\hline 74 & O02F 0314 \\
\hline 75 & 0031 E2 \\
\hline 76 & 0032 03F8 \\
\hline 77 & 0034 E639 \\
\hline 78 & 003627 \\
\hline 79 & 0037 C2 \\
\hline 80 & 003889 \\
\hline 81 & 003999 \\
\hline 82 & 003A OE \\
\hline 83 & 003B 93 \\
\hline 84 & \\
\hline 85 & 003C 99 \\
\hline 86 & 003D 03F3 \\
\hline 87 & 003 FaA \\
\hline 88 & 0040 E2 \\
\hline 89 & 0041 O3FF \\
\hline 90 & 0043 F64D \\
\hline 91 & 00452307 \\
\hline 92 & 0047 C2 \\
\hline 93 & 0048 23DF \\
\hline 94 & 004A 89 \\
\hline 95 & 004B OE \\
\hline 96 & 004C 93 \\
\hline 97 & 004D C2 \\
\hline 98 & 004E FA \\
\hline 99 & 004F 89 \\
\hline 100 & 0050 OE \\
\hline 101 & 005193 \\
\hline 102 & \\
\hline 103 & \\
\hline 104 & \\
\hline 105 & \\
\hline 106 & \(0052 \mathrm{C5}\) \\
\hline 107 & \(0053 \mathrm{C3}\) \\
\hline 108 & 005415 \\
\hline 109 & 005535 \\
\hline 110 & 005665 \\
\hline 111 & 005727 \\
\hline 112 & 005887 \\
\hline 113 & 00592367 \\
\hline 114 & 005B B7 \\
\hline 115 & 005C 230C \\
\hline 116 & 005E B7 \\
\hline 117 & 005F 2353 \\
\hline 118 & 0061 B7 \\
\hline 119 & 00622363 \\
\hline 120 & 0064 B7 \\
\hline 121 & 00652391 \\
\hline 122 & 0067 B7 \\
\hline 123 & 0068 231A \\
\hline 124 & 006A B7 \\
\hline 125 & 006B 2318 \\
\hline 126 & 006D B7 \\
\hline 127 & 006E 2362 \\
\hline 128 & 0070 B7 \\
\hline 129 & 00712300 \\
\hline 130 & 0073 B7 \\
\hline 131 & 007423 F 4 \\
\hline 132 & 0076 B7 \\
\hline 133 & 00772330 \\
\hline 134 & 0079 в7 \\
\hline 135 & 007A 2336 \\
\hline 136 & 007C B7 \\
\hline 137 & 007D 2389 \\
\hline 138 & 007F B7 \\
\hline 139 & 00802309 \\
\hline 140 & 0082 B7 \\
\hline 141 & \\
\hline 142 & \\
\hline
\end{tabular}
```

ADD A,\#13 ; ADVANCE TO NEXT ROW
MOVL R1,A ;SAVE NEW VALUE
ADD A,\#L(-L(STLIN)) ;CHECK FOR END OF DISPLAY
MOV A,HACC ;SUBTRACT STLIN FROM A
ADD A,\#L(-H(STLIN) - 1) ;CARRY WILL BE SET IF A WAS > OR =
JNC UPTRU ;NEW VALUE OK, LOAD SROW AND RETURN
CLR A ;RESET SROW TO BEGINNING
MOV HACC,A
MOVL R1,A
UPTRU: MOVL A,R1 ;LOAD R1 INTO SROW
MOV SROW,A
RETR
DOWN: MOVL A,R1 ;SCROLL DOWN
ADD A,\#-13 ;SUBTRACT TO NEXT ROW
MOV R2,A ;TEMP SAVE OF LOW ORDER
MOV A,HACC ;NOW DO UPPER HALF
ADD A,\#OFF ;CARRY WILL BE SET IF A WAS 12 OR MORE
JC DNTRU ;NEW VALUE OK, LOAD VALUE INTO SROW
MOV A,\#H(LSTLIN) ;RESET SROW TO LAST ROW
MOV HACC,A
MOV A, \#L(LSTLIN)
MOVL R1,A
MOV SROW,A
RETR
DNTRU: MOV HACC,A
MOV A,R2
MOVL R1,A
MOV SROW,A
RETR
.FORM
;START OF INITIALIZING CODE
bEGIN: SEL MBO
SEL RBO
DIS XI ;INTERRUPTS OFF FOR NOW
DIS II
STOP T ;TIMER OFF
CLR A ;SET UP TIMING CHAIN FOR DEMO BOARD
MOV TCP, A
MOV A, \#103
MOV @TCP, A
MOV A, \#12
MOV ©TCP, A
MOV A, \#83
MOV @TCP, A
MOV A, \#99
MOV @TCP, A
MOV A, \#091
MOV @TCP, A
MOV A, \#26
MOV @TCP, A
mOV A, \#24
MOV GTCP, A
MOV A,\#062
MOV @TCP, A
MOV A, \#OO
MOV @TCP, A
MOV A, \#OF4
MOV @TCP, A
MOV A, \#030
MOV @TCP, A
mOV A, \#O36
MOV @TCP, A
MOV A, \#089
MOV बTCP, A
MOV A, \#009
MOV @TCP,A
;HORIZONTAL LENGTH
;CHARACTERS/ROW
;HORIZONTAL SYNC BEGIN
;HORIZONTAL SYNC END
;CHARACTER HEIGHT/ EXTRA SCANS
;VERTICAL LENGTH
;VERTICAL BLANK
;VERTICAL SYNC BEGIN/END
;STATUS ROW BEGIN
;BLINK RATE
;GRAPHICS COLUMN REGISTER
;GRAPHICS ROW REGISTER
;UNDERLINE SIZE REGISTER
;CURSOR SIZE REGISTER

```

144 145008555 146
147008627
1480087 C2
1490088 OD
1500089 OE
151 008A 88
152008 B 89
153008 C 2307 154 008E C2
155 008F 23EC
1560091 OC
1570092 8A
158009323 FF
1590095 C 2
1600096 8B
1610097 3C
1620098 3D
163009985
164 009A A5
165 009B 2320
166 009D 82
167
168 009E 3456
169
170 OOAO 05
171 OOA1 2400
172
73 00A3 86A3
174
175
176
177
178
179 OOA5 85
180 OOA6 2300
181 00A8 45
182 00A9 3456
183 00AB 27
184 OOAC C2
185 OOAD OE
186 OOAE BA9C
187 OOBO 2305
188 00B2 88
189 OOB3 23 CO
190 00B5 C2
191 O0B6 89
192 OOB7 BBOD
193 00B9 8C 194 OOBA 25 195
196 OOBB 66BB
197
198
199 OOBD A5
200 OOBE BA9C
201 OOCO 27
202006162
20300022305
\(20400 \mathrm{C4} 88\)
\(20500 C 5\) BBO8
206000790
207 00C8 04CB
208 OOCA FC
209 OOCB F7
210 OOCC AC
211 OOCD F6D3
212 OOCF 2330
213 00D1 04D5
. FORM
\begin{tabular}{|c|c|c|}
\hline \multirow[t]{25}{*}{} & MOV A, \#004 & ;SET SYSTEM CONTROL REGISTER \\
\hline & MOV SCR, A & ;8 BI, 7 DOTS, DIVIDE 1, SEQUENTIAL LOOKUP \\
\hline & CLR A ; SET V & VIDEO RAM POINTERS \\
\hline & MOV HACC, A & ; ACCumulator cleared \\
\hline & MOV BEGD, A & \\
\hline & MOV SROW, A & ;SROW WILL BE OUT HOME \\
\hline & MOVL RO, A & ; CLEAR MEMORY POINTER \\
\hline & MOVL R1, A & ; \({ }^{\text {d }}\) IS SROW IMAGE \\
\hline & MOV A, \#H(MEMEND & \\
\hline & MOV HACC, A & \\
\hline & MOV A,\#L(MEMEND & +1) \\
\hline & MOV ENDD, A & ;SET END OF MEMORY POINTER \\
\hline & MOV HOME, A & ;SET POINTER TO TITLE ROW \\
\hline & MOV A, \#OFF & \\
\hline & MOV HACC, A & \\
\hline & MOV CURS, A & ;NO CURSOR \\
\hline & MOV ALO, A & ;NO ATTRIBUTES FOR LATCH 0 \\
\hline & MOV AL1, A & ;NO ATTRIBUTES FOR LATCH 1 \\
\hline & CLR FO ;FO IS & "START" BIT \\
\hline & CLR F1 ;F1 IS & "THROUGH" BIT \\
\hline & MOV A,\#020 & \\
\hline & MOV MASK, A & ;SET INTERRUPT MASK \\
\hline & CALL MEMCLR & ; CLEAR VIDEO MEMORY \\
\hline & EN XI ;REENA & ABLE EXTERNAL INTERRUPTS \\
\hline & JMP LINNUM & ;DISPLAY TITLE INFORMATION \\
\hline KEYIN: & JNFO KEYIN & ; WAIT FOR KEYBOARD INPUT \\
\hline \multicolumn{3}{|l|}{. FORM} \\
\hline \multicolumn{3}{|l|}{;DATA ACQUISITION ROUTINES} \\
\hline \multicolumn{3}{|c|}{CLR FO ; CLEAR START BIT} \\
\hline & MOV A,\#VOFF & ;VIDEO OFF \\
\hline \multicolumn{3}{|c|}{MOV VCR, A} \\
\hline & CALL MEMCLR & ; CLEAR VIDEO MEMORY \\
\hline \multicolumn{3}{|c|}{CLR A} \\
\hline \multicolumn{3}{|c|}{MOV HACC, A} \\
\hline & MOV SROW, A & ;RESET SROW TO BEGINNING \\
\hline & MOV R2, \#156 & ;SET LOOP COUNTER FOR \# WORDS TO READ \\
\hline & MOV A,\#5 & \\
\hline & MOVL RO,A & ;SET MEMORY POINTER TO FIRST DATA DEPOSIT \\
\hline \multicolumn{3}{|c|}{MOV A, HOCO} \\
\hline \multicolumn{3}{|c|}{MOV HACC, A} \\
\hline & MOVL R1, A & ;LOAD R1 WITH ADDRESS OF SWITCH REGISTER \\
\hline & MOV R3,\#13 & ;LOAD R3 WITH POINTER BUMP CONSTANT \\
\hline & MOV A,INTR & ;CLEAR OUT ANY PENDING INTERRUPTS \\
\hline & EN II ;REENA & ABLE LP INTERRUPT \\
\hline DATAIN: & : JNF1 DATAIN & ; WAIT FOR "THROUGH" BIT TO SET \\
\hline \multicolumn{3}{|l|}{; DISASSEMBLE DATA INTO DISPLAY FORMAT} \\
\hline \multicolumn{3}{|c|}{CLR F1 ;RESET "THROUGH"} \\
\hline & MOV R2,\#156 & ;DISASSEMBLE DATA, LOAD WORD COUNTER \\
\hline \multicolumn{3}{|c|}{CLR A} \\
\hline \multicolumn{3}{|c|}{MOV HACC, A} \\
\hline \multicolumn{3}{|c|}{MOV A, \#5} \\
\hline & MOVL RO,A & ;SET MEMORY POINTER TO FIRST DATA DEPOSIT \\
\hline & MOV R3, \#8 & ;DO 8 BITS \\
\hline UNASS: & MOVX A,@RO & ; LOAD IN DATA BYTE \\
\hline \multicolumn{3}{|c|}{JMP DEPST} \\
\hline RETRIV & : MOV A,R4 & ; RETRIEVE CHARACTER \\
\hline DEPST: & RLC A ; ROTA & TE BIT INTO CARRY \\
\hline & MOV R4, A & ; TEMPORARY SAVE \\
\hline \multicolumn{3}{|c|}{JC ONE ;STORE A "1"} \\
\hline & MOV A,\#'O' & ;STORE A "O" \\
\hline \multicolumn{3}{|c|}{JMP CONT} \\
\hline
\end{tabular}

MOV A, \#OO4 ;SET SYSTEM CONTROL REGISTER

CLR A ;SET VIDEO RAM POINTERS
; ACCUMULATOR CLEARED
MOV SROW, A ;SROW WILL BE OUT HOME
MOV RO, A ;CLEAR NEMORY POINTER
MOVL R1, A ; 1 IS SROW IMAGE
MOV HACC, A
MOV A, \#L (MEMEND + 1 )
SET END OF MEMORY POINTER
HOV HOME, A SET POINTER TO TITLE ROW
MOV HACC, A
MOV CURS, A ;NO CURSOR
MOV ALO, A ; NO ATTRIBUTES FOR LATCH O
MOV ALI, A \(\operatorname{ANO}\) ATTRIBUTES FOR LATCH
CLR F1 ;F1 IS "THROUGH" BIT
MOV A,\#O20

CALL MEMCLR ;CLEAR VIDEO MEMORY
EN XI ; REENABLE EXTERNAL INTERRUPTS
JMP LINNUM ;DISPLAY TITLE INFORMATION
KEYIN: JNFO KEYIN ;WAIT FOR KEYBOARD INPUT

CLR FO ;CLEAR START BIT
, \#V
; CLEAR VIDEO MEMORY
LR A
;RESET SROW TO BEGINNING
MOV R2, \#156 ;SET LOOP COUNTER FOR \# WORDS TO READ
MOV A, \#5
MOVL RO,A
MOV HACC, A
MOVL R1,A ;LOAD R1 WITH ADDRESS OF SWITCH REGISTER
MOV R3.\#13 ;LOAD R3 WITH POINTER BUMP CONSTANT
MOV A,INTR ;CLEAR OUT ANY PENDING INTERRUPTS
EN II ;REENABLE LP INTERRUPT
DATAIN: JNF1 DATAIN ;WAIT FOR "THROUGH" BIT TO SET
;DISASSEMBLE DATA INTO DISPLAY FORMAT
CLR FI IRESET "THROUGH"
MOV R2,\#156 ;DISASSENBLE DATA, LOAD WORD COUNTER
MOV HACC, A
MOV A, \#5
MOVL RO,A ;SET MEMORY POINTER TO FIRST DATA DEPOSIT
MOV R3, \#8 ;DO 8 BITS
JMP
;RETRIEVE CHARACTER
RETRIV: MOV A,R4 ;RETRIEVE CHARACI
MOV R4,A ;TEMPORARY SAVE
MOV A,\#'O' ; STORE A "O"
JMP CONT
TL/DD/6970-8

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{7}{|l|}{285} \\
\hline 286013 F & 39 & CHAR : & . \(\mathrm{BYTE}^{\prime} 987654321\) & & & \\
\hline \multicolumn{7}{|l|}{287} \\
\hline 2880149 & 53 & TITLE: & - BYTE 'STEP 7 DA & ATA \(0^{\prime}\) & & \\
\hline \multicolumn{7}{|l|}{289} \\
\hline 2900156 & 27 & \multirow[t]{6}{*}{MEMCLR :} & \multicolumn{4}{|c|}{;VIDEO MEMORY CLEAR LOOP} \\
\hline 2910157 & C2 & & MOV HACC, A ; & \multicolumn{3}{|l|}{; ACCUMULATOR CLEAR} \\
\hline 2920158 & 88 & & MOVL RO, A & \multicolumn{3}{|l|}{; RO CLEAR} \\
\hline 2930159 & BAOO & & MOV R2,\#0 & \multicolumn{3}{|l|}{; INNER LOOP COUNTER SET} \\
\hline 294 015B & BB08 & & MOV R3, \#8 & \multicolumn{3}{|l|}{;OUTER LOOP COUNTER SET} \\
\hline 295015 D & 2320 & & MOV A,\#020 & \multicolumn{3}{|l|}{;SPACE CHARACTER} \\
\hline 296015 F & 80 & \multicolumn{2}{|l|}{MCLRLP: MOVX فRO, A} & \multicolumn{3}{|l|}{; STORE A CHARACTER} \\
\hline 2970160 & 38 & & \multicolumn{4}{|l|}{INCL RO ; INCREMENT POINTER} \\
\hline 2980161 & EA5F & & \multicolumn{4}{|l|}{DJNZ R2,MCLRLP ;TEST INNER LOOP} \\
\hline 2990163 & BAOO & & MOV R2,\#0 & \multicolumn{2}{|l|}{;RELOAD INNER LOOP} & COUNTER \\
\hline 3000165 & EB5F & & DJNZ R3, MCLRLP ; & \multicolumn{2}{|l|}{;TEST OUTER LOOP} & \\
\hline 3010167 & 93 & & \multirow[t]{2}{*}{RETR ;THRO} & \multicolumn{2}{|l|}{OUGH, RETURN} & \\
\hline 302 & & & & & & \\
\hline 303 & & - END & & & & \\
\hline BEGIN & 0052 & CHAR & 013F CKOFF & 0024 & CONNUM & 0126 \\
\hline CONT & OOD5 & DATAIN & OOBB DEPST & 00CB & DNTRU & 004D \\
\hline DOWN & 003 C & EXI & 0003 * INI & 0007 & KEY & 0012 \\
\hline KEYIN & 00A3 & LINNUM & 0100 LKUP & 013B & LSTLIN & 07DF \\
\hline MCLRLP & 015F & MEMCLR & 0156 MEMEND & 07EB & NOTRU & 0011 \\
\hline NUMLP & O10B & ONE & OOD3 RESET & 0000 & RETRIV & OOCA \\
\hline START & 0027 & STLIN & O7EC TITLE & 0149 & TITLP & 012E \\
\hline UNASS & 0007 & UP & 002B UPTRU & 0039 & VOFF & 0000 \\
\hline VON & 0020 & & & & & \\
\hline
\end{tabular}

\section*{NO ERROR LINES}

\section*{328 ROM BYTES USED}

SOURCE CHECKSUM \(=40 \mathrm{DB}\)
OBJECT CHECKSUM \(=0649\)
INPUT FILE A:LOGIC.MAC
LISTING FILE A:LOGIC.PRN
OBJECT FILE A:LOGIC.LM

\section*{Building an Inexpensive but Powerful Color Terminal}

Historically, the design of a color CRT terminal has involved a significant upgrade of the circuit for a monochrome terminal. The result was a stiff increase in price for the electronics as well as for the monitor when going from monochrome to color. As a result, most companies built monochrome terminals and a few built color terminals only.
On the personal computer front where separate monitors are common, manufacturers have started to offer video cards which will support either a monochrome or a color monitor. More recently, color terminals have begun to appear which are extensions of monochrome terminal families. They require a board full of I.C.s for even the most space efficient designs. But now, using the TMP, you can do the same job with just one VLSI chip and a half dozen 7400 family TTL chips.
The National Semiconductor NS405 Series Terminal Management Processor (TMP) was originally conceived as a monochrome "terminal on a chip". However, the design team took special pains to build in "hooks" to allow users to augment the basic features of the TMP. In particular the TMP supports almost unlimited attribute expansion, and therein lies the key to adding color to a TMP-based terminal. Even nicer, the addition of color attributes does not sacrifice any of the other powerful features provided by the TMP.
Here, we will delve into a little of the mechanics of TMP attribute handling. The diagram in Figure 1 shows the path of the attribute bits (normally 8) from the display memory

National Semiconductor Corp. Application Note 374 Leigh Cropper

into the TMP, through the FIFO, the attribute control logic, and finally to the video output section where the attributes are combined with the serialized video output.
Because the display memory space may be large (up to 64k \(x\) 16), it is easy to store many more attribute bits by adding display memory chips. A \(2 k \times 8\) RAM will hold 8 attribute bits for every location on an 80 row by 25 line display. However, in order to implement color attributes, three problems must be examined: (1) how to let both the CPU and the display controller address the extra attribute memory in a practical manner; (2) how to imitate the behavior of the internal FIFO and maintain proper synchronization; and (3) how to combine the color attributes and the video output signal.
Before addressing the three problems in detail, a discussion of the number and type of color attributes is in order. The simplest type of color display would require only 3 bits (red, green, and blue). That allows a character to be displayed in any of 7 colors over a black background or, when reverse video is asserted, the character is black on a colored background. For independent control of both the foreground and background colors, 6 bits are required. To get more shades of color, add more bits.
A practical approach employs a \(2 k \times 8\) RAM for the color attribute memory. Three of the bits control the foreground color, three control the background color and the remaining two may be used to adjust intensity ( 1 for foreground and 1 for background).


TL/DD/7923-1
FIGURE 1. TMP Attribute Processing

Vow let's tackle the problems one by one.
I. COLOR ATTRIBUTE MEMORY ADDRESSING. When fetching data for the display, we need to get 24 bits in parallel ( 8 data, 8 attribute and 8 color attribute). But when the CPU accesses memory, it can handle only 16
bits at a time, so the CPU must be able to read and write color attributes in a different bank of memory from that where the data and ordinary attributes are stored. For an 80 character by 25 row display the memory could be mapped as shown in Figures 2 and 3:


FIGURE 2. Memory Map as Selected for Screen Refresh


FIGURE 3. Memory Map as Selected for CPU Access

The mapping is implemented by the following circuit:


TL/DD/7923-4
FIGURE 4. Color Attribute Memory Mapping Circuit

During a display refresh cycle the color attribute memory is selected by the low bank select (the same select signal that enables the data and attribute memories). However, the color attribute bits drive the external FIFO's, whereas the output from the other two memories is routed through the TMP. The data path from the color attribute memory to the TMP is buffered by an octal transceiver which is disabled when the low bank is selected. During a CPU access to color attribute memory, the high bank select enables the color attribute memory and the octal transceiver. The direction control of the transceiver is controlled by the RAM RD signal from the TMP.
2. EXTERNAL FIFO SYNCHRONIZATION. The TMP provides FI CLK (FIFO Input Clock) and FO CLK (FIFO Output clock) signals which may be used to clock an external FIFO. The FI CLK signal is identical in timing and duty cycle to the RAM RD signal except that FI CLK is disabled (stays high) when the CPU accesses display memory. When the 74LS224 is used as an external FIFO, FI CLK must be inverted. The rising edge of FO CLK occurs when output of the internal FIFO is loaded into the internal dot shifter. The FO CLK is used to empty a word from the external FIFO and clock it into an octal latch.
3. COMBINING COLOR ATTRIBUTES WITH VIDEO. When using foreground and background color attributes, a 74LS157 multiplexer works nicely to switch between the two. The eight color attribute bits from the latch are separated into groups of four. The video output signal is used to switch the multiplexer. When the video output is high, foreground attributes are selected: and when the
video output is low, background attributes are selected. The outputs of the multiplexer (red, green, blue and intensity) directly drive the color monitor inputs. A minor problem arises because the video output from the TMF already includes the blanking signal. That makes it impossible to differentiate between a series of spaces in the middle of the screen and the horizontal blanking interval. In either case, the video output is low. The easiest solution is handled in software. Let's assume that we want an 80 column display and are using three \(2 \mathrm{~K} \times 8\) memory chips for the data, attribute and color memories. We set up the TMP for 81 columns and then configure the program so that the 81st column always contains a space code with all attribute bits off (including color). That way the background color will always be black during both horizontal and vertical retrace. The cost is 25 locations in each of the memories, but we can afford that many because an \(80 \times 25\) display requires 2000 locations, leaving 48 free.

\section*{A Practical Example}

Here we will present a color terminal circuit with the associated program as an example of what you may want to do. We started with the terminal design of the TMP development board. See the block diagram in Figure 5.
The block diagram of the color terminal (with the old portions of the original monochrome terminal unshaded and the new color circuits shaded) appears in Figure 6. The new circuitry was added in the prototyping area of the development board.



TL/DD/7923-6
FIGURE 6. TMP Development Board Color Circuitry Block Diagram

\section*{COLOR ATTRIBUTE BIT ASSIGNMENTS}

The bit assignments are:
Bit \(0-\quad\) Blue foreground
Bit \(1-\quad\) Green foreground
Bit \(2-\)
Red foreground
Bit \(3-\)
Blue background
Bit \(4-\)
Breen background
Bit \(5-\)
Red background
Bit \(6-\quad\) Foreground intensity
Bit \(7-\quad\) Background intensity

Without using the intensity control bits you get 8 foreground colors: red, green, blue, magenta, cyan, yellow, white, and black (beam off). The same 8 colors may be independently selected for the background. There are several RGB monitors available in the moderate price range with sufficient bandwidth to work with a 12 MHz TMP. Some of them include a separate intensity (or luminence) input. Others include internal decoding circuitry which provides the ability to handle 4 bits of color input and provide as many as 16 different colors.

The demonstration program which runs on the development board allows limited color support. The Escape, V sequence from the keyboard or the receiver prompts the program to treat the next character received as an eight bit color attribute byte with the bit assignments as listed above. That byte is written to the color attribute memory as each succeeding character is received, until another escape, V sequence is encountered. The table which follows includes the foreground and background color combinations for characters which can be entered from the keyboard, but it ignores the effect of the 2 high-order bits (foreground and background intensity).

\section*{COLOR COMBINATIONS FOR RGB MONITORS}

Table I gives the Foreground/Background color combinations that occur when using the '<ESC> Vv' Escape sequence. To set the current color attribute, all that you need to do is select the color combination from the Table below, and send it to the NS405 as part of the <ESC> Vx sequence. For example, '<ESC> \(\mathrm{V}^{\prime \prime}\) ' causes the Foreground color to be green and the Background color to be red... not all that pleasing, to my tastes, but choose what you will.

TABLEI
Foreground/Background Color Combinations
\begin{tabular}{|c|c|c|c|c|c|}
\hline Char & Fore/Back & Char & Fore/Back & Char & Fore/Back \\
\hline sp & Black/Red & 6 & Yellow/Yellow & K & Cyan/Blue \\
\hline ! & Blue/Red & 7 & White/Yellow & L & Red/Blue \\
\hline " & Green/Red & 8 & Black/White & M & Magenta/Blue \\
\hline \# & Cyan/Red & 9 & Blue/White & N & Yellow/Blue \\
\hline \$ & Red/Red & : & Green/White & 0 & White/Blue \\
\hline \% & Magenta/Red & ; & Cyan/White & P & Black/Green \\
\hline \& & Yellow/Red & \(<\) & Red/White & Q & Blue/Green \\
\hline , & White/Red & \(=\) & Magenta/White & R & Green/Green \\
\hline ( & Black/Magenta & > & Yellow/White & S & Cyan/Green \\
\hline ) & Blue/Magenta & ? & White/White & T & Red/Green \\
\hline * & Green/Magenta & @ & Black/Black & U & Magenta/Green \\
\hline + & Cyan/Magenta & A & Blue/Black & V & Yellow/Green \\
\hline , & Red/Magenta & B & Green/Black & W & White/Green \\
\hline - & Magenta/Magenta & C & Cyan/Black & \(X\) & Black/Cyan \\
\hline . & Yellow/Magenta & D & Red/Black & Y & Blue/Cyan \\
\hline 1 & White/Magenta & E & Magenta/Black & Z & Green/Cyan \\
\hline 0 & Black/Yellow & F & Yellow/Black & [ & Cyan/Cyan \\
\hline 1 & Blue/Yellow & G & White/Blue & 1 & Red/Cyan \\
\hline 2 & Green/Yellow & H & Black/Blue & ] & Magenta/Cyan \\
\hline 3 & Cyan/Yellow & 1 & Blue/Blue & \(\wedge\) & Yellow/Cyan \\
\hline 4 & Red/Yellow & J & Green/Blue & - & White/Cyan \\
\hline 5 & Magenta/Yellow & & & & \\
\hline
\end{tabular}

\section*{TMP Extended Program Memory Application Note}

\section*{OVERVIEW/INTRODUCTION}

The purpose of this application note is to describe methods for expanding the program memory of the NS405 series TERMINAL MANAGEMENT PROCESSOR (TMP) and to provide direction in software techniques for utilizing the expanded memory efficiently. The chip has a built-in capability of addressing up to 8 k of external program memory (ROM), via the ROM Expand Bus, and 64k of video display memory (RAM), via the System Bus. Although 8k of program memory is sufficient for most applications there are many applications, such as emulating multiple terminals or using many look-up tables, that require still more memory. However, it is

National Semiconductor Corp. Application Note 399 Richard Lazovick

very rare that the entire 64 k of video RAM is used since that is more than enough memory to store two screens of data in the pixel mode or thirty-two screens of data in the alphanumeric/block graphics mode. Therefore it is practical to use a video memory address to switch between two or more 8 k memory arrays.
The idea behind using a bank select switch to change from one memory array to another is not new, nor is it difficult, and when implemented properly it can be a very useful tool. The TMP has all the necessary control signals to make both the software and hardware straight-forward.


TL/DD/8430-

\section*{SOFTWARE}

For purposes of demonstration it will be easier to look at the software aspects of using an array select switch first, then designing the hardware to implement it.
The easiest case occurs if we use less than 16k of display memory. Then we have two system bus address lines available to select either of our two arrays. To switch arrays all we have to do is read from (or write to) an address that uses the address line you wish to toggle. It is safer to read from the address since we do not want to change data in memory at the location addressed by the lower order address lines.
Suppose we choose SB14 to select the low order array and SB15 to select the high order array. The program steps we would go through to switch from the low array to the high array could be:
\begin{tabular}{lll} 
MOV A,\#080 & ;Load HACC w/ 80H to set SB15 HI \\
MOV HACC,A & ;and set SB14 LO. We do not care \\
MOVL RO,A & ;about the other address bits. \\
MOVX A, @RO & ;SB15 goes HI.
\end{tabular}

In general we will want to switch arrays several times, and we will want to be able to conveniently control the destination address in the new array.
Since it is very cumbersome to rewrite the whole sequence everytime, let's mimic the internal select memory bank command (SEL MBx) by using a subroutine and a CALL followed by a JMP to conveniently control our array switching.
\begin{tabular}{lll} 
CALL SELHA & ;Select HI order array. \\
JMP & HERE & ;Jump to HERE in new array. \\
SELHA : MOV A,\#O80 & \\
MOV HACC,A & ;Load HACC w/ 80H to set SB15 HI \\
MOVL RO,A & ;about the other address bits. \\
MOVX A,@RO & ;SBl5 goes HI. \\
RET & & ;Return to execute the jump.
\end{tabular}

Now each time we switch to the high order array all we have to do is execute a CALL and a JMP.


Note 1: Enable ROM output drivers.
TL/DD/8430-2
Note 2: ROM address available.
Note 3: RE bus addresses changes during rising edge of ALE and are stable by falling edge.
Note 4: No \(\overline{\text { PSEN }}\) signal present during last cycle of MOVX instruction, however \(\overline{\text { PSEN }}\) is active during both RET cycles.

\section*{HARDWARE}

Now that we have made the software simple and straightforward we have to look at what hardware is necessary to implement it.

We want to: 1) create two mutually exclusive enable signals-one for each array,
2) be able to easily use and latch the address line signals, and
3) delay the actual switching of arrays until after the jump instruction, with the new address, is read into the TMP from the old array.
Looking at the program we see that the system bus chang.
es after the MOVX instruction with the RET and JMP instructions still to be read in from memory before we actually want to switch arrays. Each instruction takes two cycles, therefore we want to delay our array switching signal by four cycles. Looking at all the output signals on the TMP there are two possible signals to use as a clock to delay the array switching signal. These signals are PSEN and ALE (see System Signals Timing Diagram).
The main disadvantage of using ALE is that whereas we want a rising edge to clock the flip-flops used for the delay, the ROM addresses are not stable until the falling edge of ALE. Therefore, we save one inverter by using PSEN.
One possible circuit implementation is shown below:

\section*{Circuit Dlagram}


TL/DD/8430-3

The first flip-flop latches one of the two system bus signals and the next four delay the array switching signal by four PSEN cycles. The two inverters are there so that we trigger off a ONE on the address. If the system bus was configured as a 16 bit address/data bus (bit 4 of SCR set) then the latched address lines would have to be used. Since it is always desirable to have the flip-flops in a known state at power up, some sort of reset circuitry should be used (e.g., by tying the power up reset circuit to the clear inputs on the flip-flops), or both arrays should have identical reset sequences that include setting the flip-flops to a known state.

\section*{LOOKING IN DEPTH}
use and the hardware to implement it, let's look at what is actually happening (see Array Switching Timing Diagram 1). The system bus line switches after the first cycle of the MOVX instruction, but there is no PSEN during the second cycle. Then there are two \(\overline{\text { PSEN }}\) signals during the RET instruction and two \(\overline{\text { PSEN }}\) signals during the JMP instruction. Just after the second byte of the JMP is read into the TMP, the arrays are switched, the PC gets loaded with the new address, and the program continues execution as normal in the new array from the address indicated in the JMP instruction. Be sure you understand the Array Switching Timing Diagram 1 before continuing.

Note 1: No PSEN signal.
Note 2: Arrays switch here.
Note 3: Valid approximately 360 ns .

\section*{ADDENDUMS}

Although it can be a problem when trying to execute a call across array boundaries, the problem can be easily overcome as can the confusion that arises when many array switchings occur. All that one needs to do is to organize the program memory efficiently. One such scheme would be to set aside a block of memory in each bank, such as the last page to use for memory mapping. For example if we wanted to jump from location HOME in the LO array to location HERE in the HI array and then back to HOME we could map our memory as shown below:

Lo Array

MAIN PROGRAM:


ARRAY SWITCHING SUBROUTINE:
\begin{tabular}{lllll}
0700 & SELHA: MOV A,\#080 & 0700 & SELLA: & MOV A,\#O40 \\
0702 & MOV & HACC, A & 0702 & MOV HACC ,A \\
0703 & MOVL, RO,A & 0703 & MOVL RO,A \\
0704 & MOVX A, @RO & 0704 & MOVX A,RO \\
0705 & NOP & 0705 & NOP \\
0706 & NOP & 0708 & NOP \\
0707 & RET & 0707 & RET
\end{tabular}

\section*{MEMORY MAP:}


Note: The arrows show which JMP corresponds to which subroutine call. For example the JMP HOME at location 070C in the LO ARRAY corresponds to the CALL at location 070A In the HI ARRAY. The ()'s show how the CALL's and JMP's can be strung together in a neat pattern.
Notice that there are two NOP's in the subroutine. Since the JMP after the CALL was moved to the new array the two NOP's were added to the subroutine so that the actual array switching occurs just after the completion of the RET instruction. The PC is then loaded with the new jump value, loaded in from the new array, and we continue execution as expected. Be sure to understand the timing before going any further (see Array Switching Timing Diagram 2). The way the memory map is set up it is easy to organize and keep track of jumps using the pattern indicated in the example. This method also eliminates any problems with the assembler searching for undefined labels.


Since there are two extra NOP's in the switching array subroutine the hardware can now be simplified and the system speed increased by removing two of the flip-flops from the chain. Through the use of the SEL MBx commands the memory map can be located in any page of any memory bank. For example if we wanted to jump to location HERE in memory bank 2 of the HI array from memory bank 1 of the LO array (after having removed two flip-flops) we could map our memory as shown below:

\section*{Lo Array}

Note 3: Arrays switch.
Note 4: Now in new array.

\section*{Hi Array}

\section*{ARRAY SWITCHING SUBROUTINE:}
\begin{tabular}{llllll}
0700 & SELHA : MOV A,\#080 & 0700 & SELIA: MOV & A,\#040 \\
0702 & MOV & HACC,A & 0702 & MOV & HACC,A \\
0703 & MOVL RO,A & 0703 & MOVL RO,A \\
0704 & MOVX A,@RO & 0704 & MOVX A, @RO \\
0705 & RET & & 0705 & RET
\end{tabular}

\section*{MEMORY MAP:}
\begin{tabular}{lllll} 
O70A HERE: CALL SELHA & 070A & \\
O70C & & \(070 C\) & SEL & MB2 \\
\(070 E\) & & \(070 E\) & JMP & HERE
\end{tabular}

MAIN PROGRAM:
\begin{tabular}{llll}
0800 & HOME : & SEL & MBO \\
0801 & & JMP & HERE
\end{tabular}

1000 HERE: NOP
If a call into the other array is necessary a similar pattern to that above could be used. Start by replacing the JMP's with CALL's to the desired subroutine and appropriately placing returns. For example (here it comes) if we wanted to CALL HOME from HERE we could memory map as shown below.

\section*{Hi Array}

MAIN PROGRAM:
HOME: NOP
HERE: NOP
RET
CALL HOME

\section*{ARRAY SWITCHING SUBROUTINE:}
\begin{tabular}{rlc} 
SELHA : & • & SELLA: \\
• & • \\
RET & • \\
& \\
RET
\end{tabular}

\section*{MEMORY MAP:}

HOME : CALL SELLA
CALL HOME
CALL SELHA
RET TL/DD/8430-7

Since calling between different memory banks is not straight forward it is advisable to be very careful when doing it, or to limit calls between arrays only to those that reside in the same memory bank.

\section*{HELPFUL HINTS}

These schemes can all be modified to multiple arrays and easier or fancier mappings, however there are a few things to keep in mind.
1) If using a system bus address line to toggle the array, don't use that line as part of an actual display memory address.
2) The MOVX instruction can require more than two cycles depending on system bus contention, however we are only concerned with the last two cycles and the PSEN signals that occur after the system bus line changes.
3) If using interrupts-disable them while switching arrays and keep all time critical routines in the same array.
4) A demux or decoder can be used to select memory arrays or decode address lines when more than two 8 k arrays are implemented or more than 16k of video RAM is being used.
5) If extra memory is needed, but a good deal of the program memory is data storage, the data could be stored in the video memory space instead of implementing a new array.
6) If the TMP is going to be used in a noisy environment or the system bus is configured as a 16 bit bidirectional bus a synchronous latch should be used to assure stable levels on SB14 and SB15.
7) The given array switching circuit can be implemented with the demo board by wiring it into an extension board that can be plugged into the prom socket U9. Wire the two new proms in parallel with each other and with a cable that can plug directly into the prom socket. However, instead of using pin 20 from the demo board, use the two array enable lines as the chip enables for the 2764 proms.
Also use SB12 and SB13 instead of SB14 and SB15.

\section*{Section 8}

\section*{Microcontroller}

\section*{Development Tools}

\section*{Section 8 Contents}
Mole ..... 8-3
AN-456 Microcontroller Development Tools ..... 8-4

\section*{MOLETM}

The MOLE (Microcontroller On-Line Emulator) is a low cost development system and emulator for all National microcontroller roducts.
The MOLE system was developed for the microcontroller design engineer and provides a method of writing, debugging and mulating microcontroller software.
This low-cost and powerful development system consists of three components-a computer, a Brain Board and a Personality 3oard. This partitioning gives you added flexibility in emulating microcontrollers.
「he host provides editing and program assembly with cost-effective bulk storage and high-speed processing capabilities. Object ;ode results are downloaded to the Brain/Personality Boards via RS232C interface for real-time in-system emulation.
lesident firmware allows the user to display and alter memory in both hex and mnemonic format; initiate breakpoints, traces and iming on addresses or external events; and examine and modify the internal resources of the microcontroller being emulated. The Brain Board, common to all versions of the MOLE, contains an NSC800, 64k ROM, 32k ROM, 3 RS-232C channels and a 'ROM programmer.
ihe Personality Board contains the necessary hardware and firmware to tailor the MOLE system to the specific microcontroller. Nhen connected to a CRT, the two boards provide all the resources for stand-alone emulation and debugging.
Jonnecting a MOLE to Intel's MDS, or other CP/M MS-DOS-based computers completes the development system.

\section*{Microcontroller Development Tools}


\section*{MOLETM DEVELOPMENT TOOLS}

The MOLE (Microcontroller On Line Emulator) system was designed to support the development of all NSC Microcontroller products. These include COPSTM family, TMP, and the HPC family of products. The MOLE provides effective support for the development of both software and hardware in the user's application.
The purpose of MOLE is to provide the user with the tools to write and assemble code for the target microcontroller and assist in the debugging of both the hardware and software. A MOLE system consists of three components: a MOLE Brain Board, a MOLE Personality Board, and software for the user's host computer. This partitioning provides the Microcontroller design engineer with a new concept in flexibility. As an example of the flexibility consider the latitude the user has in the choice of a host CPU. The host may be IBM \({ }^{\text {- }}-\mathrm{PC}\), Intel's MDS800, or Intellec \({ }^{\text {® }}\) series II, or Kaypro, or one of a number of inexpensive personal computers. The software provided by National Semiconductor will run under control of the host computer CP/M or MS-DOS operating system.
Further flexibility is provided by the Personality board. This component tailors the system to emulate a single microcontroller family or device. For instance, one Personality Board supports the COPS CMOS and NMOS family. This Personality Board provides support for 42 Microcontroller device types.

Additionally, Personality boards are available for the HPC family of products and the NS405 Terminal Management Processor (TMP).
The MOLE components have been designed to provide maximum utility. The host CPU contributes cost effective bulk storage and high speed processing. Disk editing and assembly operations are controlled by the host CPU. The results are down loaded to the Brain Board over the RS-232 link. The Brain Board/Personality Board combination provides FULL emulation capability.
The resident firmware allows the user to down load from the host computer, display and alter code in both hex and mnemonic format, initiate Breakpoints, Traces, and timing on addresses and external events, examine and modify the internal resources of the Microcontroller being emulated. Hardware and Firmware are provided for programming EPROMs or EEPROMs.
Once debugged, the code is transmitted to National Semiconductor for use in creating the tooling necessary for manufacturing the masked Microcontroller part.
The MOLE concept provides maximum flexibility and maximum utility for development of a Microcontroller based system.


\section*{MOLE BRAIN BOARD}

The Brain Board is the pivotal component of the MOLE concept. In conjunction with a terminal and Personality Board it provides the user with a freestanding workstation for Microcontroller emulation. It ties the system together by communicating with the Personality Board, printers, modems, optional host computer, and other Brain Boards. Multiple Brain Boards, tied to a common host, can function as emulators for individual projects where each Brain Board is a separate workstation. They can also function as individual Microcontroller emulators within a multicontroller system.
The MOLE Brain Board utilizes a NSC800TM Microprocessor with 64k RAM and 32k ROM. It has an EPROM /EEPROM programmer for on-line changes. There are three RS-232 ports and a bus to connect the Brain to the Personality Board for actual emulation of code in the user's application system.
The RS-232 ports are used via the communication routines in firmware to interface with a host computer, terminal, modem, printer, or other MOLEs, for greater flexibility during system development.
The MOLE firmware is controlled by an EXEC. There are three major sets of EXEC commands. The first set of commands are calls to other main programs. These are:
\begin{tabular}{ll} 
COMM & Invoke Communications Program \\
DIAG & Invoke Diagnostics Program \\
MONITOR & Invoke Personality Emulation Monitor \\
PROG & Invoke PROM Programming Program
\end{tabular}

The second set of EXEC commands are:
\begin{tabular}{ll} 
CALC & Adds/Subtracts decimal and hex numbers \\
COMPARE & Compares one buffer with another \\
ERASE & Used to erase all or part of a buffer \\
HELP & Prints a summary of EXEX commands \\
MOVE & Moves data from one buffer to another \\
STATUS & Display status of buffers, display and alter \\
& RS-232 parameters
\end{tabular}

The third set of commands are used exclusively for multiple MOLE configurations and they are:
CONNECT Connect the user with the requested system
DISCONNECT Disconnects the MOLE IDENT Identifies a MOLE system
The MOLE Brain Board supports NSC's entire family of MOLE Personality boards.

\section*{MOLE Brain Board Block Diagram}


TL/DD/8830-5
- Single 5V operation
- Ability to interface to a wide variety of host computers
- Full communication control with host computer, a modem of other MOLEs
- Three RS-232 ports
- Auto baud selection (110, 300, 600, 1200, 2400, 4800, 9600,19200 baud)
- Mask data submission via modem
- Self diagnostics
- Program EPROMS
- MM2716, NMC27C16
- MM2732, NMC27C32
— NMC2764
- Program EEPROMs
- 2816A
```

PHYSICAL SIZE
10" x 12"
POWER REQUIREMENTS
+5V DC @ 3.5A
+12.5/+21V or +25V @ 50 mA
(Optional-required only for PROM programming)
WHAT P/N TO ORDER
MOLE-BRAIN
MOLE-BRAIN PACKAGE CONTAINS
MOLE Brain Board
MOLE Brain User's Manual P/N 420408188-001
2 RS-232 Cables
Power Cable
Miscellaneous Hardware

```

\section*{MOLE COPS FAMILY PERSONALITY BOARD}

The MOLE COPS Family Personality Board supports the emulation of COPS family of Microcontrollers. The Personality Board allows the user to emulate the appropriate Microcontroller in the user's end system for fast development of application code and hardware. The Personality Board consists of: a Monitor, the hardware to control the operation of the Microcontroller in the emulation system, and an emulation cable to connect the emulator to the application system. The cable has the same pin configuration as the final masked part.
The Personality Board Monitor is contained in 32k of ROM, contains an assembler and disassembler and is directly executable by the NSC800 on the Brain Board. The Monitor commands will allow the user to execute the application code, examine and modify internal registers and I/O, examine and alter object code in hex or mnemonic format, execute Time measurements, and set Trace and Breakpoints.
The Personality Board also contains \(2 k\) bytes of shared memory (RAM) for application code and the necessary hardware for Trace and Breakpoint operation.
When the system is thoroughly tested, the code is sent to National Semiconductor for use in creating the required tooling for manufacturing the masked COPS production part.
- Supports entire COPS CMOS and NMOS family
- Single 5V operation
- Firmware monitor directly executed by Brain CPU
- Firmware diagnostics directly executed by Brain CPU
- Firmware Line Assembler
- Firmware Unassembler
- \(2 k\) bytes of shared memory
- 256 deep trace memory
- Eight external event inputs
- Trace on multiple addresses
- Trace on multiple address ranges
- Trace on external events
- Breakpoint on multiple addresses
- Breakpoint on multiple address ranges
- Breakpoint on external events
- List and alter shared memory
- Print and modify internal registers
- Singlestep
- Next-singlestep around subroutine calls
- Trigger output for logic analyzer
- Real time emulation

\section*{MOLE CMOS COPS Family Personality Board Block Dlagram}


TL/DD/8830-7

PHYSICAL SIZE \(12^{\prime \prime} \times 12^{\prime \prime}\)
POWER REQUIREMENTS +5 V @ 3.5A
WHAT P/N TO ORDER MOLE-COPS-PB1
MOLE-COPS PB1 PACKAGE CONTAINS MOLE CMOS COPS Personality Board MOLE CMOS COPS PB Manual P/N 420408189-001
3 Emulator Cables
Power Cable
Miscellaneous Hardware

\section*{SOFTWARE ORDERED SEPARATELY See Mole Software \\ COPS PROGRAMMERS MANUAL Order P/N 424410284-001}

\section*{MOLE TMP PERSONALITY BOARD}

The TMP Personality Board allows the MOLE system to emulate the NS405 Terminal Management Processor (TMP). The Personality Board consists of a Monitor, 8 k bytes of shared memory, \(2 k\) bytes of video memory, \(2 k\) bytes of character font memory, emulation hardware, and an In-Sys-tem-Emulation, (ISETM), cable. The ISE cable has the same pinout as the chip and allows the Personality Board to function within the application system.
The NSC800 CMOS Microprocessor, located on the Brain Board, directly executes the 32k Personality Board monitor firmware. The Monitor allows execution of application code, examination and alteration of internal registers, examination and alteration of program memory contents, setting of trace and breakpoints, and control of the character generator memory. The ISE cable connects these capabilities to the application system. Up to eight external events may be traced in the 2 k deep trace memory. Multiple trace, breakpoints are available to the user along with assemble and unassemble of shared memory.
Application programs of up to \(8 k\) bytes may be executed from Personality Board RAM or user system memory. Video display RAM also may be accessed from the Personality Board (2k bytes) or user system memory ( 64 k bytes). Unique character sets may be displayed by accessing a high speed character font memory.
Once debugged, the code is transmitted to National Semiconductor for use in creating the tooling required to manufacture the part.
- Supports NS455 (TMP) microcontroller
- Single 5 V operation
- Firmware monitor directly executed by Brain CPU
- Firmware diagnostics directly executed by Brain CPU
- Firmware Line Assembler
- Firmware Unassembler
- 8 k bytes of shared program memory
- \(2 k\) bytes of video display memory
- \(2 k\) bytes of character font memory
- 2048 deep trace memory
- Eight external event inputs
- Trace on multiple addresses
- Trace on multiple address ranges
- Trace on external events
- Breakpoint on multiple addresses
- Breakpoint on multiple address ranges
- Breakpoint on external events
- List and alter shared memory
- List and alter display memory
- List and alter character font memory
- Print and modify internal registers
- Singlestep
- Next-singlestep around subroutine calls
- Trigger output for logic analyzer
- Real time emulation

MOLE NS455 (TMP) Personality Board Block Dlagram

```

PHYSICAL SIZE
12" x 12"
POWER REQUIREMENTS
+5V @ 4A
WHAT P/N TO ORDER
MOLE-TMP-PB1

```
MOLE-TMP-PB1 PACKAGE CONTAINS
    MOLE TMP Personality Board
    MOLE TMP PB User's Manual
        P/N 420406203-001
    1 Emulator Cable
    Power Cable
    Miscellaneous Hardware
```

SOFTWARE ORDERED SEPARATELY
See Mole Software
TMP APPLICATIONS MANUAL
Order P/N 420040401-001

```

TMP Personality Board


\section*{MOLE COP800 FAMILY PERSONALITY BOARD}

The COP800 Family Personality Board allows the MOLE system to emulate the COP800 family. The Personality Board consists of a firmware Monitor, 16k bytes of shared memory, 2000 deep Trace memory, Port recreation logic to recapture the pins used for emulation, emulation hardware, and an In System Emulator (ISE) cable. The ISE cable has the same pinout as a socketed masked part and allows the Personality Board to function within the application system. The NSC800 CMOS Microprocessor, located on the Brain Board, directly executes the 64k of Personality Board Monitor firmware. The Monitor allows execution of application code, examination and alteration of internal registers, examination and alteration of shared memory, and the setting of trace and breakpoints. The ISE cable connects these capabilities to the application system. Up to eight external events as well as 15 -bit address and 8 -bit data busses can be traced in the 2000 deep trace memory. Multiple breakpoints, plus assemble and unassemble commands are at the user's disposal.
Applications programs of up to 16 k bytes from Personality Board RAM may be emulated.
Once debugged, the code is transmitted to National Semiconductor for use in creating the tooling required to manufacture the masked part.
- Supports COP800 microcontroller family
- Single 5V operation
- Firmware monitor directly executed by Brain CPU
- Firmware diagnostics directly executed by Brain CPU
- Firmware Line Assembler
- Firmware Unassembler
- 16 k bytes of shared program memory
- 2000 deep trace memory
- Eight external event inputs
- Trace on multiple addresses
- Trace on multiple address ranges
- Trace on external events
- Breakpoint on multiple addresses
- Breakpoint on multiple address ranges
- Breakpoint on external events
- List and alter shared memory
- Print and modify internal registers
- Singlestep
- Next-singlestep around subroutine calls
- Trigger output for logic analyzer
- Real time emulation

MOLE CMOS COP800 Family Personality Board Block Dlagram


TL/DD/8830-15

PHYSICAL SIZE
\(12^{\prime \prime} \times 12^{\prime \prime}\)
POWER REQUIREMENTS +5 V @ 3.5A
WHAT P/N TO ORDER MOLE-COP8-PB1
MOLE-COP8-PB1 PACKAGE CONTAINS MOLE CMOS COP8 Personality Board MOLE CMOS COP8 PB Manual

P/N 420410528-001
Emulator Cables
Power Cable
Miscellaneous Hardware

\section*{MOLE HPC FAMILY PERSONALITY BOARD}

The HPC Family Personality Board allows the MOLE system to emulate the High Performance Controller (HPC) family. The Personality Board consists of a firmware Monitor, 16k bytes of shared memory, 2k x 48 Trace memory, Port recreation logic to recapture the pins used for emulation, emulation hardware, and an In System Emulator, ISE, cable. The ISE cable has the same pinout as a socketed masked part and allows the Personality Board to function within the application system.
The NSC800 CMOS Microprocessor, located on the Brain Board, directly executes the 32k of Personality Board Monitor firmware. The Monitor allows execution of application code, examination and alteration of internal registers, examination and alteration of shared memory, and the setting of trace and breakpoints. The ISE cable connects these capabilities to the application system. Up to eight external events as well as 16 -bit address and 16-bit data busses can be traced in the 2 k deep trace memory. Multiple breakpoints, and chip error conditions plus assemble and unassemble commands are at the user's disposal.
Applications programs of up to 16 k bytes from Personality Board RAM or 64 k bytes from user system RAM may be emulated.
Once debugged, the code is transmitted to National Semiconductor for use in creating the tooling required to manufacture the masked part.
- Supports HPC microcontroller family
- Single 5V operation
- Firmware monitor directly executed by Brain CPU
- Firmware diagnostics directly executed by Brain CPU
- Firmware Line Assembler
- Firmware Unassembler
- 16k bytes of shared program memory
- 2000 deep trace memory
- Eight external event inputs
- Trace on multiple addresses
- Trace on multiple address ranges
- Trace on external events
- Breakpoint on multiple addresses
- Breakpoint on multiple address ranges
- Breakpoint on external events
- List and alter shared memory
- List and alter display memory
- Print and modify internal registers
- Singlestep
- Next-singlestep around subroutine calls
- Trigger output for logic analyzer
- Real time emulation

MOLE HPC Family Personality Board Block Dlagram


TL/DD/8830-11
```

PHYSICAL SIZE
12" x 12"
POWER REQUIREMENTS
+5V @ 8A
WHAT P/N TO ORDER
MOLE-HPC-PB1
MOLE-HPC-PB1 PACKAGE CONTAINS
MOLE HPC Personality Board
MOLE HPC PB User's Manual
P/N 420410477-001
1 Emulator Cable
Power Cable
Miscellaneous Hardware

```
```

SOFTWARE ORDERED SEPARATELY
See Mole Software
HPC PROGRAMMERS MANUAL
Order P/N 420410704-001

```

HPC Personality Board


\section*{HOW TO ORDER}

MOLE systems are available for a variety of host systems. To order a complete development package, select the section for the microcontroller to be developed and order the
parts listed. MOLE software is available for several systems. For software other than for IBM systems, consult the alternate software selection table and substitute for the assembler software for the IBM.

Development Tools Selection Table
\begin{tabular}{|c|c|c|c|c|}
\hline Icrocontrolier & Order Part Number & Description & Includes & Manual Number \\
\hline \multirow{6}{*}{HPC} & MOLE-BRAIN & Brain Board & Brain Board Users Manual & 420408188-001 \\
\hline & MOLE-HPC-PB1 & Personality Board & HPC Personality Board Users Manual & 420410477-001 \\
\hline & MOLE-HPC-IBM \({ }^{*}\) & Assembler Software for IBM & HPC Software Users Manual and Software Disk PC-DOS Communications Software Users Manual & \[
\begin{array}{r}
424410446-001 \\
420040416-001 \\
\hline
\end{array}
\] \\
\hline & MOLE-HPC-IBM-C & C Compiler for IBM & HPC C Compiler Users Manual and Software Disk Assembler Software for IBM MOLE-HPC-IBM & 424410559-001 \\
\hline & 420410704-001 & Programmers Manual & & 420410704-001 \\
\hline & 420410705-001 & Hardware Manual & & 420410705-001 \\
\hline \multirow{5}{*}{COP800} & MOLE-BRAIN & Brain Board & Brain Board Users Manual & 420408188-001 \\
\hline & MOLE-COP8-PB1 & Personality Board & COP800 Personality Board Users Manual & 420410528-001 \\
\hline & MOLE-COP8-IBM* & Assembler Software for IBM & COP800 Software Users Manual and Software Disk PC-DOS Communications Software Users Manual & \[
\begin{array}{r}
424410527-001 \\
420040416-001 \\
\hline
\end{array}
\] \\
\hline & MOLE-COP8-IBM-C & C Compiler for IBM & COP800 C Compiler Users Manual and Software Disk Assembler Software for IBM MOLE-COP8-IBM & Available 1988 \\
\hline & 420410703-001 & Programmers Manual & & 420410703-001 \\
\hline \multirow{4}{*}{COP400} & MOLE-BRAIN & Brain Board & Brain Board Users Manual & 420408188-001 \\
\hline & MOLE-COPS-PB1 & Personality Board & COP400 Personality Board Users Manual & 420408189-001 \\
\hline & MOLE-COPS-IBM* & Assembler Software for IBM & COP400 Software Users Manual and Software Disk PC-DOS Communications Software Users Manual & \[
\begin{aligned}
& 424409479-002 \\
& 420040416-001 \\
& \hline
\end{aligned}
\] \\
\hline & 424410284-001 & Programmers Manual & & 424410284-001 \\
\hline \multirow{6}{*}{TMP} & MOLE-BRAIN & Brain Board & Brain Board Users Manual & 420408188-001 \\
\hline & MOLE-TMP-PB1 & Personality Board & TMP Personality Board Users Manual & 420408203-001 \\
\hline & MOLE-TMP-IBM* & Assembler Software for IBM & \begin{tabular}{l}
TMP Software Users Manual and Software Disk \\
PC-DOS \\
Communications Software Users Manual
\end{tabular} & \[
\begin{aligned}
& 424410087-002 \\
& 420040416-001 \\
& \hline
\end{aligned}
\] \\
\hline & 420040401-001 & Applications Manual & & 420040401-001 \\
\hline & TMP-DEMO-12 & 12 MHz Demo Board (5x7 Font) & Demo Board, Data Sheet, and Operating Manual & 420409478-001 \\
\hline & TMP-DEMO-18 & 18 MHz Demo Board (7x9 Font) & Demo Board, Data Sheet, and Operating Manual & 420409478-001 \\
\hline
\end{tabular}

\footnotetext{
For CP/M software see alternate assembler software selection table.
}

\section*{MOLE SOFTWARE}

MOLE software is available for a variety of host computers. The software package provides cross assembly for the specific Microcontroller on the specific type of host computer. Included, along with the cross assembler, in the software package are two file conversion routines to convert the assembler output (LM) to HEX and to convert HEX to LM. Also
included in the software package is a COMM program which facilitates the downloading and uploading between the host and the MOLE, and adds the capability to make the host act as a terminal. In addition, for the TMP, a program is provided to create custom fonts (FONT).
If using a host computer other than the IBM the select the Assembler software package from the following table.

Alternate Assembler Software Selection Table
\begin{tabular}{|c|c|c|c|c|}
\hline HPC & COP800 & COP400 & TMP & Description \\
\hline MOLE-HPC-CPM & MOLE-COP8-CPM & MOLE-COPS-CPM & MOLE-TMP-CPM & Assembler Software for CP/M Systems ( \(8^{\prime \prime}\) SD Disk) \\
\hline MOLE-HPC-INT-S & MOLE-COP8-INT-S & MOLE-COPS-INT-S & MOLE-TMP-INT-S & Assembler Software for Intel Single Density System ( \(8^{\prime \prime}\) SD Disk) \\
\hline MOLE-HPC-INT-D & MOLE-COP8-INT-D & MOLE-COPS-INT-D & MOLE-TMP-INT-D & Assembler Software for Intel Double Density Syster ( \(8^{\prime \prime}\) DD Disk) \\
\hline MOLE-HPC-KAY & MOLE-COP8-KAY & MOLE-COPS-KAY & MOLE-TMP-KAY & Assembler Software for KAYPRO2 Systems
\(\left(5.25^{\prime \prime}\right.\) DD Disk) \\
\hline CP/M & \multicolumn{4}{|l|}{Communications Software Users Manual (Included with the above Software) 420040415-0,} \\
\hline
\end{tabular}

\section*{DIAL-A-HELPER}

Dial-A-Helper is a service provided by the MOLE (Microcontroller On Line Emulator) applications group. It consists of both an electronic bulletin board information system and a method by which applications can take control of a MOLE Development System at a remote site via modem in order to resolve any problems.

\section*{Information System}

The Dial-A-Helper system provides access to an automated information storage and retrieval system that may be accessed over standard dial-up telephone lines 24 hours a day. The system capabilities include a MESSAGE SECTION (electronic mail) for communications to and from the Microcontroller Applications Group and a FILE SECTION mode that can be used to search out and retrieve application data about NSC Microcontrollers. The user needs as a minimum, a Dumb terminal, 300 or 1200 baud Modem, and a telephone.

If the user has a PC with a communications package then files from the FILE SECTION can be down loaded to disk for later use.

\section*{Factory Applications Support}

Dial-A-Helper also provides immediate factory applications support. If a user is having difficulty in getting a MOLE to operate in a particular mode or something peculiar is occuring, he can contact us via his system and modem. He can leave messages on our electronic bulletin board, which we will respond to, or he can arrange for us to actually take control of his system via modem for debugging purposes.
The applications group can then cause his system to execute various commands and try to resolve the customers problem by actually getting customers system to respond. Both parties see exactly what is occurring, as it is happening.
This allows us to respond in minutes when applications help is needed.

DIAL-A-HELPER


USER STIE

\section*{TMP DEMO BOARD}

The TMP demo board is a minimum system configuration, CRT terminal. It utilizes the NS405 Terminal Management Processor (TMP) Single Chip CRT Controller microchip. TMP is suitable for low cost terminal, imbedded or display functions.
The Demo board is an excellent vehicle for evaluating the performance and capabilities of TMP or for OEM applications.
The addition of a keyboard, and a display is all that is required to provide ADM 3A terminal compatibility. The user has the flexibility of executing the on-board ROM functions or creating their own versions utilizing an external EPROM. The manual contains a complete, well documented listing, of the source code.
In addition, the user has complete control over temrinal operation through the use of the many escape sequences programmed into the microchip. Many cursor and character attribute display options available can easily be evaluated.
The heart of the Demo board is the NS405 Terminal Management Processor. Normally the TMP will be running its internal masked program, but will go external for program memory if instructed.
The ROM Expand bus is multiplexed with external program EPROM and 8-bit I/O port for the keyboard input. The System Bus similarly multiplexes the Video RAM and switch configuration register.
The video memory requirement of 80 columns by 25 rows is stored in a \(2048 \times 8\) NMC2116 static RAM. Also mapped into the video RAM space is the switch configuration register. The switch register is used on power up initialization to set up the UART operation. The video outputs are either buffered or mixed together for composite video. The UART serial IN and OUT are level shifted to RS232 levels by the dual op-amp (LM1458).

Block Dlagram


Features
- 80 column x 25 row display
- Double wide font

■ 12 or 18 MHz bandwidth with \(5 \times 7\) or \(7 \times 9\) fonts respectively
- Ball or composite video output
- RS-232C serial interface with full duplex 110-19.2k baud
- \(50 / 60 \mathrm{~Hz}\) operation
- Status line display
- 24 escape sequences
- 15 control sequences
- Internal masked ROM program or self-programmed EPROM operation


TL/DD/8830-17

\section*{HARDWARE DESCRIPTION}

\section*{Keyboard Input}

Seven-bit parallel ASCII data from an encoded keyboard is input through a row of wire wrap pins that make up the J2 connector. In addition to data input, +5 V to -12 V power to operate the keyboard is available. Characters are strobed in on each logic low level. The strobe may be any duration greater than \(1.25 \mu \mathrm{~s}\); the TMP checks to see that the strobe line has returned to its quiescent logic high state before accepting new characters. For strobes longer than 750 ms , an auto repeat function outputs 15 characters/s. In auto repeat, data lines are sampled 15 times/s. In general, data must be read within \(10 \mu \mathrm{~s}\) after the falling strobe edge and \(20 \mu \mathrm{~s}\) after the falling strobe. Data lines should change only when a new character is available.

\section*{Serial Interface}

The demo board can be interfaced to a host computer with a RS-232C data link by using the J1 Plastic D connector. The parameters associated with serial data communication are user selectable.

\section*{Video Interface}

The video input can be either a composite video or Ball (separate H-Sync, V-Sync, Video Input) monitor input. The monitor should have at least a 12 MHz or 18 MHz bandwidth to operate properly with, respectively, 12 MHz or 18 MHz TMP Demo Boards.

\section*{Program Memory}

The program to run the demo board is shipped with the board in a 2716 EPROM. Both boards allow the user to customize their own program by adding or changing the EPROM.

\section*{Light Pen Input}

The TMP chip has the capability of using a light pen. The TMP Demo Board is able to take advantage of this by connecting the light pen to jumper W8A.

\section*{TMP Terminal Operation}

With everything powered up and running, a blinking block cursor will be in the upper left hand corner and the system
status line on bottom of screen. At powerup, the screen format is an 80 -column by 25 row display with the following character and cell dimensions.

TABLE II
\begin{tabular}{|c|c|c|}
\hline & Character Slze & Cell Slze \\
\hline \(12 \mathrm{MHz}, 50 \mathrm{~Hz}\) & \(5 \times 7\) & \(7 \times 12\) \\
\(12 \mathrm{MHz}, 60 \mathrm{~Hz}\) & \(5 \times 7\) & \(7 \times 10\) \\
\(18 \mathrm{MHz}, 50 \mathrm{~Hz}\) & \(7 \times 9\) & \(9 \times 12\) \\
\(18 \mathrm{MHz}, 60 \mathrm{~Hz}\) & \(7 \times 9\) & \(9 \times 12\) \\
\hline
\end{tabular}

The user has the option of displaying the status line in the 25 th row or providing a full 25 -row data field. Operation at this point is like any other CRT data terminal. A number of special Control and Escape sequences programmed into the TMP give a user a higher degree of flexibility in terminal operation. The Control and Escape sequences may be activated by sending the proper codes from either the ASCII keyboard or host computer through the RS-232 data link.
Escape sequences are 2 or more character transmissions with ESC being the first character sent.

\section*{PART NUMBERS}

The TMP (Terminal Management Processor) boards can be ordered by requesting the following part numbers:
TMP-DEMO-12
(for \(5 \times 7\) character font- 12 MHz bandwidth)
TMP-DEMO-18
(for \(7 \times 9\) character font- 18 MHz bandwidth)
CONTAINS:
Demo Board
NS405 Series Data Sheet
Demo Board Operating Manual
P/N 420409478-001

TMP APPLICATIONS MANUAL:
Order P/N 420040401-001

Section 9
Appendices/
Physical Dimensions

\section*{Section 9 Contents}
PCC Packaging ..... 9-3
Technical Manuals ..... 9-7
Physical Dimensions ..... 9-8
Data BookshelfSales and Distribution Offices

National
Semiconductor Corporation

\section*{Plastic Chip Carrier（PCC）Packaging}

\section*{General Description}

The Plastic Chip Carrier（PCC）is a miniaturized low cost semiconductor package designed to replace the Plastic Dual－In－Line Package（P－DIP）in high density applications． The PCC utilizes a smaller lead－to－lead spacing－ \(0.050^{\prime \prime}\) versus \(0.100^{\prime \prime}\)－and leads on all four sides to achieve a significant footprint reduction over the P－DIP．The rolled un－ der \(J\)－bend leadform separates this package style from oth er plastic quad packages with flat or gull wing lead forms．As with virtually all packages of 0.050 ＂or less lead spacing， the PCC requires surface mounting to printed circuit boards as opposed to the more conventional thru－hole mounting of the P－DIP．

\section*{History}

The Plastic Chip Carrier with J－bend leadform was first intro－ duced in 1976 as a premolded plastic package．The pre－ molded version has yet to become popular but the quad format with J－Bend leads has been adapted to traditional post molded packaging technology（the same technology used to manufacture the P－DIP）．In 1980 National Semicon－ ductor developed a post molded version of the PCC．The J－ bend leadform allowed them to adopt the footprint connec－ tion pattern already registered with JEDEC for the leadless chip carrier（LCC）．In 1981 a task force was organized within JEDEC to develop a PCC registration for package I／O counts of \(20,28,44,52,68,84,100\) ，and 124．A registered outline was completed in 1984 （JEDEC Outline MO－047）af－ ter many changes and improvements over the original pro－ posals．This first PCC registration covers square packages with an equal number of leads on all sides．A second regis－ tration，MO－052，was completed in 1985 for rectangular packages with I／O counts of 18，22， 28 and 32.
Since 1980 many additional semiconductor manufacturers and packaging subcontractors have developed PCC capa－ bility．There are now well over 20 sources with the number growing steadily．

\section*{Surface Mounting}

Surface mounting refers to component attachment whereby the component leads or pads rest on the surface of the PCB instead of the traditional approach of inserting the leads into through－holes which go through the board．With surface mounting there are solder pads on the PCB which align with the leads or pads on the component．The resulting solder joint forms both the mechanical and electrical connection．

\section*{ADVANTAGES}

The primary reason for surface mounting is to allow leads to be placed closer together than the \(0.100^{\prime \prime}\) standard for DIPs with through－hole mounting．Through－hole mounting on smaller than \(0.100^{\prime \prime}\) spacing is difficult to achieve in produc－ tion and generally avoided．The move to \(0.050^{\prime \prime}\) lead spac－ ing offered with the current generation of surface mounted components，along with a switch from a dual－in－line format to a quad format，has achieved a threefold increase in com－ ponent mounting density．A need to achieve greater density is a major driving force in today＇s marketplace．

\section*{MANUFACTURING TECHNIQUES}

Learning how to surface mount components to printed cir－ cuit boards requires the user to become educated in new assembly processes not typically associated with through－ hole insertion／wave soldering assembly methods．

Surface mounting involves three basic process steps：
1）Application of solder or solder paste to the printed circuit board．
2）Positioning of the component onto the printed circuit board
3）Reflowing of the solder or solder paste．
As with any process，there are many details involved to achieve acceptable throughput and acceptable quality． Na － tional Semiconductor offers a surface mounting guide which deals with the specifics of successful surface mounting．We encourage the user to review this document and to contact us if further information on surface mounting is desired．

\section*{Benefits of the PCC}

There are four principle advantages offered the user by switching from P－DIP to PCC．These four advantages are outlined below as follows：
1．Increased Density－
－Typically 3 －to－1 size reduction of printed circuit boards．See Figure 1 for a footprint comparison be－ tween PCC and P－DIP．This can be as high as 6－to－1 in certain applications．
－Surface mounting allows components to be placed on both sides of the board．
－Surface mount and thru－hole mount components can be placed on the same board．
－The large diameter thru－holes can be reduced in number，entirely eliminated，or reduced in size（if needed for via connection）．
2．Increased Performance－
－Shorter traces on printed circuit boards．
－Better high frequency operation．
－Shorter leads in package．Figure 2 and Table I com－ pare PCC and P－DIP mechanical and electrical char－ acteristics．
3．Increased Reliability－
－Leads are well protected．
－Fewer connectors．
－Simplified rework．
－Vibration and shock resistant．
4．Reduced Cost－
－Fewer or smaller printed circuit boards．
－Less hardware．
－Same low cost printed circuit board material．
－Plastic packaging material．
－Reduced number of costly plated－through－holes．
－Fewer circuit layers．


FIGURE 1. Footprint Area of PCC vs. P-DIP

TABLE I. Electrical Performance of PCC vs. P-DIP (44 I/O PCC vs. 40 I/O P-DIP, both with Copper Leads)
\begin{tabular}{c|c|c|c|c}
\hline \multirow{2}{*}{ Criterla } & \multicolumn{2}{|c|}{ Shortest Lead } & \multicolumn{2}{c}{ Longest Lead } \\
\cline { 2 - 5 } & PCC & P-DIP & PCC & P-DIP \\
\hline \begin{tabular}{l} 
Lead Resistance \\
(Measured)
\end{tabular} & \(3 \Omega\) & \(4 \Omega\) & \(6 \Omega\) & \(7 \Omega\) \\
\hline \begin{tabular}{l} 
Lead-to-Lead Capacitance \\
(Measured on Adjacent Leads)
\end{tabular} & 0.1 pF & 0.1 pF & 0.3 pF & 3.0 pF \\
\hline \begin{tabular}{l} 
Lead Self-Inductance \\
(Calculated)
\end{tabular} & 3.2 nH & 1.4 nH & 3.5 nH & 19.1 nH \\
\hline
\end{tabular}


TL/ZZ/0001-3
FIGURE 3. Package Outline
TABLE II. Principle Dimensions Inches/(Millimeters) (Refer to Figure 3)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Lead Count} & \multicolumn{2}{|c|}{Total Width} & \multicolumn{2}{|c|}{Total Helght} & \multicolumn{2}{|c|}{Body Width} & \multicolumn{2}{|l|}{Contact Spread} \\
\hline & Min & Max & Min & Max & Min & Max & Min & Max \\
\hline 20 & \[
\begin{gathered}
0.385 \mathrm{sq} . \\
(9.779)
\end{gathered}
\] & \[
\begin{aligned}
& 0.395 \text { sq. } \\
& (10.03)
\end{aligned}
\] & \[
\begin{gathered}
0.165 \mathrm{sq} . \\
(4.191)
\end{gathered}
\] & \[
\begin{gathered}
0.180 \text { sq. } \\
(4.572) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.345 \mathrm{sq} . \\
(8.763)
\end{gathered}
\] & \[
\begin{gathered}
0.355 \mathrm{sq} . \\
(9.017)
\end{gathered}
\] & \[
\begin{gathered}
0.310 \text { sq. } \\
(7.874) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.330 \mathrm{sq} . \\
(8.382)
\end{gathered}
\] \\
\hline 28 & \[
\begin{gathered}
0.485 \mathrm{sq} . \\
(12.32) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
\hline 0.495 \mathrm{sq} . \\
(12.57) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.165 \text { sq. } \\
(4.191) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.180 \mathrm{sq} . \\
(4.572) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.445 \mathrm{sq} \\
(11.30)
\end{gathered}
\] & \[
\begin{gathered}
0.455 \mathrm{sq} . \\
(11.56) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.410 \text { sq. } \\
(10.41) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.430 \mathrm{sq} . \\
(10.92)
\end{gathered}
\] \\
\hline 44 & \[
\begin{gathered}
0.685 \text { sq. } \\
(17.40) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.695 \mathrm{sq} . \\
(17.65) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.165 \mathrm{sq} . \\
(4.191) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.180 \mathrm{sq} . \\
(4.572) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.645 \mathrm{sq} . \\
(16.38) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.655 \mathrm{sq} . \\
(16.64) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.610 \text { sq. } \\
(15.49) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.630 \mathrm{sq} . \\
(16.00)
\end{gathered}
\] \\
\hline
\end{tabular}

TABLE II. Principle DImensions Inches/(Millimeters) (Refer to Figure 3) (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Lead Count} & \multicolumn{2}{|c|}{Total Width} & \multicolumn{2}{|c|}{Total Helght} & \multicolumn{2}{|c|}{Body Width} & \multicolumn{2}{|l|}{Contact Spread} \\
\hline & Min & Max & Min & Max & Min & Max & Min & Max \\
\hline 68 & \[
\begin{gathered}
0.985 \text { sq. } \\
(25.02)
\end{gathered}
\] & \[
\begin{gathered}
0.995 \text { sq. } \\
(25.27) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.165 \mathrm{sq} . \\
(4.191) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.180 \mathrm{sq} . \\
(4.572) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.945 \mathrm{sq} . \\
(24.00)
\end{gathered}
\] & \[
\begin{gathered}
0.955 \text { sq. } \\
(24.26) \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& 0.910 \text { sq. } \\
& (23.11)
\end{aligned}
\] & \[
\begin{gathered}
0.930 \mathrm{sq} . \\
(23.62) \\
\hline
\end{gathered}
\] \\
\hline 84 & \[
\begin{aligned}
& 1.185 \mathrm{sq} . \\
& (30.10)
\end{aligned}
\] & \[
\begin{gathered}
1.195 \mathrm{sq} . \\
(30.36)
\end{gathered}
\] & \[
\begin{gathered}
0.165 \mathrm{sq} . \\
(4.191) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.180 \text { sq. } \\
(4.572)
\end{gathered}
\] & \[
\begin{aligned}
& 1.150 \mathrm{sq} \text {. } \\
& (29.21)
\end{aligned}
\] & \[
\begin{aligned}
& 1.158 \mathrm{sq} \text {. } \\
& (29.41)
\end{aligned}
\] & \[
\begin{aligned}
& 1.110 \text { sq. } \\
& (28.20)
\end{aligned}
\] & \[
\begin{aligned}
& 1.130 \text { sq. } \\
& (28.70)
\end{aligned}
\] \\
\hline 124 & \[
\begin{aligned}
& 1.685 \mathrm{sq} . \\
& (49.13)
\end{aligned}
\] & \[
\begin{gathered}
1.695 \mathrm{sq} . \\
(49.39)
\end{gathered}
\] & \[
\begin{gathered}
0.180 \mathrm{sq} . \\
(4.572) \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
0.200 \text { sq. } \\
(5.080)
\end{gathered}
\] & \[
\begin{aligned}
& 1.650 \mathrm{sq} . \\
& (41.91)
\end{aligned}
\] & \[
\begin{gathered}
1.658 \text { sq. } \\
(42.11)
\end{gathered}
\] & \[
\begin{aligned}
& 1.610 \text { sq. } \\
& (40.90)
\end{aligned}
\] & \[
\begin{aligned}
& 1.630 \text { sq. } \\
& (41.40)
\end{aligned}
\] \\
\hline
\end{tabular}

TABLE III. Package Thermal Resistance (Deg. C/Watt, Junction-to-Amblent, Board Mount)
\begin{tabular}{c|c|c|c}
\hline \multirow{2}{*}{ Lead Count } & \multicolumn{3}{|c}{ Device Size } \\
\cline { 2 - 4 } & \(\mathbf{1 , 0 0 0} \mathrm{MII}^{2}\) & \(\mathbf{1 0 , 0 0 0} \mathrm{Mil}^{2}\) & \(\mathbf{1 0 0 , 0 0 0 \mathrm { MII } ^ { 2 }}\) \\
\hline 20 & 102 & 85 & 67 \\
\hline 28 & 95 & 73 & 55 \\
\hline 44 & 54 & 47 & 40 \\
\hline 68 & 44 & 40 & 38 \\
\hline \(84^{*}\) & 40 & 35 & 30 \\
\hline \(124^{*}\) & 40 & 35 & 30 \\
\hline
\end{tabular}
timated values

\section*{Package Design Criteria}

Experience has taught us there are certain criteria to the PCC design which must be followed to provide the user with the proper mechanical and thermal performance. These requirements should be carefully reviewed by the user when selecting suppliers for devices in PCC. Some of these are covered by the JEDEC registration and some are not. These important requirements are listed in Table IV.

\section*{Reliability}

National Semiconductor utilizes an assembly process for the PCC which is similar to our P-DIP assembly process. We also utilize identical materials. This is a very important point
when considering reliability. Many years of research and development have gone into steadily improving our P-DIP quality and maintaining a leadership position in plastic package reliability. All of this technology can be directly applied to the PCC. Table \(V\) shows the results of applying this technology to the PCC. As we make further advances in plastic package reliability, these will also be applied to the PCC.

\section*{Sockets}

There are several manufacturers currently offering sockets for the plastic chip carrier. Following is a listing of those manufacturers. The listing is divided into test/burn-in and production categories. There may be some individual sockets that will cover both requirements.

TABLE IV. Package Design Criteria
\begin{tabular}{l|c}
\hline \multicolumn{1}{c|}{ Criteria } & \begin{tabular}{c} 
Required to Comply wlth \\
JEDEC Reglstration
\end{tabular} \\
\hline \begin{tabular}{l} 
Minimum Inside Bend Radius of Lead at Shoulder Equal or Greater than Lead \\
Thickness-to Prevent Lead Cracking/Fatigue
\end{tabular} & Not Required \\
\hline \begin{tabular}{l} 
Minimum One Mil Clearance Between Lead and Plastic Body at all Points-to \\
Provide Lead Compliancy and Prevent Shoulder Joint Cracking/Fatigue
\end{tabular} & Not Required \\
\hline Copper Leads for Low Thermal Resistance & Not Required \\
\hline \begin{tabular}{l} 
Minimum 10 Mil Lead Thickness for Low Thermal Resistance and Good \\
Handling Properties
\end{tabular} & Not Required \\
\hline \begin{tabular}{l} 
Minimum 26 Mil Lead Shoulder Width to Prevent Interlocking of Devices \\
During Handling
\end{tabular} & Yes \\
\hline Maximum 4 Mils coplanarity Across Seating Plane of all Leads & Yes \\
\hline
\end{tabular}

TABLE V. Reliability Test Data
(Expressed as Failures per Units Tested)
\begin{tabular}{|l|c|c|c|c|c|}
\hline \multicolumn{1}{|c|}{ Device/Package } & OPL & TMCL & TMSK & BHTL & ACLV \\
\hline LM324/20 Lead & \(0 / 96\) & \(0 / 199\) & \(0 / 50\) & \(0 / 97\) & \(0 / 300\) \\
\hline LF353/20 Lead & \(0 / 50\) & \(0 / 50\) & - & \(0 / 45\) & \(0 / 100\) \\
\hline DS75451/20 Lead & \(0 / 47\) & - & \(0 / 50\) & \(0 / 93\) & \(0 / 179\) \\
\hline DM875191/28 Lead & \(0 / 154\) & \(0 / 154\) & \(0 / 154\) & \(0 / 154\) & \(0 / 154\) \\
\hline DM875181/28 Lead & \(0 / 77\) & \(0 / 77\) & \(0 / 77\) & \(0 / 77\) & \(0 / 77\) \\
\hline
\end{tabular}

OPL \(=\) Dynamic high temperature operating life at \(125^{\circ} \mathrm{C}\) or \(150^{\circ} \mathrm{C}, 1,000\) hours.
TMCL \(=\) Temperature cycle, Air-to-Air, \(-40^{\circ} \mathrm{C}\) to \(+125^{\circ} \mathrm{C}\) or \(-65^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}, 2,000\) cycles.
TMSK \(=\) Thermal shock, Liquid-to-Liquid, \(-65^{\circ} \mathrm{C}\) to \(+150^{\circ} \mathrm{C}, 100\) cycles.
BHTL \(=\) Biased humidity temperature life, \(85^{\circ} \mathrm{C}, 85 \%\) humidity, 1,000 hours.
ACLV = Autoclave, \(15 \mathrm{psi}, 121^{\circ} \mathrm{C}, 100 \%\) humidity, 1,000 hours.

\section*{Production Sockets}

AMP
Harrisburg, PA
(715) 564-0100

Augat
Attleboro, MA
(617) 222-2202

Burndy
Norwalk, CT
(203) 838-4444

Methode
Rolling Meadows, IL
(312) 392-3500

Textool
Irving, TX
(214) 259-2676

Thomas \& Betts
Raritan, NJ
(201) 469-4000

\section*{Test/Burn-In Sockets}

Plastronics
Irving, TX
(214) 258-1906

Textool
Irving, TX
(214) 259-2676

Yamaichi
c/o Nepenthe Dist.
(415) 856-9332

\section*{ADDITIONAL INFORMATION AND SERVICES}

National Semiconductor offers additional Databooks which cover surface mount technology in much greater detail. We also have a surface mount laboratory to provide demonstrations and customer support, as well as technology development. Feel free to contact us about these additional resources.

\section*{Technical Manuals}

Technical Manuals are available from National's Sales offices
\begin{tabular}{lll} 
MOLE Brain Board Users Manual & COPS, HPC, TMP 8050 & \(420408188-001\) \\
Software Users Manual & COPS & \(424409479-002\) \\
Personality Board Manual & COPS & \(420408189-001\) \\
& TMP & \(420408203-001\) \\
PC-DOS Software Users Manual & COPS, TMP, HPC, 8050 & \(420040416-001\) \\
\hline TMP-DEMO-12/18 Board Users Manual & & \(420409478-001\) \\
NS405 Terminal Management Processor (TMP) & \\
\multicolumn{2}{c}{ Application Manual } & \(420040401-001\) \\
COPS Programming Manual & \(424410284-001\) \\
CPM Software Users Manual & & \(420040415-001\)
\end{tabular}


NS Package D14D




NS Package D28C


J08A (AEV M)
NS Package J08A


NS Package J14A




NS Package M14B





N22A (REV D)
NS Package N22A
Physical Dimensions


NS Package N24C


N24C (REV F)
NS Package N24C



NS Package N40A


NS Package N48A


NS Package U68A




\section*{National Semiconductor Corporation}

\section*{Bookshelf of Technical Support Information}

National Semiconductor Corporation recognizes the need to keep you informed about the availability of current technical literature.
This bookshelf is a compilation of books that are currently available. The listing that follows shows the publication year and section contents for each book.
Please contact your local National sales office for possible complimentary copies. A listing of sales offices follows this bookshelf.

We are interested in your comments on our technical literature and your suggestions for improvement.
Please send them to:
Technical Communications Dept. M/S 23-200
2900 Semiconductor Drive
P.O. Box 58090

Santa Clara, CA 95052-8090
For a recorded update of this listing plus ordering information for these books from National's Literature Distribution operation, please call (408) 749-7378.

\section*{DATA CONVERSION/ACQUISITION DATABOOK—1984}

Selection Guides • Active Filters • Amplifiers • Analog Switches • Analog-to-Digital Converters
Analog-to-Digital Display (DVM) • Digital-to-Analog Converters • Sample and Hold • Sensors/Transducers
Successive Approximation Registers/Comparators • Voltage References

\section*{HYBRID PRODUCTS DATABOOK—1982}

Operational Amplifiers • Buffers • Instrumentation Amplifiers • Sample \& Hold Amplifiers • Comparators Non-Linear Functions • Precision Voltage Regulators and References • Analog Switches MOS Clock Drivers • Digital Drivers • A-D Converters • D-A Converters • Fiber-Optic Products
Active Filters \& Telecommunication Products • Precision Networks • 883/RETS

\section*{INTERFACE DATABOOK—1986}

Transmission Line Drivers/Receivers • Bus Transceivers • Peripheral/Power Drivers • Display Controllers/Drivers Memory Support • Microprocessor Support • Level Translators/Buffers • Frequency Synthesis

\author{
INTERFACE/BIPOLAR LSI/BIPOLAR MEMORY/PROGRAMMABLE LOGIC DATABOOK-1983 \\ Transmission Line Drivers/Receivers • Bus Transceivers • Peripheral/Power Drivers \\ Level Translators/Buffers • Display Controllers/Drivers • Memory Support • Dynamic Memory Support \\ Microprocessor Support • Data Communications Support • Disk Support • Frequency Synthesis \\ Interface Appendices • Bipolar PROMs • Bipolar and ECL RAMs • 2900 Family/Bipolar Microprocessor \\ Programmable Logic
}

\section*{INTUITIVE IC CMOS EVOLUTION—1984}

Thomas M. Frederiksen's new book targets some of the most significant transitions in semiconductor technology since the change from germanium to silicon. Intuitive IC CMOS Evolution highlights the transition in the reduction in defect densities and the development of new circuit topologies. The author's latest book is a vital aid to engineers, and industry observers who need to stay abreast of the semiconductor industry.

\section*{INTUITIVE IC OP AMPS-1984}

Thomas M. Frederiksen's new book, Intuitive IC Op Amps, explores the many uses and applications of different IC op amps. Frederiksen's detailed book differs from others in the way he focuses on the intuitive groundwork in the basic functioning concepts of the op amp. Mr. Frederiksen's latest book is a vital aid to engineers, designers, and industry observers who need to stay abreast of the computer industry.

\section*{LINEAR APPLICATIONS HANDBOOK—1986}

The purpose of this handbook is to provide a fully indexed and cross-referenced collection of linear integrated circuit applications using both monolithic and hybrid circuits from National Semiconductor.
Individual application notes are normally written to explain the operation and use of one particular device or to detail various methods of accomplishing a given function. The organization of this handbook takes advantage of this innate coherence by keeping each application note intact, arranging them in numerical order, and providing a detailed Subject Index.

\section*{LINEAR SUPPLEMENT DATABOOK—1984}

Amplifiers • Comparators • Voltage Regulators • Voltage References • Converters • Analog Switches Sample and Hold • Sensors • Filters • Building Blocks • Motor Controllers • Consumer Circuits Telecommunications Circuits • Speech • Special Analog Functions

\section*{LOGIC DATABOOK VOLUME I-1984}

CMOS AC Switching Test Circuits and Timing Waveforms • CMOS Application Notes • MM54HC/MM74HC MM54HCT/MM74HCT • CD4XXX • MM54CXXX/MM74CXXX • LSI/VLSI

\section*{LOGIC DATABOOK VOLUME II—1984}

Introduction to Bipolar Logic • Advanced Low Power Schottky • Advanced Schottky • Low Power Schottky Schottky • TTL • Low Power

\section*{MASS STORAGE HANDBOOK—1986}

Disk Interface Design Guide and User Manual • Winchester Disk Support • Winchester Disk Data Controller Floppy Disk Support • Drive Interface Support Circuits

\section*{MEMORY SUPPORT HANDBOOK—1986}

Dynamic Memory Control • Error Checking and Correction • Microprocessor Interface and Applications Memory Drivers and Support

\section*{MOS MEMORY DATABOOK—1984}

Standard Terminology • MOS Memory Cross Reference Guide • Dynamic RAMs • NMOS Static RAMs CMOS Static RAMs • EPROMs • EEPROMs • Military/Aerospace • Reliability

\section*{THE NSC800 MICROPROCESSOR FAMILY DATABOOK—1985}

CPU • Peripherals • Evaluation Board • Logic Devices • MA2000 Macrocomponent Family

\section*{SERIES 32000 DATABOOK—1986}

Introduction • CPU-Central Processing Unit • Slave Processors • Peripherals • Data Communications and LAN's Disk Control and Interface • DRAM Interface • Development Tools • Software Support • Application Notes

\section*{RELIABILITY HANDBOOK—1986}

Reliability and the Die • Internal Construction • Finished Package • MIL-STD-883 • MIL-M-38510
The Specification Development Process • Reliability and the Hybrid Device • VLSI/VHSIC Devices
Radiation Environment • Electrostatic Discharge • Discrete Device • Standardization
Quality Assurance and Reliability Engineering • Reliability and Documentation • Commercial Grade Device
European Reliability Programs • Reliability and the Cost of Semiconductor Ownership
Reliability Testing at National Semiconductor - The Total Military/Aerospace Standardization Program 883B/RETSTM Products • MILS/RETSTM Products • 883/RETSTM Hybrids • MIL-M-38510 Class B Products Radiation Hardened Technology • Wafer Fabrication • Semiconductor Assembly and Packaging Semiconductor Packages • Glossary of Terms • Key Government Agencies • AN/ Numbers and Acronyms Bibliography •MIL-M-38510 and DESC Drawing Cross Listing

\section*{THE SWITCHED-CAPACITOR FILTER HANDBOOK—1985}

Introduction to Filters • National's Switched-Capacitor Filters • Designing with Switched-Capacitor Filters Application Circuits • Filter Design Program • Nomographs and Tables

\section*{TRANSISTOR DATABOOK—1982}

NPN Transistors • PNP Transistors • Junction Field Effect Transistors • Selection Guides • Pro Electron Series Consumer Series • NA/NB/NR Series • Process Characteristics Double-Diffused Epitaxial Transistors Process Characteristics Power Transistors • Process Characteristics JFETs • JFET Applications Notes

\section*{VOLTAGE REGULATOR HANDBOOK—1982}

Product Selection Procedures • Heat Flow \& Thermal Resistance • Selection of Commercial Heat Sink Custom Heat Sink Design • Applications Circuits and Descriptive Information • Power Supply Design Data Sheets

\section*{48-SERIES MICROPROCESSOR HANDBOOK—1980}

The 48-Series Microcomputers • The 48-Series Single-Chip System • The 48-Series Instruction Set Expanding the 48 -Series Microcomputers • Applications for the 48 -Series • Development Support Analog I/O Components • Communications Components • Digital I/O Components • Memory Components Peripheral Control Components

\section*{NATIONAL SEMICONDUCTOR CORPORATION AUTHORIZED DISTRIBUTORS}
\begin{tabular}{|c|c|}
\hline alabama & Sunnyvale \\
\hline Huntsville & Bell Industries \\
\hline Hall-Mark & (408) 734-8570 \\
\hline (205) 837-8700 & Hamilton/Avnet \\
\hline Hamilton/Avnet & (408) 743-3355 \\
\hline (205) 837-7210 & Thousand Oaks \\
\hline Pioneer & Bell Industries \\
\hline (205) 837-9300 & (805) 499-6821 \\
\hline Schweber & Tustin \\
\hline (205) 882-2200 & Hall-Mark \\
\hline ARIZONA & (714) 669-4700 \\
\hline Phoenix & COLORADO \\
\hline Schweber & Englewood \\
\hline (602) 997-4874 & Anthem Electronics \\
\hline Tempe & (303) 790-4500 \\
\hline Anthem Electronics & Hamilton/Avnet \\
\hline (602) 966-6600 & (303) 779-9998 \\
\hline Hamilton/Avnet & Schweber \\
\hline (602) 231-5100 & (303) 799-0258 \\
\hline CALIFORNIA & Wheatridge \\
\hline Canoga Park & Bell Industries \\
\hline Hall-Mark & (303) 424-1985 \\
\hline (818) 716-7300 & CONNECTICUT \\
\hline Schweber & Danbury \\
\hline (818) 999-4702 & Hamilton/Avnet \\
\hline Chatsworth & (203) 797-2800 \\
\hline Anthem Electronics & Schweber \\
\hline (818) 700-1000 & (203) 748-7080 \\
\hline Avnet Electronics & Meridian \\
\hline (818) 700-8668 & Lionex Inc. \\
\hline Hamilton Electro Sales & (203) 237-2282 \\
\hline (818) 700-6050 & Norwalk \\
\hline Citrus Heights & Pioneer Northeast \\
\hline Hall-Mark & (203) 853-1515 \\
\hline (916) 722-8600 & FLORIDA \\
\hline Costa Mesa & Altamonte Springs \\
\hline Avnet Electronics & Pioneer \\
\hline (714) 754-6050 & (305) 834-9090 \\
\hline Hamilton Electro Sales & Schweber \\
\hline (714) 641-4159 & (305) 331-7555 \\
\hline Culver City & Clearwater \\
\hline Hamilton Electro Sales & Hall-Mark \\
\hline (213) 558-2121 & (813) 530-4543 \\
\hline Garden Grove & Deerrield \\
\hline Bell Industries & Pioneer \\
\hline (714) 895-7801 & (305) 428-8877 \\
\hline Gardena & Ft. Lauderdale \\
\hline Bell Industries & Hamilton/Avnet \\
\hline (213) 515-1800 & (305) 971-2900 \\
\hline Irvine & Hollywood \\
\hline Anthem Electronics & Schweber \\
\hline (714) 768-4444 & (305) 927-0511 \\
\hline Schweber & Orlando \\
\hline (714) 863-0200 & Hall-Mark \\
\hline Roseville & (305) 855-4020 \\
\hline Bell Industries & Pompano Beach \\
\hline (916) 969-3100 & Hall-Mark \\
\hline Sacramento & (305) 971-9280 \\
\hline Hamilton/Avnet & Winter Park \\
\hline (916) 925-2216 & Hamilton-Avnet \\
\hline Schweber & (305) 628-3888 \\
\hline (916) 929-9732 & GEORGIA \\
\hline  & Norcross \\
\hline (619) 279-5200 & Hall-Mark \\
\hline Hamilton/Avnet & (404) 447-8000 \\
\hline (619) 571-7510 & Hamilton-Avnet \\
\hline San Jose & (404) 447-7500 \\
\hline Anthem Electronics & Pioneer \\
\hline (408) 946-8000 & (404) 448-1711 \\
\hline Hall-Mark & Schweber \\
\hline (408) 946-0900 & (404) 449-9170 \\
\hline Schweber & \\
\hline (408) 946-7171 & \\
\hline
\end{tabular}
ILLINOIS
Bensenville
Hamilton/Avnet
(312) \(860-7780\)
Chicago
Bell Industries
(312) \(982-9210\)
Elk Grove Village
Pioneer
(312) \(952-8440\)
Schweber
(312) \(364-3750\)
Wood Dale
Hall-Mark
(312) \(860-3800\)

INDIANA
Carmel Hamilton/Avnet (317) 844-9333

Indianapolis Advent (317) 872-4910 Pioneer (317) 849-7300

IOWA
Cedar Rapids Advent Electronics (319) 363-0221 Bell Industries (319) 395-0730 Hamilton/Avnet (319) 362-4757 Schweber (319) 373-1417

KANSAS
Lenexa Hall-Mark (913) 888-4747

Overland Park Hamilton/Avnet (913) 888-8900 Schweber (913) 492-2921

MARYLAND
Columbia Hall-Mark (301) 988-9800 Hamilton/Avnet (301) 995-3500

Gaithersburg Pioneer Washington (301) 921-0660 Schweber (301) 840-5900

MASSACHUSETTS
Bedford Schweber (617) 275-5100

Billerica Hall-Mark (617) 935-9777

Lexington Pioneer Northeast (617) 861-9200

Wilmington Lionex (617) 657-5170

Woburn Hamilton/Avnet (617) 273-7500

MICHIGAN
Grand Rapids Hamilton/Avnet (616) 243-8805 R-M Michigan (616) 531-9300

Livonia Hamilton/Avnet (313) 522-4700 Pioneer (313) 525-1800 Schweber (313) 525-8100

MINNESOTA
Bloomington Hall-Mark (612) 854-3223

Edina Schweber (612) 941-5280

Minnetonka Hamilton/Avnet (612) 932-0600 Pioneer (612) 935-5444

MISSOURI
Earth City Hamilton/Avnot (314) 344-1200 Schweber (314) 739-0526

Maryland Heights Hall-Mark (314) 291-5350

NEW HAMPSHIRE Manchester Hamilton/Avnet (603) 624-9400 Schweber (603) 625-2250

NEW JERSEY
Cherry Hill Hall-Mark (609) 424-7300 Hamilton/Avnet (609) 424-0100

Fairfield Hall-Mark (201) 575-4415 Hamilton/Avnet (201) 575-3390 Lionex (201) 227-7960 Schweber (201) 227-7880

Pine Brook Pioneer Northeast (201) 575-3510

NEW MEXICO
Albuquerque Alliance Electronics (505) 292-3360 Bell/Century (505) 292-2700 Hamilton(Avnet (505) 765-1500

\section*{NATIONAL SEMICONDUCTOR CORPORATION AUTHORIZED DISTRIBUTORS (Continued)}

\section*{NEW YORK \\ Buffalo}

Summit Distributors (716) 887-2800

East Syracuse Hamilton/Avnet (315) 437-2642

Fairport
Pioneer
(716) 381-7070

Hauppauge Hamilton/Avnet
(516) 434-7413

Lionex
(516) 273-1660

Rochester Hamilton/Avnet (716) 475-9130 Schweber (716) 424-2222 Summit Electronics (716) \(334-8110\)

Ronkonkoma
Hall-Mark (516) 737-0600

Vestal
Pioneer
(607) 748-8211

Westbury Hamilton/Avnet (516) 897-6868 Schweber (516) 334-7474

Woodbury Pioneer (516) 921-8700

NORTH CAROLINA
Charlotte
Pioneer (704) 527-8188

Raleigh Hall-Mark (919) 872-0712 Hamilton/Avnet (919) 878-0810 Schweber (919) 876-0000

OHIO
Beechwood Schweber (216) 464-2970

Cleveland Hamilton/Avnet (216) 831-3500 Pioneer (216) 587-3600

Dayton Bell Industries (513) 435-8660 Hamilton/Avnet (513) 439-6700 Pioneer (513) 236-9900

Highland Heights CAM/OHIO (216) 461-4700

Solon
Hall-Mark (216) 349-4632

Westerville Hall-Mark (614) 891-4555

OKLAHOMA
Tulsa Hall-Mark (918) 665-3200 Quality Components (918) 664-8812 Radio Inc. (918) 587-9123 Schweber (918) 622-8000

OREGON
Beaverton Almac Electronics (503) 641-9070

Lake Oswego Anthem Electronics (503) 684-2661 Bell Industries (503) 241-4115 Hamilton/Avnet (503) 635-7850

PENNSYLVANIA
Horsham
Lionex (215) 443-5150 Pioneer (215) 674-4000 Schweber (215) 441-0600

Pittsburgh
CAM/RPC
(412) 782-3770

Pioneer
(412) 782-2300

Schweber (412) 782-1600

TEXAS
Addison
Quality Components (214) 733-4300

Austin
Hall-Mark
(512) 258-8848

Hamilton/Avnet
(512) 837-8911

Pioneer
(512) 835-4000

Quality Components
(512) 835-0220

Schweber
(512) 458-8253

Dallas
Hall-Mark
(214) 553-4300

Pioneer
(214) 386-7300

Schweber
(214) 661-5010

Houston
Hall-Mark
(713) 781-6100 Hamilton/Avnet (713) 780-1771 Pioneer (713) 988-5555

Schweber
(713) 784-3600

Irving
Hamilton/Avnet (214) 659-4151

Sugarland
Quality Components
(713) 491-2255

UTAH
Salt Lake City
Anthem Electronics (801) 973-8555 Bell Industries (801) 972-6969 Hamilton/Avnet (801) 972-4300

WASHINGTON
Bellevue
Hamilton/Avnet
(206) 453-5844

Redmond
Anthem Electronics
(208) 881-0850

Seattle
Almac Electronics
(206) 643-9992

WISCONSIN
Brookfield
Schweber
(414) 784-9020

Milwaukee
Taylor Electric Co.
(414) 241-4321

New Berlin
Hall-Mark
(414) 761-3000

Hamilton/Avnet
(414) 784-4516

Waukesha Bell Industries (414) 547-8879

\section*{CANADA}

Western Provinces Calgary Hamilton/Avnet (403) 230-3586 Zentronics (403) 272-1021

Edmonton
Zentronics (403) 463-3014

Richmond Zentronics (604) 273-5575

Winnipeg Zentronics (204) 775-8661

Eastern Provinces
Brampton Zentronics (416) 451-9600

Doval Semad (514) 636-4614

Markham Semad (416) 475-8500

Missisauga Hamilton/Avnet (416) 677-7432

Népean Hamilton/Avnet (613) 226-1700

Ottawa Semad (613) 729-6145 Zentronics (613) 238-6411

St. Laurent Zentronics (514) 735-5361

Waterloo Zentronics (519) 884-5700

\section*{SALES OFFICES AND REPRESENTATIVES}

\section*{ALABAMA}

Huntsville
New Interep Associates (205) 533-1730

Mobile
New Interep Associates (205) 478-1036

ARIZONA
Temple
National Semiconductor (602) 966-4563

Phoenix
Desert Technical Sales (602) 244-0735

CALIFORNIA
Santa Clara
National Semiconductor (408) 730-3054

Bay Tech Sales (408) 730-3009

Roseville
Bay Tech Sales
(916) 969-5577

Woodland Hills National Semiconductor (818) 888-2602

Encino
Great American Rep. Co. (818) 990-4870

Invine
National Semiconductor (714) 250-1440

Santa Ana Great American Rep. Co. (714) 954-0371

San Diego National Semiconductor (619) 279-0724

COLORADO
Englewood National Semiconductor (303) 790-8090

Aurora
Skyline Technical Sales (303) 360-0955

CONNECTICUT
Ridgefield National Semiconductor (203) 431-8182

Fairfield
NRG Limited
(203) 384-1112

FLORIDA
No. Miami Beach National Semiconductor (305) 947-0031

St. Petersburg QXI
(813) 821-2281

Boca Raton QXI (305) 392-2626

\section*{GEORGIA \\ Atlanta}

National Semiconductor (404) 393-2626

Action Component Sales (404) 393-9494

ILLINOIS
Schaumburg
National Semiconductor (312) 397-8777

Arlington Heights
Delta Technical Sales
(312) 253-9440

INDIANA
Carmel
National Semiconductor (317) 843-7160

Indianapolis
Advanced Component Sales (317) 545-6441

Fort Wayne
Advanced Component Sales
(219) 484-0722

IOWA
Cedar Rapids
Stan Clothier Company (319) 395-0245

MARYLAND
Hanover
National Semiconductor (301) 796-8900

Glen Burnie
TRIMARK, Inc.
(301) 761-6000

MASSACHUSETTS
Burlington
National Semiconductor (617) 273-3170

Lexington
A/D Systems Sales, Inc. (617) 861-6371

MICHIGAN
W. Bloomfield National Semiconductor (313) 855-0166

MINNESOTA
Bloomington National Semiconductor (612) 854-8200

Minneapolis Stan Clothier Company (612) 944-3456

MISSOURI
Kansas City National Semiconductor (816) 941-3537

Raytown
-Cen Tech (816) 358-8100

Bridgeton
Cen Tech (314) 291-4230

NEW JERSEY
Paramus National Semiconductor (201) 599-0955

NEW MEXICO
Albuquerque Reptronix, Inc. (505) 292-1718

NEW YORK
Fairport National Semiconductor (716) 425-1358

Syracuse Electra Sales Corp. (315) 463-1248

Rochester Electra Sales Corp. (716) 461-5252

Poughkeepsie National Semiconductor (914) 473-8830

Melville
Parallax Sales
(516) 351-1000

NORTH CAROLINA
Durham
National Semiconductor
(919) 683-2676

Cary
Engineering Devices Corp. (919) 469-9323

OHIO
Highland Heights National Semiconductor
(216) 461-0191

Micro-Tec, Inc.
(216) 442-1555

Dayton
National Semiconductor
(513) 435-6886

Micro-Tec, Inc.
(513) 435-0644

Columbus
Micro-Tec, Inc. (614) 451-2400

OREGON
Beaverton
Meritech, Inc. (503) 644-0304

PENNSYLVANIA
Ft. Washington National Semiconductor (215) 643-4910

Huntingdon Valley Omega Electronic Sales (215) 947-4135

TENNESSEE
Knoxville Action Component Sales (615) 694-0140

TEXAS
Richardson
National Semiconductor (214) 690-4552 Interactive Component Sales (214) 669-4031

Austin
National Semiconductor (512) 339-7555 Interactive Component Sales
(512) 451-0201

Houston
Interactive Component
Sales
(713) 270-6141

UTAH
Salt Lake City Skyline Technical Sales (801) 261-5402

WASHINGTON
Bellevue
National Semiconductor (206) 453-9944

Meritech, Inc.
(206) 454-4600

WISCONSIN
Milwaukee Delta Technical Sales (414) 527-3800

CANADA
Mississauga National Semiconductor (416) 678-2920

Brampton Canadian Micro Sales (416) \(453-9121\)

Lachine Canadian Micro Sales (514) 636-8525

Nepean Canadian Micro Sales (613) 596-0411

PUERTO RICO
Puerto Nuevo National Semiconductor (809) 792-9110

National Semiconductor Corporate Headquarters 2900 Semiconductor Drive
P.O. Box 58090

Santa Clara, CA 95052-8090
Tel: (408) 721-5000
TWX: (910) 339-9240

\section*{SALES OFFICES AND REPRESENTATIVES (Continued)}

\section*{INTERNATIONAL OFFICES}

Electrönica NSC de Mexico SA Juventino Rošas No. 118-2 ) Col Guadalupe Inn
Mexico, 01020 D.F. Mexico Tel: (905) 524-9402
National Semicondutores
* Do Brasil Lida.

Av. Brig. Faria Lima, 830 8 Andar
01452 Sao Paulo, SP. Brasil
Tel: (55/11) 212-5066
Telex: 391-1131931 NSBR BR
National Semiconductor GmbH Industriestraße 10 D-8080 Fürstenfeldbruck
West Germany
Tel: (0 8141) 103-0
Telex: 527649
National Semiconductor (UK) Lid.
301 Harpur Centre
Horne Lane
Bedford MK40 1TR
United Kingdom
Tel: 0234-47147
Telex: 826209
National Semiconductor Benelux
Ave Charles Quint 545
B-1080 Bruxelles
Belgium
Tei: (02) 4661807
Telex: 61007

National Semiconductor (UK) Ltd. 1, Bianco Lunos Alle DK-1868 Copenhagen V Denmark
Tel: (01) 213211
Telex: 15179
National Semiconductor
IExpansion 10000
28, Rue de la Redoute
F-92 260 Fontenay-aux-Roses
France
Tel: (01) 660-8140
Telex: 250956
National Semiconductor S.p.A.
Via Solferino 19
20121 Milano
Italy
Tel: (02) 345-2046/7/8/9
Telex: 332835
National Semiconductor AB
Box 2016
Stensätravägen 13
S-12702 Skärholmen
Sweden
- Tel: (08) 970190

Telex: 10731
National Semiconductor GmbH
Calle Agustin de Foxa, 27 (9.D)
28036 Madrid
Spain
Tel: (01) 7332958
Telex: 46133

National Semiconductor Switzerland
Alte Winterthurerstrasse 53 Postfach 567
CH-8304 Wallisellen-Zurich
Tel: (01) 830-2727
Telex: 59000
National Semiconductor
Pasilanraitio 6C
SF-00240 Helsinki 24
Finland
Tel: (90) 140344
Telex: 124854
NS Japan Lid.
4-403 Ikebukuro, Toshima-ku
Tokyo 171, Japan
Tel: (03) 988-2131
Fax: 011-81-3-988-1700
National Semiconductor
Hong Kong Ltd.
Southeast Asia Marketing
Austin Tower, 4th Floor 22-26A Austin Avenue Tsimshatsui, Kowloon; H.K.
Tel: 3-7231290
Cable: NSSEAMKTG
Telex: 52996 NSSEA HX .. ,

National Semiconductor
Advanced Systems PTY LTD
11-17 Khartoum Road
North Ryde, N.S.W. 2113
Sydney, Australia
Tel: (03) 729-6333
Telex: AA32096
National Semiconductor (PTE),
Ltd.
51 Goldhill Plaza, No. 10-01
Newton Road
Singapore 1130
Tel: 2506884
Telex: RS 33877
National Semiconductor (Far East)
Ltd.
Taiwan Branch
P.O. Box 68-332 Taipei

7th Floor, Nan Shan Life Bldg.
302 Min Chuan East Road,
Taipei, Taiwan R.O.C.
Tel: (02) 501-7227
Telex: 22837 NSTW
Cable: NSTW TAIPEI
National Semiconductor (Far East)
Ltd.
Korea Office
Third Floor, Hankyung Bldg.
4-25 Hannam-Dong
Yongsan-Ku, Seoul 140, Korea
Tel: 797-8001/3
Telex: K24942 NSRK```


[^0]:    Note 1: $\mathrm{V}_{\mathrm{CC}}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
    Note 2: TRI-STATE and LED configurations are excluded.
    Note 3: SO output " 0 " level must be less than 0.8 V for normal operation.

[^1]:    Note 1: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
    Note 2: TRI-STATE and LED configurations are excluded.
    Note 3: SO output " 0 " level must be less than 0.6 V for normal operation.
    Note 4: Human body model, 100 pF discharged through a $1.5 \mathrm{k} \Omega$ resistor.

[^2]:    Note: $15 k \leq R \leq 150 k$

[^3]:    Note 1: Supply current is measured after running 2000 cycle times with a square-wave clock on CKI, CKO open, and all other pins pulled to $V_{C C}$ with 20 K resistors. See current drain equation, see power dissipation.
    Note 2: The HALT mode will stop CKI from oscillating in the RC and crystal configurations. Test conditions: all inputs tied to $V_{C C}$, L lines in TRI-STATE mode and tied to ground, all outputs low and tied to ground.
    Note 3: When forcing HALT, current is only needed for a short time (approx. 200 ns ) to flip the HALT flip-flop.
    Note 4: This parameter is only sampled and not $100 \%$ tested.
    Note 5: Voltage change must be less than 0.5 volts in a 1 ms period.
    Note 6: SO output sink curent must be limited to keep $V_{O L}$ less than $0.3 \mathrm{~V}_{\mathrm{CC}}$ when part is running in order to prevent entering test mode.
    Note 7: If CKI is crystal divide by 16 option, maximum CKI frequency is $3.2 \mathrm{MHz}, t_{c}=5 \mu \mathrm{~s}$ for $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ and $0.8 \mathrm{MHz}, \mathrm{t}_{\mathrm{c}}=20 \mu \mathrm{~s}$ for $2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V}$. If CKI is crystal $\div 32$ option, maximum CKI frequency is $3.2 \mathrm{MHz}, \mathrm{t}_{\mathrm{c}}=10 \mu \mathrm{~s}$ for $\mathrm{V}_{\mathrm{CC}} \geq 4 \mathrm{~V}$ and $0.8 \mathrm{MHz}, \mathrm{t}_{\mathrm{c}}=40 \mu \mathrm{~s}$ for $2.4 \mathrm{~V} \leq \mathrm{V}_{\mathrm{CC}}<4 \mathrm{~V}$.
    Note 8: I/O pin voltage held above $V_{C C}$ or below GND (e.g., $+2 \mathrm{~V} /-2 \mathrm{~V}$ with $+200 \mathrm{~mA} /-200 \mathrm{~mA}$, or $+20 \mathrm{~V} /-20 \mathrm{~V}$ with $+20 \mathrm{~mA} /-20 \mathrm{~mA}$ ).
    Note 9: Human Body Model, 100 pF through $1.5 \mathrm{~K} \Omega$.

[^4]:    Note 1: Duty Cycle $=\mathrm{tw}_{\mathrm{w}} /\left(\mathrm{t}_{\mathrm{w}}+\mathrm{t}_{\mathrm{w}}\right)$.
    Note 2: See Figure for additional I/O Characteristics.
    Note 3: $V_{C C}$ voltage change must be less than 0.5 V in a 1 ms period to maintain proper operation.
    Note 4: Exercise great care not to exceed maximum device power dissipation limits when direct-driving LEDs (or sourcing similar loads) at high temperature.

[^5]:    - Uses one more wire than load cell itself
    - Two mini-DIPs could be mounted inside load cell for digital output transducer
    - Electronic offset and gain trims relax mechanical specs for gauge factor and offset
    - Low level cell output is converted immediately for high noise immunity

[^6]:    

    $$
    \begin{gathered}
    t_{A}=(A+1) t \\
    N=B+1
    \end{gathered}
    $$

    Where: $\quad A=$ Contents of register $A$
    $B=$ Contents of register $B$
    $t=$ period of internal clock
    (as previously defined)
    $1 \leq A \leq 65535, A \neq 0\left(1 \leq A \leq\right.$ FFFF $\left._{16}\right)$
    $0 \leq \mathrm{B} \leq 65535 \quad\left(0 \leq \mathrm{B} \leq \mathrm{FFFF}_{16}\right)$

[^7]:    Note 1: All typicals are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    Note 2: Not more than one output should be shorted at a time, and the duration should not exceed one second.
    Note 3: $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$.

[^8]:    ; 2 ROUTINES ARE CALLED FROM THE SUBROUTINE PAGE BY THIS

